/** 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 */
html { height: 100%; width: 100%; }

body { font: 200 12pt/1.5 "Source Sans Pro", Helvetica, Arial, sans-serif; color: #111; height: 100%; width: 100%; background-color: #fdfdfd; -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; }

/** 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 { max-width: 100%; vertical-align: middle; }

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

figcaption { font-size: 10.5pt; }

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

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

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

/** Links */
a { color: #2a7ae2; text-decoration: none; }
a:visited { color: #1756a9; }
a:hover { color: #111; text-decoration: underline; }

/** 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-size: 15px; border: 1px solid #e8e8e8; border-radius: 3px; background-color: #eef; }

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; }
@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 */
.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; }

/** Site header */
.site-spanimage { height: 85%; height: -webkit-calc(100% - 88px); height: calc(100% - 88px); width: 100%; -webkit-background-size: cover; -moz-background-size: cover; -o-background-size: cover; background-size: cover; background-repeat: no-repeat; background-position: 50% 75%; background-attachment: fixed; }
@media screen and (max-width: 600px) { .site-spanimage { background-attachment: scroll; } }
.site-spanimage p { position: absolute; bottom: 70px; right: 10px; text-align: right; font-size: 18pt; font-weight: 800; color: #bbb; }
@media screen and (max-width: 600px) { .site-spanimage p { visibility: hidden; } }
.site-spanimage span { padding-left: 16px; padding-right: 16px; padding-top: 4px; background-color: #fdfdfd; }

/** Page content */
.page-spanimage { height: 42%; height: -webkit-calc(100vh - 310px); height: calc(100vh - 310px); width: 100%; -webkit-background-size: cover; -moz-background-size: cover; -o-background-size: cover; background-size: cover; background-repeat: no-repeat; background-position: 50% 100%; background-attachment: fixed; }
@media screen and (max-width: 600px) { .page-spanimage { background-attachment: scroll; } }

.page-aboutspanimage { height: 42vh; width: 100%; -webkit-background-size: cover; -moz-background-size: cover; -o-background-size: cover; background-size: cover; background-repeat: no-repeat; background-position: 50% 100%; background-attachment: fixed; }
@media screen and (max-width: 600px) { .page-aboutspanimage { background-attachment: scroll; } }

.page-imagesrc { width: -webkit-calc(100% - (30px / 2)); width: calc(100% - (30px / 2)); font-size: 9pt; text-align: right; color: #bbb; }

.page-content { padding: 30px 0; }
.page-content h2 { font-size: 22px; font-weight: 800; margin-top: 32px; color: #777; letter-spacing: -1px; }
.page-content h3 { font-size: 26px; }
.page-content h4 { font-size: 20px; }
@media screen and (max-width: 800px) { .page-content h4 { font-size: 18px; } }

.page-heading { font-weight: 800; font-size: 32px; color: #777; letter-spacing: -1px; line-height: 1; }

.page-navigation { height: 30px; background-color: #fdfdfd; }
.page-navigation p { text-align: center; position: relative; top: 50%; transform: translateY(-50%); font-weight: 400; font-size: 12px; color: #bbb; letter-spacing: 5pt; }
.page-navigation a, .page-navigation a:visited { color: #777; }

.post-list { margin-left: 0; list-style: none; }
.post-list > li { margin-bottom: 30px; }

.post-meta { font-size: 10.5pt; text-align: center; color: #828282; }

.post-link { display: block; font-weight: 800; font-size: 32px; color: #777; letter-spacing: -1px; line-height: 1; }
.post-link, .post-link:visited { color: #777; }

/** Share Buttons */
.social-share { text-align: center; background-color: #fdfdfd; }

.social-sharetext { font-size: 7pt; font-weight: 400; color: #bbb; text-align: center; line-height: 2; letter-spacing: 1px; }

.social-shareicon { font-size: 36px; text-align: center; line-height: 1; color: #bbb; padding: 10px; }
.social-shareicon, .social-shareicon:link { color: #bbb; }
.social-shareicon, .social-shareicon:visited { color: #bbb; }
.social-shareicon, .social-shareicon:hover { color: #333; }

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

.post-title { font-weight: 800; font-size: 32px; text-align: center; color: #777; letter-spacing: -1px; line-height: 1; }

.post-content { margin-bottom: 30px; }
.post-content h2 { font-size: 22px; font-weight: 800; margin-top: 32px; color: #777; letter-spacing: -1px; }
.post-content h3 { font-size: 26px; }
.post-content h4 { font-size: 20px; }
@media screen and (max-width: 800px) { .post-content h4 { font-size: 18px; } }

.post-description { height: 72pt; overflow: hidden; }
.post-description a, .post-description a:link { color: #111; }
.post-description a, .post-description a:visited { color: #111; }
.post-description a, .post-description a:hover { color: #111; text-decoration: none; }

/** 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; }
