:root{--bg: #0d1117;--surface: #161b22;--surface-soft: #1f2937;--text-main: #c9d1d9;--text-muted: #8b949e;--accent: #58a6ff;--accent-alt: #f0883e;--accent-soft: #1f6feb;--code-color: #0b1220;--border: #30363d;--radius: 10px}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--text-main);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;line-height:1.6}:root{--bp-sm: 576px;--bp-md: 768px;--bp-lg: 992px;--bp-xl: 1200px}html[data-theme=light]{--bg: #ffffff;--surface: #f8fafc;--surface-soft: #f1f5f9;--text-main: #0a214d;--text-muted: #475569;--accent: #2563eb;--accent-alt: #9333ea;--accent-soft: #eef2ff;--code-color: #F9F5FC;--border: #e5e7eb}main{width:100%;max-width:min(1040px,100% - 2rem);margin-inline:auto;padding-inline:clamp(1rem,3vw + .5rem,2rem);padding-top:clamp(2rem,5vh,3rem);padding-bottom:clamp(3rem,8vh,5rem)}html{transition:background-color .25s ease,color .25s ease}html{font-size:16px}@media(min-width:576px){html{font-size:16.5px}}@media(min-width:768px){html{font-size:17px}}@media(min-width:992px){html{font-size:17.5px}}@media(min-width:1200px){html{font-size:18px}}*{transition:background-color .25s ease,border-color .25s ease,color .25s ease}@media print{nav,.navbar,.breadcrumb,#command-palette{display:none!important}body{background:#fff;color:#000}.code-gutter{display:none}.code-section{grid-template-columns:1fr}a{color:#000;text-decoration:none}details{border:none}}.navbar{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1.2rem;margin-bottom:3.5rem;background:linear-gradient(180deg,rgba(255,255,255,.02),transparent);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:999;backdrop-filter:blur(10px)}.navbar.scrolled{border-bottom-color:var(--accent)}.nav-left{display:flex;align-items:center;gap:1.4rem}.brand{color:var(--accent);font-weight:500;opacity:.9;margin-right:.6rem}.nav-link{color:var(--text-muted);text-decoration:none;position:relative;font-size:.95rem}.nav-link:before{content:"";position:absolute;left:0;bottom:-4px;width:0;height:1px;background:var(--accent);transition:width .2s ease}.nav-link:hover{color:var(--text-main);text-decoration:none}.nav-link:hover:before{width:100%}.nav-link.active{color:var(--accent)}.nav-link.active:before{width:100%}.nav-right button{font-family:inherit;background:transparent;border:1px solid var(--border);color:var(--text-muted);padding:.35rem .7rem;border-radius:6px;cursor:pointer;font-size:.85rem}.nav-right button:hover{color:var(--accent);border-color:var(--accent)}h1{font-size:1.7rem;line-height:1.25;margin-bottom:1.2rem}h2{font-size:1.2rem;color:var(--accent);font-weight:500}h2:before{content:"▸ ";color:var(--accent-alt)}h3{font-size:1rem;margin-bottom:.4rem}p,li{color:var(--text-muted);max-width:75ch}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit}.ui-button{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;height:32px;padding:0 .6rem;font-family:inherit;font-size:.75rem;line-height:1;background:var(--surface);color:var(--text-muted);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.ui-button:hover{color:var(--text-main);background-color:var(--surface-soft);border-color:var(--accent)}.ui-button:active{transform:translateY(.5px)}.ui-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}#theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-muted);cursor:pointer}#theme-toggle:hover{color:var(--accent);border-color:var(--accent)}#theme-toggle svg{display:none}html[data-theme=light] #icon-moon{display:inline}html:not([data-theme=light]) #icon-sun{display:inline}#theme-toggle:hover svg{transform:rotate(15deg);transition:transform .15s ease}.hero{max-width:900px}.hero p{font-size:1rem}.no-code .code-gutter{display:none}.no-code{grid-template-columns:1fr}.no-code p{max-width:none}.code-section{display:grid;grid-template-columns:auto 1fr;gap:1.5rem;align-items:start;margin-top:4.5rem;opacity:0;transform:translateY(12px);transition:opacity .4s ease,transform .4s ease;content-visibility:auto;contain-intrinsic-size:400px}.code-section.visible{opacity:1;transform:translateY(0)}.code-gutter{color:var(--text-muted);font-size:.75rem;line-height:1.6;text-align:right;padding-top:.3rem;user-select:none;opacity:.7}.code-content{min-width:0}.code-gutter:after{content:"";display:block;width:1px;height:100%;background:var(--border);margin-left:auto;margin-top:.5rem}.project{padding:2.2rem 0;border-bottom:1px solid var(--border)}.project:last-child{border-bottom:none}.project-title{color:var(--text-main)}.project-meta{color:var(--accent-alt);font-size:.85rem;margin-top:.4rem}.callout{background:var(--code-color);border:.5px solid var(--border);border-left:4px solid var(--accent-alt);padding:1.6rem 2rem;color:var(--text-muted)}code{background:transparent;padding:.2em .45em;border-radius:6px;color:var(--accent-alt)}pre{padding:.75rem 1rem;border-radius:8px;overflow-x:auto}footer{margin-top:6rem;padding-top:2rem;border-top:1px solid var(--border);color:var(--text-muted);font-size:.85rem}.breadcrumbs{font-size:.8rem;color:var(--text-muted);margin-bottom:2.2rem}.breadcrumb-item{display:inline-flex;align-items:center}.breadcrumb-separator{margin:0 .4rem;color:var(--border)}.breadcrumbs a{color:var(--text-muted);text-decoration:none}.breadcrumbs a:hover{color:var(--accent);text-decoration:underline}.breadcrumb-current{color:var(--text-main)}.breadcrumb-prefix{margin-right:.4rem;color:var(--accent)}details{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:0;margin-top:1.2rem}details summary{cursor:pointer;list-style:none;padding:1rem 1.4rem;font-weight:500;color:var(--accent);display:flex;align-items:center;gap:.6rem}details summary:before{content:"▸";color:var(--text-muted);transition:transform .2s ease}details[open] summary:before{transform:rotate(90deg)}details summary::-webkit-details-marker{display:none}details .fold-content{padding:0 1.4rem 1.4rem;color:var(--text-muted)}details .fold-content{animation:fold-in .15s ease}@keyframes fold-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.palette{position:fixed;inset:0;background:#00000073;display:flex;align-items:flex-start;justify-content:center;padding-top:15vh;z-index:1000;opacity:0;transform:translateY(-8px) scale(.98);transition:all .15s ease}.palette.hidden{display:none}.palette:not(.hidden){opacity:1;transform:translateY(0) scale(1)}.palette-box{background:var(--surface);border:1px solid var(--border);border-radius:10px;width:420px;max-width:90%;padding:.8rem}#palette-input{width:100%;background:transparent;border:none;border-bottom:1px solid var(--border);padding:.6rem;color:var(--text-main);font-family:inherit;outline:none}#palette-list{list-style:none;margin:.6rem 0 0;padding:0}#palette-list li{padding:.5rem .6rem;cursor:pointer;border-radius:6px;color:var(--text-muted)}#palette-list li:hover{background:var(--surface-soft);color:var(--text-main)}.toc{position:fixed;right:1.5rem;top:7rem;width:220px;font-size:.75rem;color:var(--text-muted)}.toc a{display:block;margin-bottom:.4rem;color:var(--text-muted);text-decoration:none}.toc a:hover{color:var(--accent)}@media(max-width:1100px){.toc{display:none}}.project-list{list-style:none;padding-left:0}.project-list li{margin-bottom:1rem}.project-list a{text-decoration:none;color:inherit;display:block}.project-list a:hover strong{text-decoration:underline}.project-meta{font-size:.85rem;opacity:.7;margin-top:.25rem;line-height:1.4}.about-hero{margin-bottom:2rem}.subtitle{color:var(--muted);max-width:60ch}.role details{margin-top:.5rem}.role summary{cursor:pointer;color:var(--text-muted);font-size:.85rem;user-select:none}.role summary:hover{color:var(--text-main)}.role details[open] summary{color:var(--accent)}.nav-link,#theme-toggle,.project-title a{position:relative}.nav-link:after,.project-title a:after{content:"";position:absolute;inset:-6px;background:radial-gradient(circle at var(--x, 50%) var(--y, 50%),rgba(255,255,255,.12),transparent 40%);opacity:0;transition:opacity .2s ease;pointer-events:none}.nav-link:hover:after,.project-title a:hover:after{opacity:1}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem}.project-card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:1.25rem 1.25rem 1.1rem;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:.6rem;transition:border-color .15s ease,box-shadow .15s ease,transform .12s ease}.project-card:after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;box-shadow:inset 0 0 0 1px transparent}.project-card:before{content:"↗";position:absolute;top:.5rem;right:1rem;font-size:1.2rem;color:var(--text-muted);opacity:0;transition:opacity .15s ease}.project-card:hover:before{opacity:.6}.project-card:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 8px 24px #0000002e}html[data-theme=light] .project-card:hover{box-shadow:0 10px 30px #00000014}.project-card h3{font-size:1rem;font-weight:600;color:var(--text-main);margin:0}.project-card .subtitle{font-size:.9rem;color:var(--text-muted);line-height:1.45}.project-card .project-meta{font-size:.75rem;letter-spacing:.02em;margin-top:.25rem}.project-card .hint{margin-top:auto;font-size:.7rem;color:var(--text-muted);opacity:.75;transition:opacity .15s ease,color .15s ease}.project-card:hover .hint{opacity:1;color:var(--accent)}.project-card:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.modal{position:fixed;inset:0;z-index:9999}.modal.hidden{display:none}.modal-backdrop{position:absolute;inset:0;background:#0009}.modal-content{position:relative;margin:0 auto;top:clamp(3.5rem,8vh,6rem);max-width:720px;max-height:calc(100dvh - 8rem);background:var(--bg);border-radius:12px;overflow:hidden;animation:modal-in .15s ease-out}.modal-scroll{max-height:calc(100dvh - 8rem);overflow-y:auto}.modal-header{position:sticky;top:0;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-bottom:1rem;margin-bottom:1.25rem;background:var(--bg);border-bottom:1px solid var(--border)}.modal-title{margin:0;font-size:1rem;font-weight:600;color:var(--accent)}.modal-header .modal-close{position:static;flex-shrink:0}.modal-footer{margin-top:2rem;padding-top:1rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:1rem}.modal-hint{font-size:.75rem;color:var(--text-muted)}.modal-content .astro-code{box-shadow:inset 0 0 0 1px var(--border)}.modal-header,.modal-body,.modal-footer{padding-left:1rem;padding-right:1rem}.modal-header{padding-top:1.5rem;padding-bottom:1rem}.modal-body{padding-top:0}.modal-footer{padding-top:1rem;padding-bottom:1.5rem}.modal-header{transition:box-shadow .15s ease}.modal-header.is-scrolled{box-shadow:0 6px 12px #00000026}html[data-theme=light] .modal-header.is-scrolled{box-shadow:0 6px 12px #00000014}.modal{opacity:1;pointer-events:auto}.modal.hidden{opacity:0;pointer-events:none}.modal-backdrop{opacity:1;transition:opacity .2s ease}.modal.hidden .modal-backdrop{opacity:0}.modal-content{transform:translateY(0);opacity:1;transition:transform .2s ease,opacity .2s ease}.modal.hidden .modal-content{transform:translateY(-8px);opacity:0}@keyframes modal-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@media(max-width:480px){.project-card{padding:1.4rem}.project-card .hint{opacity:1}}.astro-code{background:var(--surface-soft)!important;box-shadow:inset 0 0 0 1px var(--border);border-radius:10px;padding:1rem 1.25rem;margin:1rem 0;font-size:.85rem;line-height:1.5;overflow-x:auto}.astro-code code{background:transparent!important;padding:0}.astro-code span{font-style:normal!important}.astro-code pre{position:relative}.astro-code pre:before{content:"Copy";position:absolute;top:.5rem;right:.5rem}html[data-theme=dark] .astro-code,html[data-theme=dark] .astro-code span{background-color:var(--shiki-dark-bg)!important;color:var(--shiki-dark)!important}.code-pre{position:relative;background:var(--surface-soft);padding:1rem 1.5rem;border-radius:8px;overflow-x:auto}.code-pre.line-numbers{counter-reset:line}.diagram-block{background:var(--surface-soft);padding:1rem 1.25rem;border-radius:8px;overflow-x:auto;font-family:var(--font-mono);color:var(--text-muted)}.astro-code .line:empty:before{display:none}.diagram-block .line:before{display:none!important}.code-block{position:relative}.code-block .code-copy{position:absolute;top:.5rem;right:.5rem;z-index:3;opacity:0;pointer-events:none;transform:translateY(-2px);transition:opacity .15s ease,transform .15s ease}.code-block .astro-code{padding-top:2.2rem!important}.code-block:hover .code-copy,.code-block:focus-within .code-copy{opacity:1;pointer-events:auto;transform:translateY(0)}.code-lang{position:absolute;top:.5rem;left:.6rem;font-size:.65rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);background:var(--surface);padding:.15rem .4rem;border-radius:6px;border:1px solid var(--border);z-index:2}.diagram-text{font-family:var(--font-mono);white-space:pre;color:var(--text-muted)}.diagram-text:before{content:"▸ ";opacity:.4}.diagram-text[data-emphasis=true]{color:var(--accent)}.diagram-line{animation:fade-in .3s ease forwards}
