:root{--ink-950:#110c08;--ink-900:#19120e;--ink-850:#201914;--ink-800:#29231d;--ink-700:#3d3732;--ink-500:#7f7974;--ink-300:#bcb6af;--ink-100:#f0eae4;--accent:#e06255;--accent-soft:#e0625524;--accent-line:#e0625566;--font-sans:"Inter Tight", "Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--font-serif:"Fraunces", "Times New Roman", serif;--section-pad:96px;--gutter:clamp(20px, 4vw, 56px);--glass-bg:#241e198c;--glass-border:#68625c2e;--glass-border-hover:#a49d9552}@supports (color:lab(0% 0 0)){:root{--ink-950:lab(3.68116% 1.3494 2.16347);--ink-900:lab(6.16505% 2.21551 3.56528);--ink-850:lab(9.48528% 2.53431 4.67978);--ink-800:lab(14.1269% 2.50317 4.76944);--ink-700:lab(23.4144% 2.09373 4.04474);--ink-500:lab(51.2609% 1.70156 3.33912);--ink-300:lab(74.4854% 1.39746 4.33755);--ink-100:lab(93.0452% 1.15132 3.60589);--accent:lab(57.8839% 49.5195 32.6605);--accent-soft:lab(57.8839% 49.5195 32.6605/.14);--accent-line:lab(57.8839% 49.5195 32.6605/.4);--glass-bg:lab(11.8062% 2.51749 4.78258/.55);--glass-border:lab(42.0039% 1.42604 4.35734/.18);--glass-border-hover:lab(65.2054% 1.64828 5.0727/.32)}}*{box-sizing:border-box}html{scroll-behavior:smooth}html,body{background:var(--ink-950);color:var(--ink-100);font-family:var(--font-sans);font-feature-settings:"ss01", "cv11";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0}body{background:radial-gradient(ellipse 1200px 600px at 80% -10%, #55110e73, transparent 60%), radial-gradient(ellipse 900px 500px at 10% 30%, #3a0e0b59, transparent 60%), var(--ink-950);min-height:100vh;overflow-x:hidden}@supports (color:lab(0% 0 0)){body{background:radial-gradient(ellipse 1200px 600px at 80% -10%, lab(17.823% 31.2619 21.5264/.45), transparent 60%), radial-gradient(ellipse 900px 500px at 10% 30%, lab(11.1659% 21.7835 12.8741/.35), transparent 60%), var(--ink-950)}}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,textarea,select{color:inherit;font-family:inherit}.display{font-family:var(--font-sans);letter-spacing:-.035em;font-size:clamp(40px,6vw,88px);font-weight:500;line-height:1}.h1{font-family:var(--font-sans);letter-spacing:-.028em;font-size:clamp(28px,3.6vw,52px);font-weight:500;line-height:1.05}.h2{font-family:var(--font-sans);letter-spacing:-.022em;font-size:clamp(22px,2.4vw,36px);font-weight:500;line-height:1.1}.body-lg{color:var(--ink-300);letter-spacing:-.005em;text-wrap:pretty;font-size:clamp(17px,1.4vw,22px);line-height:1.55}.body{color:var(--ink-300);font-size:16px;line-height:1.6}.mono{font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;color:var(--ink-500);font-size:12px;font-weight:450}.mono-md{font-family:var(--font-mono);letter-spacing:.02em;color:var(--ink-300);font-size:13px}.shell{max-width:1440px;padding:0 var(--gutter);margin:0 auto}section{padding-top:var(--section-pad);padding-bottom:var(--section-pad);position:relative}.section-header{grid-template-columns:1fr;gap:24px;margin-bottom:64px;display:grid}@media (min-width:900px){.section-header{grid-template-columns:220px 1fr;align-items:end;gap:40px}}.section-header.centered{text-align:center;flex-direction:column;align-items:center;gap:20px;margin-bottom:56px;display:flex}.section-header.centered .h1{text-wrap:balance;margin:0}.section-header.centered .section-marker{gap:14px}.section-header.centered .section-sub{max-width:56ch;margin:0}.section-marker{align-items:center;gap:12px;display:flex}.section-marker .dot{background:var(--accent);width:6px;height:6px;box-shadow:0 0 12px var(--accent);border-radius:50%}.section-divider{justify-content:center;align-items:center;gap:16px;max-width:720px;margin:0 auto 80px;padding:0 8px;display:flex}.section-divider .line{transform-origin:50%;background:linear-gradient(90deg,#0000 0%,#68625c40 50%,#0000 100%);background:linear-gradient(90deg,#0000 0%,lab(42.0039% 1.42604 4.35734/.25) 50%,#0000 100%);flex:1;height:1px;transition:transform 1.1s cubic-bezier(.6,0,.2,1) .2s;transform:scaleX(0)}.section-divider.in .line{transform:scaleX(1)}.section-divider .diamond{background:var(--accent);width:7px;height:7px;box-shadow:0 0 18px var(--accent-line);border-radius:1px;transition:transform .55s cubic-bezier(.5,1.6,.4,1) .9s;transform:rotate(45deg)scale(0)}.section-divider.in .diamond{transform:rotate(45deg)scale(1)}.topnav{z-index:50;padding:18px var(--gutter);-webkit-backdrop-filter:blur(14px)saturate(140%);background:#110c0859;background:lab(3.68116% 1.3494 2.16347/.35);border-bottom:1px solid #68625c00;border-bottom:1px solid lab(42.0039% 1.42604 4.35734/0);justify-content:space-between;align-items:center;transition:background .35s,border-color .35s,padding .35s,-webkit-backdrop-filter .35s,backdrop-filter .35s;display:flex;position:fixed;top:0;left:0;right:0}.topnav.is-scrolled{padding:12px var(--gutter);-webkit-backdrop-filter:blur(22px)saturate(160%);background:#110c08b3;background:lab(3.68116% 1.3494 2.16347/.7);border-bottom-color:#68625c1f;border-bottom-color:lab(42.0039% 1.42604 4.35734/.12)}.topnav .logo{font-family:var(--font-mono);letter-spacing:.04em;color:var(--ink-100);cursor:pointer;z-index:1;align-items:center;gap:10px;font-size:13px;display:flex}.topnav .logo .mark{border:1.5px solid var(--accent);width:22px;height:22px;color:var(--accent);border-radius:6px;place-items:center;font-size:11px;transition:transform .3s;display:grid}.topnav .logo:hover .mark{transform:rotate(-8deg)}.topnav nav{background:#20191466;background:lab(9.48528% 2.53431 4.67978/.4);border:1px solid #68625c1a;border:1px solid lab(42.0039% 1.42604 4.35734/.1);border-radius:999px;align-items:center;padding:4px 6px;display:none;position:relative}@media (min-width:760px){.topnav nav{display:flex}}.nav-pill{border:1px solid var(--accent-line);box-shadow:0 0 0 1px #ffffff0a inset, 0 6px 18px -8px var(--accent-line);pointer-events:none;background:#4026228c;background:lab(18.4491% 12.0069 8.1472/.55);border-radius:999px;transition:left .55s cubic-bezier(.4,1.4,.35,1),width .55s cubic-bezier(.4,1.4,.35,1),opacity .35s;position:absolute;top:4px;bottom:4px}@supports (color:lab(0% 0 0)){.nav-pill{box-shadow:0 0 0 1px lab(100% 0 0/.04) inset, 0 6px 18px -8px var(--accent-line)}}.topnav nav a{z-index:1;font-family:var(--font-mono);letter-spacing:.04em;color:var(--ink-500);text-transform:uppercase;border-radius:999px;padding:8px 14px;font-size:11.5px;transition:color .3s;position:relative}.topnav nav a:hover,.topnav nav a.is-active{color:var(--ink-100)}.topnav nav a .num{color:var(--ink-700);margin-right:8px;font-size:10px;transition:color .3s}.topnav nav a.is-active .num,.topnav nav a:hover .num{color:var(--accent)}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}.nav-pill{transition:opacity .2s}}.hero{padding-top:calc(var(--section-pad) + 40px);flex-direction:column;justify-content:center;min-height:100vh;padding-bottom:120px;display:flex}.hero-grid{grid-template-columns:1fr;gap:48px;display:grid}@media (min-width:1000px){.hero-grid{grid-template-columns:1fr 320px;align-items:end;gap:80px}}.hero-name-row{grid-template-columns:auto 1fr;align-items:center;gap:28px;display:grid}.avatar-slot{aspect-ratio:1;background:var(--glass-bg);border:1.5px solid var(--glass-border);-webkit-backdrop-filter:blur(16px)saturate(140%);background-image:radial-gradient(circle at 30% 30%, #e0625538, transparent 60%), var(--glass-bg);border-radius:50%;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:4px;width:clamp(96px,11vw,156px);display:flex;position:relative;overflow:hidden}@supports (color:lab(0% 0 0)){.avatar-slot{background-image:radial-gradient(circle at 30% 30%, lab(57.8839% 49.5195 32.6605/.22), transparent 60%), var(--glass-bg)}}.avatar-slot:after{content:"";border-radius:inherit;pointer-events:none;background-image:repeating-linear-gradient(135deg,#ffffff0a 0 6px,#0000 6px 12px);background-image:repeating-linear-gradient(135deg,lab(100% 0 0/.04) 0 6px,#0000 6px 12px);position:absolute;inset:0}.avatar-img{object-fit:cover;object-position:center 10%;z-index:1;border-radius:inherit;width:100%;height:100%;position:absolute;inset:0}.avatar-fallback{z-index:1;flex-direction:column;align-items:center;gap:4px;display:flex;position:relative}.avatar-initials{font-family:var(--font-sans);letter-spacing:-.02em;color:var(--ink-100);z-index:1;font-size:clamp(24px,2.6vw,38px);font-weight:500}.avatar-hint{letter-spacing:.08em;color:var(--ink-500);z-index:1;font-size:9px!important}.name-line{white-space:nowrap;display:block}@media (max-width:760px){.hero-name-row{grid-template-columns:1fr;gap:20px}.name-line{white-space:normal}}.hero-meta{flex-direction:column;gap:18px;margin-bottom:32px;display:flex}.location-pill{background:var(--glass-bg);border:1px solid var(--glass-border);font-family:var(--font-mono);letter-spacing:.04em;width:fit-content;color:var(--ink-300);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:999px;align-items:center;gap:10px;padding:8px 14px;font-size:12px;display:inline-flex}.location-pill .pulse{background:var(--accent);width:6px;height:6px;box-shadow:0 0 0 0 var(--accent);border-radius:50%;animation:2.4s ease-out infinite pulse}@keyframes pulse{0%{box-shadow:0 0 #e06255b3;box-shadow:0 0 lab(57.8839% 49.5195 32.6605/.7)}70%{box-shadow:0 0 0 8px #e0625500;box-shadow:0 0 0 8px lab(57.8839% 49.5195 32.6605/0)}to{box-shadow:0 0 #e0625500;box-shadow:0 0 lab(57.8839% 49.5195 32.6605/0)}}.hero h1.display{color:var(--ink-100);margin:0}.hero h1 .role{color:var(--ink-500);letter-spacing:-.02em;margin-top:.15em;font-size:.55em;font-weight:400;display:block}.hero h1 .accent-stroke{background:linear-gradient(180deg, var(--ink-100), var(--ink-300));color:#0000;-webkit-background-clip:text;background-clip:text}.hero-side{flex-direction:column;gap:24px;display:flex}.hero-side .body-lg{max-width:32ch}.cta-row{flex-wrap:wrap;gap:14px;margin-top:12px;display:flex}.btn{letter-spacing:-.005em;border:1px solid #0000;border-radius:999px;align-items:center;gap:10px;padding:14px 22px;font-size:14px;font-weight:500;transition:transform .2s,background .2s,border-color .2s;display:inline-flex}.btn:hover{transform:translateY(-1px)}.btn .arrow{transition:transform .2s;display:inline-block}.btn:hover .arrow{transform:translate(2px,-2px)}.btn-primary{background:var(--accent);color:var(--ink-100);border-color:var(--accent)}.btn-primary:hover{background:#f17264;background:lab(63.6935% 49.4079 32.2534)}.btn-ghost{background:var(--glass-bg);color:var(--ink-100);border-color:var(--glass-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn-ghost:hover{border-color:var(--glass-border-hover)}.hero-stats{text-align:center;border-top:1px solid #68625c1f;border-top:1px solid lab(42.0039% 1.42604 4.35734/.12);flex-wrap:wrap;justify-content:center;align-items:baseline;gap:32px 56px;width:100%;margin:64px auto 0;padding-top:32px;display:flex}.stat{white-space:nowrap;align-items:baseline;gap:14px;display:inline-flex}.stat .num{letter-spacing:-.03em;color:var(--ink-100);font-size:clamp(28px,2.6vw,40px);font-weight:500;line-height:1}.stat .lbl{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-500);margin:0;font-size:11px;display:inline-block}.about-grid{grid-template-columns:1fr;gap:24px;display:grid}@media (min-width:900px){.about-grid{grid-template-columns:220px 1fr 1fr;gap:40px}}.about-grid p{margin:0}.about-grid p+p{margin-top:1em}.glass{background:var(--glass-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(16px)saturate(140%);border-radius:20px;transition:border-color .35s,transform .35s,background .35s;position:relative;overflow:hidden}.glass:before{content:"";border-radius:inherit;pointer-events:none;background:linear-gradient(135deg,#ffffff0f 0%,#0000 40% 60%,#ffffff05 100%);background:linear-gradient(135deg,lab(100% 0 0/.06) 0%,#0000 40% 60%,lab(100% 0 0/.02) 100%);position:absolute;inset:0}.glass:hover{border-color:var(--glass-border-hover);background:#29231da6;background:lab(14.1269% 2.50317 4.76944/.65)}.flagship{grid-template-columns:1fr;gap:24px;margin-bottom:32px;padding:36px;display:grid}@media (min-width:1000px){.flagship{grid-template-columns:420px 1fr;gap:56px;padding:48px}}.flagship-meta{flex-direction:column;align-self:center;gap:20px;display:flex}.flagship-meta .badge{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--accent);align-items:center;gap:8px;width:fit-content;font-size:11px;display:inline-flex}.flagship-meta .badge:before{content:"";background:var(--accent);width:24px;height:1px}.flagship-meta h3{letter-spacing:-.025em;margin:0;font-size:clamp(28px,3vw,42px);font-weight:500;line-height:1.05}.flagship-meta .tagline{color:var(--ink-300);max-width:36ch;margin:0;font-size:17px;line-height:1.55}.flagship-stats{flex-wrap:wrap;gap:32px;margin-top:8px;display:flex}.flagship-stats .item .v{letter-spacing:-.02em;color:var(--ink-100);font-size:22px;font-weight:500}.flagship-stats .item .l{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-500);margin-top:6px;font-size:10px;display:block}.flagship-tags{flex-wrap:wrap;gap:8px;display:flex}.flagship-tags .tag{border:1px solid var(--glass-border);font-family:var(--font-mono);color:var(--ink-300);border-radius:999px;padding:5px 11px;font-size:11px}.flagship-cta{color:var(--ink-100);border-bottom:1px solid var(--glass-border-hover);align-items:center;gap:10px;width:fit-content;margin-top:8px;padding-bottom:4px;font-size:14px;font-weight:500;transition:border-color .2s,color .2s;display:inline-flex}.flagship-cta:hover{color:var(--accent);border-color:var(--accent)}.phone-shelf{scroll-snap-type:x mandatory;scrollbar-width:thin;scrollbar-color:var(--ink-700) transparent;align-items:flex-end;gap:16px;margin:0 -16px;padding:8px 16px;display:flex;overflow-x:auto}.phone-shelf::-webkit-scrollbar{height:6px}.phone-shelf::-webkit-scrollbar-thumb{background:var(--ink-800);border-radius:3px}.phone{aspect-ratio:9/19.5;background:var(--ink-900);scroll-snap-align:start;border:1.5px solid #4c474166;border:1.5px solid lab(30.4029% 1.44568 4.3718/.4);border-radius:28px;flex:none;width:168px;padding:6px;transition:transform .4s;position:relative;box-shadow:0 30px 60px -20px #00000080,inset 0 0 0 1px #857f790f;box-shadow:0 30px 60px -20px lab(0% 0 0/.5),inset 0 0 0 1px lab(53.6046% 1.41281 4.34804/.06)}.phone:hover{transform:translateY(-6px)}.phone:nth-child(odd){transform:rotate(-1deg)}.phone:nth-child(2n){transform:rotate(1deg)}.phone:nth-child(odd):hover{transform:rotate(-1deg)translateY(-6px)}.phone:nth-child(2n):hover{transform:rotate(1deg)translateY(-6px)}.phone-screen{background:linear-gradient(160deg,#451914,#250e0c);background:linear-gradient(160deg,lab(15.8158% 21.6752 14.3127),lab(6.88369% 12.0615 5.8176));border-radius:22px;width:100%;height:100%;position:relative;overflow:hidden}.phone-screen .notch{background:var(--ink-950);z-index:2;border-radius:999px;width:60px;height:18px;position:absolute;top:8px;left:50%;transform:translate(-50%)}.phone-img{object-fit:cover;object-position:top center;width:100%;height:100%;position:absolute;inset:0}.placeholder-stripes{text-align:center;background-image:repeating-linear-gradient(135deg,#ffffff0a 0 8px,#0000 8px 16px);background-image:repeating-linear-gradient(135deg,lab(100% 0 0/.04) 0 8px,#0000 8px 16px);flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:40px 12px;display:flex;position:absolute;inset:0}.placeholder-stripes .lbl{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:#ffffff80;color:lab(100% 0 0/.5);font-size:9px}.placeholder-stripes .num{font-family:var(--font-mono);color:#ffffffb3;color:lab(100% 0 0/.7);font-size:24px;font-weight:500}.work-grid{grid-template-columns:1fr;grid-auto-flow:dense;gap:20px;display:grid}@media (min-width:700px){.work-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1100px){.work-grid{grid-template-columns:repeat(3,1fr);gap:24px}}.work-card{cursor:pointer;flex-direction:column;min-height:240px;padding:24px;display:flex;position:relative}.work-card.span-2{grid-column:span 1;min-height:320px}@media (min-width:1100px){.work-card.span-2{grid-column:span 2}}.work-card .accent-bar{background:var(--accent);border-radius:0 4px 4px 0;width:0;height:32px;transition:width .35s cubic-bezier(.6,0,.2,1);position:absolute;top:24px;left:0}.work-card:hover .accent-bar{width:4px}.work-card .top{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:auto;display:flex}.work-card .idx,.work-card .year{font-family:var(--font-mono);letter-spacing:.04em;color:var(--ink-500);font-size:11px}.work-card .card-icon{border:1px solid var(--glass-border);background:var(--ink-900);object-fit:cover;border-radius:12px;width:52px;height:52px;transition:transform .35s cubic-bezier(.4,1.4,.35,1),border-color .35s;box-shadow:0 6px 18px -6px #00000080;box-shadow:0 6px 18px -6px lab(0% 0 0/.5)}.work-card:hover .card-icon{border-color:var(--accent-line);transform:translateY(-2px)rotate(-3deg)}.work-card.span-2 .card-icon{border-radius:14px;width:64px;height:64px}.work-card .external-tag{letter-spacing:.06em;color:var(--ink-500);border:1px solid var(--glass-border);background:#1a151180;background:lab(7.19909% 2.05951 3.4455/.5);border-radius:6px;padding:4px 8px;font-size:10px;transition:color .2s,border-color .2s;position:absolute;bottom:16px;right:16px}.work-card:hover .external-tag{color:var(--accent);border-color:var(--accent-line)}.work-archive{margin-top:64px}.archive-header{color:var(--ink-500);border-bottom:1px solid #68625c1f;border-bottom:1px solid lab(42.0039% 1.42604 4.35734/.12);padding-bottom:12px;display:block}.work-compact .info-row{cursor:default}.work-compact .info-row:hover{background:0 0;padding-left:8px}.work-compact .info-row:hover .name{color:var(--ink-100)}.eng-bucket{margin-bottom:64px}.eng-bucket:last-child{margin-bottom:0}.eng-bucket-header{border-bottom:1px solid #68625c1f;border-bottom:1px solid lab(42.0039% 1.42604 4.35734/.12);grid-template-columns:1fr auto;align-items:baseline;gap:12px;margin-bottom:24px;padding-bottom:16px;display:grid}.eng-bucket-header h3{letter-spacing:-.02em;color:var(--ink-100);margin:0;font-size:22px;font-weight:500}.eng-bucket-header .eng-sub{color:var(--ink-500);grid-column:1/2;margin:4px 0 0;font-size:14px}.eng-bucket-header .eng-count{color:var(--ink-700);grid-row:1/span 2;align-self:center}.eng-grid{grid-template-columns:1fr;gap:16px;display:grid}@media (min-width:720px){.eng-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1100px){.eng-grid{grid-template-columns:repeat(3,1fr);gap:20px}}.eng-card{min-height:180px;color:inherit;flex-direction:column;gap:12px;padding:22px;text-decoration:none;display:flex}.eng-card.is-link{cursor:pointer}.eng-card .eng-top{justify-content:space-between;align-items:center;display:flex}.eng-card .eng-kind{color:var(--accent);letter-spacing:.06em;font-size:11px}.eng-card .eng-arr{color:var(--ink-500);font-size:14px;transition:transform .2s,color .2s}.eng-card.is-link:hover .eng-arr{color:var(--accent);transform:translate(2px,-2px)}.eng-card .eng-name{letter-spacing:-.015em;color:var(--ink-100);margin:0;font-size:18px;font-weight:500;transition:color .2s}.eng-card.is-link:hover .eng-name{color:var(--accent)}.eng-card .eng-role{color:var(--ink-300);flex:1;margin:0;font-size:13.5px;line-height:1.5}.eng-card .eng-tags{flex-wrap:wrap;gap:6px;margin-top:auto;display:flex}.eng-card .eng-tags span{font-family:var(--font-mono);letter-spacing:.04em;color:var(--ink-500);background:#1a151166;background:lab(7.19909% 2.05951 3.4455/.4);border:1px solid #68625c2e;border:1px solid lab(42.0039% 1.42604 4.35734/.18);border-radius:4px;padding:3px 8px;font-size:10px}.eng-card .eng-link{color:var(--ink-500);border-top:1px solid #68625c1a;border-top:1px solid lab(42.0039% 1.42604 4.35734/.1);margin-top:4px;padding-top:12px;font-size:11px}.work-card .body{margin-top:60px}.work-card h4{letter-spacing:-.02em;color:var(--ink-100);margin:0 0 8px;font-size:22px;font-weight:500;line-height:1.15;transition:color .2s}.work-card.span-2 h4{font-size:32px}.work-card:hover h4{color:var(--accent)}.work-card .desc{color:var(--ink-300);margin:0 0 16px;font-size:14px;line-height:1.5}.work-card .tags{flex-wrap:wrap;gap:6px;display:flex}.work-card .tags span{font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;color:var(--ink-500);font-size:10px}.work-card .tags span+span:before{content:"·";color:var(--ink-700);margin-right:6px}.work-compact{border-top:1px solid #68625c1a;border-top:1px solid lab(42.0039% 1.42604 4.35734/.1);grid-template-columns:1fr;margin-top:32px;display:grid}.work-compact .row{cursor:pointer;border-bottom:1px solid #68625c1a;border-bottom:1px solid lab(42.0039% 1.42604 4.35734/.1);grid-template-columns:50px 1fr 100px;align-items:center;gap:20px;padding:18px 8px;transition:background .2s,padding .35s;display:grid;position:relative}@media (min-width:800px){.work-compact .row{grid-template-columns:60px 2fr 1.5fr 100px}}.work-compact .row:hover{background:#241e1966;background:lab(11.8062% 2.51749 4.78258/.4);padding-left:20px}.work-compact .row .idx{font-family:var(--font-mono);color:var(--ink-500);font-size:11px}.work-compact .row .name{color:var(--ink-100);letter-spacing:-.01em;font-size:16px;font-weight:500}.work-compact .row:hover .name{color:var(--accent)}.work-compact .row .meta{font-family:var(--font-mono);color:var(--ink-500);letter-spacing:.02em;font-size:11px;display:none}@media (min-width:800px){.work-compact .row .meta{display:block}}.work-compact .row .year{font-family:var(--font-mono);color:var(--ink-500);text-align:right;font-size:11px}.empty-state{text-align:center;border:1px dashed #68625c2e;border:1px dashed lab(42.0039% 1.42604 4.35734/.18);border-radius:16px;margin-top:32px;padding:48px 24px}.empty-state .mono{color:var(--ink-500);margin-bottom:12px;display:block}.empty-state p{color:var(--ink-300);margin:0}.empty-state .btn{margin-top:20px}.skills{grid-template-columns:1fr;gap:32px;display:grid}@media (min-width:800px){.skills{grid-template-columns:repeat(2,1fr);gap:48px}}@media (min-width:1200px){.skills{grid-template-columns:repeat(3,1fr)}}.skill-group h5{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-500);border-bottom:1px solid #68625c1f;border-bottom:1px solid lab(42.0039% 1.42604 4.35734/.12);justify-content:space-between;margin:0 0 16px;padding-bottom:12px;font-size:12px;font-weight:450;display:flex}.skill-group h5 .ct{color:var(--ink-700)}.chips{flex-wrap:wrap;gap:8px;display:flex}.chip{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--ink-100);letter-spacing:-.005em;cursor:default;border-radius:8px;padding:8px 14px;font-size:13px;transition:border-color .2s,color .2s,background .2s}.chip:hover{border-color:var(--accent-line);color:var(--accent)}.chip.primary{background:var(--accent-soft);border-color:var(--accent-line);color:var(--accent)}.timeline{flex-direction:column;gap:0;display:flex}.tl-row{border-top:1px solid #68625c1f;border-top:1px solid lab(42.0039% 1.42604 4.35734/.12);grid-template-columns:1fr;gap:12px;padding:32px 0;display:grid;position:relative}@media (min-width:800px){.tl-row{grid-template-columns:220px 1fr 200px;gap:48px}}.tl-row:last-child{border-bottom:1px solid #68625c1f;border-bottom:1px solid lab(42.0039% 1.42604 4.35734/.12)}.tl-row .when{font-family:var(--font-mono);letter-spacing:.04em;color:var(--ink-500);text-transform:uppercase;font-size:12px}.tl-row .role h4{letter-spacing:-.02em;color:var(--ink-100);margin:0 0 6px;font-size:22px;font-weight:500}.tl-row .role .co{color:var(--ink-500);margin:0 0 12px;font-size:14px}.tl-row .role .summary{color:var(--ink-300);max-width:60ch;margin:0;font-size:15px;line-height:1.55}.tl-row .stack{flex-wrap:wrap;align-items:flex-start;gap:6px;display:flex}.tl-row .stack span{font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;color:var(--ink-500);border:1px solid #68625c26;border:1px solid lab(42.0039% 1.42604 4.35734/.15);border-radius:4px;padding:4px 8px;font-size:10px}.two-col{grid-template-columns:1fr;gap:32px;display:grid}@media (min-width:900px){.two-col{grid-template-columns:1.4fr 1fr;gap:64px}}.edu-card{padding:32px}.edu-card+.edu-card{margin-top:16px}.edu-card h4{letter-spacing:-.02em;margin:0 0 6px;font-size:22px;font-weight:500}.edu-card .meta{font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;color:var(--ink-500);margin:0 0 16px;font-size:11px}.edu-card .body{color:var(--ink-300);margin:0;font-size:15px;line-height:1.55}.lang-list{flex-direction:column;gap:16px;display:flex}.lang-row{border-bottom:1px solid #68625c1a;border-bottom:1px solid lab(42.0039% 1.42604 4.35734/.1);grid-template-columns:1fr 100px;align-items:center;gap:20px;padding:16px 0;display:grid}.lang-row:last-child{border-bottom:none}.lang-row .name{font-size:17px;font-weight:500}.lang-row .level{font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;color:var(--ink-500);text-align:right;font-size:11px}.lang-bars{gap:4px;margin-top:6px;display:flex}.lang-bars .seg{background:#68625c26;background:lab(42.0039% 1.42604 4.35734/.15);border-radius:2px;flex:1;height:3px}.lang-bars .seg.on{background:var(--accent)}.contact-block{text-align:left;grid-template-columns:1fr;gap:40px;padding:56px 32px;display:grid}@media (min-width:900px){.contact-block{grid-template-columns:1.4fr 1fr;align-items:center;gap:80px;padding:80px 72px}}.contact-block h2{letter-spacing:-.028em;text-wrap:balance;margin:0;font-size:clamp(28px,3.2vw,44px);font-weight:500;line-height:1.1}.contact-block h2 .accent{color:var(--accent);font-style:italic;font-family:var(--font-serif);font-weight:400}.contact-links{flex-direction:column;gap:8px;width:100%;display:flex}.contact-row{cursor:pointer;border-bottom:1px solid #68625c26;border-bottom:1px solid lab(42.0039% 1.42604 4.35734/.15);grid-template-columns:80px 1fr 24px;align-items:center;gap:16px;padding:16px 0;transition:padding .25s;display:grid}.contact-row:hover{padding-left:6px}.contact-row .lbl{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-500);font-size:11px}.contact-row .val{color:var(--ink-100);font-size:16px}.contact-row:hover .val{color:var(--accent)}.contact-row .arr{color:var(--ink-500);transition:transform .25s,color .25s}.contact-row:hover .arr{color:var(--accent);transform:translate(2px,-2px)}footer{padding:32px var(--gutter);font-family:var(--font-mono);letter-spacing:.04em;color:var(--ink-500);text-transform:uppercase;border-top:1px solid #68625c1a;border-top:1px solid lab(42.0039% 1.42604 4.35734/.1);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;font-size:11px;display:flex}.reveal{--reveal-delay:0s;opacity:0;transition:opacity .9s cubic-bezier(.2, .7, .2, 1) var(--reveal-delay), transform .9s cubic-bezier(.2, .7, .2, 1) var(--reveal-delay);will-change:opacity, transform;transform:translateY(28px)}.reveal.in{opacity:1;transform:translateY(0)}section.reveal.in .shell>*{animation:.9s cubic-bezier(.2,.7,.2,1) backwards cascade-up}section.reveal.in .shell>:first-child{animation-delay:0s}section.reveal.in .shell>:nth-child(2){animation-delay:.12s}section.reveal.in .shell>:nth-child(3){animation-delay:.22s}section.reveal.in .shell>:nth-child(4){animation-delay:.32s}section.reveal.in .shell>:nth-child(5){animation-delay:.4s}@keyframes cascade-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.reveal,.reveal.in,section.reveal.in .shell>*{opacity:1!important;transition:none!important;animation:none!important;transform:none!important}.section-divider .line{transform:scaleX(1)!important}.section-divider .diamond{transform:rotate(45deg)scale(1)!important}}.detail-nav{-webkit-backdrop-filter:blur(22px)saturate(160%);background:#110c08b3;background:lab(3.68116% 1.3494 2.16347/.7);border-bottom:1px solid #68625c1f;border-bottom:1px solid lab(42.0039% 1.42604 4.35734/.12)}.detail-nav .logo .back-arrow{border:1.5px solid var(--accent);width:22px;height:22px;color:var(--accent);border-radius:6px;place-items:center;font-size:12px;transition:transform .25s;display:inline-grid}.detail-nav .logo:hover .back-arrow{transform:translate(-3px)}.detail-nav-meta{color:var(--ink-500);letter-spacing:.08em;align-items:center;gap:10px;font-size:11px;display:flex}.detail-nav-meta .sep{color:var(--ink-700)}.detail-hero{padding-top:calc(var(--section-pad) + 60px);padding-bottom:56px}.detail-meta-row{margin-bottom:32px}.detail-meta-row .badge{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--ink-300);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:999px;align-items:center;gap:10px;padding:8px 14px;display:inline-flex}.detail-meta-row .badge .dot{background:var(--accent);width:6px;height:6px;box-shadow:0 0 10px var(--accent);border-radius:50%}.detail-title{letter-spacing:-.032em;color:var(--ink-100);text-wrap:balance;margin:0;font-size:clamp(36px,5.6vw,80px);line-height:1}.detail-tagline{max-width:60ch;color:var(--ink-300);text-wrap:pretty;margin:28px 0 0;font-size:clamp(18px,1.6vw,24px);line-height:1.5}.detail-spec{border-top:1px solid #68625c1f;border-top:1px solid lab(42.0039% 1.42604 4.35734/.12);grid-template-columns:repeat(2,1fr);gap:24px 32px;margin-top:48px;padding-top:32px;display:grid}@media (min-width:800px){.detail-spec{grid-template-columns:repeat(4,1fr)}}.detail-spec>div{flex-direction:column;gap:8px;display:flex}.detail-spec .lbl{letter-spacing:.08em;color:var(--ink-500);font-size:10px}.detail-spec .val{color:var(--ink-100);letter-spacing:-.005em;font-size:15px;line-height:1.4}.detail-spec .stack-list{font-family:var(--font-mono);color:var(--ink-300);letter-spacing:0;font-size:12px;line-height:1.5}.detail-screens{padding:32px 0 64px}.screens-shelf{scroll-snap-type:x mandatory;scrollbar-width:thin;scrollbar-color:var(--ink-700) transparent;margin:0 calc(-1 * var(--gutter));padding:12px 4px 28px;padding-left:var(--gutter);padding-right:var(--gutter);align-items:flex-end;gap:20px;display:flex;overflow-x:auto}.screens-shelf::-webkit-scrollbar{height:6px}.screens-shelf::-webkit-scrollbar-thumb{background:var(--ink-800);border-radius:3px}.screens-shelf .phone{scroll-snap-align:start;width:220px}@media (min-width:800px){.screens-shelf .phone{width:240px}}.detail-overview{padding:64px 0}.overview-grid{grid-template-columns:1fr;gap:48px;display:grid}@media (min-width:1000px){.overview-grid{grid-template-columns:1.4fr 1fr;align-items:start;gap:80px}}.overview-text .kicker{margin-bottom:20px;display:block}.overview-text .body-lg{max-width:60ch;margin:0}.overview-stats{grid-template-columns:repeat(2,1fr);gap:14px;display:grid}.stat-card{border-radius:16px;flex-direction:column;gap:8px;padding:24px 20px;display:flex}.stat-card .v{letter-spacing:-.03em;color:var(--ink-100);font-size:clamp(28px,2.4vw,36px);font-weight:500;line-height:1}.stat-card .l{letter-spacing:.08em;color:var(--ink-500);font-size:10px}.kicker{letter-spacing:.08em;color:var(--accent);text-transform:uppercase;align-items:center;gap:10px;font-size:11px;display:inline-flex}.detail-sections{border-top:1px solid #68625c1a;border-top:1px solid lab(42.0039% 1.42604 4.35734/.1);padding:96px 0}.story-row{border-bottom:1px solid #68625c14;border-bottom:1px solid lab(42.0039% 1.42604 4.35734/.08);grid-template-columns:1fr;gap:16px;max-width:920px;margin:0 auto;padding:56px 0;display:grid}.story-row:first-child{padding-top:0}.story-row:last-child{border-bottom:none}.story-row .kicker{margin-bottom:4px}.story-row .story-title{letter-spacing:-.024em;color:var(--ink-100);text-wrap:balance;margin:0;font-size:clamp(22px,2.4vw,32px);font-weight:500;line-height:1.15}.story-row .story-body{text-wrap:pretty;max-width:64ch;margin:16px 0 0}.detail-links{border-top:1px solid #68625c1a;border-top:1px solid lab(42.0039% 1.42604 4.35734/.1);padding:64px 0 96px}.detail-links .kicker{margin-bottom:24px;display:block}.links-list{flex-direction:column;max-width:640px;display:flex}.link-row{cursor:pointer;border-bottom:1px solid #68625c1f;border-bottom:1px solid lab(42.0039% 1.42604 4.35734/.12);grid-template-columns:1fr 24px;align-items:center;gap:16px;padding:20px 0;transition:padding .25s;display:grid}.link-row:hover{padding-left:6px}.link-row .val{color:var(--ink-100);letter-spacing:-.01em;font-size:18px}.link-row:hover .val{color:var(--accent)}.link-row .arr{color:var(--ink-500);transition:transform .25s,color .25s}.link-row:hover .arr{color:var(--accent);transform:translate(2px,-2px)}.detail-footer{border-top:1px solid #68625c1a;border-top:1px solid lab(42.0039% 1.42604 4.35734/.1);padding:32px 0 96px}.prev-next{grid-template-columns:1fr;gap:16px;margin-bottom:48px;display:grid}@media (min-width:800px){.prev-next{grid-template-columns:1fr 1fr;gap:24px}}.pn-card{cursor:pointer;border-radius:18px;flex-direction:column;gap:8px;padding:28px;transition:transform .35s,border-color .35s,background .35s;display:flex}.pn-card:hover{transform:translateY(-3px)}.pn-card.align-right{text-align:right;align-items:flex-end}.pn-card .kicker{color:var(--ink-500)}.pn-card:hover .kicker{color:var(--accent)}.pn-card .pn-name{letter-spacing:-.02em;color:var(--ink-100);font-size:22px;font-weight:500;line-height:1.2}.pn-card .pn-tag{letter-spacing:.08em;color:var(--ink-500);font-size:10px}.back-home{justify-content:center;display:flex}.detail-404{text-align:center;place-items:center;min-height:80vh;display:grid}.detail-404 .shell{flex-direction:column;align-items:center;gap:24px;display:flex}.detail-404 .mono{color:var(--accent);letter-spacing:0;font-size:72px}.detail-404 h1{font-size:clamp(32px,4vw,56px)}.admin-shell{max-width:980px;padding:120px var(--gutter) 80px;margin:0 auto}.admin-header{flex-wrap:wrap;justify-content:space-between;align-items:end;gap:24px;margin-bottom:32px;display:flex}.admin-header h1{letter-spacing:-.03em;margin:0;font-size:clamp(32px,4vw,56px)}.admin-header .sub{color:var(--ink-500);margin-top:8px;font-size:14px}.admin-list{flex-direction:column;display:flex}.admin-list .row{border-bottom:1px solid #68625c1a;border-bottom:1px solid lab(42.0039% 1.42604 4.35734/.1);grid-template-columns:60px 1fr auto auto;align-items:center;gap:16px;padding:18px 16px;display:grid}.admin-list .row .idx{font-family:var(--font-mono);color:var(--ink-500);font-size:11px}.admin-list .row .name{color:var(--ink-100);font-size:16px;font-weight:500}.admin-list .row .meta{font-family:var(--font-mono);color:var(--ink-500);gap:12px;font-size:11px;display:flex}.admin-list .row .actions{gap:8px;display:flex}.admin-list .row .actions a,.admin-list .row .actions button{font-family:var(--font-mono);border:1px solid var(--glass-border);color:var(--ink-300);cursor:pointer;text-transform:uppercase;letter-spacing:.04em;background:0 0;border-radius:6px;padding:6px 12px;font-size:11px;transition:color .2s,border-color .2s}.admin-list .row .actions a:hover{color:var(--accent);border-color:var(--accent-line)}.admin-list .row .actions .danger:hover{color:#ff827a;color:lab(69.229% 56.4936 32.6318);border-color:#ff827a66;border-color:lab(69.229% 56.4936 32.6318/.4)}.form-grid{gap:24px;display:grid}.form-row{gap:8px;display:grid}.form-row label{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-500);font-size:11px}.form-row label .hint{color:var(--ink-700);text-transform:none;letter-spacing:0;margin-left:8px;font-size:11px}.form-row input,.form-row textarea,.form-row select{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--ink-100);border-radius:10px;padding:12px 14px;font-size:14px;transition:border-color .2s}.form-row textarea{resize:vertical;min-height:92px;line-height:1.5}.form-row input:focus,.form-row textarea:focus,.form-row select:focus{border-color:var(--accent-line);outline:none}.form-row.cols-2{grid-template-columns:1fr 1fr;gap:16px}@media (max-width:700px){.form-row.cols-2{grid-template-columns:1fr}}.repeater{flex-direction:column;gap:12px;display:flex}.repeater .item{border:1px solid var(--glass-border);background:#1a151166;background:lab(7.19909% 2.05951 3.4455/.4);border-radius:12px;gap:8px;padding:16px;display:grid}.repeater .item .item-row{grid-template-columns:1fr 1fr;gap:8px;display:grid}.repeater .item .item-row textarea{grid-column:1/-1}.repeater .item .item-actions{justify-content:flex-end;display:flex}.repeater button.add{font-family:var(--font-mono);border:1px dashed var(--glass-border);color:var(--ink-300);cursor:pointer;text-transform:uppercase;letter-spacing:.04em;background:0 0;border-radius:999px;align-self:flex-start;padding:8px 14px;font-size:11px}.repeater button.add:hover{color:var(--accent);border-color:var(--accent-line)}.repeater button.remove{font-family:var(--font-mono);border:1px solid var(--glass-border);color:var(--ink-500);cursor:pointer;text-transform:uppercase;letter-spacing:.04em;background:0 0;border-radius:4px;padding:4px 10px;font-size:10px}.repeater button.remove:hover{color:#ff827a;color:lab(69.229% 56.4936 32.6318);border-color:#ff827a66;border-color:lab(69.229% 56.4936 32.6318/.4)}.uploader{border:1px dashed var(--glass-border);text-align:center;cursor:pointer;background:#1a15114d;background:lab(7.19909% 2.05951 3.4455/.3);border-radius:12px;padding:24px;transition:border-color .2s}.uploader:hover{border-color:var(--accent-line)}.uploader input[type=file]{display:none}.uploader .lbl{font-family:var(--font-mono);color:var(--ink-300);letter-spacing:.06em;text-transform:uppercase;font-size:11px}.uploader .hint{color:var(--ink-500);margin-top:8px;font-size:12px;display:block}.upload-thumbs{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.upload-thumbs .thumb{border:1px solid var(--glass-border);background:var(--ink-900);border-radius:8px;width:64px;height:96px;position:relative;overflow:hidden}.upload-thumbs .thumb img{object-fit:cover;width:100%;height:100%}.upload-thumbs .thumb button{color:#fff;cursor:pointer;background:#000000b3;background:lab(0% 0 0/.7);border:none;border-radius:50%;width:18px;height:18px;font-size:11px;line-height:1;position:absolute;top:2px;right:2px}.form-actions{border-top:1px solid var(--glass-border);justify-content:flex-end;gap:12px;padding-top:16px;display:flex}.toast{z-index:60;background:var(--glass-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);color:var(--ink-100);border-radius:10px;padding:12px 18px;font-size:13px;position:fixed;bottom:24px;right:24px}.toast.error{color:#ffb8b1;color:lab(81.6511% 30.9962 17.0515);border-color:#fa686380;border-color:lab(63.4204% 56.5783 32.9929/.5)}.lab-shell{flex-direction:column;min-height:100vh;display:flex}.lab-nav{padding:28px var(--gutter);justify-content:space-between;align-items:center;gap:20px;display:flex}.lab-mark{-webkit-user-select:none;user-select:none;width:auto;height:36px;display:block}.lab-meta-link{color:var(--ink-500);transition:color .2s}.lab-meta-link:hover{color:var(--ink-100)}.lab-hero{text-align:center;padding:60px var(--gutter) 80px;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:32px;display:flex}.lab-kicker{font-family:var(--font-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-500);font-size:12px}.lab-kicker .accent{color:var(--accent)}.lab-title{font-family:var(--font-serif);letter-spacing:-.025em;max-width:18ch;color:var(--ink-100);text-wrap:balance;margin:0;font-size:clamp(40px,6.4vw,92px);font-style:italic;font-weight:400;line-height:1.05}.lab-title .accent{color:var(--accent);font-style:italic}.lab-sub{color:var(--ink-300);letter-spacing:-.005em;text-wrap:pretty;max-width:56ch;margin:0;font-size:clamp(16px,1.4vw,20px);line-height:1.6}.lab-cta{background:var(--accent);color:var(--ink-950);letter-spacing:-.005em;box-shadow:0 12px 32px -16px var(--accent-line);border-radius:999px;align-items:center;gap:14px;margin-top:4px;padding:16px 26px;font-size:15px;font-weight:500;transition:transform .2s,background .2s,box-shadow .2s;display:inline-flex}.lab-cta:hover{box-shadow:0 18px 38px -16px var(--accent-line);background:#f17264;background:lab(63.6935% 49.4079 32.2534);transform:translateY(-1px)}.lab-cta .arr{transition:transform .2s;display:inline-block}.lab-cta:hover .arr{transform:translate(3px)}.lab-cta-row{flex-direction:column;align-items:center;gap:14px;margin-top:4px;display:flex}.lab-cta-secondary{color:var(--ink-500);letter-spacing:.05em;font-size:12px;transition:color .2s}.lab-cta-secondary:hover{color:var(--ink-100)}.lab-foot{padding:24px var(--gutter) 28px;color:var(--ink-500);justify-content:space-between;gap:12px;display:flex}@media (max-width:600px){.lab-meta-link{display:none}.lab-foot{flex-direction:column;align-items:flex-start}}
