@charset "UTF-8";
/*! normalize.css v3.0.2 | MIT License | git.io/normalize */
/** 1. Set default font family to sans-serif. 2. Prevent iOS text size adjust after orientation change, without disabling user zoom. */
html { font-family: sans-serif; /* 1 */ -ms-text-size-adjust: 100%; /* 2 */ -webkit-text-size-adjust: 100%; /* 2 */ }

/** Remove default margin. */
body { margin: 0; }

/* HTML5 display definitions ========================================================================== */
/** Correct `block` display not defined for any HTML5 element in IE 8/9. Correct `block` display not defined for `details` or `summary` in IE 10/11 and Firefox. Correct `block` display not defined for `main` in IE 11. */
article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary { display: block; }

/** 1. Correct `inline-block` display not defined in IE 8/9. 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera. */
audio, canvas, progress, video { display: inline-block; /* 1 */ vertical-align: baseline; /* 2 */ }

/** Prevent modern browsers from displaying `audio` without controls. Remove excess height in iOS 5 devices. */
audio:not([controls]) { display: none; height: 0; }

/** Address `[hidden]` styling not present in IE 8/9/10. Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22. */
[hidden], template { display: none; }

/* Links ========================================================================== */
/** Remove the gray background color from active links in IE 10. */
a { background-color: transparent; }

/** Improve readability when focused and also mouse hovered in all browsers. */
a:active, a:hover { outline: 0; }

/* Text-level semantics ========================================================================== */
/** Address styling not present in IE 8/9/10/11, Safari, and Chrome. */
abbr[title] { border-bottom: 1px dotted; }

/** Address style set to `bolder` in Firefox 4+, Safari, and Chrome. */
b, strong { font-weight: bold; }

/** Address styling not present in Safari and Chrome. */
dfn { font-style: italic; }

/** Address variable `h1` font-size and margin within `section` and `article` contexts in Firefox 4+, Safari, and Chrome. */
h1 { font-size: 2em; margin: 0.67em 0; }

/** Address styling not present in IE 8/9. */
mark { background: #ff0; color: #000; }

/** Address inconsistent and variable font size in all browsers. */
small { font-size: 80%; }

/** Prevent `sub` and `sup` affecting `line-height` in all browsers. */
sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; }

sup { top: -0.5em; }

sub { bottom: -0.25em; }

/* Embedded content ========================================================================== */
/** Remove border when inside `a` element in IE 8/9/10. */
img { border: 0; }

/** Correct overflow not hidden in IE 9/10/11. */
svg:not(:root) { overflow: hidden; }

/* Grouping content ========================================================================== */
/** Address margin not present in IE 8/9 and Safari. */
figure { margin: 1em 40px; }

/** Address differences between Firefox and other browsers. */
hr { -moz-box-sizing: content-box; box-sizing: content-box; height: 0; }

/** Contain overflow in all browsers. */
pre { overflow: auto; }

/** Address odd `em`-unit font size rendering in all browsers. */
code, kbd, pre, samp { font-family: monospace, monospace; font-size: 1em; }

/* Forms ========================================================================== */
/** Known limitation: by default, Chrome and Safari on OS X allow very limited styling of `select`, unless a `border` property is set. */
/** 1. Correct color not being inherited. Known issue: affects color of disabled elements. 2. Correct font properties not being inherited. 3. Address margins set differently in Firefox 4+, Safari, and Chrome. */
button, input, optgroup, select, textarea { color: inherit; /* 1 */ font: inherit; /* 2 */ margin: 0; /* 3 */ }

/** Address `overflow` set to `hidden` in IE 8/9/10/11. */
button { overflow: visible; }

/** Address inconsistent `text-transform` inheritance for `button` and `select`. All other form control elements do not inherit `text-transform` values. Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera. Correct `select` style inheritance in Firefox. */
button, select { text-transform: none; }

/** 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio` and `video` controls. 2. Correct inability to style clickable `input` types in iOS. 3. Improve usability and consistency of cursor style between image-type `input` and others. */
button, html input[type="button"], input[type="reset"], input[type="submit"] { -webkit-appearance: button; /* 2 */ cursor: pointer; /* 3 */ }

/** Re-set default cursor for disabled elements. */
button[disabled], html input[disabled] { cursor: default; }

/** Remove inner padding and border in Firefox 4+. */
button::-moz-focus-inner, input::-moz-focus-inner { border: 0; padding: 0; }

/** Address Firefox 4+ setting `line-height` on `input` using `!important` in the UA stylesheet. */
input { line-height: normal; }

/** It's recommended that you don't attempt to style these elements. Firefox's implementation doesn't respect box-sizing, padding, or width.  1. Address box sizing set to `content-box` in IE 8/9/10. 2. Remove excess padding in IE 8/9/10. */
input[type="checkbox"], input[type="radio"] { box-sizing: border-box; /* 1 */ padding: 0; /* 2 */ }

/** Fix the cursor style for Chrome's increment/decrement buttons. For certain `font-size` values of the `input`, it causes the cursor style of the decrement button to change from `default` to `text`. */
input[type="number"]::-webkit-inner-spin-button, input[type="number"]::-webkit-outer-spin-button { height: auto; }

/** 1. Address `appearance` set to `searchfield` in Safari and Chrome. 2. Address `box-sizing` set to `border-box` in Safari and Chrome (include `-moz` to future-proof). */
input[type="search"] { -webkit-appearance: textfield; /* 1 */ -moz-box-sizing: content-box; -webkit-box-sizing: content-box; /* 2 */ box-sizing: content-box; }

/** Remove inner padding and search cancel button in Safari and Chrome on OS X. Safari (but not Chrome) clips the cancel button when the search input has padding (and `textfield` appearance). */
input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-decoration { -webkit-appearance: none; }

/** Define consistent border, margin, and padding. */
fieldset { border: 1px solid #c0c0c0; margin: 0 2px; padding: 0.35em 0.625em 0.75em; }

/** 1. Correct `color` not being inherited in IE 8/9/10/11. 2. Remove padding so people aren't caught out if they zero out fieldsets. */
legend { border: 0; /* 1 */ padding: 0; /* 2 */ }

/** Remove default vertical scrollbar in IE 8/9/10/11. */
textarea { overflow: auto; }

/** Don't inherit the `font-weight` (applied by a rule above). NOTE: the default cannot safely be changed in Chrome and Safari on OS X. */
optgroup { font-weight: bold; }

/* Tables ========================================================================== */
/** Remove most spacing between table cells. */
table { border-collapse: collapse; border-spacing: 0; }

td, th { padding: 0; }

/* Colors – from https://github.com/mrmrs/colors */
/** Syntax highlighting styles */
.highlight { background: #fff; }
.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; }

/* ------------------------------------------------------ */
/* Template Styles */
/* ------------------------------------------------------ */
html, body { height: 100%; }

a { color: #0074D9; }

hr { height: 1px; background: #BFBFBF; border: none; }

.content { margin: 0 auto; padding: 0 15px; max-width: 800px; }

.wrapper { min-height: 100%; height: auto !important; height: 100%; margin: 0 auto -150px 0; }

.center { text-align: center; }

/* Header */
/* ------------------------------------------------------ */
header.site-header { padding: 25px 0; font-size: 18px; font-weight: bold; color: #FFF; background: #0074D9; }
header.site-header .site-logo-img { position: relative; top: -13px; width: 50px; height: 50px; margin-right: 15px; float: left; }
header.site-header a { color: #FFF; }
header.site-header nav ul { margin: 0; padding: 0; list-style: none; float: right; }
header.site-header nav ul li { display: inline; margin-left: 25px; margin-bottom: 0.25em; }
header.site-header nav ul li .icon { position: relative; right: -15px; margin-top: -20px; float: right; width: 64px; height: 64px; }
header.site-header nav ul li .icon.menu #mobile-menu-icon { position: relative; top: 22px; left: 20px; }
header.site-header nav ul.site-menu-mobile-expand { display: none; -webkit-tap-highlight-color: transparent; }
header.site-header nav a { text-decoration: none; }
header.site-header nav a:hover { border-bottom: 2px solid #B4DFF5; border-bottom: 2px solid rgba(255, 255, 255, 0.7); }
header.site-header .site-menu-mobile { display: none; margin-top: 20px; margin-bottom: -20px; text-align: center; }
header.site-header .site-menu-mobile ul { margin: 0; padding: 0; list-style: none; }
header.site-header .site-menu-mobile ul a:last-child li { padding-bottom: 12px; }
header.site-header .site-menu-mobile ul li { margin: 0; padding: 8px 0; border-top: 1px rgba(255, 255, 255, 0.5) solid; }
header.site-header .site-menu-mobile ul li:hover { background: rgba(255, 255, 255, 0.1); }
header.site-header a { color: #FFF; text-decoration: none; }

#mobile-menu-icon { fill: #fff; }

/* Main */
/* ------------------------------------------------------ */
.main { padding: 15px 0; }
.main h1, .main h2, .main h3, .main h4 { margin-top: 1.25em; }
.main h1 { font-size: 32px; }
.main h2 { font-size: 26px; }
.main h3 { font-size: 20px; }
.main p { font-size: 17px; line-height: 1.7em; }
.main li { font-size: 17px; }
.main pre { font-size: 17px; }
.main img { margin: 15px 0; max-width: 100%; }
.main blockquote { font-style: italic; }
.main table { display: block; width: 100%; margin: 30px 0; overflow: auto; word-break: normal; word-break: keep-all; }
.main table th { font-weight: bold; }
.main table th, .main table td { padding: 6px 13px; border: 1px solid #ddd; }
.main table tr { background-color: #fff; border-top: 1px solid #ccc; }
.main table tr:nth-child(2n) { background-color: #f8f8f8; }

/* Breadcrumbs */
/* ------------------------------------------------------ */
.breadcrumbs { margin-bottom: 14px; }
.breadcrumbs ul { margin: 0; padding: 0; }
.breadcrumbs ul li { display: inline-block; padding: 0 30px 0 5px; list-style: none; background-position: 100% 50%; background-image: url(../template/separator.svg); background-repeat: no-repeat; }
.breadcrumbs ul li img.back-arrow { position: relative; top: 4px; margin: 0; -moz-transform: scale(-1, 1); -webkit-transform: scale(-1, 1); -o-transform: scale(-1, 1); transform: scale(-1, 1); filter: FlipH; }
.breadcrumbs ul li:first-child { padding-left: 0; }
.breadcrumbs ul li:last-child { padding-right: 0; background-image: none; }

/* Page */
/* ------------------------------------------------------ */
.page-header { margin-bottom: 30px; }
.page-header h1 { margin: 0; font-size: 38px; }
.page-header h2 { margin: 0; font-size: 24px; font-weight: normal; color: #808080; }

.contents { position: relative; margin: 0 25px 20px 0; float: left; width: 175px; }
.contents h1 { margin: 0 0 .25em 0; font-size: 18px; }
.contents ul { margin: 10px 0 0 0; padding: 0; }
.contents ul li { padding: 10px 0; list-style: none; border-bottom: 1px solid #bfbfbf; }

.page-content > :first-child { margin-top: 0; }

.page-content { margin-bottom: 30px; }
.page-content li { margin-bottom: .5em; }

.page-content.margin { margin-left: 200px; }

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

article.post-excerpt { margin-bottom: 40px; }
article.post-excerpt h1 { margin: 0 0 15px 0; }

.post-header h1 { margin: 0 0 15px 0; }

.post-label::after { content: ","; }

.post-label:last-child::after { content: ""; }

.post-author-img img { position: relative; top: 5px; margin: 0; width: 25px; height: 25px; border-radius: 3px; }

/* Footer */
/* ------------------------------------------------------ */
footer .footer-content { background: #DEE0E2; border-top: 1px solid #A1ACB2; height: 100%; min-height: 100px; }

footer, .push { height: 150px; overflow: hidden; }

footer, .push { clear: both; }

/* Code */
/* ------------------------------------------------------ */
pre code { display: block; padding: 10px; overflow-y: auto; line-height: 1.4; border: 0; }

code { padding: 0 3px; line-height: 1.5em; }

pre, code { background: #F2F2F2; border: 1px solid #DEE0E2; border-radius: 3px; }

pre.terminal { padding: 5px; background: #333; color: #FFF; border: 1px solid #000; border-radius: 3px; }

pre.terminal code { background-color: #333; }

/* long code snippets */
pre code::-webkit-scrollbar { height: 6px; }

pre code::-webkit-scrollbar-track-piece { background: #DEE0E2; }

pre code::-webkit-scrollbar-thumb { background: rgba(0, 0, 0, 0.2); }

/* Misc */
/* ------------------------------------------------------ */
.edit-page { margin-bottom: 10px; }
.edit-page p { margin: 0; }

.warning { margin: 14px 0; padding: 10px; color: #BF9540; background: #FEF6E7; border: 1px solid #F5DAA3; border-radius: 3px; }
.warning a { color: #BF9540; }

/* Media Queries */
/* ------------------------------------------------------ */
@media (min-width: 1100px) { .content { max-width: 960px; }
  .contents { width: 200px; }
  .page-content.margin { margin-left: 250px; } }
@media (max-width: 568px) { .main h1 { font-size: 28px; }
  .main h2 { font-size: 24px; }
  .main h3 { font-size: 20px; }
  .main p { line-height: 1.5em; }
  header.site-header { padding: 20px 0; }
  header.site-header .site-logo-img { top: -10px; width: 45px; height: 45px; }
  header.site-header nav ul.site-menu { display: none; }
  header.site-header nav ul.site-menu-mobile-expand { display: block; }
  .contents { margin: 0 0 30px 0; float: none; width: 100%; }
  .contents h1 { font-size: 18px; }
  .page-header h1 { font-size: 32px; }
  .page-header h2 { font-size: 22px; }
  .page-content.margin { margin: 0; } }
/* Custom Styles */
body { font-family: 'Open Sans', sans-serif; }

h1, h2, h3, h4 { font-family: Raleway; }

code { font-family: 'Source Code Pro'; }

.page-header h1 { margin-bottom: 10px; }

header.site-header { background: #fff; }
header.site-header a { font-family: Raleway; font-weight: 700; color: #404040; }

#mobile-menu-icon { fill: #000; }

header.site-header .site-menu-mobile ul li { border-top: 1px #bfbfbf solid; }
header.site-header .site-menu-mobile ul a:last-child li { border-bottom: 1px #bfbfbf solid; }
