:root{--ink: #0B0D10;--ink-2: #14171C;--navy: #0E1A2B;--navy-2: #132338;--slate-900: #0F172A;--slate-700: #334155;--slate-600: #475569;--slate-500: #64748B;--slate-400: #94A3B8;--slate-300: #CBD5E1;--slate-200: #E2E8F0;--slate-100: #F1F5F9;--off-white: #F7F7F5;--paper: #FAFAF8;--white: #FFFFFF;--electric: #3D7BFD;--electric-2: #5B8FFF;--electric-dim: #1E3A8A;--signal-green: #34D399;--signal-amber: #F59E0B;--signal-red: #EF4444;--sans: "Geist", "Inter", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;--mono: "Geist Mono", "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 24px;--s-6: 32px;--s-7: 48px;--s-8: 64px;--s-9: 96px;--s-10: 128px}*{box-sizing:border-box}html,body{margin:0;font-family:var(--sans);font-feature-settings:"ss01","cv11";-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}img,svg,video,canvas,iframe{max-width:100%;height:auto}figure{margin:0}.mono{font-family:var(--mono)}.hr{height:1px;background:#ffffff14;width:100%}.theme-light .hr{background:#0000001a}:root{--accent: var(--electric);--accent-2: var(--electric-2);--accent-dim: var(--electric-dim);--bg: var(--ink);--bg-2: var(--ink-2);--fg: var(--off-white);--fg-dim: var(--slate-300);--fg-quiet: var(--slate-500);--hair: rgba(255, 255, 255, .08);--hair-strong: rgba(255, 255, 255, .16);--card-bg: var(--ink-2);--max-w: 1440px;--pad-x: clamp(16px, 4.5vw, 96px);--section-y: clamp(64px, 10vw, 120px);color-scheme:dark}html{scroll-behavior:smooth}html,body{background:var(--bg);color:var(--fg);font-family:var(--sans);font-size:16px;line-height:1.55}body{min-height:100vh}body.theme-light{--bg: var(--paper);--bg-2: #FFFFFF;--fg: var(--ink);--fg-dim: var(--slate-700);--fg-quiet: var(--slate-500);--hair: rgba(0, 0, 0, .1);--hair-strong: rgba(0, 0, 0, .18);--card-bg: #ffffff;color-scheme:light}::selection{background:var(--accent);color:#fff}.page{max-width:var(--max-w);margin:0 auto;padding:0 var(--pad-x)}.section{padding-top:var(--section-y);padding-bottom:var(--section-y);position:relative;border-top:1px solid var(--hair)}.section:first-of-type{border-top:none}.section-head{display:grid;grid-template-columns:240px 1fr;gap:64px;margin-bottom:64px;align-items:start}@media(max-width:900px){.section-head{grid-template-columns:1fr;gap:24px}}.section-num{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-quiet);display:flex;flex-direction:column;gap:8px}.section-num .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent)}.section-num .label{color:var(--accent)}.section-title{font-weight:500;font-size:clamp(36px,5vw,72px);line-height:1.02;letter-spacing:-.03em;margin:0;text-wrap:balance}.section-kicker{margin-top:24px;max-width:640px;color:var(--fg-dim);font-size:clamp(16px,1.4vw,20px);line-height:1.5;text-wrap:pretty}.site-header{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:color-mix(in oklab,var(--bg) 78%,transparent);border-bottom:1px solid var(--hair)}.site-header .inner{display:flex;align-items:center;justify-content:space-between;padding:18px var(--pad-x);max-width:var(--max-w);margin:0 auto}.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--fg);font-weight:500;letter-spacing:-.01em}.brand .mk{width:22px;height:22px;color:var(--fg);display:inline-flex}.brand .mk svg{width:100%;height:100%}.brand .dot{color:var(--accent)}.nav{display:flex;gap:28px;align-items:center}.nav a{font-family:var(--mono);font-size:13px;letter-spacing:.04em;color:var(--fg-dim);text-decoration:none;transition:color .12s}.nav a:hover{color:var(--fg)}.nav .idx{color:var(--fg-quiet);margin-right:6px}.nav .pill{padding:7px 14px;border:1px solid var(--hair-strong);border-radius:999px;color:var(--fg);display:inline-flex;align-items:center;gap:8px}.theme-toggle{width:34px;height:34px;border:1px solid var(--hair-strong);border-radius:50%;background:transparent;color:var(--fg);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .16s;padding:0}.theme-toggle:hover{border-color:var(--fg);background:color-mix(in oklab,var(--fg) 4%,transparent)}.theme-toggle .icon-sun{display:none}body.theme-light .theme-toggle .icon-sun{display:block}body.theme-light .theme-toggle .icon-moon{display:none}.lang-toggle{height:34px;min-width:34px;padding:0 10px;border:1px solid var(--hair-strong);border-radius:999px;background:transparent;color:var(--fg);font-family:var(--mono);font-size:11px;letter-spacing:.08em;font-weight:500;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;transition:all .16s}.lang-toggle:hover{border-color:var(--fg);background:color-mix(in oklab,var(--fg) 4%,transparent);color:var(--fg)}.nav .pill .pulse{width:7px;height:7px;border-radius:50%;background:var(--signal-green);box-shadow:0 0 color-mix(in oklab,var(--signal-green) 60%,transparent);animation:pulse 2.2s ease-out infinite}@keyframes pulse{0%{box-shadow:0 0 color-mix(in oklab,var(--signal-green) 60%,transparent)}70%{box-shadow:0 0 0 8px color-mix(in oklab,var(--signal-green) 0%,transparent)}to{box-shadow:0 0 color-mix(in oklab,var(--signal-green) 0%,transparent)}}@media(max-width:860px){.nav .desktop-only{display:none}.nav{gap:14px}}.hero{padding-top:clamp(64px,10vw,140px);padding-bottom:clamp(64px,10vw,140px);position:relative;overflow:hidden}.hero .hairgrid-bg{position:absolute;inset:-200px;background-image:linear-gradient(to right,var(--hair) 1px,transparent 1px),linear-gradient(to bottom,var(--hair) 1px,transparent 1px);background-size:80px 80px;mask-image:radial-gradient(circle at 30% 0%,black 0%,transparent 70%);-webkit-mask-image:radial-gradient(circle at 30% 0%,black 0%,transparent 70%);opacity:.6;pointer-events:none}.hero-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:80px;align-items:end;position:relative}@media(max-width:1000px){.hero-grid{grid-template-columns:1fr;gap:48px;align-items:start}}.hero h1{font-weight:500;font-size:clamp(56px,10vw,168px);line-height:.92;letter-spacing:-.045em;margin:0;text-wrap:balance}.hero h1 .accent{color:var(--accent)}.hero .eyebrow-mono{display:inline-flex;align-items:center;gap:12px;font-family:var(--mono);font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:32px}.hero .eyebrow-mono .bracket{color:var(--fg-quiet)}.hero-lead{margin-top:36px;font-size:clamp(20px,2vw,28px);line-height:1.4;color:var(--fg-dim);max-width:760px;font-weight:400;text-wrap:pretty;letter-spacing:-.01em}.hero-lead strong{color:var(--fg);font-weight:500}.hero-cta{margin-top:40px;display:flex;gap:14px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:10px;padding:13px 22px;border-radius:6px;font-family:var(--sans);font-weight:500;font-size:15px;letter-spacing:-.005em;border:1px solid transparent;cursor:pointer;transition:all .16s ease-out;text-decoration:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-2);transform:translateY(-1px)}.btn-secondary{background:transparent;border-color:var(--hair-strong);color:var(--fg)}.btn-secondary:hover{border-color:var(--fg)}.btn .arrow{display:inline-block;transition:transform .16s}.btn:hover .arrow{transform:translate(3px)}.hero-sheet{display:flex;flex-direction:column;gap:22px;padding-bottom:12px}.hero-sheet .hr{background:var(--hair)}.hero-sheet .sheet-rows{font-family:var(--mono);display:grid;grid-template-columns:auto minmax(0,1fr);gap:14px 28px;font-size:13px;color:var(--fg-dim)}.hero-sheet .sheet-rows>*{min-width:0;overflow-wrap:break-word}.hero-sheet .sheet-rows .k{color:var(--fg-quiet);letter-spacing:.04em}.hero-sheet .sheet-rows .v a{color:inherit;text-decoration:none;border-bottom:1px solid var(--hair-strong)}.hero-sheet .sheet-rows .v a:hover{color:var(--accent);border-color:var(--accent)}.hero-mark{width:84px;height:84px;color:var(--fg);margin-bottom:8px}.hero-mark svg{width:100%;height:100%;fill:currentColor}.status{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hair);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}.status .cell{background:var(--bg);padding:28px var(--pad-x);display:flex;flex-direction:column;gap:6px}.status .cell:not(:first-child){padding-left:32px}.status .k{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-quiet)}.status .v{font-size:18px;letter-spacing:-.01em;color:var(--fg);font-weight:500}.status .v .live{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--signal-green);margin-right:8px;vertical-align:middle}@media(max-width:900px){.status{grid-template-columns:1fr 1fr}.status .cell:nth-child(odd){padding-left:var(--pad-x)}}@media(max-width:560px){.status{grid-template-columns:1fr}.status .cell:not(:first-child){padding-left:var(--pad-x)}}.work-list{display:flex;flex-direction:column}.work-row{display:grid;grid-template-columns:80px 1.3fr 2fr 200px;gap:32px;padding:36px 0;border-top:1px solid var(--hair);align-items:start;transition:background .18s;position:relative}.work-row:hover{background:color-mix(in oklab,var(--accent) 4%,transparent)}.work-row:last-child{border-bottom:1px solid var(--hair)}.work-row .yr{font-family:var(--mono);font-size:13px;color:var(--fg-quiet);padding-top:4px;letter-spacing:.04em}.work-row .name{font-size:clamp(24px,2.4vw,36px);font-weight:500;letter-spacing:-.02em;line-height:1.05;color:var(--fg)}.work-row .role{margin-top:6px;font-size:14px;font-family:var(--mono);color:var(--accent);letter-spacing:.02em}.work-row .summary{color:var(--fg-dim);font-size:16px;line-height:1.55;margin:0;text-wrap:pretty}.work-row .stack{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}.work-row .chip{font-family:var(--mono);font-size:11px;letter-spacing:.04em;padding:4px 8px;border:1px solid var(--hair);border-radius:4px;color:var(--fg-dim)}.work-row .arrow-cell{display:flex;flex-direction:column;align-items:flex-end;gap:14px;padding-top:4px}.work-row .link-tag{font-family:var(--mono);font-size:12px;color:var(--fg-quiet);letter-spacing:.04em}.work-row .link-tag.live{color:var(--signal-green)}.work-row .arrow-bg{width:44px;height:44px;border:1px solid var(--hair-strong);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--fg);transition:all .2s}.work-row:hover .arrow-bg{background:var(--accent);border-color:var(--accent);transform:rotate(-45deg)}.work-row:hover .arrow-bg svg{color:#fff}@media(max-width:1000px){.work-row{grid-template-columns:70px 1fr;grid-template-areas:"yr     arr" "name   name" "sum    sum";gap:14px 18px}.work-row .yr{grid-area:yr}.work-row .arrow-cell{grid-area:arr;flex-direction:row;align-items:center}.work-row>div:nth-child(2){grid-area:name}.work-row>div:nth-child(3){grid-area:sum}}.project-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}@media(max-width:900px){.project-grid{grid-template-columns:1fr}}.project-card{--card-pad: clamp(20px, 4vw, 36px);background:var(--card-bg);border:1px solid var(--hair);border-radius:8px;padding:var(--card-pad);display:flex;flex-direction:column;gap:22px;transition:border-color .2s,transform .2s}.project-image{display:block;position:relative;width:calc(100% + (var(--card-pad) * 2));margin:calc(var(--card-pad) * -1) calc(var(--card-pad) * -1) 6px;aspect-ratio:16/9;background:color-mix(in oklab,var(--fg) 4%,transparent);border-bottom:1px solid var(--hair);border-radius:8px 8px 0 0;overflow:hidden}.project-image img{width:100%;height:100%;object-fit:cover;display:block}.project-card:hover{border-color:var(--hair-strong);transform:translateY(-2px)}.project-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.project-name{font-size:32px;font-weight:500;letter-spacing:-.02em;line-height:1.05;color:var(--fg)}.project-tag{margin-top:6px;font-family:var(--mono);font-size:13px;color:var(--accent);letter-spacing:.02em}.project-link{width:40px;height:40px;border:1px solid var(--hair-strong);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--fg);flex-shrink:0;transition:all .2s}.project-link:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(-45deg)}.project-desc{color:var(--fg-dim);font-size:16px;line-height:1.6;margin:0;text-wrap:pretty}.project-stack{display:flex;flex-wrap:wrap;gap:6px}.project-stack .chip{font-family:var(--mono);font-size:11px;letter-spacing:.04em;padding:4px 8px;border:1px solid var(--hair);border-radius:4px;color:var(--fg-dim)}.project-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 24px;padding-top:22px;border-top:1px solid var(--hair);margin-top:auto}.project-meta .m{display:flex;flex-direction:column;gap:4px}.project-meta .m.repo{grid-column:1 / -1}.project-meta .k{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-quiet)}.project-meta .v{font-family:var(--mono);font-size:13px;color:var(--fg)}.project-meta .v a{color:var(--fg);text-decoration:none;border-bottom:1px solid var(--hair-strong)}.project-meta .v a:hover{color:var(--accent);border-color:var(--accent)}.project-meta .v .live{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--signal-amber);margin-right:6px;vertical-align:middle}.project-meta .v .live-MVP-ready{background:var(--signal-green)}.project-meta .v .live-shipped{background:var(--accent)}.skills-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--hair);border:1px solid var(--hair)}.skill-group{background:var(--bg);padding:36px}.skill-group h4{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin:0 0 22px;display:flex;align-items:center;gap:10px}.skill-group h4 .num{color:var(--fg-quiet)}.skill-group .pillrow{display:flex;flex-wrap:wrap;gap:8px}.skill-group .pill{font-family:var(--mono);font-size:13px;padding:6px 12px;border-radius:4px;border:1px solid var(--hair);color:var(--fg-dim);display:inline-flex;align-items:baseline;gap:8px;background:color-mix(in oklab,var(--fg) 2%,transparent)}.skill-group .pill .y{color:var(--fg-quiet);font-size:11px}.skill-group .pill.primary{color:var(--fg);border-color:color-mix(in oklab,var(--accent) 45%,var(--hair-strong));background:color-mix(in oklab,var(--accent) 12%,transparent)}.skill-group .pill.primary .y{color:var(--accent)}@media(max-width:800px){.skills-grid{grid-template-columns:1fr}}.about-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:start}@media(max-width:900px){.about-grid{grid-template-columns:1fr;gap:40px}.project-meta{grid-template-columns:1fr;gap:12px}}.about-photo{position:relative;aspect-ratio:3/5;width:100%;min-height:560px;border-radius:4px;overflow:hidden;background:var(--bg-2);border:1px solid var(--hair);display:block}.about-photo img{width:100%;height:100%;object-fit:cover;display:block}.about-body{font-size:clamp(20px,1.8vw,26px);line-height:1.5;color:var(--fg);font-weight:400;letter-spacing:-.01em;text-wrap:pretty}.about-body p{margin:0 0 24px}.about-body p:last-child{margin-bottom:0}.about-body .quiet{color:var(--fg-dim)}.about-meta{margin-top:40px;display:grid;grid-template-columns:1fr 1fr;gap:24px 40px;padding-top:28px;border-top:1px solid var(--hair)}.about-meta .k{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-quiet);margin-bottom:6px}.about-meta .v{font-size:16px;color:var(--fg)}.personal-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}@media(max-width:800px){.personal-grid{grid-template-columns:1fr}}.personal-card{background:var(--card-bg);border:1px solid var(--hair);border-radius:8px;padding:36px;display:flex;flex-direction:column;gap:14px}.personal-card.highlight{border-color:color-mix(in oklab,var(--accent) 25%,var(--hair));background:linear-gradient(180deg,color-mix(in oklab,var(--accent) 4%,var(--card-bg)) 0%,var(--card-bg) 100%)}.personal-kicker{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--accent)}.personal-title{font-size:28px;font-weight:500;letter-spacing:-.02em;line-height:1.1;margin:0;color:var(--fg)}.personal-body{color:var(--fg-dim);font-size:16px;line-height:1.55;margin:0;text-wrap:pretty}.personal-body strong{color:var(--fg);font-weight:500}.award{margin-top:12px;display:flex;align-items:center;gap:18px;padding:18px;border:1px solid var(--hair);border-radius:6px;background:color-mix(in oklab,var(--fg) 2%,transparent)}.award-medal{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#d4a857,#8a6a2c);color:#fff;font-weight:500;font-size:22px;letter-spacing:-.02em;display:flex;align-items:center;justify-content:center;flex-shrink:0}.award-medal .ord{font-size:11px;margin-left:1px;align-self:flex-start;margin-top:4px}.award-title{font-size:16px;color:var(--fg);font-weight:500;letter-spacing:-.01em}.award-sub{font-family:var(--mono);font-size:12px;color:var(--fg-quiet);margin-top:4px;letter-spacing:.04em}.contact{text-align:center;padding:clamp(96px,14vw,200px) 0;border-top:1px solid var(--hair);position:relative;overflow:hidden}.contact .lead-line{font-family:var(--mono);font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:32px}.contact h2{font-weight:500;font-size:clamp(48px,9vw,144px);line-height:.95;letter-spacing:-.04em;margin:0;text-wrap:balance}.contact h2 a{color:var(--accent);text-decoration:none;border-bottom:3px solid var(--accent);padding-bottom:6px;transition:opacity .16s}.contact h2 a:hover{opacity:.75}.contact .sub{margin-top:40px;display:flex;justify-content:center;gap:32px;flex-wrap:wrap;font-family:var(--mono);font-size:14px;color:var(--fg-dim);letter-spacing:.02em}.contact .sub a{color:var(--fg);text-decoration:none}.contact .sub a:hover{color:var(--accent)}.site-footer{border-top:1px solid var(--hair);padding:40px var(--pad-x)}.site-footer .inner{max-width:var(--max-w);margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:16px;font-family:var(--mono);font-size:12px;color:var(--fg-quiet);letter-spacing:.04em;flex-wrap:wrap}.site-footer .inner a{color:var(--fg-dim);text-decoration:none}.site-footer .inner a:hover{color:var(--fg)}.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s ease-out,transform .7s ease-out}.reveal.is-in{opacity:1;transform:translateY(0)}@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}@media(max-width:900px){.about-photo{min-height:0;aspect-ratio:4 / 5}.about-meta{grid-template-columns:1fr;gap:16px;margin-top:28px}}@media(max-width:560px){.hero h1{font-size:clamp(44px,12vw,88px)}.contact h2{font-size:clamp(34px,10vw,88px)}.contact h2 a{border-bottom-width:2px;padding-bottom:3px;word-break:break-word}.personal-card,.skill-group{padding:24px}.work-row{padding:28px 0}.work-row .name{font-size:clamp(22px,6.5vw,32px)}.project-card{gap:18px}.project-name{font-size:26px}.section-head{margin-bottom:40px}.hero-cta{width:100%}.hero-cta .btn{flex:1 1 auto;justify-content:center}.award{padding:14px;gap:14px}.award-medal{width:48px;height:48px;font-size:19px}.nav{gap:10px}.nav .pill{display:none}}
