/** Reset some basic elements */
body, h1, h2, h3, h4, h5, h6, p, blockquote, pre, hr, dl, dd, ol, ul, figure { margin: 0; padding: 0; }

/** Basic styling */
body { font-weight: 400; font-size: 16px; line-height: 1.5; font-family: "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif; color: #111; background-color: #fffdf5; -webkit-text-size-adjust: 100%; -webkit-font-feature-settings: "kern" 1; -moz-font-feature-settings: "kern" 1; -o-font-feature-settings: "kern" 1; font-feature-settings: "kern" 1; font-kerning: normal; }

div * { font-family: "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif; }

html, button, input, select, textarea, .pure-g [class*="pure-u"] { font-family: "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif; }

/** Set `margin-bottom` to maintain vertical rhythm */
h1, h2, h3, h4, h5, h6, p, blockquote, pre, ul, ol, dl, figure, .highlight { margin-bottom: 15px; }

/** Images */
img, video { max-width: 100%; vertical-align: middle; }

/** Figures */
figure > img { display: block; }

figcaption { font-size: 14px; }

/** Lists */
ul, ol { margin-left: 30px; }

li > ul, li > ol { margin-bottom: 0; }

/** Headings */
h1, h2, h3, h4, h5, h6 { font-weight: 400; }

/** Links */
a { color: #0050ad; text-decoration: none; }

a:visited { color: #0050ad; }

a:hover { color: #002147; text-decoration: underline; }

a.secret { color: inherit; text-decoration: inherit; }

/** Blockquotes */
blockquote { color: #828282; border-left: 4px solid #e8e8e8; padding-left: 15px; font-size: 18px; letter-spacing: -1px; font-style: italic; }

blockquote > :last-child { margin-bottom: 0; }

/** Code formatting */
pre, code { font-family: "Roboto Mono", monospace !important; font-size: 15px; border: 1px solid #e8e8e8; border-radius: 3px; background-color: #eef; }

pre *, code * { font-family: "Roboto Mono", monospace !important; }

code { padding: 1px 5px; }

pre { padding: 8px 12px; overflow-x: auto; }

pre > code { border: 0; padding-right: 0; padding-left: 0; }

/** Wrapper */
.wrapper { max-width: -webkit-calc(800px - (30px * 2)); max-width: calc(800px - (30px * 2)); margin-right: auto; margin-left: auto; padding-right: 30px; padding-left: 30px; }

.wrapper.wrapper-header { max-width: -webkit-calc(100% - (30px * 2)); max-width: calc(100% - (30px * 2)); }

.wrapper.wrapper-footer a, .wrapper.wrapper-footer a:visited { color: dimgray; }

@media screen and (max-width: 800px) { .wrapper { max-width: -webkit-calc(800px - (30px)); max-width: calc(800px - (30px)); padding-right: 15px; padding-left: 15px; } }

/** Clearfix */
.footer-col-wrapper:after, .wrapper:after { content: ""; display: table; clear: both; }

/** Icons */
.icon > svg { display: inline-block; width: 16px; height: 16px; vertical-align: middle; }

.icon > svg path { fill: #828282; }

/** Modifiers */
.slab { font-family: "Roboto Slab", "Times New Roman", serif !important; }

.mono { font-family: "Roboto Mono", monospace !important; }

.shadow { box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.3); transition: box-shadow 0.15s ease-in-out; }

.shadow-hover:hover { box-shadow: 0 0.1rem 0.2rem rgba(0, 0, 0, 0.3); }

.inline { float: left; margin-right: 15px; margin-bottom: 15px; }

/** Site header */
.site-header { background: #002147; min-height: 56px; position: relative; }

.site-title { font-size: 26px; font-weight: 300; line-height: 56px; margin-bottom: 0; float: left; }

.site-title:hover { text-decoration: none; }

.site-title, .site-title:visited, .site-title:hover { color: #e8e8e8; }

.social-link { display: inline-block !important; height: 100%; margin-top: 17px; margin-left: 7.5px; }

.social-link:first-child { margin-left: 22.5px; }

.social-link svg { width: 20px; height: 20px; color: #8090a3; }

.social-link svg:hover { color: #ccd3da; }

.site-nav { float: right; line-height: 56px; }

.site-nav .menu-icon { display: none; }

.site-nav .page-link { color: #8090a3; line-height: 1.5; }

.site-nav .page-link.active { color: #fff; }

.site-nav .page-link.active:hover { text-decoration: none; color: #fff; }

.site-nav .page-link:hover { text-decoration: none; color: #ccd3da; }

.site-nav .page-link:not(:last-child) { margin-right: 20px; }

@media screen and (max-width: 600px) { .site-nav { position: absolute; top: 9px; right: 15px; background-color: #002147; border: 1px solid #e8e8e8; border-radius: 5px; text-align: right; } .site-nav .menu-icon { display: block; float: right; width: 36px; height: 26px; line-height: 0; padding-top: 10px; text-align: center; } .site-nav .menu-icon > svg { width: 18px; height: 15px; display: initial !important; } .site-nav .menu-icon > svg path { fill: #e8e8e8; } .site-nav .trigger { clear: both; display: none; } .site-nav:hover .trigger { display: block; padding-bottom: 5px; } .site-nav .page-link { display: block; padding: 5px 10px; margin-left: 20px; } .site-nav .page-link:not(:last-child) { margin-right: 0; } }

/** Site footer */
.site-footer { background: #e8e8e8; color: #828282; text-align: center; font-size: 14px; padding: 12px 0; }

.footer-heading { font-size: 18px; margin-bottom: 15px; }

.contact-list, .social-media-list { list-style: none; margin-left: 0; }

.footer-col-wrapper { font-size: 15px; color: #828282; margin-left: -15px; }

.footer-col { float: left; margin-bottom: 15px; padding-left: 15px; }

.footer-col-1 { width: -webkit-calc(35% - (30px / 2)); width: calc(35% - (30px / 2)); }

.footer-col-2 { width: -webkit-calc(20% - (30px / 2)); width: calc(20% - (30px / 2)); }

.footer-col-3 { width: -webkit-calc(45% - (30px / 2)); width: calc(45% - (30px / 2)); }

@media screen and (max-width: 800px) { .footer-col-1, .footer-col-2 { width: -webkit-calc(50% - (30px / 2)); width: calc(50% - (30px / 2)); } .footer-col-3 { width: -webkit-calc(100% - (30px / 2)); width: calc(100% - (30px / 2)); } }

@media screen and (max-width: 600px) { .footer-col { float: none; width: -webkit-calc(100% - (30px / 2)); width: calc(100% - (30px / 2)); } }

/** Page content */
.page-content { padding: 30px 0; min-height: calc(100vh - 101px - (30px * 2)); }

.page-heading { font-size: 20px; }

.post-list { margin-left: 0; list-style: none; }

.post-list > li { margin-bottom: 30px; }

.post-cell { padding: 5px; }

.post-tags { text-align: right; }

.post-tag { color: white; background: #828282; padding: 1px 10px; border-radius: 50px; }

.post-tag:hover, .post-tag:link, .post-tag:visited, .post-tag:active { color: white; text-decoration: none; }

.post-tag-projects { background: #9d44bb; }

.post-tag-tips { background: #1e9d2c; }

.post-tag-thoughts { background: #1363bf; }

.post-meta { font-size: 14px; color: #828282; }

.post-link { display: block; font-size: 24px; }

.post-summary { color: #424242; }

/** Posts */
.post-header { margin-bottom: 30px; }

.post-title { letter-spacing: -1px; }

.post-title, .project-title { margin-bottom: 5px; font-size: 42px; line-height: 1; }

@media screen and (max-width: 800px) { .post-title, .project-title { font-size: 36px; } }

.post-content { margin-bottom: 30px; }

.post-content h1 { font-size: 32px; }

@media screen and (max-width: 800px) { .post-content h1 { font-size: 28px; } }

.post-content h2 { font-size: 28px; }

@media screen and (max-width: 800px) { .post-content h2 { font-size: 26px; } }

.post-content h3 { font-size: 26px; }

@media screen and (max-width: 800px) { .post-content h3 { font-size: 22px; } }

.post-content h4 { font-size: 20px; }

@media screen and (max-width: 800px) { .post-content h4 { font-size: 18px; } }

/** Projects */
.project-banner { text-align: center; background: #e8e8e8; background-position: center !important; background-repeat: no-repeat !important; background-size: cover !important; padding-top: 90px; padding-bottom: 90px; }

.project-subtitle { color: dimgray; }

.project-button { margin-top: 30px; }

/** Iframes */
.iframe-container { overflow: hidden; padding-top: 56.25%; position: relative; margin-bottom: 30px; }

.iframe-container iframe { border: 0; height: 100%; left: 0; position: absolute; top: 0; width: 100%; }

/* 4x3 Aspect Ratio */
.iframe-container-4x3 { padding-top: 75%; }

/** Syntax highlighting styles */
.highlight { background: #fff; }

.highlighter-rouge .highlight { background: #eef; }

.highlight .c { color: #998; font-style: italic; }

.highlight .err { color: #a61717; background-color: #e3d2d2; }

.highlight .k { font-weight: bold; }

.highlight .o { font-weight: bold; }

.highlight .cm { color: #998; font-style: italic; }

.highlight .cp { color: #999; font-weight: bold; }

.highlight .c1 { color: #998; font-style: italic; }

.highlight .cs { color: #999; font-weight: bold; font-style: italic; }

.highlight .gd { color: #000; background-color: #fdd; }

.highlight .gd .x { color: #000; background-color: #faa; }

.highlight .ge { font-style: italic; }

.highlight .gr { color: #a00; }

.highlight .gh { color: #999; }

.highlight .gi { color: #000; background-color: #dfd; }

.highlight .gi .x { color: #000; background-color: #afa; }

.highlight .go { color: #888; }

.highlight .gp { color: #555; }

.highlight .gs { font-weight: bold; }

.highlight .gu { color: #aaa; }

.highlight .gt { color: #a00; }

.highlight .kc { font-weight: bold; }

.highlight .kd { font-weight: bold; }

.highlight .kp { font-weight: bold; }

.highlight .kr { font-weight: bold; }

.highlight .kt { color: #458; font-weight: bold; }

.highlight .m { color: #099; }

.highlight .s { color: #d14; }

.highlight .na { color: #008080; }

.highlight .nb { color: #0086B3; }

.highlight .nc { color: #458; font-weight: bold; }

.highlight .no { color: #008080; }

.highlight .ni { color: #800080; }

.highlight .ne { color: #900; font-weight: bold; }

.highlight .nf { color: #900; font-weight: bold; }

.highlight .nn { color: #555; }

.highlight .nt { color: #000080; }

.highlight .nv { color: #008080; }

.highlight .ow { font-weight: bold; }

.highlight .w { color: #bbb; }

.highlight .mf { color: #099; }

.highlight .mh { color: #099; }

.highlight .mi { color: #099; }

.highlight .mo { color: #099; }

.highlight .sb { color: #d14; }

.highlight .sc { color: #d14; }

.highlight .sd { color: #d14; }

.highlight .s2 { color: #d14; }

.highlight .se { color: #d14; }

.highlight .sh { color: #d14; }

.highlight .si { color: #d14; }

.highlight .sx { color: #d14; }

.highlight .sr { color: #009926; }

.highlight .s1 { color: #d14; }

.highlight .ss { color: #990073; }

.highlight .bp { color: #999; }

.highlight .vc { color: #008080; }

.highlight .vg { color: #008080; }

.highlight .vi { color: #008080; }

.highlight .il { color: #099; }

#home { display: flex; background: linear-gradient(#fafafa80, #fafafa80), url("/media/homebg.jpg"); background-position: center; background-repeat: no-repeat; background-size: cover; min-height: calc(100vh - 101px); /*min-height: calc(100vh - 56px);*/ text-align: center; }

#home-inner { margin: auto; max-width: 800px; }

#photo { margin-bottom: 30px; }

#photo img { border-radius: 50%; border: 1px solid #fff; }

#home-heading { font-size: 48px; margin-bottom: 0; }

#home-subheading { font-size: 30px; color: #828282; margin-bottom: 45px; }

#home-arrow { position: absolute; bottom: 20px; width: 80px; left: calc(50% - 40px); text-align: center; font-size: 3em; color: #002147; }

@media screen and (max-height: 770px) { #home-arrow { bottom: -12px; } }

#home-lower { min-height: calc(100vh - 45px); font-size: 1.3em; }

.home-lower-inner { max-width: 1000px; padding-left: 30px; padding-right: 30px; margin: 80px auto; }

a button { width: 100%; }

.button { cursor: pointer; color: #111; background-color: transparent; text-align: center; vertical-align: middle; border: 1px solid #002147; border-radius: 0.25rem; font-size: 18px; padding: 8px 16px 8px 16px; transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out; }

.button-primary { color: #fff; background-color: #002147; border-color: #002147; }

.button-primary:hover { background-color: #0050ad; border-color: #0050ad; }

.button-primary:active { background-color: #005ac1; border-color: #005ac1; }

.small-only { display: none; }

@media screen and (max-width: 35.5em) { .small-only { display: inherit; } }

.large-only { display: inherit; }

@media screen and (max-width: 35.5em) { .large-only { display: none; } }

.project-container { width: 100%; background: white; padding: calc(30px / 2); border-radius: 8px; cursor: pointer; }

.project-container:not(:last-child) { margin-bottom: 30px; }

.summary-container { width: 100%; }

.square-image-box { position: relative; overflow: hidden; }

.square-image-box:before { content: ""; display: block; padding-top: 100%; }

.square-image { position: absolute; top: 0; left: 0; bottom: 0; right: 0; height: 100%; width: 100%; object-fit: cover; }

.project-thumbnail { width: calc(100% - (30px / 2)); padding-right: calc(30px / 2); }

@media screen and (max-width: 35.5em) { .project-thumbnail { width: 100%; padding-top: calc(30px / 2); padding-bottom: calc(30px / 2); padding-right: 0; } }

.summary-container .post-summary { margin-bottom: 0; }

.table { width: 100%; border-collapse: collapse; margin-bottom: 30px; }

.table td { border-top: 1px solid #e8e8e8; }

.social-links { list-style: none; }

.carousel { border-top: 10px solid #e8e8e8; width: 100%; color: #828282; }

.carousel img { min-width: 10vw; max-width: initial; display: block; height: 24vw; }

@media screen and (max-width: 35.5em) { .carousel img { min-width: 20vw; height: 60vw; } }

.footnotes { font-size: 0.8em; color: #828282; margin-top: 30px; }

.papers .paper { margin: 1em 0; }

.papers .paper .paper-title { font-weight: bold; }

.papers .paper .paper-date { color: #424242; }

.papers .paper .paper-awards { font-weight: bold; }

.papers .paper .paper-venue { font-style: italic; }

.talks .talk { margin: 1em 0; }

.talks .talk .talk-title { font-weight: bold; }

.talks .talk .talk-date { color: #424242; }

.talks .talk .talk-venue { font-style: italic; }

/*# sourceMappingURL=main.css.map */