pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}
/*!
  Theme: GitHub Dark
  Description: Dark theme as seen on github.com
  Author: github.com
  Maintainer: @Hirse
  Updated: 2021-05-15

  Outdated base version: https://github.com/primer/github-syntax-dark
  Current colors taken from GitHub's CSS
*/.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id,.hljs-variable{color:#79c0ff}.hljs-meta .hljs-string,.hljs-regexp,.hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-code,.hljs-comment,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-pseudo,.hljs-selector-tag{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}:root{--bg:#fff;--fg:#1a1a1a;--muted:#6b7280;--border:#e5e7eb;--accent:#2563eb;--accent-contrast:#fff;--surface:#f8fafc;--danger:#dc2626;--max-width:720px}*{box-sizing:border-box;margin:0;padding:0}body,html{max-width:100vw}body{color:var(--fg);background:var(--bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.container{max-width:var(--max-width);margin:0 auto;padding:3rem 1.25rem 5rem}.site-header{margin-bottom:2.5rem}.site-title{font-size:2rem;letter-spacing:-.02em}.site-tagline{color:var(--muted);margin-top:.25rem}.back-link{margin-bottom:1.5rem;font-size:.9rem}.empty{color:var(--muted)}.post-list{list-style:none;display:flex;flex-direction:column;gap:2rem}.post-card-title{font-size:1.4rem;letter-spacing:-.01em}.post-card-title a{color:var(--fg)}.post-card-subtitle{color:var(--muted);margin-top:.2rem}.post-card-meta{margin-top:.5rem;font-size:.85rem;color:var(--muted);display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.post-card-tags{display:inline-flex;gap:.5rem;flex-wrap:wrap}.tag{font-size:.8rem;color:var(--muted)}.post-header{margin-bottom:2rem}.post-title{font-size:2.25rem;letter-spacing:-.02em;line-height:1.2}.post-subtitle{font-size:1.2rem;color:var(--muted);margin-top:.5rem}.post-meta{margin-top:.75rem;font-size:.9rem;color:var(--muted)}.post-tags{margin-top:2.5rem;display:flex;gap:.75rem;flex-wrap:wrap;border-top:1px solid var(--border);padding-top:1.5rem}.prose{font-size:1.05rem}.post-body>*+*{margin-top:1.1rem}.post-body h1,.post-body h2,.post-body h3{margin-top:2rem;line-height:1.25;letter-spacing:-.01em}.post-body h2{font-size:1.5rem}.post-body h3{font-size:1.25rem}.post-body ol,.post-body ul{padding-left:1.5rem}.post-body li+li{margin-top:.35rem}.post-body blockquote{border-left:3px solid var(--border);padding-left:1rem;color:var(--muted)}.post-body img{max-width:100%;height:auto;border-radius:8px}.post-body code:not(.hljs){background:var(--surface);border:1px solid var(--border);padding:.1em .35em;border-radius:4px;font-size:.9em}.code-block{margin:1.25rem 0;border-radius:8px;overflow:auto}.code-block code.hljs{display:block;padding:1rem 1.25rem;font-size:.9rem;line-height:1.5}.callout{border:1px solid var(--border);border-left-width:4px;border-radius:6px;padding:1rem 1.25rem;background:var(--surface)}.callout-note{border-left-color:var(--accent)}.callout-tip{border-left-color:#059669}.callout-warning{border-left-color:#d97706}.callout-title{font-weight:600;margin-bottom:.35rem}.button{display:inline-block;background:var(--accent);color:var(--accent-contrast);border:none;border-radius:6px;padding:.5rem .9rem;font-size:.9rem;font-weight:500;cursor:pointer}.button:hover{text-decoration:none;filter:brightness(1.05)}.button:disabled{opacity:.5;cursor:not-allowed}.link-button{background:none;border:none;color:var(--accent);cursor:pointer;font-size:.9rem;padding:0}.link-button.danger{color:var(--danger)}.studio{display:flex;flex-direction:column;height:100vh}.studio-bar{display:flex;gap:1rem;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--border)}.studio-title-input{flex:1 1;font-size:1.1rem;font-weight:600;border:none;outline:none;background:transparent}.studio-actions{display:flex;gap:.75rem;align-items:center}.studio-fields{display:flex;gap:.75rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);flex-wrap:wrap}.studio-fields input{flex:1 1;min-width:180px;padding:.4rem .6rem;border:1px solid var(--border);border-radius:6px;font-size:.9rem}.studio-error{color:var(--danger);padding:.5rem 1rem;background:#fef2f2}.studio-panes{flex:1 1;display:grid;grid-template-columns:1fr 1fr;min-height:0}.studio-pane{overflow:auto;min-height:0}.studio-editor{border-right:1px solid var(--border);background:#1e1e1e}.studio-editor-loading{color:#ccc;padding:1rem}.studio-preview{padding:1.5rem 2rem}.studio-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.studio-head-actions{display:flex;gap:1rem;align-items:center}.studio-list{list-style:none;display:flex;flex-direction:column;gap:1rem}.studio-list-item{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1rem;border:1px solid var(--border);border-radius:8px}.studio-list-title{font-weight:600;color:var(--fg);margin-right:.6rem}.studio-list-meta{color:var(--muted);font-size:.85rem;margin-top:.25rem}.studio-list-actions{display:flex;gap:1rem;white-space:nowrap}.badge{font-size:.7rem;font-weight:600;padding:.1rem .45rem;border-radius:999px;vertical-align:middle}.badge-draft{background:#fef3c7;color:#92400e}.badge-published{background:#d1fae5;color:#065f46}.token-form{display:flex;gap:.75rem;margin-top:1rem;max-width:420px}.token-form input{flex:1 1;padding:.5rem .7rem;border:1px solid var(--border);border-radius:6px}