@font-face{font-family:Sora;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/c5f10e9e72d35c52-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Sora;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/3dc379dc9b5dec12-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Sora;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/c5f10e9e72d35c52-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Sora;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/3dc379dc9b5dec12-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Sora;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/c5f10e9e72d35c52-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Sora;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/3dc379dc9b5dec12-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Sora;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/c5f10e9e72d35c52-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Sora;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/3dc379dc9b5dec12-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Sora Fallback;src:local("Arial");ascent-override:85.29%;descent-override:25.50%;line-gap-override:0.00%;size-adjust:113.73%}.__className_35e689{font-family:Sora,Sora Fallback;font-style:normal}.__variable_35e689{--font-display-next:"Sora","Sora Fallback"}@font-face{font-family:Geist;font-style:normal;font-weight:300;font-display:swap;src:url(/_next/static/media/f639721981034f88-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Geist;font-style:normal;font-weight:300;font-display:swap;src:url(/_next/static/media/9766a7e9e2e0ad5a-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Geist;font-style:normal;font-weight:300;font-display:swap;src:url(/_next/static/media/b66cf8e69499582a-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Geist;font-style:normal;font-weight:300;font-display:swap;src:url(/_next/static/media/aa016aab0e6d1295-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Geist;font-style:normal;font-weight:300;font-display:swap;src:url(/_next/static/media/22a5144ee8d83bca-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Geist;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/f639721981034f88-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Geist;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/9766a7e9e2e0ad5a-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Geist;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/b66cf8e69499582a-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Geist;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/aa016aab0e6d1295-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Geist;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/22a5144ee8d83bca-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Geist;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/f639721981034f88-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Geist;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/9766a7e9e2e0ad5a-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Geist;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/b66cf8e69499582a-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Geist;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/aa016aab0e6d1295-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Geist;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/22a5144ee8d83bca-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Geist;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/f639721981034f88-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Geist;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/9766a7e9e2e0ad5a-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Geist;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/b66cf8e69499582a-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Geist;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/aa016aab0e6d1295-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Geist;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/22a5144ee8d83bca-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Geist Fallback;src:local("Arial");ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.00%;size-adjust:104.76%}.__className_34dee6{font-family:Geist,Geist Fallback;font-style:normal}.__variable_34dee6{--font-body-next:"Geist","Geist Fallback"}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/edc640959b0c7826-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/ac0e76ddaeeb7981-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/64d784ea54a4acde-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/ff71da380fbe67dd-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/6d831b18ae5b01dc-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/558ca1a6aa3cb55e-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/edc640959b0c7826-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/ac0e76ddaeeb7981-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/64d784ea54a4acde-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/ff71da380fbe67dd-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/6d831b18ae5b01dc-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/558ca1a6aa3cb55e-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:JetBrains Mono Fallback;src:local("Arial");ascent-override:75.79%;descent-override:22.29%;line-gap-override:0.00%;size-adjust:134.59%}.__className_6d24ac{font-family:JetBrains Mono,JetBrains Mono Fallback;font-style:normal}.__variable_6d24ac{--font-mono-next:"JetBrains Mono","JetBrains Mono Fallback"}:root{--font-display:var(--font-display-next,"Sora",ui-sans-serif,system-ui,sans-serif);--font-body:var(--font-body-next,"Geist",ui-sans-serif,system-ui,sans-serif);--font-mono:var(--font-mono-next,"JetBrains Mono",ui-monospace,monospace);--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--radius-xl:26px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;--space-7:48px;--space-8:64px;--space-9:96px;--container:1240px;--accent-cyan:#22d3ee;--accent-blue:#6aa1ff;--accent-violet:#a78bfa;--accent-green:#4ade80}:root,[data-theme=dark]{--bg:#06080f;--bg-grad-a:#070b18;--bg-grad-b:#0a0f1e;--bg-grad-c:#06080f;--surface:rgba(255,255,255,0.03);--surface-strong:rgba(255,255,255,0.05);--surface-hover:rgba(255,255,255,0.06);--surface-solid:#0d1322;--border:rgba(255,255,255,0.08);--border-strong:rgba(255,255,255,0.14);--text:#e8ecf5;--text-strong:#ffffff;--text-muted:#8a93a8;--text-faint:#5a6378;--chip-bg:rgba(255,255,255,0.04);--chip-border:rgba(255,255,255,0.08);--shadow-card:0 1px 0 rgba(255,255,255,0.04) inset,0 20px 50px -20px rgba(0,0,0,0.7);--shadow-soft:0 10px 30px -15px rgba(0,0,0,0.7);--grid-line:rgba(255,255,255,0.035);--glow-cyan:rgba(34,211,238,0.18);--glow-violet:rgba(167,139,250,0.18);--glow-blue:rgba(106,161,255,0.16);--code-bg:rgba(255,255,255,0.03)}[data-theme=light]{--bg:#f6f7fb;--bg-grad-a:#eef1f8;--bg-grad-b:#f7f8fc;--bg-grad-c:#eef1f8;--surface:rgba(255,255,255,0.7);--surface-strong:rgba(255,255,255,0.85);--surface-hover:rgba(255,255,255,0.95);--surface-solid:#ffffff;--border:rgba(15,23,42,0.08);--border-strong:rgba(15,23,42,0.16);--text:#15192b;--text-strong:#05070f;--text-muted:#5a6378;--text-faint:#8993a8;--chip-bg:rgba(15,23,42,0.04);--chip-border:rgba(15,23,42,0.08);--shadow-card:0 1px 0 rgba(255,255,255,0.6) inset,0 24px 40px -28px rgba(15,23,42,0.25);--shadow-soft:0 10px 30px -18px rgba(15,23,42,0.2);--grid-line:rgba(15,23,42,0.05);--glow-cyan:rgba(34,211,238,0.22);--glow-violet:rgba(124,92,250,0.18);--glow-blue:rgba(59,130,246,0.18);--accent-blue:#2563eb;--accent-violet:#7c3aed;--accent-cyan:#0891b2;--accent-green:#059669;--code-bg:rgba(15,23,42,0.04)}*,:after,:before{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font-body);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"ss01","cv01";font-size:15.5px;line-height:1.6;min-height:100vh;overflow-x:hidden}.bg-layer{background:radial-gradient(1100px 600px at 8% -8%,var(--glow-violet),transparent 60%),radial-gradient(900px 500px at 92% 4%,var(--glow-blue),transparent 60%),radial-gradient(900px 600px at 50% 110%,var(--glow-cyan),transparent 60%),linear-gradient(180deg,var(--bg-grad-a),var(--bg-grad-b) 50%,var(--bg-grad-c))}.bg-grid,.bg-layer{position:fixed;inset:0;z-index:-1;pointer-events:none}.bg-grid{background-image:linear-gradient(to right,var(--grid-line) 1px,transparent 1px),linear-gradient(to bottom,var(--grid-line) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(ellipse at center,#000 30%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse at center,#000 30%,transparent 75%)}.glow{position:fixed;z-index:-1;border-radius:50%;filter:blur(80px);opacity:.55;pointer-events:none;animation:float 18s ease-in-out infinite}.glow.a{width:420px;height:420px;background:var(--glow-violet);top:12%;left:-120px}.glow.b{width:360px;height:360px;background:var(--glow-cyan);top:40%;right:-120px;animation-delay:-6s}.glow.c{width:320px;height:320px;background:var(--glow-blue);bottom:-120px;left:30%;animation-delay:-12s}@keyframes float{0%,to{transform:translate(0) scale(1)}50%{transform:translate(30px,-20px) scale(1.06)}}h1,h2,h3,h4{font-family:var(--font-display);color:var(--text-strong);margin:0;letter-spacing:-.02em;font-weight:600;line-height:1.12;text-wrap:balance}h1{font-size:clamp(2.4rem,5.2vw,4rem)}h2{font-size:clamp(1.8rem,3.6vw,2.6rem)}h3{font-size:clamp(1.2rem,2vw,1.4rem)}p{margin:0;text-wrap:pretty}a{color:inherit;text-decoration:none}.mono{font-family:var(--font-mono);font-feature-settings:"ss02"}.eyebrow{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted)}.eyebrow:before{content:"";width:18px;height:1px;background:linear-gradient(90deg,var(--accent-cyan),transparent)}.gradient-text{background:linear-gradient(120deg,var(--text-strong) 0,var(--accent-blue) 45%,var(--accent-violet) 75%,var(--accent-cyan) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.container{width:100%;max-width:var(--container);padding:0 var(--space-5);margin:0 auto}section{padding:var(--space-9) 0;position:relative}.section-head{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-7);max-width:720px}.section-head p{color:var(--text-muted);font-size:1.02rem}.nav{position:-webkit-sticky;position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:color-mix(in oklab,var(--bg) 70%,transparent);border-bottom:1px solid transparent;transition:border-color .25s,background .25s}.nav.scrolled{border-bottom-color:var(--border);background:color-mix(in oklab,var(--bg) 85%,transparent)}.nav-inner{justify-content:space-between;height:68px}.brand,.nav-inner{display:flex;align-items:center}.brand{gap:var(--space-3);font-family:var(--font-display);font-weight:600;color:var(--text-strong);letter-spacing:-.01em}.brand-mark{width:30px;height:30px;display:grid;place-items:center;border-radius:9px;background:linear-gradient(140deg,var(--accent-violet),var(--accent-blue) 60%,var(--accent-cyan));box-shadow:0 8px 24px -10px var(--accent-blue)}.brand-mark svg{width:16px;height:16px;color:#06080f}.brand-meta{display:flex;flex-direction:column;line-height:1.1}.brand-meta small{font-family:var(--font-mono);font-size:10px;color:var(--text-muted);letter-spacing:.14em;text-transform:uppercase}.nav-links{display:flex;gap:var(--space-2);align-items:center}.nav-links a{font-size:14px;color:var(--text-muted);padding:8px 12px;border-radius:8px;transition:color .2s,background .2s}.nav-links a:hover{color:var(--text-strong);background:var(--surface)}.nav-cta{display:flex;align-items:center;gap:var(--space-3)}.theme-toggle{width:38px;height:38px;display:grid;place-items:center;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:background .2s,transform .2s,border-color .2s}.theme-toggle:hover{background:var(--surface-hover);border-color:var(--border-strong)}.theme-toggle svg{width:16px;height:16px}.theme-toggle .icon-sun,[data-theme=light] .theme-toggle .icon-moon{display:none}[data-theme=light] .theme-toggle .icon-sun{display:block}.menu-btn{display:none;width:38px;height:38px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;place-items:center}.menu-btn svg{width:18px;height:18px}.btn{display:inline-flex;align-items:center;gap:var(--space-2);height:42px;padding:0 18px;border-radius:10px;font-family:var(--font-body);font-weight:500;font-size:14px;border:1px solid transparent;cursor:pointer;transition:transform .18s ease,background .18s ease,border-color .18s,box-shadow .25s;white-space:nowrap}.btn svg{width:15px;height:15px}.btn:hover{transform:translateY(-1px)}.btn-primary{color:#04060c;background:linear-gradient(135deg,#d4ecff,#ffffff);box-shadow:0 0 0 1px rgba(255,255,255,.2),0 10px 30px -10px rgba(106,161,255,.55)}[data-theme=light] .btn-primary{color:#ffffff;background:linear-gradient(135deg,var(--accent-blue),var(--accent-violet));box-shadow:0 10px 28px -10px rgba(37,99,235,.5)}.btn-primary:hover{box-shadow:0 0 0 1px rgba(255,255,255,.3),0 14px 36px -10px rgba(106,161,255,.7)}.btn-ghost{color:var(--text-strong);background:var(--surface);border-color:var(--border)}.btn-ghost:hover{background:var(--surface-hover);border-color:var(--border-strong)}.btn-outline{color:var(--text);background:transparent;border-color:var(--border)}.btn-outline:hover{background:var(--surface);color:var(--text-strong);border-color:var(--border-strong)}.btn-sm{height:36px;padding:0 14px;font-size:13px}.btn-disabled{opacity:.48;cursor:not-allowed;pointer-events:none}.hero{padding-top:var(--space-7);padding-bottom:var(--space-7)}.hero-grid{display:grid;grid-template-columns:minmax(0,1.18fr) minmax(420px,.92fr);grid-gap:var(--space-7);gap:var(--space-7);align-items:center}.hero-badge{display:inline-flex;align-items:center;gap:10px;padding:6px 12px 6px 8px;border:1px solid var(--border);border-radius:999px;background:var(--surface);font-family:var(--font-mono);font-size:12px;color:var(--text-muted);margin-bottom:var(--space-4)}.hero-badge .dot{width:8px;height:8px;border-radius:50%;background:var(--accent-green);box-shadow:0 0 0 4px color-mix(in oklab,var(--accent-green) 25%,transparent);animation:pulse 2.4s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.hero h1{margin-bottom:var(--space-3);font-size:clamp(2.5rem,3.8vw,4.35rem);line-height:1.08}.hero-sub{font-size:1.08rem;color:var(--text-muted);max-width:620px}.hero-meta,.hero-sub{margin-bottom:var(--space-4)}.hero-meta{display:flex;flex-wrap:wrap;gap:var(--space-2)}.hero-meta span{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.04em;padding:6px 10px;border-radius:8px;background:var(--chip-bg);border:1px solid var(--chip-border);color:var(--text-muted)}.hero-meta span b{color:var(--text-strong);font-weight:500}.hero-cta{display:flex;flex-wrap:wrap;gap:var(--space-3)}.diagram-card{position:relative;border-radius:var(--radius-xl);background:var(--surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);box-shadow:var(--shadow-card);overflow:hidden}.diagram-card:before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;background:radial-gradient(600px 200px at 20% -10%,var(--glow-violet),transparent 60%),radial-gradient(500px 300px at 100% 100%,var(--glow-cyan),transparent 60%);opacity:.6}.diagram-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);position:relative}.diagram-head .title{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-muted)}.diagram-head .title b{color:var(--text-strong);font-weight:500}.diagram-head .dots{display:flex;gap:6px}.diagram-head .dots i{width:9px;height:9px;border-radius:50%;background:var(--surface-strong);border:1px solid var(--border)}.diagram-body{padding:26px 20px 22px;position:relative}.diagram-body svg{width:100%;height:auto;display:block}.screenshot-carousel{position:relative;border-radius:var(--radius-xl);background:var(--surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);box-shadow:var(--shadow-card);overflow:hidden}.screenshot-carousel:before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;background:radial-gradient(600px 200px at 20% -10%,var(--glow-violet),transparent 60%),radial-gradient(500px 300px at 100% 100%,var(--glow-cyan),transparent 60%);opacity:.62}.carousel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);position:relative}.carousel-head .title{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-muted)}.carousel-head .title b{color:var(--text-strong);font-weight:500}.carousel-head .dots{display:flex;gap:6px}.carousel-head .dots i{width:9px;height:9px;border-radius:50%;background:var(--surface-strong);border:1px solid var(--border)}.carousel-viewport{position:relative;overflow:hidden;padding:18px}.carousel-track{display:flex;width:200%;animation:screenshot-carousel 10s ease-in-out infinite}.carousel-slide{width:calc(100% / 2);margin:0;padding:0;position:relative;aspect-ratio:16/10;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);background:var(--surface-solid);box-shadow:0 28px 70px -38px rgba(0,0,0,.85)}.carousel-slide img{width:100%;height:100%;display:block;object-fit:cover}.carousel-slide figcaption{position:absolute;left:14px;right:14px;bottom:14px;display:flex;align-items:flex-end;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:color-mix(in oklab,var(--surface-solid) 82%,transparent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.carousel-slide figcaption span{font-family:var(--font-display);font-size:.98rem;color:var(--text-strong);font-weight:600}.carousel-slide figcaption small{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);text-align:right}.carousel-progress{display:flex;gap:8px;margin-top:14px;position:relative}.carousel-progress span{flex:1 1;height:3px;border-radius:999px;background:var(--chip-bg);border:1px solid var(--chip-border);overflow:hidden;position:relative}.carousel-progress span:before{content:"";position:absolute;inset:0;transform:scaleX(0);transform-origin:left;background:linear-gradient(90deg,var(--accent-violet),var(--accent-blue),var(--accent-cyan));animation:screenshot-progress 10s linear infinite;animation-delay:inherit}@keyframes screenshot-carousel{0%,44%{transform:translateX(0)}50%,94%{transform:translateX(-50%)}to{transform:translateX(0)}}@keyframes screenshot-progress{0%,49.99%,to{transform:scaleX(0);opacity:0}4%,46%{transform:scaleX(1);opacity:1}}@media (prefers-reduced-motion:reduce){.carousel-progress span:before,.carousel-track{animation:none}}.card{position:relative;border-radius:var(--radius-lg);background:var(--surface);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);padding:var(--space-5);box-shadow:var(--shadow-card);transition:transform .28s ease,border-color .28s ease,box-shadow .28s ease,background .28s}.card:hover{transform:translateY(-3px);border-color:var(--border-strong);background:var(--surface-hover)}.card-icon{width:38px;height:38px;display:grid;place-items:center;border-radius:10px;background:var(--chip-bg);border:1px solid var(--chip-border);color:var(--accent-cyan);margin-bottom:var(--space-4)}.card-icon svg{width:18px;height:18px}.card h3{margin-bottom:8px;font-size:1.1rem}.card p{color:var(--text-muted);font-size:.96rem}.about-grid{display:grid;grid-template-columns:1.05fr 1.2fr;grid-gap:var(--space-7);gap:var(--space-7);align-items:start}.about-head{max-width:980px}.about-grid-text-only{display:block;max-width:100%}.about-copy{max-width:100%}.about-copy p{color:var(--text);font-size:1.05rem;line-height:1.8}.text-accent{color:var(--accent-cyan);font-weight:500}.about-grid .about-cards{display:grid;grid-template-columns:1fr;grid-gap:var(--space-4);gap:var(--space-4)}.project-list{grid-template-columns:1fr;grid-gap:var(--space-6)}.project,.project-list{display:grid;gap:var(--space-6)}.project{grid-template-columns:1.05fr 1fr;grid-gap:var(--space-6);padding:var(--space-6);border-radius:var(--radius-xl);background:var(--surface);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);box-shadow:var(--shadow-card);overflow:hidden;position:relative;align-items:stretch;transition:border-color .3s,transform .3s}.project:after{content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;background:linear-gradient(135deg,transparent 30%,color-mix(in oklab,var(--accent-blue) 35%,transparent) 60%,transparent 90%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .4s;pointer-events:none}.project:hover{border-color:var(--border-strong);transform:translateY(-2px)}.project:hover:after{opacity:1}.project.alt{grid-template-columns:1fr 1.05fr}.project.alt .project-visual{order:-1}.project-carousel{align-items:stretch}.project-carousel .lead{margin-bottom:var(--space-3)}.project-carousel .tech-row{margin-bottom:var(--space-4)}.project-carousel .project-visual,.project-carousel-copy{animation:project-slide-in .35s ease both}.project-carousel-copy{display:flex;flex-direction:column}.project-carousel-top{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-3)}.project-tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);padding:5px 10px;border-radius:999px;background:var(--chip-bg);border:1px solid var(--chip-border);margin-bottom:var(--space-3)}.project-carousel-top .project-tag{margin-bottom:0}.project-tag.tone-violet{color:var(--accent-violet);border-color:color-mix(in oklab,var(--accent-violet) 30%,var(--chip-border))}.project h3{font-size:1.55rem;margin-bottom:var(--space-3)}.project .lead{color:var(--text-muted);margin-bottom:var(--space-4);font-size:.98rem}.carousel-controls{display:inline-flex;gap:6px;padding:4px;border-radius:999px;background:var(--chip-bg);border:1px solid var(--chip-border)}.carousel-controls button{width:28px;height:28px;display:grid;place-items:center;border:1px solid transparent;border-radius:999px;background:transparent;color:var(--text-muted);cursor:pointer;transition:background .2s,border-color .2s,color .2s}.carousel-controls button span{font-family:var(--font-mono);font-size:11px}.carousel-controls button.active,.carousel-controls button:hover{color:var(--text-strong);background:var(--surface-hover);border-color:var(--border-strong)}.bullets{display:grid;grid-template-columns:1fr 1fr;grid-gap:6px 16px;gap:6px 16px;margin:0 0 var(--space-4);padding:0;list-style:none}.bullets li{font-size:.86rem;color:var(--text-muted);padding-left:16px;position:relative;line-height:1.55}.bullets li:before{content:"";position:absolute;left:0;top:9px;width:6px;height:6px;border-radius:2px;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue))}.tech-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:var(--space-5)}.pill{font-family:var(--font-mono);font-size:11px;padding:5px 10px;border-radius:999px;background:var(--chip-bg);border:1px solid var(--chip-border);color:var(--text)}.pill.accent-cyan{color:var(--accent-cyan);border-color:color-mix(in oklab,var(--accent-cyan) 35%,transparent)}.pill.accent-violet{color:var(--accent-violet);border-color:color-mix(in oklab,var(--accent-violet) 35%,transparent)}.pill.accent-blue{color:var(--accent-blue);border-color:color-mix(in oklab,var(--accent-blue) 35%,transparent)}.pill.accent-green{color:var(--accent-green);border-color:color-mix(in oklab,var(--accent-green) 35%,transparent)}.project-proof{border-left:1px solid var(--border);padding:8px 0 8px 16px;margin-bottom:var(--space-5)}.project-proof small{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-faint)}.project-proof p{font-size:.96rem;color:var(--text);margin-top:4px}.project-cta{display:flex;flex-wrap:wrap;gap:10px}.projects-more{display:flex;flex-direction:column;align-items:center;justify-content:center;margin-top:var(--space-3)}.projects-more .carousel-controls{box-shadow:var(--shadow-soft)}@keyframes project-slide-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.project-visual{position:relative;border-radius:var(--radius-lg);background:color-mix(in oklab,var(--surface-solid) 70%,transparent);border:1px solid var(--border);padding:20px;min-height:320px;display:flex;flex-direction:column;gap:12px;overflow:hidden}.project-visual:before{content:"";position:absolute;inset:0;background:radial-gradient(400px 200px at 100% 0,var(--glow-violet),transparent 65%),radial-gradient(400px 200px at 0 100%,var(--glow-cyan),transparent 65%);opacity:.55;pointer-events:none}.project-visual .visual-head{display:flex;justify-content:space-between;align-items:center;position:relative}.project-visual .visual-head .tag{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-faint)}.project-visual .visual-head .live{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11px;color:var(--accent-green)}.project-visual .visual-head .live i{width:6px;height:6px;border-radius:50%;background:var(--accent-green);box-shadow:0 0 0 4px color-mix(in oklab,var(--accent-green) 25%,transparent)}.project-visual svg{width:100%;flex:1 1;position:relative}.project-shot-card{min-height:360px;justify-content:stretch}.project-shot-frame{position:relative;flex:0 0 auto;width:100%;aspect-ratio:16/10;border-radius:14px;border:1px solid var(--border);overflow:hidden;box-shadow:0 24px 60px -36px rgba(0,0,0,.85);background:var(--surface-solid)}.project-shot{width:100%;height:100%;object-fit:cover;object-position:top center;position:relative}.projects-page{min-height:100vh;position:relative}.projects-archive-hero{padding-top:var(--space-8);padding-bottom:var(--space-5)}.projects-archive-hero .section-head{max-width:900px}.projects-archive-hero h1{max-width:980px}.projects-archive-list{padding-top:0}.projects-archive-list .project{min-height:680px}.cs-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-5);gap:var(--space-5)}.cs-card{padding:var(--space-6);border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:var(--space-4);transition:border-color .3s,transform .3s;position:relative;overflow:hidden}.cs-card:hover{border-color:var(--border-strong);transform:translateY(-2px)}.cs-card:before{content:"";position:absolute;top:-50%;right:-30%;width:60%;height:200%;background:radial-gradient(closest-side,var(--glow-blue),transparent);opacity:.5;pointer-events:none}.cs-card.violet:before{background:radial-gradient(closest-side,var(--glow-violet),transparent)}.cs-card .cs-head{display:flex;align-items:center;justify-content:space-between}.cs-card .cs-title{display:flex;align-items:center;gap:12px}.cs-mark{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent-blue),var(--accent-cyan))}.cs-card.violet .cs-mark{background:linear-gradient(135deg,var(--accent-violet),var(--accent-blue))}.cs-mark svg{width:18px;height:18px;color:#06080f}.cs-card h3{font-size:1.25rem}.cs-card .cs-item{display:grid;grid-template-columns:110px 1fr;grid-gap:var(--space-3);gap:var(--space-3);padding:var(--space-3) 0;border-top:1px solid var(--border);font-size:.92rem}.cs-card .cs-item small{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-faint);padding-top:2px}.cs-card .cs-item p{color:var(--text)}.stack-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:var(--space-5);gap:var(--space-5)}.stack-card{padding:var(--space-5);border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--border);position:relative;overflow:hidden}.stack-card h4{font-family:var(--font-display);font-size:.92rem;letter-spacing:.06em;color:var(--text-strong);margin-bottom:var(--space-3);display:flex;align-items:center;gap:10px}.stack-card h4 .ico{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;background:var(--chip-bg);border:1px solid var(--chip-border);color:var(--accent-cyan)}.stack-card h4 .ico svg{width:14px;height:14px}.stack-card ul{margin:0;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:6px}.stack-card li{font-family:var(--font-mono);font-size:11.5px;padding:5px 9px;border-radius:6px;background:var(--chip-bg);border:1px solid var(--chip-border);color:var(--text-muted)}.experience-section{padding-top:var(--space-8)}.experience-section .section-head{max-width:1120px;margin-bottom:var(--space-6)}.experience-section .section-head h2{max-width:1080px}.experience-section .section-head p{max-width:920px}.timeline{position:relative;display:grid;grid-gap:var(--space-4);gap:var(--space-4)}.timeline:before{content:"";position:absolute;top:12px;bottom:12px;left:180px;width:1px;background:linear-gradient(180deg,transparent,var(--border-strong) 12%,var(--border-strong) 88%,transparent)}.tl-item{display:grid;grid-template-columns:180px minmax(0,1fr);grid-gap:var(--space-5);gap:var(--space-5);align-items:start;position:relative;padding:var(--space-5) 0;border-top:1px dashed var(--border)}.tl-item:first-child{border-top:0;padding-top:var(--space-3)}.tl-meta{position:relative;padding-right:var(--space-4)}.tl-meta .date{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--text)}.tl-meta .place{display:block;margin-top:6px;font-family:var(--font-mono);font-size:11px;color:var(--text-faint)}.tl-dot{position:absolute;top:6px;right:-7px;width:14px;height:14px;border-radius:50%;background:var(--surface-solid);border:1px solid var(--border-strong);display:grid;place-items:center;z-index:1}.tl-dot:after{content:"";width:6px;height:6px;border-radius:50%;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));box-shadow:0 0 0 3px color-mix(in oklab,var(--accent-cyan) 22%,transparent)}.tl-item.current .tl-dot:after{background:var(--accent-green);box-shadow:0 0 0 3px color-mix(in oklab,var(--accent-green) 30%,transparent)}.tl-body{padding-left:var(--space-5)}.tl-role{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin-bottom:6px}.tl-role h3{font-size:1.15rem;font-family:var(--font-display);color:var(--text-strong)}.tl-role .at{display:inline-flex;align-items:center;gap:7px;flex-wrap:wrap;color:var(--text-muted);font-size:.95rem}.tl-role .at b{color:var(--text);font-weight:500}.company-links{display:inline-flex;align-items:center;gap:5px;min-width:53px}.company-links.placeholder{visibility:hidden}.company-links a{width:24px;height:24px;display:inline-grid;place-items:center;border-radius:999px;background:var(--chip-bg);border:1px solid var(--chip-border);color:var(--text-muted);transition:color .2s,border-color .2s,background .2s,transform .2s}.company-links a:hover{color:var(--accent-cyan);border-color:color-mix(in oklab,var(--accent-cyan) 35%,var(--chip-border));background:var(--surface-hover);transform:translateY(-1px)}.company-links svg{width:13px;height:13px}.tl-tag{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;padding:3px 8px;border-radius:999px;background:var(--chip-bg);border:1px solid var(--chip-border);color:var(--text-muted)}.tl-tag.live{color:var(--accent-green);border-color:color-mix(in oklab,var(--accent-green) 30%,transparent)}.tl-summary{color:var(--text-muted);font-size:.96rem;margin-bottom:var(--space-3);max-width:980px}.tl-points{margin:0 0 var(--space-3);padding:0;list-style:none;display:grid;grid-gap:6px;gap:6px}.tl-points li{position:relative;padding-left:18px;font-size:.92rem;color:var(--text);line-height:1.55}.tl-points li:before{content:"";position:absolute;left:0;top:9px;width:8px;height:1px;background:var(--accent-cyan)}.tl-tech{display:flex;flex-wrap:wrap;gap:6px}.company-engagements{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:var(--space-3);gap:var(--space-3);margin:var(--space-5) 0}.engagement-card{padding:var(--space-4);border-radius:var(--radius-md);background:var(--surface);border:1px solid var(--border);position:relative}.engagement-card.current{border-color:color-mix(in oklab,var(--accent-green) 32%,var(--border))}.engagement-head{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-gap:var(--space-3);gap:var(--space-3);align-items:flex-start;margin-bottom:8px}.engagement-title{display:grid;grid-template-columns:minmax(0,max-content) 56px;align-items:center;grid-gap:8px;gap:8px;min-width:0}.engagement-head h4{font-size:1rem;font-family:var(--font-display);color:var(--text-strong)}.engagement-head>span{font-family:var(--font-mono);font-size:10.5px;color:var(--text-faint);white-space:nowrap;padding-top:3px}.engagement-card p{color:var(--text-muted);font-size:.9rem;margin-bottom:var(--space-3)}.engagement-card .tl-points{margin-bottom:0}@media (max-width:1180px){.company-engagements{grid-template-columns:1fr 1fr}}@media (max-width:760px){.timeline:before{left:8px}.tl-item{grid-template-columns:1fr;gap:var(--space-3);padding-left:28px}.tl-meta{padding-right:0}.tl-dot{right:auto;left:-25px;top:8px}.tl-body{padding-left:0}.company-engagements,.engagement-head{grid-template-columns:1fr}}.skill-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:var(--space-5);gap:var(--space-5)}.skill-block{position:relative;padding:var(--space-6);border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-card);overflow:hidden;transition:border-color .3s,transform .3s}.skill-block:hover{border-color:var(--border-strong);transform:translateY(-2px)}.skill-block:before{content:"";position:absolute;top:-40%;right:-25%;width:50%;height:180%;background:radial-gradient(closest-side,var(--glow-cyan),transparent);opacity:.55;pointer-events:none}.skill-block.violet:before{background:radial-gradient(closest-side,var(--glow-violet),transparent)}.skill-block.blue:before{background:radial-gradient(closest-side,var(--glow-blue),transparent)}.skill-block.green:before{background:radial-gradient(closest-side,color-mix(in oklab,var(--accent-green) 40%,transparent),transparent)}.skill-head{display:flex;align-items:center;gap:14px;margin-bottom:var(--space-4);position:relative}.skill-head .ico{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:var(--chip-bg);border:1px solid var(--chip-border);color:var(--accent-cyan)}.skill-head .ico svg{width:20px;height:20px}.skill-block.violet .skill-head .ico{color:var(--accent-violet)}.skill-block.blue .skill-head .ico{color:var(--accent-blue)}.skill-block.green .skill-head .ico{color:var(--accent-green)}.skill-head h3{font-size:1.15rem;font-family:var(--font-display);margin:0}.skill-head small{display:block;margin-top:2px;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-faint)}.skill-primary{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:var(--space-4);position:relative}.skill-primary .chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:10px;background:var(--surface-strong);border:1px solid var(--border-strong);font-family:var(--font-mono);font-size:12.5px;color:var(--text-strong)}.skill-primary .chip .dot{width:6px;height:6px;border-radius:50%;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue))}.skill-block.violet .skill-primary .chip .dot{background:linear-gradient(135deg,var(--accent-violet),var(--accent-blue))}.skill-block.blue .skill-primary .chip .dot{background:var(--accent-blue)}.skill-block.green .skill-primary .chip .dot{background:var(--accent-green)}.skill-meta{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:var(--space-4);position:relative}.skill-meta .pill{font-size:11px;padding:4px 9px;border-radius:6px;background:var(--chip-bg);border:1px solid var(--chip-border)}.skill-meta .pill,.skill-note{font-family:var(--font-mono);color:var(--text-muted)}.skill-note{display:flex;gap:10px;padding:12px 14px;border-radius:10px;background:var(--code-bg);border:1px solid var(--border);font-size:.88rem;position:relative;line-height:1.55}.skill-note:before{content:"// ";color:var(--accent-cyan);flex:none}@media (max-width:760px){.skill-grid{grid-template-columns:1fr}}.contact{padding:var(--space-9) 0;position:relative}.contact-wrap{border-radius:var(--radius-xl);background:var(--surface);border:1px solid var(--border);padding:var(--space-8) var(--space-7);box-shadow:var(--shadow-card);display:grid;grid-template-columns:1.1fr 1fr;grid-gap:var(--space-7);gap:var(--space-7);align-items:center;position:relative;overflow:hidden}.contact-wrap:before{top:-40%;left:-10%;background:radial-gradient(closest-side,var(--glow-violet),transparent)}.contact-wrap:after,.contact-wrap:before{content:"";position:absolute;width:60%;height:180%;opacity:.55;pointer-events:none}.contact-wrap:after{bottom:-60%;right:-10%;background:radial-gradient(closest-side,var(--glow-cyan),transparent)}.contact h2{margin-bottom:var(--space-3)}.contact .lead{color:var(--text-muted);margin-bottom:var(--space-5)}.contact-info{display:flex;flex-direction:column;gap:10px;position:relative}.contact-row{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1px solid var(--border);border-radius:12px;background:var(--surface-strong);transition:border-color .2s,background .2s,transform .2s;cursor:pointer}.contact-row:hover{border-color:var(--border-strong);background:var(--surface-hover);transform:translateY(-1px)}.contact-row .ico{width:36px;height:36px;display:grid;place-items:center;border-radius:9px;background:var(--chip-bg);border:1px solid var(--chip-border);color:var(--accent-cyan)}.contact-row .ico svg{width:16px;height:16px}.contact-row .label{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-faint);display:block}.contact-row .val{color:var(--text-strong);font-size:.96rem}.contact-row .arrow{margin-left:auto;color:var(--text-muted)}.contact-row .arrow svg{width:16px;height:16px}footer{border-top:1px solid var(--border);padding:var(--space-6) 0;color:var(--text-muted);font-size:13px}.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap}.footer-inner .made{font-family:var(--font-mono);font-size:12px;color:var(--text-faint)}.diag-node{fill:var(--surface-solid);stroke:var(--border-strong);stroke-width:1}.diag-text{fill:var(--text-strong);font-family:var(--font-display);font-size:11px;font-weight:500}.diag-text.sub{fill:var(--text-muted);font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase}.diag-line{stroke:var(--border-strong)}.diag-glow,.diag-line{stroke-width:1.2;fill:none}.diag-dot,.diag-icon{fill:var(--accent-cyan)}@keyframes flow{0%{stroke-dashoffset:60}to{stroke-dashoffset:0}}.diag-flow{stroke:var(--accent-cyan);stroke-width:1.5;stroke-dasharray:4 8;fill:none;filter:drop-shadow(0 0 4px var(--accent-cyan));animation:flow 2.4s linear infinite}.mobile-menu{position:fixed;inset:68px 0 0 0;background:color-mix(in oklab,var(--bg) 96%,transparent);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:40;padding:var(--space-6) var(--space-5);transform:translateX(100%);transition:transform .3s ease;display:flex;flex-direction:column;gap:var(--space-4)}.mobile-menu.open{transform:translateX(0)}.mobile-menu a{font-family:var(--font-display);font-size:1.4rem;color:var(--text);padding:10px 0;border-bottom:1px solid var(--border)}@media (max-width:960px){.about-copy,.about-grid,.contact-wrap,.hero-grid,.project,.project.alt{grid-template-columns:1fr}.about-copy{gap:var(--space-4)}.project.alt .project-visual{order:0}.cs-grid{grid-template-columns:1fr}.stack-grid{grid-template-columns:1fr 1fr}.nav-links{display:none}.menu-btn{display:grid}.project-carousel,.projects-archive-list .project{min-height:0}section{padding:var(--space-8) 0}}@media (max-width:560px){body{font-size:15px}.container{padding:0 var(--space-4)}.bullets,.stack-grid{grid-template-columns:1fr}.contact-wrap,.cs-card,.project{padding:var(--space-5)}.project-carousel-top{flex-direction:column}.hero{padding-top:var(--space-6)}.hero h1,h1{font-size:2.2rem}.project-visual{min-height:260px}}.cs-hero{padding-top:var(--space-7);padding-bottom:var(--space-7)}.cs-back{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:12px;color:var(--text-muted);margin-bottom:var(--space-5);transition:color .2s}.cs-back:hover{color:var(--text-strong)}.cs-back svg{width:12px;height:12px}.cs-hero h1{margin-bottom:var(--space-3)}.cs-hero .lead{color:var(--text-muted);font-size:1.1rem;max-width:720px;margin-bottom:var(--space-5)}.cs-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:var(--space-6)}.cs-section{padding:var(--space-7) 0;border-top:1px solid var(--border)}.cs-section h2{margin-bottom:var(--space-5);font-size:1.7rem}.cs-prose{color:var(--text);font-size:1rem;line-height:1.75;max-width:760px}.cs-prose p{margin-bottom:var(--space-3)}.cs-prose p+p{color:var(--text-muted)}.cs-feature-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:var(--space-4);gap:var(--space-4);margin-top:var(--space-5)}@media (max-width:800px){.cs-feature-grid{grid-template-columns:1fr}}.cs-arch{border-radius:var(--radius-xl);background:var(--surface);border:1px solid var(--border);padding:var(--space-6);position:relative;overflow:hidden}.cs-arch:before{content:"";position:absolute;inset:0;background:radial-gradient(800px 300px at 100% 0,var(--glow-violet),transparent 60%),radial-gradient(800px 300px at 0 100%,var(--glow-cyan),transparent 60%);opacity:.5;pointer-events:none}.cs-arch svg{position:relative;width:100%;height:auto}@media (prefers-reduced-motion:no-preference){.reveal{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease}.reveal.in{opacity:1;transform:translateY(0)}}