/* Thorsten Ball's design */

@font-face { font-family: "Inter"; font-style: normal; font-weight: 200; font-display: swap; src: url("/assets/fonts/Inter-ExtraLight.woff2") format("woff2"); }
@font-face { font-family: "Inter"; font-style: italic; font-weight: 200; font-display: swap; src: url("/assets/fonts/Inter-ExtraLightItalic.woff2") format("woff2"); }
@font-face { font-family: "Inter"; font-style: normal; font-weight: 400; font-display: swap; src: url("/assets/fonts/Inter-Regular.woff2") format("woff2"); }
@font-face { font-family: "Inter"; font-style: italic; font-weight: 400; font-display: swap; src: url("/assets/fonts/Inter-Italic.woff2") format("woff2"); }
@font-face { font-family: "Inter"; font-style: normal; font-weight: 700; font-display: swap; src: url("/assets/fonts/Inter-Bold.woff2") format("woff2"); }
@font-face { font-family: "Inter"; font-style: italic; font-weight: 700; font-display: swap; src: url("/assets/fonts/Inter-BoldItalic.woff2") format("woff2"); }

html {
    font-family: "Inter", sans-serif;
}

a {
    color: black;
    text-decoration: none;
    border-bottom: solid 2px #e74c3c;
    padding: 0;
}

a:visited {
    color: black;
}

a:hover,
a:active {
    color: #e74c3c;
}

a.image-link,
a.image-link:visited,
a.image-link:hover,
a.image-link:active {
    text-decoration: none;
    border: none;
    padding: 0;
}

h1 {
    margin-top: 0;
    margin-bottom: 0.5em;
    line-height: 1.2em;
}

h2 {
    margin-top: 1.5em;
    margin-bottom: 0.5em;
}

p {
    margin-bottom: 1em;
}

body {
    line-height: 1.5em;
}

.clearfix {
    clear: both;
}

.wrapper {
    max-width: 800px;

    margin-left: 1em;
    margin-right: 1em;
    margin-top: 2em;

    display: flex;
    flex-direction: column;
}

.columns {
    display: flex;
    flex-direction: column;
    gap: 3em;
}

.menu {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;

    margin-top: 0;
    margin-bottom: 0;
}

@media screen and (min-width: 575px) {
    .wrapper {
        margin: auto;
        margin-top: 5em;
    }

    .columns {
        display: flex;
        flex-direction: row;
        gap: 0;
    }

    .sidebar {
        width: 30%;
        padding-right: 2em;
    }

    .main {
        width: 70%;
        min-width: 0;
        overflow-x: hidden;
    }

    .menu {
        flex-direction: column;
    }
}

.sidebar header {
    font-size: xx-large;
    margin-bottom: 1em;
}

.sidebar header a {
    border-bottom: none;
}

.sidebar header a:hover {
    color: #e74c3c;
}

.main > :first-child {
    margin-top: 0 !important;
    margin-left: 0 !important;
}
.main > :last-child {
    margin-bottom: 0 !important;
    margin-right: 0 !important;
}

.menu .menu-item {
    text-decoration: none;
    margin: 0.2em 0;
    line-height: 1.8em;
}

.menu .menu-item a {
    display: inline-block;
}

.menu .menu-item.active {
    font-weight: bold;
    color: black;
}

.menu .menu-item.active a {
    border-bottom: none;
}

/* Images */
img {
    max-width: 100%;
    height: auto;
    display: block;
    margin: 1.5rem 0;
}

/* Article images */
article img {
    max-width: 100%;
    height: auto;
    border-radius: 4px;
}

/* Image captions */
article p > em {
    display: block;
    text-align: center;
    font-style: italic;
    font-size: 0.9em;
    color: #666;
    margin-top: -1rem;
    margin-bottom: 1.5rem;
}

.avatar {
    width: 125px;
    height: 125px;
    float: left;
    border-radius: 6px;
    margin-bottom: 1em;
    margin-right: 2em;
    margin-top: 1em;
}

ul.values {
    list-style-type: none;
    padding-left: none;
}
ul.values li {
    padding: 0.5em;
}

.book-detail {
    margin-top: 2em;
    margin-bottom: 2em;
}

.book-detail h2 {
    margin-bottom: 0.2em;
}

.book-detail .publication-date {
    font-weight: 200;
    margin-top: 0em;
}

.book-detail .cover {
    float: left;
    margin-top: 10px;
    margin-right: 10px;
}

.book-detail img {
    height: 126px;
    width: 100px;
}

.posts tr td:first-child,
.talks tr td:first-child,
.podcasts tr td:first-child {
    min-width: 100px;
    font-weight: 200;
    text-align: right;
}

.posts td.stars {
    max-width: 1em;
    padding: 0;
}

.posts,
.talks,
.podcats > tr,
td {
    padding: 10px;
}

.posts .post-star {
    color: #e74c3c;
}

ul.misc-list {
    padding-left: 0;
}
ul.misc-list li {
    padding: 0.5em;
}

.meta {
    margin-top: 0.3em;
    font-weight: 200;
}

pre {
    background-color: #faffff;
    border: 1px solid #ddd;
    padding: 0.8em;
    overflow: scroll;
    border-radius: 6px;
    line-height: 1.3em;
}

pre::-webkit-scrollbar {
    display: none;
}

ul,
ol {
    margin-left: 1.35em;
}

code {
    border: 1px solid #ddd;
    background-color: #faffff;
    padding: 0 0.2em;
}

pre code {
    border: none;
}

/* terminal */
pre.terminal {
    border: 1px solid #000;
    background-color: #333;
    color: #fff;
}

pre.terminal code {
    background-color: #333;
}

blockquote {
    font-style: italic;
    padding-left: 10px;
}

.postfooter {
    border-top: 1px solid;
    margin-top: 3em;
    font-style: italic;
}

.footer {
    margin-top: 5em;
    padding-top: 2em;
    text-align: center;
    color: grey;
    font-size: 0.9em;
}
.footer a {
    color: grey;
    border-bottom-color: grey;
}

.footer a:visited {
    color: grey;
}

.footer a:hover {
    color: grey;
}

/* Syntax highlighting */
.highlight .c { color: #999988; font-style: italic } /* Comment */
.highlight .err { color: #a61717; background-color: #e3d2d2 } /* Error */
.highlight .k { font-weight: bold } /* Keyword */
.highlight .o { font-weight: bold } /* Operator */
.highlight .cm { color: #999988; font-style: italic } /* Comment.Multiline */
.highlight .cp { color: #999999; font-weight: bold } /* Comment.Preproc */
.highlight .c1 { color: #999988; font-style: italic } /* Comment.Single */
.highlight .cs { color: #999999; font-weight: bold; font-style: italic } /* Comment.Special */
.highlight .gd { color: #000000; background-color: #ffdddd } /* Generic.Deleted */
.highlight .gd .x { color: #000000; background-color: #ffaaaa } /* Generic.Deleted.Specific */
.highlight .ge { font-style: italic } /* Generic.Emph */
.highlight .gr { color: #aa0000 } /* Generic.Error */
.highlight .gh { color: #999999 } /* Generic.Heading */
.highlight .gi { color: #000000; background-color: #ddffdd } /* Generic.Inserted */
.highlight .gi .x { color: #000000; background-color: #aaffaa } /* Generic.Inserted.Specific */
.highlight .go { color: #888888 } /* Generic.Output */
.highlight .gp { color: #555555 } /* Generic.Prompt */
.highlight .gs { font-weight: bold } /* Generic.Strong */
.highlight .gu { color: #aaaaaa } /* Generic.Subheading */
.highlight .gt { color: #aa0000 } /* Generic.Traceback */
.highlight .kc { font-weight: bold } /* Keyword.Constant */
.highlight .kd { font-weight: bold } /* Keyword.Declaration */
.highlight .kp { font-weight: bold } /* Keyword.Pseudo */
.highlight .kr { font-weight: bold } /* Keyword.Reserved */
.highlight .kt { color: #445588; font-weight: bold } /* Keyword.Type */
.highlight .m { color: #009999 } /* Literal.Number */
.highlight .s { color: #d14 } /* Literal.String */
.highlight .na { color: #008080 } /* Name.Attribute */
.highlight .nb { color: #0086B3 } /* Name.Builtin */
.highlight .nc { color: #445588; font-weight: bold } /* Name.Class */
.highlight .no { color: #008080 } /* Name.Constant */
.highlight .ni { color: #800080 } /* Name.Entity */
.highlight .ne { color: #990000; font-weight: bold } /* Name.Exception */
.highlight .nf { color: #990000; font-weight: bold } /* Name.Function */
.highlight .nn { color: #555555 } /* Name.Namespace */
.highlight .nt { color: #000080 } /* Name.Tag */
.highlight .nv { color: #008080 } /* Name.Variable */
.highlight .ow { font-weight: bold } /* Operator.Word */
.highlight .w { color: #bbbbbb } /* Text.Whitespace */
.highlight .mf { color: #009999 } /* Literal.Number.Float */
.highlight .mh { color: #009999 } /* Literal.Number.Hex */
.highlight .mi { color: #009999 } /* Literal.Number.Integer */
.highlight .mo { color: #009999 } /* Literal.Number.Oct */
.highlight .sb { color: #d14 } /* Literal.String.Backtick */
.highlight .sc { color: #d14 } /* Literal.String.Char */
.highlight .sd { color: #d14 } /* Literal.String.Doc */
.highlight .s2 { color: #d14 } /* Literal.String.Double */
.highlight .se { color: #d14 } /* Literal.String.Escape */
.highlight .sh { color: #d14 } /* Literal.String.Heredoc */
.highlight .si { color: #d14 } /* Literal.String.Interpol */
.highlight .sx { color: #d14 } /* Literal.String.Other */
.highlight .sr { color: #009926 } /* Literal.String.Regex */
.highlight .s1 { color: #d14 } /* Literal.String.Single */
.highlight .ss { color: #990073 } /* Literal.String.Symbol */
.highlight .bp { color: #999999 } /* Name.Builtin.Pseudo */
.highlight .vc { color: #008080 } /* Name.Variable.Class */
.highlight .vg { color: #008080 } /* Name.Variable.Global */
.highlight .vi { color: #008080 } /* Name.Variable.Instance */
.highlight .il { color: #009999 } /* Literal.Number.Integer.Long */
