:root {
  --spacer: 1rem;
  --spacer-2: calc(var(--spacer) * 2);
  --spacer-3: calc(var(--spacer) * 3);
  --body-font-family: -apple-system,system-ui,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  --body-font-size: 16px;
  --body-line-height: 1.5;
  --border-radius: .5em;
  --code-font-family: ui-monospace, Menlo, Monaco, "Cascadia Mono", "Segoe UI Mono", "Roboto Mono", "Oxygen Mono", "Ubuntu Monospace", "Source Code Pro", "Fira Mono", "Droid Sans Mono", "Courier New", monospace;
  /**
   * Color
   */
  --body-bg-color: var(--oc-white);
  --body-color: var(--oc-gray-9);
  --code-bg-color: var(--oc-gray-1);
  --heading-color: var(--oc-black);
  --border-color: var(--oc-gray-4);
  --link-color: var(--oc-blue-9);
  --link-color-rgb: var(--oc-blue-9-rgb);
  --link-hover-color: var(--oc-blue-7);
  --info-color: var(--oc-green-9);
  --warning-color: var(--oc-yellow-9);
  --danger-color: var(--oc-red-9);
}

@media (prefers-color-scheme: dark) {
  :root {
    /**
     * Color
     */
    --body-bg-color: var(--oc-gray-9);
    --body-color: var(--oc-gray-4);
    --code-bg-color: var(--oc-gray-7);
    --heading-color: var(--oc-white);
    --border-color: var(--oc-gray-7);
    --link-color: var(--oc-cyan-4);
    --link-color-rgb: var(--oc-cyan-4-rgb);
    --link-hover-color: var(--oc-cyan-6);
    --info-color: var(--oc-green-1);
    --warning-color: var(--oc-yellow-1);
    --danger-color: var(--oc-red-1);
  }
}
* {
  box-sizing: border-box;
}

body {
  color: var(--body-color);
  background-color: var(--body-bg-color);
  font-family: var(--body-font-family);
  font-size: var(--body-font-size);
  line-height: var(--body-line-height);
}

a {
  color: var(--link-color);
  text-decoration: none;
}
a:hover, a:focus {
  color: var(--link-hover-color);
  text-decoration: underline;
}

p {
  margin-top: 0;
  margin-bottom: var(--spacer);
}

ul, ol, dl {
  margin-top: 0;
  margin-bottom: var(--spacer);
}

blockquote {
  padding: 0 var(--spacer);
  margin: 0 0 var(--spacer) 0;
  border-left: 0.25em solid var(--border-color);
  opacity: 0.65;
}

figure {
  margin: 0;
}

figcaption {
  margin-bottom: var(--spacer);
  font-size: 0.85em;
}

img {
  display: block;
  max-width: 100%;
  margin-top: 0;
  margin-bottom: var(--spacer);
  border-radius: var(--border-radius);
}

code,
pre {
  font-family: var(--code-font-family);
}

code {
  padding: 0.1em 0.25em;
  background-color: var(--code-bg-color);
  border-radius: var(--border-radius);
}

pre {
  display: block;
  overflow: auto;
  padding: var(--spacer);
  margin: var(--spacer) 0;
}
pre code {
  padding: 0;
  background-color: inherit;
}

table {
  margin-top: 0;
  margin-bottom: var(--spacer);
  width: 100%;
  border: 0 solid var(--border-color);
  border-collapse: collapse;
}

td,
th {
  padding: 0.25em 0.5em;
  border-color: inherit;
  border-style: solid;
  border-width: 0;
  border-bottom-width: 1px;
}

th {
  text-align: left;
}

thead th {
  border-bottom-color: currentColor;
}

mark {
  padding: 0.15em;
  border-radius: var(--border-radius);
  color: var(--body-bg-color);
  background-color: var(--info-color);
}

hr {
  position: relative;
  margin: var(--spacer-2) 0;
  border: 0;
  border-top: 1px solid var(--border-color);
}

abbr {
  font-weight: bold;
  text-transform: uppercase;
}
abbr[title] {
  cursor: help;
  border-bottom: 1px dotted var(--border-color);
}

.container {
  max-width: 48rem;
  padding-left: var(--spacer);
  padding-right: var(--spacer);
  margin-left: auto;
  margin-right: auto;
}

@media screen and (min-width: 48rem) {
  .container {
    padding-left: var(--spacer-2);
    padding-right: var(--spacer-2);
  }
}
/**
 * Header
 */
.masthead {
  padding-top: var(--spacer);
  padding-bottom: var(--spacer);
  margin-bottom: var(--spacer);
}

.masthead-title {
  font-size: 1.3em;
  font-weight: bold;
}
.masthead-title a {
  color: inherit;
  text-decoration: none;
}
.masthead-title .tagline {
  opacity: 0.5;
}

.nav-list {
  padding: 0;
  margin: var(--spacer) 0 0 0;
  border-top: 1px solid var(--border-color);
  border-bottom: 1px solid var(--border-color);
  list-style: none;
}
.nav-list li {
  display: inline-block;
  margin: 0 0.4em;
}
.nav-list a {
  color: inherit;
}
.nav-list a:hover, .nav-list a:focus {
  text-decoration: line-through;
}
.nav-list a.current {
  text-decoration: line-through;
}

/**
 * Post
 */
.posts .post {
  padding: var(--spacer);
  margin-bottom: var(--spacer);
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius);
}
.posts .post .post-excerpt {
  margin-bottom: 0;
}

.page,
.post {
  margin-bottom: var(--spacer-2);
}
.page h1, .page h2, .page h3, .page h4, .page h5, .page h6,
.post h1,
.post h2,
.post h3,
.post h4,
.post h5,
.post h6 {
  color: var(--heading-color);
}

.page-title,
.post-title {
  margin-top: 0;
}
.page-title a,
.post-title a {
  color: inherit;
}

.post-meta {
  display: block;
  margin-top: -0.5em;
  margin-bottom: var(--spacer);
  opacity: 0.65;
  font-size: 0.85em;
}

.post-categories,
.post-tags {
  display: inline-block;
  list-style: none;
  padding: 0;
  margin: 0;
}
.post-categories li,
.post-tags li {
  display: inline-block;
}
.post-categories li:not(:last-child),
.post-tags li:not(:last-child) {
  margin-right: 0.4em;
}

.post-category {
  border-bottom: 2px dotted var(--border-color);
}

a.post-category {
  color: inherit;
}
a.post-category:hover, a.post-category:focus {
  border-bottom-style: solid;
  border-color: var(--body-color);
  text-decoration: none;
}

.post-tag {
  padding: 0.1em 0.5em;
  border: 1px solid var(--border-color);
  border-radius: var(--border-radius);
  background-color: rgba(var(--link-color-rgb), 0.3);
}

a.post-tag {
  color: inherit;
}
a.post-tag:hover, a.post-tag:focus {
  background-color: rgba(var(--link-color-rgb), 0.6);
  text-decoration: none;
}

a[href^="#fn:"],
a[href^="#fnref:"] {
  display: inline-block;
  margin-left: 0.1em;
  font-weight: bold;
}

.footnotes {
  margin-top: var(--spacer-2);
  font-size: 85%;
}

.related {
  padding-top: var(--spacer-2);
  padding-bottom: var(--spacer-2);
  margin-bottom: var(--spacer-2);
  border-top: 1px solid var(--border-color);
  border-bottom: 1px solid var(--border-color);
}

.related-title {
  margin-top: 0;
}

.related-posts {
  padding-left: 0;
  list-style: none;
}
.related-posts small {
  opacity: 0.5;
}

/**
 * Code
 */
.highlight {
  border-radius: var(--border-radius);
  background-color: var(--code-bg-color);
}

.rouge-table {
  margin: 0;
  font-size: 100%;
}
.rouge-table,
.rouge-table td,
.rouge-table th {
  border: 0;
  padding: 0;
}
.rouge-table pre {
  padding: 0;
  margin: 0;
}
.rouge-table .gutter {
  vertical-align: top;
  user-select: none;
  opacity: 0.25;
  padding-right: var(--spacer);
}

/**
 * Pagination
 */
.pagination {
  display: flex;
  text-align: center;
  margin-top: var(--spacer-2);
}

.pagination-item {
  float: left;
  width: 50%;
  padding: var(--spacer);
  border: 1px solid var(--border-color);
}
.pagination-item:first-child {
  border-right-width: 0;
  border-top-left-radius: var(--border-radius);
  border-bottom-left-radius: var(--border-radius);
}
.pagination-item:last-child {
  border-top-right-radius: var(--border-radius);
  border-bottom-right-radius: var(--border-radius);
}

a.pagination-item:hover {
  background-color: var(--border-color);
  text-decoration: none;
}

/**
 * Footer
 */
.footer {
  padding-top: var(--spacer);
  padding-bottom: var(--spacer);
  margin-top: var(--spacer-3);
}
.footer p {
  margin: 0;
}

.social-icons {
  list-style: none;
  padding: 0;
  margin: var(--spacer) 0;
  height: calc(var(--body-line-height) * var(--body-font-size));
}

.social-icon-item {
  float: left;
  margin-right: var(--spacer);
}

@media screen and (min-width: 48rem) {
  .footer {
    display: flex;
  }
  .footer-column {
    width: 100%;
  }
  .social-icons {
    margin: 0;
  }
}
/**
 * Archive
 */
.taxonomies-wrapper {
  margin-bottom: var(--spacer-2);
}

.taxonomies {
  list-style: none;
  display: grid;
  grid-column-gap: 2em;
  grid-template-columns: repeat(2, 1fr);
  margin: 0;
  padding: 0;
  font-weight: bold;
}
.taxonomies .taxonomy {
  display: flex;
  padding: 0.25em 0;
  justify-content: space-between;
  text-decoration: none;
  border-bottom: 1px solid;
  margin-bottom: var(--spacer);
}

.post-list-by-taxonomy time {
  font-family: monospace;
}

.back-to-top {
  display: block;
  font-size: 0.8em;
  text-transform: uppercase;
  text-align: right;
  text-decoration: none;
}

@media (min-width: 35.5rem) {
  .taxonomies {
    grid-template-columns: repeat(3, 1fr);
  }
}
/**
 * Markdown TOC
 */
#markdown-toc {
  padding: var(--spacer-2) var(--spacer-3);
  margin: var(--spacer-2) 0;
  border: solid var(--border-color);
  border-width: 1px 0;
}
#markdown-toc::before {
  display: block;
  margin-left: calc(var(--spacer-3) * -1);
  content: "Contents";
  font-size: 85%;
  font-weight: 500;
}

/**
 * Message -- Show different levels of alert messages to users.
 */
.message-info,
.message-warning,
.message-danger {
  padding: var(--spacer);
  border-radius: var(--border-radius);
  color: var(--body-bg-color);
}

.message-info {
  background-color: var(--info-color);
}

.message-warning {
  background-color: var(--warning-color);
}

.message-danger {
  background-color: var(--danger-color);
}

/**
 * Alignment
 */
.align-right {
  margin-bottom: 1rem;
  margin-left: 1rem;
  float: right;
}

.align-left {
  margin-right: 1rem;
  margin-bottom: 1rem;
  float: left;
}

.align-center {
  display: block;
  margin-right: auto;
  margin-left: auto;
}

figcaption.align-right {
  text-align: right;
}

figcaption.align-left {
  text-align: left;
}

figcaption.align-center {
  text-align: center;
}

/**
 * rougify style github
 */
.highlight table td {
  padding: 5px;
}

.highlight table pre {
  margin: 0;
}

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

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

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

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

.highlight .c, .highlight .ch, .highlight .cd, .highlight .cpf {
  color: #999988;
  font-style: italic;
}

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

.highlight .gd {
  color: #000000;
  background-color: #ffdddd;
}

.highlight .ge {
  color: #000000;
  font-style: italic;
}

.highlight .gr {
  color: #aa0000;
}

.highlight .gh {
  color: #999999;
}

.highlight .gi {
  color: #000000;
  background-color: #ddffdd;
}

.highlight .go {
  color: #888888;
}

.highlight .gp {
  color: #555555;
}

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

.highlight .gu {
  color: #aaaaaa;
}

.highlight .gt {
  color: #aa0000;
}

.highlight .kc {
  color: #000000;
  font-weight: bold;
}

.highlight .kd {
  color: #000000;
  font-weight: bold;
}

.highlight .kn {
  color: #000000;
  font-weight: bold;
}

.highlight .kp {
  color: #000000;
  font-weight: bold;
}

.highlight .kr {
  color: #000000;
  font-weight: bold;
}

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

.highlight .k, .highlight .kv {
  color: #000000;
  font-weight: bold;
}

.highlight .mf {
  color: #009999;
}

.highlight .mh {
  color: #009999;
}

.highlight .il {
  color: #009999;
}

.highlight .mi {
  color: #009999;
}

.highlight .mo {
  color: #009999;
}

.highlight .m, .highlight .mb, .highlight .mx {
  color: #009999;
}

.highlight .sa {
  color: #000000;
  font-weight: bold;
}

.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 .s, .highlight .dl {
  color: #d14;
}

.highlight .na {
  color: #008080;
}

.highlight .bp {
  color: #999999;
}

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

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

.highlight .no {
  color: #008080;
}

.highlight .nd {
  color: #3c5d5d;
  font-weight: bold;
}

.highlight .ni {
  color: #800080;
}

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

.highlight .nf, .highlight .fm {
  color: #990000;
  font-weight: bold;
}

.highlight .nl {
  color: #990000;
  font-weight: bold;
}

.highlight .nn {
  color: #555555;
}

.highlight .nt {
  color: #000080;
}

.highlight .vc {
  color: #008080;
}

.highlight .vg {
  color: #008080;
}

.highlight .vi {
  color: #008080;
}

.highlight .nv, .highlight .vm {
  color: #008080;
}

.highlight .ow {
  color: #000000;
  font-weight: bold;
}

.highlight .o {
  color: #000000;
  font-weight: bold;
}

.highlight .w {
  color: #bbbbbb;
}

.highlight {
  background-color: #f8f8f8;
}

@media (prefers-color-scheme: dark) {
  /**
   * rougify style gruvbox
   */
  .highlight table td {
    padding: 5px;
  }
  .highlight table pre {
    margin: 0;
  }
  .highlight, .highlight .w {
    color: #fbf1c7;
    background-color: #282828;
  }
  .highlight .err {
    color: #fb4934;
    background-color: #282828;
    font-weight: bold;
  }
  .highlight .c, .highlight .ch, .highlight .cd, .highlight .cm, .highlight .cpf, .highlight .c1, .highlight .cs {
    color: #928374;
    font-style: italic;
  }
  .highlight .cp {
    color: #8ec07c;
  }
  .highlight .nt {
    color: #fb4934;
  }
  .highlight .o, .highlight .ow {
    color: #fbf1c7;
  }
  .highlight .p, .highlight .pi {
    color: #fbf1c7;
  }
  .highlight .gi {
    color: #b8bb26;
    background-color: #282828;
  }
  .highlight .gd {
    color: #fb4934;
    background-color: #282828;
  }
  .highlight .gh {
    color: #b8bb26;
    font-weight: bold;
  }
  .highlight .k, .highlight .kn, .highlight .kp, .highlight .kr, .highlight .kv {
    color: #fb4934;
  }
  .highlight .kc {
    color: #d3869b;
  }
  .highlight .kt {
    color: #fabd2f;
  }
  .highlight .kd {
    color: #fe8019;
  }
  .highlight .s, .highlight .sb, .highlight .sc, .highlight .dl, .highlight .sd, .highlight .s2, .highlight .sh, .highlight .sx, .highlight .s1 {
    color: #b8bb26;
    font-style: italic;
  }
  .highlight .si {
    color: #b8bb26;
    font-style: italic;
  }
  .highlight .sr {
    color: #b8bb26;
    font-style: italic;
  }
  .highlight .sa {
    color: #fb4934;
  }
  .highlight .se {
    color: #fe8019;
  }
  .highlight .nn {
    color: #8ec07c;
  }
  .highlight .nc {
    color: #8ec07c;
  }
  .highlight .no {
    color: #d3869b;
  }
  .highlight .na {
    color: #b8bb26;
  }
  .highlight .m, .highlight .mb, .highlight .mf, .highlight .mh, .highlight .mi, .highlight .il, .highlight .mo, .highlight .mx {
    color: #d3869b;
  }
  .highlight .ss {
    color: #83a598;
  }
}

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