@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--bg: #0b0b0c;--surface: #141416;--elevation: #1c1c1f;--raised: #25252a;--hairline: rgba(255, 255, 255, .07);--hairline-strong: rgba(255, 255, 255, .14);--text: #f1ede5;--text-mute: rgba(241, 237, 229, .62);--text-faint: rgba(241, 237, 229, .38);--text-ghost: rgba(241, 237, 229, .22);--text-on-accent: #161210;--accent: #ec4899;--accent-2: #f472b6;--accent-soft: rgba(236, 72, 153, .14);--accent-ghost: rgba(236, 72, 153, .05);--success: #4ade80;--danger: #ef4444;--warning: #f4b740;--info: #60a5fa;--font-display: "Space Grotesk", "Pretendard", "Apple SD Gothic Neo", system-ui, sans-serif;--font-body: "Space Grotesk", "Pretendard", "Apple SD Gothic Neo", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--rail-w: 220px;--bar-h: 56px;--content-max: 1280px;--gutter: 40px;--r-sm: 4px;--r-md: 6px;--r-lg: 10px;--r-pill: 999px;--m-fast: .15s;--m-mid: .3s;--m-slow: .6s;--ease: cubic-bezier(.2, .7, .2, 1);--sh-1: 0 1px 2px rgba(0,0,0,.25);--sh-2: 0 4px 16px rgba(0,0,0,.32);--sh-3: 0 10px 32px rgba(0,0,0,.42)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);margin:0;font-family:var(--font-body);font-size:14px;line-height:1.6;letter-spacing:-.005em;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit}img,svg{display:block;max-width:100%}.num,[data-num]{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.mono{font-family:var(--font-mono);font-feature-settings:"tnum"}::selection{background:var(--accent);color:var(--text-on-accent)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--raised);border-radius:5px;border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--hairline-strong)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;border-radius:var(--r-sm);font:600 14px/1 var(--font-display);letter-spacing:-.01em;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;text-decoration:none;transition:background var(--m-fast),border-color var(--m-fast),color var(--m-fast),transform var(--m-fast)}.btn:focus-visible{outline:1px solid var(--accent);outline-offset:2px}.btn-l{height:40px;padding:0 18px;font-size:14px}.btn-m{height:32px;padding:0 14px;font-size:13px}.btn-s{height:26px;padding:0 10px;font-size:12px}.btn-primary{background:var(--accent);color:var(--text-on-accent)}.btn-primary:hover{background:var(--accent-2);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:transparent;border-color:var(--hairline-strong);color:var(--text)}.btn-secondary:hover{border-color:var(--text-mute);background:var(--surface)}.btn-ghost{background:transparent;color:var(--text-mute)}.btn-ghost:hover{color:var(--text);background:var(--surface)}.tag{display:inline-flex;align-items:center;padding:4px 9px;font:500 12px/1.4 var(--font-display);color:var(--text);background:var(--surface);border:1px solid var(--hairline-strong);border-radius:var(--r-sm);transition:border-color var(--m-fast),color var(--m-fast);cursor:default;letter-spacing:-.005em}.tag:hover{border-color:var(--accent);color:var(--accent)}.tag.is-primary{background:var(--accent-soft);color:var(--accent);border-color:transparent}.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;font:500 11px/1 var(--font-mono);color:var(--text-mute);background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-pill);letter-spacing:0;text-transform:uppercase}.pill .dot{width:6px;height:6px;border-radius:50%;background:var(--success)}.kbd{font:500 11px/1 var(--font-mono);color:var(--text-mute);background:var(--raised);border:1px solid var(--hairline-strong);padding:3px 6px;border-radius:3px}.bar{position:sticky;top:0;z-index:50;height:var(--bar-h);display:flex;align-items:center;padding:0 var(--gutter);background:#0b0b0cc7;backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid var(--hairline);gap:0}.bar .brand{display:inline-flex;align-items:center;gap:12px;padding-right:20px;margin-right:12px;border-right:1px solid var(--hairline)}.bar .brand .mark{width:28px;height:28px;border-radius:4px;background:var(--accent);color:var(--text-on-accent);display:inline-flex;align-items:center;justify-content:center;font:700 12px/1 var(--font-display);letter-spacing:.02em}.bar .brand .name{font:600 14px/1 var(--font-display);letter-spacing:-.01em}.bar .brand .role{font:400 12px/1 var(--font-mono);color:var(--text-mute);letter-spacing:0}.bar .nav{display:flex;gap:0;flex:1}.bar .nav .item{height:32px;padding:0 14px;display:inline-flex;align-items:center;gap:8px;font:500 13px/1 var(--font-display);color:var(--text-mute);background:transparent;border:0;border-radius:var(--r-sm);cursor:pointer;text-decoration:none;transition:background var(--m-fast),color var(--m-fast);letter-spacing:-.005em}.bar .nav .item:hover{background:var(--surface);color:var(--text)}.bar .nav .item.is-active{color:var(--text)}.bar .nav .item.is-active:before{content:"";display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--accent)}.bar .meta{display:flex;align-items:center;gap:16px;font:400 11px/1 var(--font-mono);color:var(--text-faint);letter-spacing:0}.bar .meta .live{display:inline-flex;align-items:center;gap:6px;color:var(--text-mute)}.bar .meta .live .dot{width:6px;height:6px;border-radius:50%;background:var(--success);box-shadow:0 0 8px var(--success);animation:pulse 2.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.bar .meta a{text-decoration:none;color:var(--text-mute);transition:color var(--m-fast)}.bar .meta a:hover{color:var(--text)}.shell{display:grid;grid-template-columns:var(--rail-w) minmax(0,1fr);max-width:var(--content-max);margin:0 auto}.rail{position:sticky;top:var(--bar-h);align-self:start;height:calc(100vh - var(--bar-h));padding:40px 16px 32px 40px;border-right:1px solid var(--hairline);overflow-y:auto;scrollbar-width:thin}.rail .rail-h{font:500 10px/1 var(--font-mono);color:var(--text-faint);text-transform:uppercase;letter-spacing:.14em;margin-bottom:14px;padding-left:12px}.rail nav{display:flex;flex-direction:column;gap:1px;margin-bottom:36px}.rail nav a{display:flex;align-items:center;gap:12px;padding:9px 12px;font:500 14px/1 var(--font-display);color:var(--text-mute);text-decoration:none;border-radius:var(--r-sm);border-left:2px solid transparent;transition:background var(--m-fast),color var(--m-fast),border-color var(--m-fast);letter-spacing:-.005em}.rail nav a:hover{background:var(--surface);color:var(--text)}.rail nav a.is-active{color:var(--text);border-left-color:var(--accent);background:var(--accent-ghost)}.rail nav a .idx{font:400 10px/1 var(--font-mono);color:var(--text-faint);width:20px;letter-spacing:0}.rail nav a.is-active .idx{color:var(--accent)}.rail .status-card{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-md);padding:14px;font:400 12px/1.5 var(--font-display)}.rail .status-card .row{display:flex;justify-content:space-between;padding:5px 0}.rail .status-card .row .k{color:var(--text-faint);font:400 11px/1.4 var(--font-mono);letter-spacing:0}.rail .status-card .row .v{color:var(--text);font-variant-numeric:tabular-nums}.rail .status-card .ok{color:var(--success)}.main{padding:0 var(--gutter);min-width:0}.section{padding:96px 0 40px;scroll-margin-top:calc(var(--bar-h) + 24px);border-bottom:1px solid var(--hairline)}.section:last-of-type{border-bottom:0}.section-h{display:flex;align-items:baseline;gap:16px;margin:0 0 32px}.section-h .num{font:500 12px/1 var(--font-mono);color:var(--accent);letter-spacing:0}.section-h h2{font:600 28px/1.2 var(--font-display);letter-spacing:-.02em;margin:0}.section-h .sub{font:400 12px/1 var(--font-mono);color:var(--text-faint);margin-left:auto;letter-spacing:0}.hero{position:relative;padding:80px 0 64px;border-bottom:1px solid var(--hairline)}.hero-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:56px;align-items:center}.hero .eyebrow{display:inline-flex;align-items:center;gap:10px;font:500 11px/1 var(--font-mono);color:var(--text-faint);margin-bottom:28px;text-transform:uppercase;letter-spacing:.14em}.hero .eyebrow:before{content:"";width:28px;height:1px;background:var(--accent)}.hero h1{font:700 72px/.98 var(--font-display);letter-spacing:-.035em;margin:0 0 20px}.hero h1 .ko{display:block;font-size:.55em;color:var(--text-mute);font-weight:400;margin-bottom:4px;letter-spacing:-.02em}.hero h1 .latin{display:block}.hero h1 .accent{color:var(--accent)}.hero h1 .blink{display:inline-block;width:.45em;height:.85em;background:var(--accent);margin-left:.06em;vertical-align:-.06em;animation:blink 1.1s steps(2) infinite}@keyframes blink{50%{opacity:0}}.hero .tagline{font:400 18px/1.55 var(--font-display);color:var(--text-mute);margin:0 0 36px;max-width:52ch;text-wrap:pretty;letter-spacing:-.005em}.hero .tagline strong{color:var(--text);font-weight:500}.hero .tagline em{font-style:normal;color:var(--text);border-bottom:1px dashed var(--accent);padding-bottom:1px}.hero .cta-row{display:flex;gap:10px;flex-wrap:wrap}.hero .quick-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:48px;border-top:1px solid var(--hairline);padding-top:24px}.hero .quick-stats .qs{padding-right:24px;border-right:1px solid var(--hairline)}.hero .quick-stats .qs:last-child{border-right:0;padding-right:0}.hero .quick-stats .qs .v{font:600 32px/1 var(--font-display);font-variant-numeric:tabular-nums;letter-spacing:-.025em;margin-bottom:8px}.hero .quick-stats .qs .v .unit{font-size:16px;color:var(--text-mute);margin-left:4px;font-weight:400}.hero .quick-stats .qs .k{font:500 10px/1.3 var(--font-mono);color:var(--text-faint);text-transform:uppercase;letter-spacing:.1em}.hero-viz{position:relative;aspect-ratio:1 / 1;background:radial-gradient(120% 80% at 50% 0%,rgba(255,107,61,.06) 0%,transparent 60%),var(--surface);border:1px solid var(--hairline);border-radius:var(--r-lg);overflow:hidden}.hero-viz canvas{width:100%;height:100%;display:block}.hero-viz .viz-chrome{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;font:500 10px/1 var(--font-mono);color:var(--text-faint)}.hero-viz .viz-chrome .tl{position:absolute;top:16px;left:18px}.hero-viz .viz-chrome .tr{position:absolute;top:16px;right:18px}.hero-viz .viz-chrome .br{position:absolute;bottom:16px;right:18px;display:flex;gap:16px}.hero-viz .viz-chrome .bl{position:absolute;bottom:16px;left:18px;color:var(--accent)}.hero-viz .viz-chrome .corner{position:absolute;width:14px;height:14px;border:1px solid var(--accent)}.hero-viz .viz-chrome .corner.tlc{top:10px;left:10px;border-right:0;border-bottom:0}.hero-viz .viz-chrome .corner.trc{top:10px;right:10px;border-left:0;border-bottom:0}.hero-viz .viz-chrome .corner.blc{bottom:10px;left:10px;border-right:0;border-top:0}.hero-viz .viz-chrome .corner.brc{bottom:10px;right:10px;border-left:0;border-top:0}.hero-viz .viz-cap{position:absolute;bottom:44px;left:18px;right:18px;font:400 11px/1.45 var(--font-display);color:var(--text-mute);max-width:260px;pointer-events:none}.hero-viz .viz-cap b{display:block;color:var(--text);font:600 13px/1.3 var(--font-display);margin-bottom:4px;letter-spacing:-.01em}.about-grid{display:grid;grid-template-columns:minmax(0,1.8fr) minmax(0,1fr);gap:40px;align-items:flex-start}.prose p{font:400 16px/1.7 var(--font-display);color:var(--text-mute);margin:0 0 18px;text-wrap:pretty;max-width:62ch;letter-spacing:-.005em}.prose p strong{color:var(--text);font-weight:600}.prose p .hl{color:var(--accent);font-weight:500}.prose p em{font-style:normal;color:var(--text);font-weight:500}.side-card{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-md);padding:22px}.side-card h4{font:500 10px/1 var(--font-mono);color:var(--text-faint);text-transform:uppercase;letter-spacing:.12em;margin:0 0 16px}.side-card .row{display:flex;justify-content:space-between;align-items:flex-start;padding:10px 0;font:400 13px/1.4 var(--font-display);border-bottom:1px solid var(--hairline);gap:16px}.side-card .row:last-child{border-bottom:0;padding-bottom:0}.side-card .row .k{color:var(--text-faint);font:400 11px/1.5 var(--font-mono);flex-shrink:0;letter-spacing:0}.side-card .row .v{color:var(--text);text-align:right}.side-card .row .v .sub{display:block;font-size:11px;color:var(--text-faint);margin-top:3px;font-family:var(--font-mono)}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hairline);border:1px solid var(--hairline);border-radius:var(--r-md);overflow:hidden}.stats .stat{background:var(--surface);padding:22px;display:flex;flex-direction:column;gap:10px;transition:background var(--m-fast);position:relative}.stats .stat:hover{background:var(--elevation)}.stats .stat:before{content:"";position:absolute;left:0;top:0;width:0;height:2px;background:var(--accent);transition:width var(--m-mid) var(--ease)}.stats .stat:hover:before{width:100%}.stats .stat .label{font:500 10px/1.3 var(--font-mono);color:var(--text-faint);text-transform:uppercase;letter-spacing:.1em}.stats .stat .value{font:700 36px/1 var(--font-display);font-variant-numeric:tabular-nums;letter-spacing:-.03em;color:var(--accent)}.stats .stat .value .unit{font-size:18px;color:var(--text-mute);margin-left:4px;font-weight:500}.stats .stat .context{font:400 12px/1.5 var(--font-display);color:var(--text-mute);margin-top:auto;letter-spacing:-.005em}.stats .stat .meta{font:400 10px/1.3 var(--font-mono);color:var(--text-faint);text-transform:uppercase;letter-spacing:.08em}.stack-grid{display:grid;grid-template-columns:180px minmax(0,1fr);gap:24px 40px}.stack-grid .grp-label{font:600 13px/1.4 var(--font-display);color:var(--text);padding-top:6px;letter-spacing:-.01em}.stack-grid .grp-label .sub{display:block;font:400 10px/1.5 var(--font-mono);color:var(--text-faint);margin-top:4px;text-transform:uppercase;letter-spacing:.08em}.tags{display:flex;flex-wrap:wrap;gap:6px}.stack-grid hr{grid-column:1 / -1;border:0;border-top:1px solid var(--hairline);margin:0}.timeline{display:flex;flex-direction:column}.job{display:grid;grid-template-columns:160px minmax(0,1fr);gap:40px;padding:28px 0;border-bottom:1px solid var(--hairline);position:relative}.job:last-child{border-bottom:0}.job .when{font:500 12px/1.5 var(--font-mono);color:var(--text-faint);letter-spacing:0}.job .when .role-tag{display:inline-block;margin-top:8px;font:500 10px/1 var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--text-mute);background:var(--surface);border:1px solid var(--hairline-strong);padding:4px 8px;border-radius:var(--r-sm)}.job .when.is-current .role-tag{color:var(--accent);background:var(--accent-soft);border-color:transparent}.job .body h3{font:600 19px/1.3 var(--font-display);margin:0 0 6px;letter-spacing:-.015em}.job .body .org{font:400 12px/1.5 var(--font-mono);color:var(--text-faint);margin-bottom:14px;letter-spacing:0}.job .body .org .sep{margin:0 8px;opacity:.5}.job .body p{font:400 13px/1.65 var(--font-display);color:var(--text-mute);margin:0 0 8px;max-width:64ch;letter-spacing:-.005em}.job .body ul{list-style:none;padding:0;margin:8px 0 0}.job .body ul li{position:relative;padding-left:18px;font:400 13px/1.65 var(--font-display);color:var(--text-mute);margin-bottom:6px;letter-spacing:-.005em}.job .body ul li:before{content:"";position:absolute;left:0;top:11px;width:8px;height:1px;background:var(--text-faint)}.job .body ul li strong{color:var(--accent);font-weight:600;font-variant-numeric:tabular-nums}.job .sub-block{margin-top:20px}.job .sub-block:first-of-type{margin-top:4px}.job .sub-block .sub-h{font:600 14px/1.4 var(--font-display);color:var(--text);margin-bottom:6px;letter-spacing:-.01em}.job .sub-block .sub-year{display:inline-block;font:500 10px/1 var(--font-mono);color:var(--accent);background:var(--accent-soft);padding:3px 6px;border-radius:var(--r-sm);margin-right:10px;letter-spacing:0}.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.proj-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-md);text-decoration:none;color:inherit;overflow:hidden;transition:border-color var(--m-mid) var(--ease),transform var(--m-mid) var(--ease),box-shadow var(--m-mid) var(--ease),background var(--m-mid) var(--ease);position:relative}.proj-card:after{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:0 50%;transition:transform var(--m-mid) var(--ease);z-index:1}.proj-card:hover{border-color:var(--hairline-strong);transform:translateY(-3px);box-shadow:var(--sh-2);background:var(--elevation)}.proj-card:hover:after{transform:scaleX(1)}.proj-thumb{height:180px;background:var(--bg);border-bottom:1px solid var(--hairline);position:relative;overflow:hidden}.proj-thumb svg,.proj-thumb canvas{width:100%;height:100%;display:block}.proj-card-body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:12px;flex:1}.proj-card .meta-row{display:flex;align-items:center;gap:8px;font:500 10px/1 var(--font-mono);color:var(--text-faint);text-transform:uppercase;letter-spacing:.1em}.proj-card .meta-row .id{color:var(--accent)}.proj-card h3{font:600 20px/1.25 var(--font-display);margin:0;letter-spacing:-.02em}.proj-card .desc{font:400 13px/1.55 var(--font-display);color:var(--text-mute);margin:0;text-wrap:pretty;letter-spacing:-.005em}.proj-card .tags{margin-top:auto;padding-top:8px}.proj-card .tags .tag{font-size:11px;padding:3px 7px;background:transparent}.proj-card .open-row{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--hairline);padding:12px 20px;font:600 12px/1 var(--font-display);color:var(--text-mute);transition:color var(--m-fast),background var(--m-fast);letter-spacing:-.005em}.proj-card:hover .open-row{color:var(--accent);background:var(--bg)}.proj-card .open-row .arrow{display:inline-block;transition:transform var(--m-mid) var(--ease)}.proj-card:hover .open-row .arrow{transform:translate(6px)}.proj-card.is-soon{border-style:dashed;background:transparent}.proj-card.is-soon .proj-thumb{background:transparent}.proj-card.is-soon h3{color:var(--text-mute)}.proj-card.is-soon .desc{color:var(--text-faint)}.proj-card.is-soon:after{display:none}.proj-card.is-soon:hover{transform:none;box-shadow:none;border-color:var(--hairline-strong);background:transparent}.proj-card.is-soon:hover .open-row{color:var(--text-faint);background:transparent}.mini-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--hairline);border:1px solid var(--hairline);border-radius:var(--r-md);overflow:hidden}.mini-card{background:var(--surface);padding:22px 24px;display:flex;flex-direction:column;gap:8px;transition:background var(--m-fast)}.mini-card:hover{background:var(--elevation)}.mini-card .label{font:500 10px/1 var(--font-mono);color:var(--text-faint);text-transform:uppercase;letter-spacing:.1em}.mini-card h4{font:600 16px/1.3 var(--font-display);margin:0;letter-spacing:-.015em}.mini-card .stack{font:400 11px/1.4 var(--font-mono);color:var(--text-faint);letter-spacing:0}.mini-card p{font:400 13px/1.6 var(--font-display);color:var(--text-mute);margin:0;letter-spacing:-.005em}.mini-card a{color:var(--accent);text-decoration:none;border-bottom:1px dashed currentColor;padding-bottom:1px}.mini-card a:hover{border-bottom-style:solid}.contact-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hairline);border:1px solid var(--hairline);border-radius:var(--r-md);overflow:hidden;margin-bottom:40px}.contact-cell{background:var(--surface);padding:22px 24px;display:flex;flex-direction:column;gap:8px;text-decoration:none;color:inherit;transition:background var(--m-fast)}.contact-cell:hover{background:var(--elevation)}.contact-cell .k{font:500 10px/1 var(--font-mono);color:var(--text-faint);text-transform:uppercase;letter-spacing:.1em}.contact-cell .v{font:600 15px/1.3 var(--font-display);font-variant-numeric:tabular-nums;word-break:break-all;transition:color var(--m-fast);letter-spacing:-.015em}.contact-cell:hover .v{color:var(--accent)}footer.foot{padding:32px 0 56px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--hairline);font:400 11px/1.4 var(--font-mono);color:var(--text-faint);letter-spacing:0;flex-wrap:wrap;gap:12px}.reveal{opacity:0;transform:translateY(16px);transition:opacity var(--m-slow) var(--ease),transform var(--m-slow) var(--ease)}.reveal.is-in{opacity:1;transform:none}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}.reveal{opacity:1;transform:none;transition:none}*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.tweaks{position:fixed;bottom:24px;right:24px;z-index:100;width:300px;background:var(--surface);border:1px solid var(--hairline-strong);border-radius:var(--r-md);box-shadow:var(--sh-3);font:400 13px/1.4 var(--font-display);display:none}.tweaks.is-open{display:block}.tweaks .tw-head{padding:12px 14px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--hairline)}.tweaks .tw-head h5{font:500 11px/1 var(--font-mono);margin:0;text-transform:uppercase;letter-spacing:.12em;color:var(--text-mute)}.tweaks .tw-head button{background:transparent;border:0;color:var(--text-faint);cursor:pointer;padding:4px;line-height:0}.tweaks .tw-head button:hover{color:var(--text)}.tweaks .tw-body{padding:14px;display:flex;flex-direction:column;gap:16px}.tweaks .tw-row{display:flex;flex-direction:column;gap:8px}.tweaks .tw-row .lbl{font:500 10px/1 var(--font-mono);color:var(--text-faint);text-transform:uppercase;letter-spacing:.12em}.tweaks .swatches{display:flex;gap:8px}.tweaks .swatches .sw{width:32px;height:32px;border:1px solid var(--hairline-strong);border-radius:var(--r-sm);cursor:pointer;position:relative;transition:transform var(--m-fast),border-color var(--m-fast)}.tweaks .swatches .sw:hover{transform:translateY(-2px)}.tweaks .swatches .sw.is-active{border-color:var(--text);box-shadow:inset 0 0 0 2px var(--bg)}.tweaks .seg{display:inline-flex;padding:2px;background:var(--bg);border:1px solid var(--hairline);border-radius:var(--r-sm)}.tweaks .seg button{padding:6px 12px;background:transparent;border:0;color:var(--text-mute);font:500 12px/1 var(--font-display);cursor:pointer;border-radius:3px;letter-spacing:-.005em;flex:1}.tweaks .seg button.is-active{background:var(--raised);color:var(--text)}.detail-shell{max-width:var(--content-max);margin:0 auto;padding:40px var(--gutter) 96px}.detail-back{display:inline-flex;align-items:center;gap:8px;font:500 12px/1 var(--font-mono);color:var(--text-mute);text-decoration:none;text-transform:uppercase;letter-spacing:.08em;margin-bottom:32px;padding:8px 12px 8px 8px;border-radius:var(--r-sm);transition:background var(--m-fast),color var(--m-fast)}.detail-back:hover{background:var(--surface);color:var(--text)}.detail-back .arrow{transition:transform var(--m-fast)}.detail-back:hover .arrow{transform:translate(-4px)}.detail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:32px;padding-bottom:40px;border-bottom:1px solid var(--hairline);margin-bottom:40px}.detail-head .left{flex:1;min-width:0}.detail-head .pid{font:500 11px/1 var(--font-mono);color:var(--accent);text-transform:uppercase;letter-spacing:.14em;margin-bottom:12px}.detail-head h1{font:700 48px/1.05 var(--font-display);margin:0 0 16px;letter-spacing:-.03em}.detail-head .lede{font:400 17px/1.55 var(--font-display);color:var(--text-mute);margin:0;max-width:64ch;text-wrap:pretty;letter-spacing:-.005em}.detail-head .right{display:flex;flex-direction:column;gap:8px;text-align:right;font:400 12px/1.5 var(--font-mono);color:var(--text-faint);flex-shrink:0}.detail-head .right .pill{align-self:flex-end}.detail-section{margin-bottom:56px}.detail-section .h{font:500 11px/1 var(--font-mono);color:var(--text-faint);text-transform:uppercase;letter-spacing:.14em;margin-bottom:20px}.detail-section .h .num{color:var(--accent);margin-right:12px}.detail-section h2{font:600 22px/1.3 var(--font-display);margin:0 0 8px;letter-spacing:-.02em}.detail-section p{font:400 14px/1.7 var(--font-display);color:var(--text-mute);margin:0 0 12px;max-width:68ch;letter-spacing:-.005em}.detail-section p strong{color:var(--text);font-weight:600}.kv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hairline);border:1px solid var(--hairline);border-radius:var(--r-md);overflow:hidden}.kv-grid .cell{background:var(--surface);padding:16px 18px;display:flex;flex-direction:column;gap:6px}.kv-grid .cell .k{font:500 10px/1 var(--font-mono);color:var(--text-faint);text-transform:uppercase;letter-spacing:.1em}.kv-grid .cell .v{font:600 17px/1.3 var(--font-display);font-variant-numeric:tabular-nums;letter-spacing:-.02em}@media(max-width:1080px){.shell{grid-template-columns:1fr}.rail{display:none}.hero-grid{grid-template-columns:1fr;gap:40px}.hero h1{font-size:56px}.stats{grid-template-columns:repeat(2,1fr)}.proj-grid{grid-template-columns:1fr}.contact-row,.kv-grid{grid-template-columns:repeat(2,1fr)}.job{grid-template-columns:1fr;gap:12px}.stack-grid{grid-template-columns:1fr;gap:8px 0}.stack-grid .grp-label{padding-top:16px}.detail-head{flex-direction:column;gap:16px}.detail-head h1{font-size:36px}.mini-grid{grid-template-columns:1fr}:root{--gutter: 24px}}
