:root {
  --c-bg: #0d1b2a;
  --c-scrollbar: #f3f3f3;
  --c-scrollbar-hover: #e0e1dd;
  --fg: #778da9;
  --fg-deep: #415a77;
  --fg-deeper: #1b263b;
}
body {
  background: #0d1b2a;
  color: #e0e1dd;
}
a {
  color: #e0e1dd;
  transition: all 0.3s;
}
a:hover {
  color: text-hover;
  text-decoration: none;
}
#app {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  width: 100%;
}
#app .container {
  flex-grow: 1;
  flex-shrink: 0;
  flex-basis: auto;
  font-family: 'LINEseed-Regular', sans-serif;
}
#app .pagination {
  text-align: center;
}
#app .pagination .page-number {
  padding: 0 1rem !important;
}
#app .pagination .extend {
  padding: 0 1rem !important;
}
.posts {
  margin: auto;
  max-width: 80ch;
  font-size: 1rem;
  line-height: 1.75;
}
.posts h2 {
  margin: 0;
  margin-top: 1rem;
}
.posts ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.posts ul li {
  margin: 0;
  padding: 0.5rem 0 0.5rem 0.5rem;
  text-decoration: none;
}
.time {
  color: #808080;
}
html,
body {
  scroll-behavior: smooth;
}
.post {
  max-width: 80ch;
  font-family: 'LINEseed-Regular', sans-serif;
  font-size: 1rem;
  line-height: 1.75;
  margin: auto;
}
.post-license {
  width: 100%;
  opacity: 0.5;
  display: flex;
  margin-top: 2.5rem;
  margin-bottom: 1.5rem;
  margin: auto;
  text-align: right;
  justify-content: right;
}
.post-license span {
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.post-header {
  margin-bottom: 2rem;
}
.post-footer {
  margin-top: 2rem;
  margin-bottom: 2rem;
}
.post-footer a {
  opacity: 0.5;
  font-size: 1rem;
  line-height: 1.75;
}
.post-footer a:hover {
  opacity: 0.75;
}
.post-title {
  color: #e0e1dd;
  font-family: 'LINEseed-Regular', sans-serif;
  font-weight: 800;
  font-size: 2.25em;
  margin-top: 0;
  margin-bottom: 0.8888889em;
  line-height: 1.1111111;
}
.post-meta {
  opacity: 0.5;
  margin-top: -0.5rem !important;
}
.post-toc {
  position: fixed;
  top: 95px;
  right: 2em;
  width: 15rem;
  font-size: 0.85rem;
}
@media screen and (max-width: 1300px) {
  .post-toc {
    display: none;
  }
}
.post-toc .tocbot-list {
  max-height: 450px;
  max-width: 250px;
  overflow: auto;
  position: relative;
  padding-right: 0.875rem;
}
.post-toc .tocbot-list:-webkit-scrollbar {
  width: 6px;
  height: 6px;
}
.post-toc .tocbot-list:-webkit-scrollbar-thumb {
  width: 6px;
  background-color: var(-fg);
  opacity: 0.6;
  border-radius: 2px;
}
.post-toc .tocbot-list ul {
  list-style: none;
  position: inherit;
  overflow: hidden;
  padding-left: 0.5rem;
  margin: 0;
}
.post-toc .toc-list-item {
  line-height: 1.8rem;
}
.post-toc .toc-link {
  text-decoration: none;
  display: inline-block;
  width: 100%;
  color: var(--fg);
  opacity: 0.6;
}
.post-toc .toc-link:before {
  background-color: var(--fg);
  height: 1.8rem;
}
.post-toc .toc-link:hover {
  opacity: 1;
}
.post-toc .is-active-link {
  opacity: 1 !important;
}
.post-toc .is-active-link:before {
  background-color: var(--fg);
}
.post-toc .tocbot-list-menu {
  margin: 1rem;
  font-size: 0.8rem;
}
.post-toc .tocbot-list-menu a {
  display: block;
  margin: 0.6rem 0;
  color: var(--fg);
  opacity: 0.6;
  cursor: pointer;
}
.post-toc .tocbot-list-menu a:hover {
  opacity: 1;
  cursor: pointer;
}
.post-content {
  margin: auto;
}
.post-content:last-child {
  margin-bottom: 0;
}
.post-content .fancybox-img {
  border: none;
}
.post-content .fancybox-img:hover {
  opacity: none;
  border: none;
}
.post-content h1 {
  color: #e0e1dd;
  font-family: 'LINEseed-Regular', sans-serif;
  font-weight: 800;
  font-size: 2.25em;
  margin-top: 0;
  margin-bottom: 0.8888889em;
  line-height: 1.1111111;
}
.post-content h2 {
  color: inherit;
  font-weight: 700;
  font-size: 1.5em;
  margin-top: 2em;
  margin-bottom: 1em;
  line-height: 1.3333333;
}
.post-content h3 {
  color: inherit;
  font-weight: 600;
  font-size: 1.25em;
  margin-top: 1.6em;
  margin-bottom: 0.6em;
  line-height: 1.6;
}
.post-content h4 {
  color: inherit;
  font-weight: 600;
  margin-top: 1.5em;
  margin-bottom: 0.5em;
  line-height: 1.5;
}
.post-content hr {
  border-color: rgba(125,125,125,0.3);
  margin-top: 3em;
  margin-bottom: 3em;
}
.post-content p {
  margin-top: 1.25em;
  margin-bottom: 1.25em;
}
.post-content strong {
  color: #e0e1dd;
  font-weight: 600;
}
.post-content em {
  color: inherit;
}
.post-content blockquote {
  font-size: 1rem;
  display: block;
  margin: 1em 0;
  padding: 1em 1.2em 1em 1.2em;
  position: relative;
  color: inherit;
  border-left: 0.25rem solid rgba(125,125,125,0.302);
}
.post-content blockquote p {
  margin: 0;
}
.post-content blockquote footer strong {
  margin-right: 0.5em;
}
.post-content ul {
  list-style: none;
  margin: 0;
  padding: 0;
  margin-top: 1.25em;
  margin-bottom: 1.25em;
  list-style-type: none;
}
.post-content ul >li {
  position: relative;
  padding-left: 1.75rem;
  margin-top: 0.5em;
  margin-bottom: 0.5em;
}
.post-content ul >li:before {
  content: "";
  position: absolute;
  background-color: #d1d5db;
  border-radius: 50%;
  width: 0.375em;
  height: 0.375em;
  top: 0.6875em;
  left: 0.25em;
}
.post-content ol {
  margin: 0;
  padding: 0;
  margin-top: 1.25em;
  margin-bottom: 0em;
  list-style-type: none;
}
.post-content ol >li {
  position: relative;
  padding-left: 1.75em;
  margin-top: 0.5em;
  margin-bottom: 0.5em;
}
.post-content ol >li:before {
  content: counter(list-item, var(--list-counter-style, decimal)) ".";
  position: absolute;
  font-weight: 400;
  color: #6b7280;
  left: 0;
}
.post-content a {
  color: #e0e1dd;
  text-decoration: none;
  font-weight: 500;
  text-decoration: none;
  border-bottom: 1px solid rgba(125,125,125,0.3);
  transition: border 0.3s ease-in-out;
}
.post-content a:hover {
  border-bottom: 1px solid var(--fg);
}
.post-content img {
  margin-top: 2em;
  margin-bottom: 2em;
}
.post-content table {
  width: 100%;
  table-layout: auto;
  text-align: left;
  margin-top: 2em;
  margin-bottom: 2em;
  font-size: 0.875em;
  line-height: 1.7142857;
  border-collapse: collapse;
  border-color: inherit;
  text-indent: 0;
}
.post-content table thead {
  color: #e0e1dd;
  font-weight: 600;
  border-bottom-width: 1px;
  border-bottom-color: #d1d5db;
}
.post-content table thead th {
  vertical-align: bottom;
  padding-right: 0.5714286em;
  padding-bottom: 0.5714286em;
  padding-left: 0.5714286em;
}
.post-content table thead th:first-child {
  padding-left: 0;
}
.post-content table thead th:last-child {
  padding-right: 0;
}
.post-content table tbody tr {
  border-bottom-width: 1px;
  border-bottom-color: #e5e7eb;
}
.post-content table tbody tr:last-child {
  border-bottom-width: 0;
}
.post-content table tbody td {
  vertical-align: top;
  padding-top: 0.5714286em;
  padding-right: 0.5714286em;
  padding-bottom: 0.5714286em;
  padding-left: 0.5714286em;
}
.post-content table tbody td:first-child {
  padding-left: 0;
}
.post-content table tbody td:last-child {
  padding-right: 0;
}
.post-content figure.highlight {
  padding: 0 0.5em;
  margin: 0.5em 0;
  border-radius: 0.3em;
  overflow: auto;
  position: relative;
}
.post-content figure.highlight table {
  position: relative;
  margin: 0;
  padding: 0;
  border: 0;
  width: 100%;
  border-collapse: collapse;
}
.post-content figure.highlight .gutter {
  width: 10px;
  color: #d0d0d0;
}
.post-content figure.highlight pre {
  font-family: 'LINEseed-Regular', sans-serif;
  font-size: 0.9rem;
  margin: 0;
  padding: 0.2em;
  color: #e0e1dd;
}
.post-content figure.highlight pre code {
  font-family: 'LINEseed-Regular', sans-serif;
  color: #e0e1dd;
  border-width: 0;
  border-radius: 0;
  padding: 0;
  font-weight: 600;
  color: inherit;
  font-size: inherit;
  font-family: inherit;
  line-height: inherit;
}
.post-content figure.highlight pre code::before {
  content: none;
}
.post-content figure.highlight pre code::after {
  content: none;
}
.post-content code {
  font-family: 'LINEseed-Regular', sans-serif;
  color: #e0e1dd;
  font-weight: 600;
  font-size: 0.875em;
}
.post-content code::before {
  content: "`";
}
.post-content code::after {
  content: "`";
}
.categories {
  margin: auto;
  max-width: 80ch;
}
.categories .category-list {
  font-size: 1.2rem;
  list-style: none;
  margin: 1.5rem 0;
  padding: 0;
}
.categories .category-list .category-item {
  margin: 1rem 0;
  padding: 0;
}
.categories .category-list .category-item .category-item-link {
  border-bottom: 1px solid #ccc;
  cursor: pointer;
  outline: 0;
  text-decoration: none;
  overflow-wrap: break-word;
}
.categories .category-list .category-item .category-item-link,
.categories .category-list .category-item .category-item-count {
  color: #778da9;
  opacity: 0.8;
}
.categories .category-list .category-item .category-item-link:hover,
.categories .category-list .category-item .category-item-count:hover {
  opacity: 1;
}
.tags {
  margin: auto;
  max-width: 80ch;
}
.tags .tag-list {
  font-size: 1.2rem;
  list-style: none;
  margin: 1.5rem 0;
  padding: 0;
}
.tags .tag-list .tag-item {
  margin: 1rem 0;
  padding: 0;
}
.tags .tag-list .tag-item .tag-item-link {
  border-bottom: 1px solid #ccc;
  cursor: pointer;
  outline: 0;
  text-decoration: none;
  overflow-wrap: break-word;
}
.tags .tag-list .tag-item .tag-item-link,
.tags .tag-list .tag-item .tag-item-count {
  color: #778da9;
  opacity: 0.6;
}
.tags .tag-list .tag-item .tag-item-link:hover,
.tags .tag-list .tag-item .tag-item-count:hover {
  opacity: 1;
}
.header {
  z-index: 40;
  margin-bottom: 1rem;
}
.header .logo {
  position: absolute;
  width: 2.5rem;
  height: 2.5rem;
  margin: 1rem;
  user-select: none;
  outline: 2px solid transparent;
  outline-offset: 2px;
}
@media (min-width: 1024px) {
  .header .logo {
    position: fixed;
  }
}
.header img {
  width: 2.5rem;
  height: auto;
  isplay: block;
  vertical-align: middle;
}
.header .nav {
  padding: 1.5rem;
  width: 100%;
  display: grid;
  grid-template-columns: auto max-content;
  box-sizing: border-box;
  font-family: 'LINEseed-Regular', sans-serif;
}
.header .nav .spacer {
  margin: auto;
}
.header .nav .right,
.header .nav .right>.menu,
.header .nav .links {
  display: grid;
  gap: 1.2rem;
  grid-auto-flow: column;
}
@media screen and (max-width: 786px) {
  .header .nav .right .menu,
  .header .nav .right>.menu .menu,
  .header .nav .links .menu {
    display: none;
  }
}
.header .nav a {
  color: #778da9;
  cursor: pointer;
  text-decoration: none;
  transition: all 0.2s ease;
  outline: none;
}
.header .nav a:hover {
  color: #c5c5c5;
  text-decoration-color: inherit;
}
.header .nav svg {
  width: 1.2rem;
  height: 1.2rem;
  vertical-align: text-bottom;
}
.footer {
  height: 4rem;
  width: 100%;
  text-align: center;
  bottom: 0;
  line-height: 4rem;
  font-family: 'LINEseed-Regular', sans-serif;
}
.footer .copyright a {
  color: #e0e1dd;
  font-family: 'LINEseed-Regular', sans-serif;
  font-size: 1rem;
  line-height: 1.75;
  transition: all 0.3s;
}
.footer .copyright a:hover {
  color: #c5c5c5;
  text-decoration: none;
}
html:not(.dark) {
  --highlight-keyword: #1c6b48;
  --highlight-background: #fbfbfb;
  --highlight-comment: #a0ada0;
  --highlight-foreground: #393a34;
  --highlight-string: #b56959;
  --highlight-gutter: #869194;
  --highlight-class: #2993a3;
  --highlight-function: #6c7834;
  --prism-builtin: #ab5959;
  --prism-property: #b58451;
  --prism-decorator: #bd8f8f;
}
html.dark {
  --highlight-keyword: #4d9375;
  --highlight-background: #111;
  --highlight-comment: #758575;
  --highlight-foreground: #d4cfbf;
  --highlight-string: #d48372;
  --highlight-gutter: #869194;
  --highlight-class: #54b1bf;
  --highlight-function: #a1b567;
  --prism-builtin: #858585;
  --prism-property: #dd8e6e;
  --prism-decorator: #bd8f8f;
}
.post-content figure.highlight {
  margin: 2em 0;
  background: var(--highlight-background);
  color: var(--highlight-foreground);
  font-size: 12px;
  overflow: scroll;
  overflow-y: hidden;
  overflow-x: auto;
}
.post-content figure.highlight .gutter {
  color: var(--hight-gutter);
}
.post-content figure.highlight pre {
  background: var(--highlight-background);
  margin: 0;
}
.post-content pre {
  padding: 10px;
  overflow: auto;
  background: var(--highlight-background);
  font-family: Menlo, Monaco, Consolas, Courier New, monospace;
}
.post-content pre code {
  padding: 0;
}
.post-content pre .comment {
  color: var(--highlight-comment);
}
.post-content pre .string {
  color: var(--highlight-string);
}
.post-content pre .keyword,
.post-content pre .doctag {
  color: var(--highlight-keyword);
}
.post-content pre .class_ {
  color: var(--highlight-class);
}
.post-content pre .function_ {
  color: var(--highlight-function);
}
.post-content pre .tag>.name {
  color: var(--prism-builtin);
}
.post-content pre .attr {
  color: var(--prism-property);
}
.post-content pre .meta {
  color: var(--prism-decorator);
}
