/**
* font-smooth
*/
* { font-smooth: always; -webkit-font-smoothing: antialiased !important; text-shadow: 0 0 1px rgba(0, 0, 0, 0.22); }

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

hr { margin-top: 15px; margin-bottom: 15px; border: 1px dashed lightgray; }

/** Basic styling */
body { font: 400 16px/1.5 "Helvetica Neue", Helvetica, Arial, sans-serif; color: #111; 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 { margin-bottom: 15px; }

/** Images */
img { 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: #2a7ae2; text-decoration: none; }
a:visited { color: #1756a9; }
a:hover { color: #111; text-decoration: underline; }

/** Blockquotes */
blockquote { color: #2d2c2c; border-left: 4px solid #69cc86; padding-left: 15px; font-size: 16px; letter-spacing: -1px; font-style: inherit; }
blockquote > :last-child { margin-bottom: 0; }

/** Code formatting */
pre, code { font-size: 14px; }

code { padding: 1px 5px; }

pre { padding: 8px 12px; overflow-x: auto; }
pre > code { padding-right: 0; padding-left: 0; }

/** Wrapper */
.wrapper { max-width: -webkit-calc(860px - (30px * 2)); max-width: calc(860px - (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(860px - (30px)); max-width: calc(860px - (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; }

/**
* image caption
*/
.image-caption { display: flex; flex-direction: column; align-content: center; flex-wrap: wrap; align-items: center; min-height: 22px; padding-top: 0px; padding-bottom: 10px; margin: 0 auto; color: #969696; line-height: 1.7; text-align: center; }
.image-caption em { border-bottom: 1px solid #d9d9d9; margin-top: 8px; padding-bottom: 2px; }
.image-caption img { border-radius: 6px; box-shadow: 0 0 10px #555; }

table { border-collapse: collapse; }
table th, table td { padding: 8px; border: 1px solid #ddd; }

.footnote:before { content: ' [ '; }
.footnote:after { content: ' ]'; }

.footnotes { color: gray; }
.footnotes a { color: gray; }

/** Site header */
.site-header { border-top: 2px solid #424242; border-bottom: 1px solid #e8e8e8; min-height: 56px; position: fixed; width: 100%; background: white; z-index: 1; }

.site-title { font-size: 26px; font-weight: 300; line-height: 56px; letter-spacing: -1px; margin-bottom: 0; float: left; }
.site-title, .site-title:visited { color: #424242; }

.site-nav { float: right; line-height: 56px; }
.site-nav .menu-icon { display: none; }
.site-nav .page-link { color: #111; line-height: 1.5; }
.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: #fdfdfd; 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; }
  .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; margin-left: 20px; }
  .site-nav .page-link:not(:last-child) { margin-right: 0; } }

/** Site footer */
.site-footer { border-top: 1px solid #e8e8e8; 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 { padding-top: 86px; }

.cayman-page-content { padding-top: 46px; }

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

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

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

.post-link { display: block; font-size: 24px; }
@media screen and (max-width: 500px) { .post-link { font-size: 20px; } }

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

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

.post-content { border-top: 1px dashed lightgray; padding-top: 1.1em; margin-bottom: 30px; }
.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; } }

.highlight, .highlighter-rouge { font-family: Consolas; background-color: #ecf7f0; border-radius: 5px; }

.highlight .hll { background-color: #ffffcc; }

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

/* Comment */
.highlight .err { border: 1px solid #FF0000; }

/* Error */
.highlight .k { color: #AA22FF; font-weight: bold; }

/* Keyword */
.highlight .o { color: #666666; }

/* Operator */
.highlight .cm { color: #008800; font-style: italic; }

/* Comment.Multiline */
.highlight .cp { color: #008800; }

/* Comment.Preproc */
.highlight .c1 { color: #008800; font-style: italic; }

/* Comment.Single */
.highlight .cs { color: #008800; font-weight: bold; }

/* Comment.Special */
.highlight .gd { color: #A00000; }

/* Generic.Deleted */
.highlight .ge { font-style: italic; }

/* Generic.Emph */
.highlight .gr { color: #FF0000; }

/* Generic.Error */
.highlight .gh { color: #000080; font-weight: bold; }

/* Generic.Heading */
.highlight .gi { color: #00A000; }

/* Generic.Inserted */
.highlight .go { color: #808080; }

/* Generic.Output */
.highlight .gp { color: #000080; font-weight: bold; }

/* Generic.Prompt */
.highlight .gs { font-weight: bold; }

/* Generic.Strong */
.highlight .gu { color: #800080; font-weight: bold; }

/* Generic.Subheading */
.highlight .gt { color: #0040D0; }

/* Generic.Traceback */
.highlight .kc { color: #AA22FF; font-weight: bold; }

/* Keyword.Constant */
.highlight .kd { color: #AA22FF; font-weight: bold; }

/* Keyword.Declaration */
.highlight .kn { color: #AA22FF; font-weight: bold; }

/* Keyword.Namespace */
.highlight .kp { color: #AA22FF; }

/* Keyword.Pseudo */
.highlight .kr { color: #AA22FF; font-weight: bold; }

/* Keyword.Reserved */
.highlight .kt { color: #00BB00; font-weight: bold; }

/* Keyword.Type */
.highlight .m { color: #666666; }

/* Literal.Number */
.highlight .s { color: #BB4444; }

/* Literal.String */
.highlight .na { color: #BB4444; }

/* Name.Attribute */
.highlight .nb { color: #AA22FF; }

/* Name.Builtin */
.highlight .nc { color: #0000FF; }

/* Name.Class */
.highlight .no { color: #880000; }

/* Name.Constant */
.highlight .nd { color: #AA22FF; }

/* Name.Decorator */
.highlight .ni { color: #999999; font-weight: bold; }

/* Name.Entity */
.highlight .ne { color: #D2413A; font-weight: bold; }

/* Name.Exception */
.highlight .nf { color: #00A000; }

/* Name.Function */
.highlight .nl { color: #A0A000; }

/* Name.Label */
.highlight .nn { color: #0000FF; font-weight: bold; }

/* Name.Namespace */
.highlight .nt { color: #008000; font-weight: bold; }

/* Name.Tag */
.highlight .nv { color: #B8860B; }

/* Name.Variable */
.highlight .ow { color: #AA22FF; font-weight: bold; }

/* Operator.Word */
.highlight .w { color: #bbbbbb; }

/* Text.Whitespace */
.highlight .mf { color: #666666; }

/* Literal.Number.Float */
.highlight .mh { color: #666666; }

/* Literal.Number.Hex */
.highlight .mi { color: #666666; }

/* Literal.Number.Integer */
.highlight .mo { color: #666666; }

/* Literal.Number.Oct */
.highlight .sb { color: #BB4444; }

/* Literal.String.Backtick */
.highlight .sc { color: #BB4444; }

/* Literal.String.Char */
.highlight .sd { color: #BB4444; font-style: italic; }

/* Literal.String.Doc */
.highlight .s2 { color: #BB4444; }

/* Literal.String.Double */
.highlight .se { color: #BB6622; font-weight: bold; }

/* Literal.String.Escape */
.highlight .sh { color: #BB4444; }

/* Literal.String.Heredoc */
.highlight .si { color: #BB6688; font-weight: bold; }

/* Literal.String.Interpol */
.highlight .sx { color: #008000; }

/* Literal.String.Other */
.highlight .sr { color: #BB6688; }

/* Literal.String.Regex */
.highlight .s1 { color: #BB4444; }

/* Literal.String.Single */
.highlight .ss { color: #B8860B; }

/* Literal.String.Symbol */
.highlight .bp { color: #AA22FF; }

/* Name.Builtin.Pseudo */
.highlight .vc { color: #B8860B; }

/* Name.Variable.Class */
.highlight .vg { color: #B8860B; }

/* Name.Variable.Global */
.highlight .vi { color: #B8860B; }

/* Name.Variable.Instance */
.highlight .il { color: #666666; }

/* Literal.Number.Integer.Long */
.box, .box_done, .task-list-item { list-style-type: none; }

.task-list-item input { margin: 0 0.2em 0.25em -1.6em; vertical-align: middle; }

.task-list-item + .task-list-item { margin-top: 3px; }
