html {
    font-family: -apple-system, system-ui, BlinkMacSystemFont, 'Segoe UI', Roboto, Ubuntu, 'Helvetica Neue', Helvetica, Arial, sans-serif;
    font-size: 137.5%;
    -webkit-font-smoothing: antialiased;
    box-sizing: border-box;
}

*, *:before, *:after {
    box-sizing: inherit;
}

p {
    line-height: 1.5rem;
    margin-top: 1rem;
    margin-bottom: 0;
    word-wrap: break-word;
}

ul,
ol {
    margin-top: 1rem;
    margin-bottom: 1rem;
}

li {
    line-height: 1.5rem;
    margin-bottom: 0.5rem;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: -apple-system, system-ui, BlinkMacSystemFont, 'Segoe UI', Roboto, Ubuntu, 'Helvetica Neue', Helvetica, Arial, sans-serif;
    margin-top: 1.5rem;
    margin-bottom: 0;
    line-height: 1.5rem;
}

h1 {
    font-size: 4.242rem;
    line-height: 4.5rem;
    margin-top: 3rem;
}

h2 {
    font-size: 2.828rem;
    line-height: 3rem;
    color: #222;
}

h3 {
    font-size: 1.414rem;
    color: #222;
}

h4 {
    font-size: 0.707rem;
    color: #444;
}

h5 {
    font-size: 0.4713333333333333rem;
}

h6 {
    font-size: 0.3535rem;
}

/* Code blocks */

code {
    vertical-align: bottom;
}

main {
    max-width: 720px;
    width: 100%;
    margin: 0 auto;
    padding: 0 16px;
}

footer {
    margin-top: 3rem;
    margin-bottom: 1rem;
    max-width: 720px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    padding: 0 16px;
}

.lead {
    font-size: 1.6rem;
    line-height: 1.3;
}

a {
    color: #222;
}

a:hover,
a:focus {
    color: #00baff;
}

span {
    line-height: 1.3rem;
}

@media only screen and (max-width: 812px) {
    html {
        font-size: 112.5%; /* Smaller base font on mobile */
    }
    
    body {
        margin: 0;
    }
    
    main, footer {
        width: 100%;
        padding: 0 20px;
    }
    
    h1 {
        font-size: 2.5rem;
        line-height: 3rem;
        margin-top: 2rem;
    }
    
    h2 {
        font-size: 2rem;
        line-height: 2.5rem;
    }
    
    .lead {
        font-size: 1.3rem;
    }
    
    top {
        position: static;
        display: block;
        text-align: right;
        padding: 10px 20px;
        margin-bottom: 1rem;
    }
    
    pre.highlight {
        font-size: 0.7rem;
        padding: 0.5rem;
        margin: 1rem -20px; /* Extend to edges */
        border-radius: 0;
        border-left: none;
        border-right: none;
    }
}

@media only screen and (max-width: 480px) {
    html {
        font-size: 100%; /* Even smaller for small phones */
    }
    
    main, footer {
        padding: 0 16px;
    }
    
    h1 {
        font-size: 2rem;
        line-height: 2.5rem;
    }
    
    h2 {
        font-size: 1.6rem;
        line-height: 2rem;
    }
    
    h3 {
        font-size: 1.2rem;
    }
    
    .lead {
        font-size: 1.1rem;
    }
    
    pre.highlight {
        font-size: 0.65rem;
        margin: 1rem -16px;
    }
}

top {
    position: absolute;
    top: 10px;
    right: 20px;
}

.small {
    font-size: 80%;
}

.project-details {
    font-size: 80%;
    margin-top: .5rem;
    display: inline-block;
}

.project-details .collaborators a {
    font-weight: bold;
}

.project-details .workplace a {
    font-weight: bold;
}

code.language-plaintext {
  background: rgba(0,0,0,0.08);
  font-size: 0.85rem;
  line-height: 1.25rem;
}

/* Syntax Highlighting with Rouge */
pre {
    margin:0;
}

pre.highlight {
    font-size: 0.8rem;
    background-color: #f6f8fa;
    border: 1px solid #e1e4e8;
    border-radius: 3px;
    padding: 0 1rem;
    overflow-x: auto;
    margin: 1rem 0;
}

table td.rouge-gutter {
    color: #666666;
    padding-right: 10px;
}

.highlight .c { color: #6a737d; } /* Comment */
.highlight .err { color: #86181e; background-color: #f6f8fa; } /* Error */
.highlight .k { color: #d73a49; } /* Keyword */
.highlight .l { color: #005cc5; } /* Literal */
.highlight .n { color: #6f42c1; } /* Name */
.highlight .o { color: #d73a49; } /* Operator */
.highlight .p { color: #24292e; } /* Punctuation */
.highlight .cm { color: #6a737d; } /* Comment.Multiline */
.highlight .cp { color: #d73a49; } /* Comment.Preproc */
.highlight .c1 { color: #6a737d; } /* Comment.Single */
.highlight .cs { color: #6a737d; } /* Comment.Special */
.highlight .gd { color: #b31c1c; background-color: #ffeaea; } /* Generic.Deleted */
.highlight .ge { font-style: italic; } /* Generic.Emph */
.highlight .gh { color: #24292e; font-weight: bold; } /* Generic.Heading */
.highlight .gi { color: #28a745; background-color: #f0f9f4; } /* Generic.Inserted */
.highlight .go { color: #6a737d; } /* Generic.Output */
.highlight .gp { color: #6a737d; } /* Generic.Prompt */
.highlight .gs { font-weight: bold; } /* Generic.Strong */
.highlight .gu { color: #6f42c1; font-weight: bold; } /* Generic.Subheading */
.highlight .gt { color: #d73a49; } /* Generic.Traceback */
.highlight .kc { color: #d73a49; } /* Keyword.Constant */
.highlight .kd { color: #d73a49; } /* Keyword.Declaration */
.highlight .kn { color: #d73a49; } /* Keyword.Namespace */
.highlight .kp { color: #d73a49; } /* Keyword.Pseudo */
.highlight .kr { color: #d73a49; } /* Keyword.Reserved */
.highlight .kt { color: #d73a49; } /* Keyword.Type */
.highlight .ld { color: #28a745; } /* Literal.Date */
.highlight .m { color: #005cc5; } /* Literal.Number */
.highlight .s { color: #28a745; } /* Literal.String */
.highlight .na { color: #6f42c1; } /* Name.Attribute */
.highlight .nb { color: #005cc5; } /* Name.Builtin */
.highlight .nc { color: #6f42c1; } /* Name.Class */
.highlight .no { color: #005cc5; } /* Name.Constant */
.highlight .nd { color: #6f42c1; } /* Name.Decorator */
.highlight .ni { color: #005cc5; } /* Name.Entity */
.highlight .ne { color: #005cc5; } /* Name.Exception */
.highlight .nf { color: #6f42c1; } /* Name.Function */
.highlight .nl { color: #005cc5; } /* Name.Label */
.highlight .nn { color: #6f42c1; } /* Name.Namespace */
.highlight .nx { color: #005cc5; } /* Name.Other */
.highlight .py { color: #005cc5; } /* Name.Property */
.highlight .nt { color: #22863a; } /* Name.Tag */
.highlight .nv { color: #005cc5; } /* Name.Variable */
.highlight .ow { color: #d73a49; } /* Operator.Word */
.highlight .w { color: #24292e; } /* Text.Whitespace */
.highlight .mb { color: #005cc5; } /* Literal.Number.Bin */
.highlight .mf { color: #005cc5; } /* Literal.Number.Float */
.highlight .mh { color: #005cc5; } /* Literal.Number.Hex */
.highlight .mi { color: #005cc5; } /* Literal.Number.Integer */
.highlight .mo { color: #005cc5; } /* Literal.Number.Oct */
.highlight .sa { color: #d73a49; } /* Literal.String.Affix */
.highlight .sb { color: #28a745; } /* Literal.String.Backtick */
.highlight .sc { color: #28a745; } /* Literal.String.Char */
.highlight .sd { color: #28a745; } /* Literal.String.Doc */
.highlight .s1 { color: #28a745; } /* Literal.String.Single */
.highlight .s2 { color: #28a745; } /* Literal.String.Double */
.highlight .se { color: #28a745; } /* Literal.String.Escape */
.highlight .sh { color: #28a745; } /* Literal.String.Heredoc */
.highlight .si { color: #28a745; } /* Literal.String.Interpol */
.highlight .sx { color: #28a745; } /* Literal.String.Other */
.highlight .sr { color: #28a745; } /* Literal.String.Regex */
.highlight .s1 { color: #28a745; } /* Literal.String.Single */
.highlight .ss { color: #28a745; } /* Literal.String.Symbol */
.highlight .bp { color: #005cc5; } /* Name.Builtin.Pseudo */
.highlight .fm { color: #005cc5; } /* Name.Function.Magic */
.highlight .vg { color: #005cc5; } /* Name.Variable.Global */
.highlight .vi { color: #005cc5; } /* Name.Variable.Instance */
.highlight .vm { color: #005cc5; } /* Name.Variable.Magic */
.highlight .il { color: #005cc5; } /* Literal.Number.Integer.Long */
