/** 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-family: Garamond, serif; font-size: 20px; line-height: 1.3; color: #111; -webkit-text-size-adjust: 100%; background-color: #f1f1f1; }

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

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

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

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

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

/** Blockquotes */
blockquote { color: #828282; border-left: 4px solid #b5b5b5; padding-left: 15px; font-size: 18px; }
blockquote > :last-child { margin-bottom: 0; }

/** Code formatting */
pre, code { font-family: Menlo, Consolas, Monaco, "Courier New", monospace, serif; }

code.highlighter-rouge { color: #000; padding: 3px 8px; font-size: 14px; white-space: nowrap; border: 1px solid #E5E5E5; background-color: #f7f7f7; }

pre { padding: 8px 12px; overflow-x: scroll; font-size: 14px; line-height: 18px; border-left: 3px #ef5138 solid; margin: 0.5em; margin-left: 10px; margin-bottom: 1.5em; padding: 0.5em; padding-left: 1em; overflow: scroll; }
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, .footer-col-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-header { background-color: #fdfdfd; padding-top: 10px; min-height: 42px; position: relative; }

.site-title { font-size: 18px; line-height: 42px; letter-spacing: -1px; margin-bottom: 0; float: left; font-family: Helvetica, sans-serif; letter-spacing: 0.5px; }
.site-title, .site-title:visited { color: #b5b5b5; }
.site-title:hover { color: #424242; }

#photoheader .site-header { background-color: transparent; }

.site-nav { font-family: Helvetica, Arial, sans-serif; font-weight: 700; float: right; line-height: 42px; }
.site-nav .menu-icon { display: none; }
.site-nav .page-link { text-transform: uppercase; color: #828282; border-bottom: 4px solid #dbdbdb; line-height: 1.3; }
.site-nav .page-link:hover { text-decoration: none; color: #2b2b2b; border-bottom-color: #2a7ae2; }
.site-nav .page-link:not(:first-child) { margin-left: 20px; }
.site-nav .page-link .selected { border-bottom-color: #2a7ae2; }
@media screen and (max-width: 600px) { .site-nav { position: absolute; top: 9px; right: 30px; background-color: #fdfdfd; border: 1px solid #b5b5b5; 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; }
  .site-nav .menu-icon > svg path { fill: #424242; }
  .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; } }

/** Site footer */
.site-footer { border-top: 1px solid #b5b5b5; padding: 30px 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 { background-color: #fdfdfd; padding: 30px 0; }

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

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

.post-meta { font-family: Helvetica; font-weight: 300; font-size: 20px; color: #b5b5b5; }
.post-list > li .post-meta { float: right; margin-top: -18px; }

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

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

.post-title { font-size: 36px; letter-spacing: -1px; line-height: 1; }
@media screen and (max-width: 800px) { .post-title { font-size: 36px; } }

.post-content { text-rendering: optimizeLegibility; margin-bottom: 30px; }
.post-content a { color: #111; border-bottom: 1px solid #ccc; }
.post-content a:hover { color: #2a7ae2; border-width: 0; }
.post-content h2 { font-size: 32px; }
@media screen and (max-width: 800px) { .post-content h2 { font-size: 28px; } }
.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; } }

/** Index Page */
.timeCount { display: inline-block; vertical-align: middle; margin-left: 4px; }

.timeBlock { float: left; width: 6px; height: 6px; border-radius: 3px; background-color: #b5b5b5; margin-right: 2px; }

#instantclick-bar { background: #2a7ae2; }

div#masonry { display: -ms-flexbox; -ms-flex-direction: column; -ms-flex-wrap: wrap; display: flex; flex-direction: column; flex-wrap: wrap; height: 100vw; font-size: 0; }

div#masonry img { width: 33.3%; }

@media screen and (max-width: 500px) { div#masonry { height: 200vw; }
  div#masonry img { width: 50%; } }
div#fullscreen { position: fixed; top: 0; bottom: 0; right: 0; left: 0; }
div#fullscreen .carousel-wrapper { position: absolute; text-align: center; width: 100%; height: 100%; }
div#fullscreen .carousel-wrapper .carousel-slide { background-color: blue; height: 100%; margin: 0 auto; }

.hidden { display: none; }

.move-left { -webkit-animation: moveToLeft .6s ease both; animation: moveToLeft .6s ease both; }

.move-right { -webkit-animation: moveToRight .6s ease both; animation: moveToRight .6s ease both; }

.move-from-right { -webkit-animation: moveFromRight .6s ease both; animation: moveFromRight .6s ease both; }

.move-from-left { -webkit-animation: moveFromLeft .6s ease both; animation: moveFromLeft .6s ease both; }

.fade-in-80 { background: transparent; -webkit-animation: fade80 .7s ease both; animation: fade80 .7s ease both; }

.fade-out-80 { background: rgba(0, 0, 0, 0.8); -webkit-animation: fade0 .5s ease both; animation: fade0 .5s ease both; }

/********************************* keyframes **************************************/
/* move from / to  */
@-webkit-keyframes moveToLeft { to { -webkit-transform: translateX(-100%); } }
@keyframes moveToLeft { to { -webkit-transform: translateX(-100%); transform: translateX(-100%); } }
@-webkit-keyframes moveFromLeft { from { -webkit-transform: translateX(-100%); } }
@keyframes moveFromLeft { from { -webkit-transform: translateX(-100%); transform: translateX(-100%); } }
@-webkit-keyframes moveToRight { to { -webkit-transform: translateX(100%); } }
@keyframes moveToRight { to { -webkit-transform: translateX(100%); transform: translateX(100%); } }
@-webkit-keyframes moveFromRight { from { -webkit-transform: translateX(100%); } }
@keyframes moveFromRight { from { -webkit-transform: translateX(100%); transform: translateX(100%); } }
/* fade */
@-webkit-keyframes fade80 { to { background: rgba(0, 0, 0, 0.8); } }
@keyframes fade80 { to { background: rgba(0, 0, 0, 0.8); } }
@-webkit-keyframes fade0 { to { background: transparent; } }
@keyframes fade0 { to { background: transparent; } }
/** Syntax highlighting styles */
.highlight { background: #ffffff; white-space: wrap; }
.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; }

.grid-2 { width: 90%; margin: 20px auto; line-height: 0; -moz-column-gap: 20; -webkit-column-gap: 20; column-gap: 20; -moz-column-count: 5; -webkit-column-count: 5; column-count: 5; }
.grid-2 img { display: inline-block; margin-bottom: 15px; width: 100% !important; height: auto !important; }

.grid-1 { width: 90%; margin: 20px auto; line-height: 0; -moz-column-gap: 20; -webkit-column-gap: 20; column-gap: 20; -moz-column-count: 5; -webkit-column-count: 5; column-count: 5; }
.grid-1 img { display: inline-block; margin-bottom: 15px; width: 100% !important; height: auto !important; }

@media (max-width: 5000px) { .grid-2 { -moz-column-count: 2; -webkit-column-count: 2; column-count: 2; }
  .grid-1 { -moz-column-count: 1; -webkit-column-count: 1; column-count: 1; } }
@media (max-width: 1000px) { .grid-2 { -moz-column-count: 2; -webkit-column-count: 2; column-count: 2; }
  .grid-1 { -moz-column-count: 1; -webkit-column-count: 1; column-count: 1; } }
@media (max-width: 800px) { .grid-2 { -moz-column-count: 2; -webkit-column-count: 2; column-count: 2; }
  .grid-1 { -moz-column-count: 1; -webkit-column-count: 1; column-count: 1; } }
@media (max-width: 400px) { .grid-2 { -moz-column-count: 1; -webkit-column-count: 1; column-count: 1; }
  .grid-1 { -moz-column-count: 1; -webkit-column-count: 1; column-count: 1; } }
