@import"https://fonts.googleapis.com/css2?family=Comfortaa:wght@400;500;700&family=Orbitron:wght@500;700&family=JetBrains+Mono:wght@400;500;700&display=swap";:root{color-scheme:dark;--radius: 8px;--shadow: 0 22px 70px rgba(17, 17, 27, .18);--font-body: "Comfortaa", ui-rounded, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display: "Orbitron", "Comfortaa", system-ui, sans-serif;--font-mono: "JetBrains Mono", "SFMono-Regular", Consolas, monospace}:root[data-theme=latte]{color-scheme:light;--base: #eff1f5;--mantle: #e6e9ef;--crust: #dce0e8;--surface: #ccd0da;--surface-2: #bcc0cc;--overlay: #9ca0b0;--text: #4c4f69;--muted: #6c6f85;--subtle: #7c7f93;--blue: #1e66f5;--sapphire: #209fb5;--green: #40a02b;--yellow: #df8e1d;--peach: #fe640b;--red: #d20f39;--mauve: #8839ef;--pink: #ea76cb;--accent: var(--mauve);--accent-2: var(--sapphire);--accent-3: var(--green);--line: rgba(76, 79, 105, .15);--panel: rgba(255, 255, 255, .58);--panel-strong: rgba(255, 255, 255, .82);--pipe: rgba(136, 57, 239, .28)}:root[data-theme=frappe]{color-scheme:dark;--base: #303446;--mantle: #292c3c;--crust: #232634;--surface: #414559;--surface-2: #51576d;--overlay: #737994;--text: #c6d0f5;--muted: #a5adce;--subtle: #949cbb;--blue: #8caaee;--sapphire: #85c1dc;--green: #a6d189;--yellow: #e5c890;--peach: #ef9f76;--red: #e78284;--mauve: #ca9ee6;--pink: #f4b8e4;--accent: var(--mauve);--accent-2: var(--sapphire);--accent-3: var(--green);--line: rgba(198, 208, 245, .14);--panel: rgba(65, 69, 89, .48);--panel-strong: rgba(65, 69, 89, .78);--pipe: rgba(202, 158, 230, .27)}:root[data-theme=macchiato]{color-scheme:dark;--base: #24273a;--mantle: #1e2030;--crust: #181926;--surface: #363a4f;--surface-2: #494d64;--overlay: #6e738d;--text: #cad3f5;--muted: #a5adcb;--subtle: #939ab7;--blue: #8aadf4;--sapphire: #7dc4e4;--green: #a6da95;--yellow: #eed49f;--peach: #f5a97f;--red: #ed8796;--mauve: #c6a0f6;--pink: #f5bde6;--accent: var(--mauve);--accent-2: var(--sapphire);--accent-3: var(--green);--line: rgba(202, 211, 245, .14);--panel: rgba(54, 58, 79, .48);--panel-strong: rgba(54, 58, 79, .78);--pipe: rgba(198, 160, 246, .28)}:root[data-theme=mocha]{color-scheme:dark;--base: #1e1e2e;--mantle: #181825;--crust: #11111b;--surface: #313244;--surface-2: #45475a;--overlay: #6c7086;--text: #cdd6f4;--muted: #a6adc8;--subtle: #9399b2;--blue: #89b4fa;--sapphire: #74c7ec;--green: #a6e3a1;--yellow: #f9e2af;--peach: #fab387;--red: #f38ba8;--mauve: #cba6f7;--pink: #f5c2e7;--accent: var(--mauve);--accent-2: var(--sapphire);--accent-3: var(--green);--line: rgba(205, 214, 244, .13);--panel: rgba(49, 50, 68, .5);--panel-strong: rgba(49, 50, 68, .8);--pipe: rgba(203, 166, 247, .28)}*{box-sizing:border-box}html{min-height:100%;scroll-behavior:smooth}@view-transition{navigation:auto}::view-transition-old(root){animation:page-out .19s ease both}::view-transition-new(root){animation:page-in .24s ease both}body{min-height:100vh;margin:0;background:linear-gradient(135deg,color-mix(in srgb,var(--base),var(--accent) 4%),var(--base) 58%,color-mix(in srgb,var(--base),var(--accent-2) 5%));color:var(--text);font-family:var(--font-body);font-size:16px;line-height:1.65;animation:page-in .26s ease both}.is-leaving body{animation:page-out .18s ease both}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button,a,[data-card-href]{transition:border-color .16s ease,background-color .16s ease,color .16s ease,opacity .16s ease,transform .16s ease}button:active,a:active,[data-card-href]:active{transform:translateY(1px)}@keyframes page-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes page-out{to{opacity:0;transform:translateY(-5px)}}::selection{background:color-mix(in srgb,var(--accent),transparent 62%);color:var(--text)}.site-header{position:relative;z-index:3;display:flex;align-items:center;justify-content:space-between;width:min(1180px,calc(100% - 40px));margin:0 auto;padding:28px 0 10px}.site-header.compact{padding-top:22px}.wordmark{font-family:var(--font-display);font-size:.92rem;color:var(--text)}.theme-switcher{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:2px;padding:3px;border:1px solid var(--line);border-radius:var(--radius);background:color-mix(in srgb,var(--panel-strong),transparent 8%);box-shadow:0 8px 30px #11111b14}.theme-switcher button{min-width:78px;min-height:34px;border:0;border-radius:6px;background:transparent;color:var(--muted);cursor:pointer}.theme-switcher button[aria-pressed]{background:color-mix(in srgb,var(--accent),transparent 78%);color:var(--text)}.home-page,.project-page{position:relative;overflow-x:hidden}.pipes-bg{position:fixed;inset:0;z-index:0;width:100%;height:100vh;overflow:hidden;pointer-events:none;opacity:.36;mix-blend-mode:screen}:root[data-theme=latte] .pipes-bg{opacity:.28;mix-blend-mode:multiply}.pipes-bg canvas{display:block;width:100%;height:100%}.pipe-frame{position:fixed;inset:0;z-index:0;pointer-events:none;color:var(--pipe);font-family:var(--font-mono)}.pipe{position:fixed;opacity:.9}.terminal-pipes{--pipe-offset: 34px;--pipe-gap-start: 30%;--pipe-gap-end: 70%}.terminal-pipe{display:flex;overflow:hidden;color:color-mix(in srgb,var(--pipe),var(--text) 14%);font-size:.82rem;line-height:1;letter-spacing:1px;text-shadow:0 0 12px color-mix(in srgb,var(--pipe),transparent 55%)}.terminal-pipe span:nth-child(4n){color:color-mix(in srgb,var(--accent-2),var(--pipe) 60%)}.pipe-top,.pipe-bottom{left:var(--pipe-offset);height:1em}.pipe-top.pipe-start,.pipe-bottom.pipe-start{width:calc(var(--pipe-gap-start) - var(--pipe-offset))}.pipe-top.pipe-end,.pipe-bottom.pipe-end{left:var(--pipe-gap-end);right:var(--pipe-offset)}.pipe-top{top:calc(var(--pipe-offset) - .45em)}.pipe-bottom{bottom:calc(var(--pipe-offset) - .45em)}.pipe-left,.pipe-right{top:var(--pipe-offset);bottom:var(--pipe-offset);flex-direction:column;justify-content:space-between;width:1em}.pipe-left{left:calc(var(--pipe-offset) - .4em)}.pipe-right{right:calc(var(--pipe-offset) - .4em)}.pipe-corner{position:fixed;z-index:1;color:color-mix(in srgb,var(--pipe),var(--text) 22%);font-size:.9rem;line-height:1}.corner-tl{top:calc(var(--pipe-offset) - .45em);left:calc(var(--pipe-offset) - .45em)}.corner-tr{top:calc(var(--pipe-offset) - .45em);right:calc(var(--pipe-offset) - .45em)}.corner-br{right:calc(var(--pipe-offset) - .45em);bottom:calc(var(--pipe-offset) - .45em)}.corner-bl{bottom:calc(var(--pipe-offset) - .45em);left:calc(var(--pipe-offset) - .45em)}.pipe-flow{position:fixed;z-index:2;color:color-mix(in srgb,var(--accent-2),var(--text) 20%);font-size:.72rem;line-height:1;opacity:.8;text-shadow:0 0 14px color-mix(in srgb,var(--accent-2),transparent 38%)}.flow-top{top:calc(var(--pipe-offset) - .4em);left:var(--pipe-offset);animation:flow-horizontal 9s linear infinite}.flow-right{top:var(--pipe-offset);right:calc(var(--pipe-offset) - .4em);animation:flow-vertical 11s linear infinite}.flow-bottom{right:var(--pipe-offset);bottom:calc(var(--pipe-offset) - .4em);animation:flow-horizontal-reverse 13s linear infinite}.flow-left{bottom:var(--pipe-offset);left:calc(var(--pipe-offset) - .4em);animation:flow-vertical-reverse 10s linear infinite}@keyframes flow-horizontal{0%{transform:translate(0)}to{transform:translate(calc(100vw - var(--pipe-offset) * 2))}}@keyframes flow-horizontal-reverse{0%{transform:translate(0)}to{transform:translate(calc((100vw - var(--pipe-offset) * 2) * -1))}}@keyframes flow-vertical{0%{transform:translateY(0)}to{transform:translateY(calc(100vh - var(--pipe-offset) * 2))}}@keyframes flow-vertical-reverse{0%{transform:translateY(0)}to{transform:translateY(calc((100vh - var(--pipe-offset) * 2) * -1))}}.pipe-glyph{position:fixed;z-index:1;display:grid;place-items:center;min-width:30px;height:22px;padding:0 5px;border:1px solid color-mix(in srgb,var(--pipe),var(--line) 45%);border-radius:6px;background:color-mix(in srgb,var(--base),transparent 7%);color:color-mix(in srgb,var(--accent),var(--text) 28%);font-family:var(--font-mono);font-size:.72rem;opacity:.72}.pipe-glyph.top-left{top:23px;left:14%}.pipe-glyph.top-right{top:23px;right:17%}.pipe-glyph.right-upper{top:23%;right:20px}.pipe-glyph.right-lower{bottom:27%;right:20px}.pipe-glyph.bottom-right{bottom:23px;right:14%}.pipe-glyph.bottom-left{bottom:23px;left:18%}.pipe-glyph.left-upper{top:32%;left:20px}.pipe-glyph.left-lower{bottom:21%;left:20px}.home-shell{position:relative;z-index:2;display:grid;gap:42px;width:min(1180px,calc(100% - 40px));margin:0 auto;padding:70px 0 96px}.home-hero{max-width:760px}.eyebrow,.project-status,.doc-toc p,.back-nav,.devlog-next span,.post-list-row time{margin:0;color:var(--accent-2);font-family:var(--font-mono);font-size:.76rem;text-transform:uppercase}.home-hero h1,.project-heading h1,.devlog-title h1{margin:10px 0 18px;font-family:var(--font-display);line-height:1.08;color:var(--text)}.home-hero h1{max-width:960px;font-size:clamp(3rem,7.2vw,6.3rem)}.home-hero p{max-width:720px;margin:0;color:var(--muted);font-size:clamp(1rem,1.8vw,1.22rem)}.home-metrics{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}.home-metrics span{display:inline-flex;align-items:center;min-height:34px;padding:0 12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);color:var(--text);font-family:var(--font-mono);font-size:.84rem}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,310px),1fr));gap:18px}.project-card{position:relative;display:grid;gap:18px;min-height:390px;padding:18px;border:1px solid var(--line);border-radius:var(--radius);background:color-mix(in srgb,var(--panel-strong),transparent 15%);box-shadow:var(--shadow);cursor:pointer}.project-card:hover,.project-card:focus-visible{border-color:color-mix(in srgb,var(--accent),var(--line) 32%);background:color-mix(in srgb,var(--panel-strong),var(--accent) 5%)}.project-card:focus-visible{outline:2px solid color-mix(in srgb,var(--accent),transparent 38%);outline-offset:3px}.project-card-head,.project-heading,.title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}.project-symbol{display:grid;place-items:center;width:76px;height:76px;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(135deg,color-mix(in srgb,var(--surface),transparent 25%),transparent),repeating-linear-gradient(90deg,transparent 0 8px,color-mix(in srgb,var(--accent),transparent 86%) 8px 9px);color:var(--accent);font-family:var(--font-mono);font-size:1.15rem}.project-card h2,.post-list-row h2{margin:5px 0 8px;color:var(--text);font-family:var(--font-display);font-size:1.35rem;line-height:1.22}.project-card p,.post-list-row p,.project-summary{margin:0;color:var(--muted)}.tag-list{display:flex;flex-wrap:wrap;gap:8px;margin:0;padding:0;list-style:none}.tag-list li{display:inline-flex;align-items:center;width:fit-content;padding:5px 8px;border:1px solid var(--line);border-bottom:1px solid var(--line);border-radius:6px;color:color-mix(in srgb,var(--accent-3),var(--text) 15%);font-family:var(--font-mono);font-size:.76rem;line-height:1;text-decoration:none;box-shadow:none}.tag-list.wide,.tag-list.devlog-tags{margin-top:18px}.devlog-list{display:grid;gap:8px;align-self:end}.devlog-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;min-height:48px;padding:10px 0;border-top:1px solid var(--line)}.latest-devlog{border-top-color:color-mix(in srgb,var(--accent),var(--line) 55%)}.devlog-row span{min-width:0;color:var(--text)}.devlog-row time{color:var(--subtle);font-family:var(--font-mono);font-size:.74rem}.more-devlogs-tab{justify-self:start;display:inline-flex;align-items:center;gap:8px;min-height:34px;padding:0 10px;border:1px solid color-mix(in srgb,var(--accent-2),var(--line) 45%);border-radius:var(--radius);background:color-mix(in srgb,var(--accent-2),transparent 88%);color:color-mix(in srgb,var(--accent-2),var(--text) 18%);font-family:var(--font-mono);font-size:.78rem}.more-devlogs-tab:hover{background:color-mix(in srgb,var(--accent-2),transparent 78%)}.quiet{color:var(--subtle)}.external-links{display:flex;align-items:center;gap:8px}.github-link,.youtube-link,.github-menu summary,.youtube-menu summary{display:grid;place-items:center;width:38px;height:38px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);color:var(--text);cursor:pointer}.github-link svg,.youtube-link svg,.github-menu svg,.youtube-menu svg{width:20px;height:20px}.github-link:hover,.youtube-link:hover,.github-menu summary:hover,.youtube-menu summary:hover{color:var(--accent);border-color:color-mix(in srgb,var(--accent),var(--line) 45%)}.youtube-link:hover,.youtube-menu summary:hover{color:#ffb3b3}.github-menu,.youtube-menu{position:relative}.github-menu summary,.youtube-menu summary{list-style:none}.github-menu summary::-webkit-details-marker,.youtube-menu summary::-webkit-details-marker{display:none}.github-menu-panel,.youtube-menu-panel{position:absolute;top:46px;right:0;z-index:10;display:grid;min-width:210px;padding:6px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel-strong);box-shadow:var(--shadow)}.github-menu-panel a,.youtube-menu-panel a{padding:9px 10px;border-radius:6px;color:var(--text);font-size:.88rem}.github-menu-panel a:hover,.youtube-menu-panel a:hover{background:color-mix(in srgb,var(--accent),transparent 84%)}.project-index{position:relative;z-index:2;width:min(920px,calc(100% - 40px));margin:0 auto;padding:58px 0 90px}.back-nav{margin-bottom:34px}.back-nav a{display:inline-flex;align-items:center;min-height:36px;padding:0 12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);color:var(--accent-2);text-decoration:none}.back-nav a:hover{color:var(--accent);border-color:color-mix(in srgb,var(--accent),var(--line) 45%);background:color-mix(in srgb,var(--accent),transparent 90%)}.project-heading h1{font-size:clamp(2.2rem,6vw,4.7rem)}.project-summary{max-width:760px;font-size:1.05rem}.post-list{display:grid;gap:12px;margin-top:42px}.post-list-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:center;padding:18px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel)}.post-list-row:hover{border-color:color-mix(in srgb,var(--accent),var(--line) 40%)}.post-list-row>span{color:var(--accent);font-family:var(--font-mono);font-size:1.2rem}.devlog-shell{display:grid;grid-template-columns:minmax(136px,210px) minmax(0,800px) minmax(50px,80px);gap:clamp(18px,4vw,54px);width:min(1180px,calc(100% - 40px));margin:0 auto;padding:54px 0 110px}.doc-toc{position:sticky;top:42px;align-self:start;max-height:calc(100vh - 84px);overflow:auto;padding:8px 0;opacity:.82}.doc-toc ol{display:grid;gap:7px;margin:14px 0 0;padding:0;list-style:none}.doc-toc a{display:block;padding:2px 0;color:var(--subtle);font-size:.82rem;line-height:1.38}.doc-toc .h3 a{padding-left:12px;font-size:.78rem}.doc-toc .h4 a{padding-left:22px;font-size:.76rem}.doc-toc a[aria-current]{color:var(--accent)}.devlog-article{min-width:0}.devlog-title{margin-bottom:46px;padding-bottom:28px;border-bottom:1px solid var(--line)}.devlog-title h1{margin-bottom:10px;font-size:clamp(2.2rem,5.6vw,4.8rem)}.devlog-title>p:last-child{max-width:680px;margin:0;color:var(--muted);font-size:1.05rem}.devlog-article :is(h2,h3,h4){scroll-margin-top:24px}.devlog-article h2{margin:52px 0 14px;color:var(--accent);font-family:var(--font-display);font-size:1.65rem;line-height:1.25}.devlog-article h3{margin:34px 0 12px;color:var(--accent-2);font-family:var(--font-display);font-size:1.24rem;line-height:1.32}.devlog-article h4{margin:26px 0 10px;color:var(--accent-3);font-family:var(--font-mono);font-size:1rem}.devlog-article p,.devlog-article li{color:var(--text)}.devlog-article p{margin:0 0 18px}.devlog-article a{color:var(--blue);text-decoration:underline;text-decoration-color:color-mix(in srgb,var(--blue),transparent 55%);text-underline-offset:3px}.devlog-article .doc-ref{display:inline-grid;place-items:center;width:1.25em;height:1.25em;margin-left:.18em;border:1px solid color-mix(in srgb,var(--accent-2),var(--line) 35%);border-radius:999px;background:color-mix(in srgb,var(--accent-2),transparent 86%);color:var(--accent-2);text-decoration:none;vertical-align:super;font-family:var(--font-mono);font-size:.62em;line-height:1}.doc-ref-overlay{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:22px;background:#11111b75;opacity:0;pointer-events:none;transition:opacity .16s ease}.doc-ref-overlay.visible{opacity:1;pointer-events:auto}.doc-ref-popover{width:min(760px,100%);max-height:min(720px,calc(100vh - 44px));overflow:auto;border:1px solid color-mix(in srgb,var(--accent),var(--line) 40%);border-radius:var(--radius);background:color-mix(in srgb,var(--base),var(--panel-strong) 35%);box-shadow:var(--shadow);transform:translateY(8px) scale(.985);transition:transform .16s ease}.doc-ref-overlay.visible .doc-ref-popover{transform:translateY(0) scale(1)}.doc-ref-popover header{position:sticky;top:0;z-index:1;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:16px 18px;border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--base),transparent 4%)}.doc-ref-popover header p{margin:0 0 3px;color:var(--accent-2);font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase}.doc-ref-popover h2{margin:0;color:var(--text);font-family:var(--font-display);font-size:1.15rem;line-height:1.25}.doc-ref-actions{display:flex;gap:8px}.doc-ref-actions a,.doc-ref-actions button{display:grid;place-items:center;width:36px;height:36px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);color:var(--text);cursor:pointer;text-decoration:none}.doc-ref-content{padding:18px}.doc-ref-highlight{padding:16px;border:1px solid color-mix(in srgb,var(--accent),var(--line) 25%);border-radius:var(--radius);background:color-mix(in srgb,var(--accent),transparent 90%)}.doc-ref-highlight :is(h2,h3,h4){margin-top:0}.devlog-article .hash-target-flash{border-radius:var(--radius);animation:hashTargetFlash 2.2s ease both}@keyframes hashTargetFlash{0%,to{background:transparent;box-shadow:none}14%,68%{background:color-mix(in srgb,var(--accent),transparent 84%);box-shadow:0 0 0 8px color-mix(in srgb,var(--accent),transparent 84%)}}.devlog-article ul,.devlog-article ol{padding-left:1.3rem}.devlog-article blockquote{margin:28px 0;padding:14px 18px;border-left:3px solid var(--accent);background:var(--panel);color:var(--muted)}.devlog-article code{border:1px solid var(--line);border-radius:6px;padding:.13rem .34rem;background:var(--mantle);color:var(--pink);font-family:var(--font-mono);font-size:.9em}.devlog-article pre{overflow-x:auto;margin:26px 0;padding:18px;border:1px solid var(--line);border-radius:var(--radius);background:var(--crust)}.devlog-article pre code{border:0;padding:0;background:transparent;color:inherit}.devlog-article img,.devlog-article video,.devlog-article iframe{display:block;max-width:100%;margin:30px 0;border:1px solid var(--line);border-radius:var(--radius);background:var(--mantle)}.devlog-article iframe{width:100%;aspect-ratio:16 / 9}.devlog-article table{display:block;width:100%;overflow-x:auto;margin:30px 0;border-collapse:collapse}.devlog-article th,.devlog-article td{padding:10px 12px;border:1px solid var(--line)}.devlog-article th{color:var(--accent-2);font-family:var(--font-mono);text-align:left}.scroll-map{position:fixed;top:104px;right:max(20px,calc((100vw - 1180px)/2));bottom:auto;display:grid;grid-template-rows:repeat(72,minmax(3px,1fr));justify-items:end;gap:4px;width:78px;height:calc(100vh - 132px);padding:0;z-index:4}.scroll-bar{width:var(--bar-size, 18px);height:3px;border:0;border-radius:3px;padding:0;background:color-mix(in srgb,var(--overlay),transparent 48%);cursor:pointer;transition:width .12s ease,background .12s ease}.scroll-bar.heading-marker{height:4px;background:color-mix(in srgb,var(--accent),transparent 36%)}.scroll-bar.active{background:var(--accent-2)}.scroll-bar[data-title]{position:relative}.scroll-bar[data-title]:after{position:absolute;top:50%;right:calc(100% + 10px);width:max-content;max-width:230px;padding:6px 8px;border:1px solid var(--line);border-radius:6px;background:var(--panel-strong);color:var(--text);content:attr(data-title);font-family:var(--font-body);font-size:.78rem;line-height:1.25;opacity:0;pointer-events:none;transform:translateY(-50%) translate(4px);transition:opacity .12s ease,transform .12s ease}.scroll-bar[data-title]:hover:after{opacity:1;transform:translateY(-50%) translate(0)}.devlog-next{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:66px;padding-top:26px;border-top:1px solid var(--line)}.devlog-next a{display:grid;gap:4px;padding:15px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);text-decoration:none}.devlog-next a:last-child{text-align:right}.devlog-next strong{color:var(--text);font-size:.96rem}.admin-page{background:var(--base)}.admin-shell{width:min(980px,calc(100% - 32px));margin:0 auto;padding:42px 0 90px}.admin-shell h1,.admin-panel h2{font-family:var(--font-display)}.admin-shell h1{margin:0 0 10px}.admin-status{min-height:28px;color:var(--accent-2);font-family:var(--font-mono);font-size:.86rem}.admin-toast{position:fixed;right:22px;bottom:22px;z-index:30;max-width:min(420px,calc(100vw - 44px));margin:0;padding:12px 14px;border:1px solid color-mix(in srgb,var(--accent-2),var(--line) 35%);border-radius:var(--radius);background:var(--panel-strong);box-shadow:var(--shadow);color:var(--text);font-family:var(--font-mono);font-size:.82rem}.admin-toast[data-state=success]{border-color:color-mix(in srgb,var(--green),var(--line) 20%);color:color-mix(in srgb,var(--green),var(--text) 18%)}.admin-toast[data-state=error]{border-color:color-mix(in srgb,var(--red),var(--line) 20%);color:color-mix(in srgb,var(--red),var(--text) 12%)}.admin-panel,.admin-login{display:grid;gap:18px;margin-top:24px;padding:18px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel)}.admin-grid{display:grid;grid-template-columns:minmax(220px,300px) minmax(0,1fr);gap:18px}.admin-section{display:grid;gap:12px;align-content:start}.admin-list{display:grid;gap:8px}.admin-list button{min-height:38px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel-strong);color:var(--text);cursor:pointer;text-align:left}.admin-form{display:grid;gap:12px}.admin-form label,.admin-field{display:grid;gap:5px;color:var(--muted);font-size:.86rem}.field-label{color:var(--muted)}.field-help{color:var(--subtle);font-size:.76rem;line-height:1.4}.admin-form input,.admin-form select,.admin-form textarea{width:100%;border:1px solid var(--line);border-radius:var(--radius);padding:10px 11px;background:var(--panel-strong);color:var(--text)}.admin-form input[readonly]{color:var(--subtle);cursor:default}.admin-form textarea{min-height:260px;resize:vertical;font-family:var(--font-mono);font-size:.88rem;line-height:1.55}.admin-help{border:1px solid var(--line);border-radius:var(--radius);background:color-mix(in srgb,var(--panel-strong),transparent 20%)}.admin-help summary{min-height:40px;padding:10px 11px;color:var(--text);cursor:pointer;font-family:var(--font-mono);font-size:.8rem}.admin-help div{display:grid;gap:10px;padding:0 11px 11px}.admin-help p{margin:0;color:var(--muted);font-size:.82rem;line-height:1.45}.admin-help pre{max-height:360px;overflow:auto;margin:0;border:1px solid var(--line);border-radius:var(--radius);padding:12px;background:var(--code-bg);color:var(--text);font-size:.78rem;line-height:1.5}.tag-editor{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;padding:8px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel-strong)}.tag-chips{grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:7px;min-height:28px}.tag-chip{min-height:28px;border:1px solid color-mix(in srgb,var(--accent-3),var(--line) 40%);border-radius:6px;padding:0 8px;background:color-mix(in srgb,var(--accent-3),transparent 88%);color:color-mix(in srgb,var(--accent-3),var(--text) 12%);cursor:pointer;font-family:var(--font-mono);font-size:.75rem}.tag-editor input{border-color:color-mix(in srgb,var(--line),transparent 20%);background:var(--base)}.tag-editor button:not(.tag-chip){min-height:40px;border:1px solid var(--line);border-radius:var(--radius);padding:0 12px;background:var(--panel);color:var(--text);cursor:pointer}.reference-controls{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr) auto auto auto;gap:8px}.reference-controls select,.reference-controls button{min-height:40px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel-strong);color:var(--text)}.reference-controls select{min-width:0;padding:0 10px}.reference-controls button{padding:0 12px;cursor:pointer}.admin-actions{display:flex;flex-wrap:wrap;gap:10px}.admin-actions button,.admin-login button{min-height:40px;border:1px solid color-mix(in srgb,var(--accent),var(--line) 45%);border-radius:var(--radius);padding:0 13px;background:color-mix(in srgb,var(--accent),transparent 80%);color:var(--text);cursor:pointer}.admin-actions button.secondary{border-color:var(--line);background:var(--panel-strong)}.hidden{display:none!important}@media(max-width:920px){.devlog-shell{grid-template-columns:minmax(0,1fr) 48px}.doc-toc{display:none}.admin-grid{grid-template-columns:1fr}}@media(max-width:700px){.site-header{align-items:flex-start;gap:16px;width:min(100% - 24px,1180px)}.theme-switcher{grid-template-columns:repeat(2,minmax(0,1fr))}.theme-switcher button{min-width:88px}.home-shell,.project-index,.devlog-shell,.admin-shell{width:calc(100% - 24px)}.terminal-pipes{--pipe-offset: 16px}.pipe-glyph.left-upper,.pipe-glyph.left-lower,.pipe-glyph.right-upper,.pipe-glyph.right-lower{display:none}.home-hero h1,.project-heading h1,.devlog-title h1{font-size:clamp(2.4rem,13vw,4.1rem)}.project-heading,.title-row{align-items:center}.post-list-row,.devlog-row,.reference-controls{grid-template-columns:1fr}.devlog-shell{grid-template-columns:minmax(0,1fr)}.scroll-map{display:none}.devlog-next{grid-template-columns:1fr}}
