@charset "UTF-8";:root{--accent: #1f6feb;--accent-2: #58a6ff;--gradient: linear-gradient(135deg, #1f6feb 0%, #58a6ff 100%);--bg: #0b0d14;--bg-elevated: #11141f;--text: #e2e6f0;--text-muted: #9aa3b5;--glass-bg: rgba(255, 255, 255, 0.05);--glass-bg-hover: rgba(255, 255, 255, 0.09);--glass-border: rgba(255, 255, 255, 0.09);--glass-shadow: 0 8px 32px rgba(0, 0, 0, 0.35);--glow-violet: rgba(31, 111, 235, 0.22);--glow-cyan: rgba(56, 166, 255, 0.14);--code-bg: rgba(255, 255, 255, 0.04);--code-border: rgba(255, 255, 255, 0.12);--code-block-bg: #161b22;--chip-text: #58a6ff;--chip-bg: rgba(56, 166, 255, 0.12);--chip-border: rgba(56, 166, 255, 0.28);--mark-bg: rgba(56, 166, 255, 0.28);--radius: 16px;--radius-sm: 10px;--container: 1080px;--font-body: "Inter", system-ui, -apple-system, sans-serif;--font-display: "Space Grotesk", var(--font-body);--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", monospace}[data-theme=light]{--accent: #0550ae;--accent-2: #0969da;--gradient: linear-gradient(135deg, #0969da 0%, #218bff 100%);--bg: #eef1f7;--bg-elevated: #ffffff;--text: #1f2328;--text-muted: #59636e;--glass-bg: rgba(255, 255, 255, 0.62);--glass-bg-hover: rgba(255, 255, 255, 0.9);--glass-border: rgba(20, 28, 48, 0.1);--glass-shadow: 0 8px 32px rgba(31, 38, 65, 0.08);--glow-violet: rgba(9, 105, 218, 0.1);--glow-cyan: rgba(33, 139, 255, 0.08);--code-bg: rgba(20, 28, 48, 0.06);--code-border: #d0d7de;--code-block-bg: #ffffff;--chip-text: #0969da;--chip-bg: rgba(9, 105, 218, 0.1);--chip-border: rgba(9, 105, 218, 0.25);--mark-bg: rgba(9, 105, 218, 0.18)}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);font-size:1rem;line-height:1.7;color:var(--text);background-color:var(--bg);min-height:100vh;display:flex;flex-direction:column;transition:background-color .3s ease,color .3s ease;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;background:radial-gradient(600px circle at 12% -5%,var(--glow-violet),transparent 60%),radial-gradient(700px circle at 88% 15%,var(--glow-cyan),transparent 60%),radial-gradient(900px circle at 50% 115%,var(--glow-violet),transparent 65%)}.site-main{flex:1;padding:40px 16px 80px}.container{max-width:var(--container);margin:0 auto}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);line-height:1.25;font-weight:700;letter-spacing:-.015em;text-wrap:balance}a{color:var(--accent-2);text-decoration:none;transition:color .2s ease}a:hover{color:var(--accent)}code,pre,kbd{font-family:var(--font-mono);font-size:.9em}img{max-width:100%;height:auto;display:block}::selection{background:var(--accent);color:#fff}:focus-visible{outline:2px solid var(--accent-2);outline-offset:2px}.page-head{margin-bottom:32px}.page-head .page-title{font-size:clamp(1.8rem,4vw,2.6rem)}.page-head .page-intro{margin-top:12px;color:var(--text-muted);max-width:640px}.glass{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius);box-shadow:var(--glass-shadow);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.glass-hover{transition:transform .25s ease,background .25s ease,border-color .25s ease,box-shadow .25s ease}.glass-hover:hover{background:var(--glass-bg-hover);transform:translateY(-3px);border-color:var(--accent);box-shadow:0 12px 40px var(--glow-violet)}.gradient-text{background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;border-radius:999px;font-weight:600;font-size:.95rem;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.btn-primary{background:var(--gradient);color:#fff;border:none}.btn-primary:hover{color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px var(--glow-violet)}.btn-ghost{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text);backdrop-filter:blur(14px)}.btn-ghost:hover{color:var(--text);border-color:var(--accent-2);transform:translateY(-2px)}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:999px;font-size:.8rem;font-weight:500;background:var(--chip-bg);border:1px solid var(--chip-border);color:var(--chip-text);transition:transform .2s ease,background .2s ease,color .2s ease}.chip:hover{transform:translateY(-2px);background:var(--gradient);color:#fff;border-color:transparent}.chip-lg{padding:8px 18px;font-size:.95rem}.site-header{position:sticky;top:0;z-index:100;padding:12px 16px 0}.header-inner{max-width:var(--container);margin:0 auto;display:flex;align-items:center;gap:24px;padding:10px 20px;position:relative}.site-logo{font-family:var(--font-display);font-weight:700;font-size:1.3rem;color:var(--text)}.site-logo:hover{color:var(--text)}.site-nav{display:flex;gap:4px;margin-left:auto}.site-nav .nav-link{padding:6px 13px;border-radius:999px;color:var(--text-muted);font-size:.92rem;font-weight:500;transition:color .2s ease,background .2s ease}.site-nav .nav-link:hover,.site-nav .nav-link.is-active{color:var(--text);background:var(--glass-bg-hover)}.header-actions{display:flex;align-items:center;gap:8px}.theme-toggle{display:grid;place-items:center;width:36px;height:36px;border-radius:999px;border:1px solid var(--glass-border);background:var(--glass-bg);color:var(--text);cursor:pointer;transition:background .2s ease,border-color .2s ease}.theme-toggle:hover{background:var(--glass-bg-hover);border-color:var(--accent-2)}[data-theme=dark] .icon-moon{display:none}[data-theme=light] .icon-sun{display:none}.nav-burger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:36px;height:36px;border-radius:999px;border:1px solid var(--glass-border);background:var(--glass-bg);cursor:pointer}.nav-burger span{display:block;width:16px;height:2px;border-radius:2px;background:var(--text)}@media(max-width:760px){.site-header{position:relative}.nav-burger{display:flex}.site-nav{display:none;position:absolute;top:calc(100% + 8px);left:0;right:0;flex-direction:column;padding:12px;background:var(--bg-elevated);border:1px solid var(--glass-border);border-radius:var(--radius);box-shadow:var(--glass-shadow);margin-left:0}.site-nav.is-open{display:flex}.site-nav .nav-link{padding:10px 14px}}.site-footer{border-top:1px solid var(--glass-border);padding:32px 16px}.footer-inner{max-width:var(--container);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.footer-social{display:flex;gap:20px}.footer-social a{color:var(--text-muted);font-size:.9rem;font-weight:500}.footer-social a:hover{color:var(--accent-2)}.footer-copy{color:var(--text-muted);font-size:.85rem}.hero{padding:64px 0 72px;text-align:center}.hero-eyebrow{font-family:var(--font-mono);font-size:.9rem;color:var(--accent-2);margin-bottom:16px}.hero-title{font-size:clamp(2.2rem,6vw,3.6rem);margin-bottom:20px}.hero-spark{color:var(--accent)}.hero-description{max-width:620px;margin:0 auto 32px;color:var(--text-muted);font-size:1.08rem}.hero-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}.section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:24px}.section-head .section-title{font-size:1.5rem}.section-head .section-link{color:var(--text-muted);font-size:.92rem;font-weight:500}.section-head .section-link:hover{color:var(--accent-2)}.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.post-list{display:flex;flex-direction:column;gap:18px}.post-card{padding:22px 24px;display:flex;flex-direction:column;gap:10px}.post-card-meta{display:flex;gap:8px;font-size:.82rem;font-family:var(--font-mono);color:var(--text-muted)}.post-card-title{font-size:1.15rem}.post-card-title a{color:var(--text)}.post-card-title a:hover{color:var(--accent-2)}.post-card-summary{color:var(--text-muted);font-size:.93rem;flex:1}.post-card-tags{display:flex;gap:8px;flex-wrap:wrap}.pagination-nav{margin-top:36px;display:flex;justify-content:center}.pagination-nav .pagination{display:flex;gap:6px;list-style:none}.pagination-nav .pagination .page-link{display:grid;place-items:center;min-width:38px;height:38px;padding:0 10px;border-radius:var(--radius-sm);background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-muted);font-size:.9rem}.pagination-nav .pagination .page-link:hover{color:var(--text);border-color:var(--accent-2)}.pagination-nav .pagination .active .page-link{background:var(--gradient);color:#fff;border-color:transparent}.pagination-nav .pagination .disabled .page-link{opacity:.35;pointer-events:none}.post{max-width:760px}.post-header{margin-bottom:32px}.post-header .post-title{font-size:clamp(1.8rem,4.5vw,2.6rem);margin-bottom:14px}.post-header .post-meta{display:flex;gap:10px;flex-wrap:wrap;font-family:var(--font-mono);font-size:.85rem;color:var(--text-muted);margin-bottom:14px}.post-header .post-tags{display:flex;gap:8px;flex-wrap:wrap}.post-toc{padding:18px 22px;margin-bottom:32px}.post-toc .toc-label{font-family:var(--font-mono);font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-2);margin-bottom:8px}.post-toc ul{list-style:none;padding-left:0}.post-toc ul ul{padding-left:18px}.post-toc a{color:var(--text-muted);font-size:.92rem;line-height:1.9}.post-toc a:hover{color:var(--accent-2)}.post-body{font-size:1.0625rem}.post-body>*+*{margin-top:1.1em}.post-body p{text-wrap:pretty}.post-body a{color:var(--accent-2);text-decoration:underline;text-decoration-color:color-mix(in srgb,var(--accent-2) 45%,transparent);text-underline-offset:.18em;text-decoration-thickness:1px}.post-body a:hover{color:var(--accent);text-decoration-color:currentColor}.post-body h2,.post-body h3,.post-body h4{margin-top:2em}.post-body h2{font-size:1.5rem;padding-bottom:8px;border-bottom:1px solid var(--glass-border)}.post-body h3{font-size:1.2rem}.post-body h4{font-size:1.05rem;color:var(--text-muted)}.post-body ul,.post-body ol{padding-left:1.4em}.post-body li+li{margin-top:.4em}.post-body blockquote{border-left:3px solid var(--accent);padding:8px 20px;background:var(--glass-bg);border-radius:0 var(--radius-sm)var(--radius-sm)0;color:var(--text-muted)}.post-body code{background:var(--code-bg);border:1px solid var(--glass-border);border-radius:5px;padding:.15em .4em}.post-body .highlight{position:relative}.post-body .highlight pre{background:var(--code-block-bg);border-radius:var(--radius-sm);border:1px solid var(--code-border);padding:18px;overflow-x:auto;line-height:1.6;font-size:.9rem;tab-size:4;font-variant-ligatures:none}.post-body .highlight pre code{background:0 0;border:none;padding:0;font-size:1em}.post-body>pre{background:var(--code-block-bg);border:1px solid var(--code-border);border-radius:var(--radius-sm);padding:18px;overflow-x:auto;line-height:1.6;font-size:.9rem;tab-size:4;font-variant-ligatures:none}.post-body>pre code{background:0 0;border:none;padding:0;font-size:1em}.post-body img{border-radius:var(--radius-sm);margin:0 auto}.post-body figure{text-align:center}.post-body figure figcaption{margin-top:8px;color:var(--text-muted)}.post-body table{width:100%;border-collapse:collapse;font-size:.93rem}.post-body table th,.post-body table td{padding:10px 14px;border:1px solid var(--glass-border);text-align:left}.post-body table th{background:var(--glass-bg)}.post-body hr{border:none;border-top:1px solid var(--glass-border)}.code-copy{position:absolute;top:8px;right:8px;padding:3px 10px;font-family:var(--font-mono);font-size:.72rem;border-radius:6px;border:1px solid var(--glass-border);background:var(--glass-bg);color:var(--text-muted);cursor:pointer;opacity:0;transition:opacity .2s ease;backdrop-filter:blur(8px)}.post-body .highlight:hover .code-copy{opacity:1}.post-share{display:flex;align-items:center;gap:16px;padding:14px 22px;margin-top:40px;font-size:.92rem}.post-share .share-label{color:var(--text-muted);font-family:var(--font-mono);font-size:.82rem}.post-share .copy-link{background:0 0;border:none;color:var(--accent-2);font:inherit;cursor:pointer;padding:0}.post-share .copy-link:hover{color:var(--accent)}.post-prevnext{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:24px}.post-prevnext .prevnext-card{padding:16px 20px;display:flex;flex-direction:column;gap:4px;color:var(--text)}.post-prevnext .prevnext-card.is-next{text-align:right}.post-prevnext .prevnext-card .prevnext-label{font-family:var(--font-mono);font-size:.78rem;color:var(--text-muted)}.post-prevnext .prevnext-card strong{font-size:.95rem}@media(max-width:600px){.post-prevnext{grid-template-columns:1fr}}.post-comments{margin-top:40px;padding:24px}[data-theme=light] .post-body .highlight{box-shadow:0 1px 6px rgba(31,38,65,.08);border-radius:var(--radius-sm)}[data-theme=light] .post-body code{border-color:var(--code-border)}[data-theme=dark]{}[data-theme=dark] .bg{color:#f8f8f2;background-color:#282a36}[data-theme=dark] .chroma{color:#f8f8f2;background-color:#282a36}[data-theme=dark] .chroma .lnlinks{outline:none;text-decoration:none;color:inherit}[data-theme=dark] .chroma .lntd{vertical-align:top;padding:0;margin:0;border:0}[data-theme=dark] .chroma .lntable{border-spacing:0;padding:0;margin:0;border:0}[data-theme=dark] .chroma .hl{background-color:#3d3f4a}[data-theme=dark] .chroma .lnt{white-space:pre;-webkit-user-select:none;user-select:none;margin-right:.4em;padding:0 .4em;color:#7f7f7f}[data-theme=dark] .chroma .ln{white-space:pre;-webkit-user-select:none;user-select:none;margin-right:.4em;padding:0 .4em;color:#7f7f7f}[data-theme=dark] .chroma .line{display:flex}[data-theme=dark] .chroma .k{color:#ff79c6}[data-theme=dark] .chroma .kc{color:#ff79c6}[data-theme=dark] .chroma .kd{color:#8be9fd;font-style:italic}[data-theme=dark] .chroma .kn{color:#ff79c6}[data-theme=dark] .chroma .kp{color:#ff79c6}[data-theme=dark] .chroma .kr{color:#ff79c6}[data-theme=dark] .chroma .kt{color:#8be9fd}[data-theme=dark] .chroma .na{color:#50fa7b}[data-theme=dark] .chroma .nb{color:#8be9fd;font-style:italic}[data-theme=dark] .chroma .nc{color:#50fa7b}[data-theme=dark] .chroma .nf{color:#50fa7b}[data-theme=dark] .chroma .nl{color:#8be9fd;font-style:italic}[data-theme=dark] .chroma .nt{color:#ff79c6}[data-theme=dark] .chroma .nv{color:#8be9fd;font-style:italic}[data-theme=dark] .chroma .vc{color:#8be9fd;font-style:italic}[data-theme=dark] .chroma .vg{color:#8be9fd;font-style:italic}[data-theme=dark] .chroma .vi{color:#8be9fd;font-style:italic}[data-theme=dark] .chroma .s{color:#f1fa8c}[data-theme=dark] .chroma .sa{color:#f1fa8c}[data-theme=dark] .chroma .sb{color:#f1fa8c}[data-theme=dark] .chroma .sc{color:#f1fa8c}[data-theme=dark] .chroma .dl{color:#f1fa8c}[data-theme=dark] .chroma .sd{color:#f1fa8c}[data-theme=dark] .chroma .s2{color:#f1fa8c}[data-theme=dark] .chroma .se{color:#f1fa8c}[data-theme=dark] .chroma .sh{color:#f1fa8c}[data-theme=dark] .chroma .si{color:#f1fa8c}[data-theme=dark] .chroma .sx{color:#f1fa8c}[data-theme=dark] .chroma .sr{color:#f1fa8c}[data-theme=dark] .chroma .s1{color:#f1fa8c}[data-theme=dark] .chroma .ss{color:#f1fa8c}[data-theme=dark] .chroma .m{color:#bd93f9}[data-theme=dark] .chroma .mb{color:#bd93f9}[data-theme=dark] .chroma .mf{color:#bd93f9}[data-theme=dark] .chroma .mh{color:#bd93f9}[data-theme=dark] .chroma .mi{color:#bd93f9}[data-theme=dark] .chroma .il{color:#bd93f9}[data-theme=dark] .chroma .mo{color:#bd93f9}[data-theme=dark] .chroma .o{color:#ff79c6}[data-theme=dark] .chroma .ow{color:#ff79c6}[data-theme=dark] .chroma .c{color:#6272a4}[data-theme=dark] .chroma .ch{color:#6272a4}[data-theme=dark] .chroma .cm{color:#6272a4}[data-theme=dark] .chroma .c1{color:#6272a4}[data-theme=dark] .chroma .cs{color:#6272a4}[data-theme=dark] .chroma .cp{color:#ff79c6}[data-theme=dark] .chroma .cpf{color:#ff79c6}[data-theme=dark] .chroma .gd{color:#f55}[data-theme=dark] .chroma .ge{text-decoration:underline}[data-theme=dark] .chroma .gh{font-weight:700}[data-theme=dark] .chroma .gi{color:#50fa7b;font-weight:700}[data-theme=dark] .chroma .go{color:#44475a}[data-theme=dark] .chroma .gu{font-weight:700}[data-theme=dark] .chroma .gl{text-decoration:underline}[data-theme=light]{}[data-theme=light] .bg{background-color:#fff}[data-theme=light] .chroma{background-color:#fff}[data-theme=light] .chroma .err{color:#a61717;background-color:#e3d2d2}[data-theme=light] .chroma .lnlinks{outline:none;text-decoration:none;color:inherit}[data-theme=light] .chroma .lntd{vertical-align:top;padding:0;margin:0;border:0}[data-theme=light] .chroma .lntable{border-spacing:0;padding:0;margin:0;border:0}[data-theme=light] .chroma .hl{background-color:#e5e5e5}[data-theme=light] .chroma .lnt{white-space:pre;-webkit-user-select:none;user-select:none;margin-right:.4em;padding:0 .4em;color:#7f7f7f}[data-theme=light] .chroma .ln{white-space:pre;-webkit-user-select:none;user-select:none;margin-right:.4em;padding:0 .4em;color:#7f7f7f}[data-theme=light] .chroma .line{display:flex}[data-theme=light] .chroma .k{color:#000;font-weight:700}[data-theme=light] .chroma .kc{color:#000;font-weight:700}[data-theme=light] .chroma .kd{color:#000;font-weight:700}[data-theme=light] .chroma .kn{color:#000;font-weight:700}[data-theme=light] .chroma .kp{color:#000;font-weight:700}[data-theme=light] .chroma .kr{color:#000;font-weight:700}[data-theme=light] .chroma .kt{color:#458;font-weight:700}[data-theme=light] .chroma .na{color:teal}[data-theme=light] .chroma .nb{color:#0086b3}[data-theme=light] .chroma .bp{color:#999}[data-theme=light] .chroma .nc{color:#458;font-weight:700}[data-theme=light] .chroma .no{color:teal}[data-theme=light] .chroma .nd{color:#3c5d5d;font-weight:700}[data-theme=light] .chroma .ni{color:purple}[data-theme=light] .chroma .ne{color:#900;font-weight:700}[data-theme=light] .chroma .nf{color:#900;font-weight:700}[data-theme=light] .chroma .nl{color:#900;font-weight:700}[data-theme=light] .chroma .nn{color:#555}[data-theme=light] .chroma .nt{color:navy}[data-theme=light] .chroma .nv{color:teal}[data-theme=light] .chroma .vc{color:teal}[data-theme=light] .chroma .vg{color:teal}[data-theme=light] .chroma .vi{color:teal}[data-theme=light] .chroma .s{color:#d14}[data-theme=light] .chroma .sa{color:#d14}[data-theme=light] .chroma .sb{color:#d14}[data-theme=light] .chroma .sc{color:#d14}[data-theme=light] .chroma .dl{color:#d14}[data-theme=light] .chroma .sd{color:#d14}[data-theme=light] .chroma .s2{color:#d14}[data-theme=light] .chroma .se{color:#d14}[data-theme=light] .chroma .sh{color:#d14}[data-theme=light] .chroma .si{color:#d14}[data-theme=light] .chroma .sx{color:#d14}[data-theme=light] .chroma .sr{color:#009926}[data-theme=light] .chroma .s1{color:#d14}[data-theme=light] .chroma .ss{color:#990073}[data-theme=light] .chroma .m{color:#099}[data-theme=light] .chroma .mb{color:#099}[data-theme=light] .chroma .mf{color:#099}[data-theme=light] .chroma .mh{color:#099}[data-theme=light] .chroma .mi{color:#099}[data-theme=light] .chroma .il{color:#099}[data-theme=light] .chroma .mo{color:#099}[data-theme=light] .chroma .o{color:#000;font-weight:700}[data-theme=light] .chroma .ow{color:#000;font-weight:700}[data-theme=light] .chroma .c{color:#998;font-style:italic}[data-theme=light] .chroma .ch{color:#998;font-style:italic}[data-theme=light] .chroma .cm{color:#998;font-style:italic}[data-theme=light] .chroma .c1{color:#998;font-style:italic}[data-theme=light] .chroma .cs{color:#999;font-weight:700;font-style:italic}[data-theme=light] .chroma .cp{color:#999;font-weight:700;font-style:italic}[data-theme=light] .chroma .cpf{color:#999;font-weight:700;font-style:italic}[data-theme=light] .chroma .gd{color:#000;background-color:#fdd}[data-theme=light] .chroma .ge{color:#000;font-style:italic}[data-theme=light] .chroma .gr{color:#a00}[data-theme=light] .chroma .gh{color:#999}[data-theme=light] .chroma .gi{color:#000;background-color:#dfd}[data-theme=light] .chroma .go{color:#888}[data-theme=light] .chroma .gp{color:#555}[data-theme=light] .chroma .gs{font-weight:700}[data-theme=light] .chroma .gu{color:#aaa}[data-theme=light] .chroma .gt{color:#a00}[data-theme=light] .chroma .gl{text-decoration:underline}[data-theme=light] .chroma .w{color:#bbb}.tag-cloud{display:flex;flex-wrap:wrap;gap:12px;padding:28px}.tag-cloud .chip-count{font-family:var(--font-mono);font-size:.75em;opacity:.7}.archive-year{margin-bottom:36px}.archive-year .archive-year-label{font-size:1.7rem;margin-bottom:14px}.archive-list{list-style:none;padding:10px 24px}.archive-list li{display:flex;align-items:baseline;gap:18px;padding:10px 0}.archive-list li+li{border-top:1px solid var(--glass-border)}.archive-list time{font-family:var(--font-mono);font-size:.82rem;color:var(--text-muted);flex-shrink:0;width:52px}.archive-list a{color:var(--text)}.archive-list a:hover{color:var(--accent-2)}.page-single{max-width:760px}.page-body{padding:32px 36px}@media(max-width:600px){.page-body{padding:22px 20px}}.error-page{display:grid;place-items:center;padding:60px 0}.error-card{text-align:center;padding:56px 48px;display:flex;flex-direction:column;align-items:center;gap:16px;max-width:460px}.error-card .error-code{font-family:var(--font-display);font-size:5.5rem;font-weight:700;line-height:1}.error-card .error-hint{color:var(--text-muted)}.portfolio-section{margin-bottom:48px}.portfolio-section:last-of-type{margin-bottom:0}.portfolio-section-title{font-size:1.35rem;margin-bottom:20px;padding-bottom:8px;border-bottom:1px solid var(--glass-border)}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:22px}@media(max-width:420px){.portfolio-grid{grid-template-columns:1fr}}.portfolio-section.is-archived .project-card{opacity:.7;transition:opacity .25s ease,transform .25s ease,background .25s ease,border-color .25s ease,box-shadow .25s ease}.portfolio-section.is-archived .project-card:hover{opacity:1}.project-card{padding:22px;display:flex;flex-direction:column;gap:12px}.project-card .project-link{display:flex;flex-direction:column;gap:12px}.project-card .project-image{border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:16/9}.project-card .project-image img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .4s ease}.project-card:hover .project-image img{transform:scale(1.06)}.project-card .project-title{font-size:1.25rem;color:var(--text)}.project-card:hover .project-title{background:var(--gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.project-card .project-description{color:var(--text-muted);font-size:.93rem;flex:1}.project-card .project-tags{display:flex;flex-wrap:wrap;gap:8px}.portfolio-contact{margin-top:36px;padding:20px 26px;color:var(--text-muted)}.file-tree{font-family:var(--font-mono);font-size:.88rem;background:var(--code-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:16px 20px}.file-tree ul{list-style:none;padding-left:18px}.file-tree>ul{padding-left:0}.file-tree li::before{content:"— ";color:var(--text-muted)}.ticks ul{list-style:none;padding-left:0}.ticks li::before{content:"✓ ";color:var(--accent-2);font-weight:700}.code-annotated{background:var(--code-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:18px;overflow-x:auto;font-size:.9rem;line-height:1.6}.code-annotated .highlight{background:var(--mark-bg);border-radius:3px;padding:.1em .25em}.article-image{border-radius:var(--radius-sm);margin:0 auto}.article-figure{text-align:center}.article-figure figcaption{margin-top:8px;color:var(--text-muted)}