:root{--navy-900:#0e2a54;--navy-800:#12356b;--navy-700:#1a4a8c;--navy-50:#edf1f7;--paper:#faf8f4;--paper-2:#f3efe7;--ink-900:#1a1c1f;--ink-700:#2e3138;--ink-500:#6b6f78;--ink-400:#8f939c;--ink-300:#c4c7ce;--ink-200:#e3e5ea;--ink-100:#eef0f3;--accent:oklch(72% .14 65);--accent-ink:oklch(38% .08 55);--accent-soft:oklch(94% .04 70);--sans:"Geist", "Inter", system-ui, -apple-system, sans-serif;--display:"Fraunces", "Times New Roman", serif;--mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--radius-sm:4px;--radius-md:8px;--radius-lg:14px;--shadow-card:0 1px 0 #0e2a540a, 0 2px 6px #0e2a540d;--shadow-card-hover:0 1px 0 #0e2a540f, 0 8px 22px #0e2a5417}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--sans);color:var(--ink-900);background:var(--paper);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"ss01", "cv11";font-size:16px;line-height:1.55}a{color:inherit}#root{min-height:100vh}.shell{grid-template-columns:320px 1fr;min-height:100vh;display:grid}.sidebar{background:var(--navy-800);color:#fff;border-right:1px solid #ffffff0f;flex-direction:column;gap:36px;height:100vh;padding:48px 36px;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-identity{flex-direction:column;gap:20px;display:flex}.avatar-frame{background:var(--navy-700);border:3px solid #ffffff1f;border-radius:50%;width:120px;height:120px;overflow:hidden;box-shadow:0 0 0 6px #ffffff0a}.avatar-frame img{object-fit:cover;width:100%;height:100%;display:block}.sidebar .name{font-family:var(--display);letter-spacing:-.01em;margin:0;font-size:30px;font-weight:400;line-height:1.08}.sidebar .role{color:#ffffffb8;letter-spacing:.01em;margin:4px 0 0;font-size:13.5px}.sidebar-nav{flex-direction:column;gap:2px;margin-top:8px;display:flex}.nav-item{color:#fffc;cursor:pointer;font-size:16px;font-family:var(--sans);background:0 0;border:none;border-top:1px solid #ffffff14;align-items:baseline;gap:14px;padding:12px 0;text-decoration:none;transition:color .2s,padding .25s;display:flex;position:relative}.nav-item:last-child{border-bottom:1px solid #ffffff14}.nav-item .idx{font-family:var(--mono);letter-spacing:.1em;color:#ffffff6b;min-width:28px;font-size:10.5px}.nav-item:hover{color:#fff;padding-left:6px}.nav-item.active{color:#fff}.nav-item.active:before{content:"";background:var(--accent);width:24px;height:1px;position:absolute;top:50%;left:-36px;transform:translateY(-50%)}.nav-item .arrow{opacity:0;color:var(--accent);margin-left:auto;transition:all .2s;transform:translate(-4px)}.nav-item:hover .arrow,.nav-item.active .arrow{opacity:1;transform:translate(0)}.sidebar-foot{color:#fff9;flex-direction:column;gap:14px;margin-top:auto;font-size:13px;display:flex}.sidebar-foot .links{flex-wrap:wrap;gap:10px;display:flex}.sidebar-foot a.btn{color:#ffffffe6;border:1px solid #ffffff29;border-radius:999px;align-items:center;gap:8px;padding:9px 14px;font-size:12.5px;text-decoration:none;transition:all .2s;display:inline-flex}.sidebar-foot a.btn:hover{background:#ffffff14;border-color:#ffffff47}.sidebar-foot .copyline{font-family:var(--mono);letter-spacing:.06em;color:#ffffff61;text-transform:uppercase;font-size:10.5px}.main{max-width:1180px;padding:64px 72px 120px;position:relative}.topbar{justify-content:space-between;align-items:center;gap:24px;margin-bottom:56px;display:flex}.crumb{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-500);font-size:11px}.crumb .sep{color:var(--ink-300);margin:0 8px}.crumb .cur{color:var(--accent-ink)}.page-head{margin-bottom:48px}.page-head .eyebrow{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-500);align-items:center;gap:12px;margin-bottom:18px;font-size:11px;display:flex}.page-head .eyebrow:before{content:"";background:var(--accent);width:18px;height:1px;display:inline-block}.page-head h1{font-family:var(--display);letter-spacing:-.02em;max-width:24ch;color:var(--ink-900);margin:0 0 20px;font-size:56px;font-weight:300;line-height:1.04}.page-head h1 em{color:var(--accent-ink);font-style:italic;font-weight:300}.page-head .lede{color:var(--ink-700);max-width:62ch;font-size:18px;line-height:1.55}.bio{grid-template-columns:1fr 1fr;gap:48px 80px;padding:16px 0 8px;display:grid}.bio p{color:var(--ink-700);margin:0;font-size:17px;line-height:1.65}.bio p strong,.bio p b{color:var(--ink-900);font-weight:600}.section-title{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-500);align-items:center;gap:14px;margin:56px 0 20px;font-size:11px;display:flex}.section-title:after{content:"";background:var(--ink-200);flex:1;height:1px}.skills{flex-wrap:wrap;gap:8px;display:flex}.skill{border:1px solid var(--ink-200);color:var(--ink-700);cursor:default;background:#fff;border-radius:999px;padding:7px 13px;font-size:13px;transition:all .2s}.skill:hover{border-color:var(--accent);color:var(--accent-ink);background:var(--accent-soft)}.skill.primary{background:var(--ink-900);color:#fff;border-color:var(--ink-900)}.skill.primary:hover{background:var(--navy-800);border-color:var(--navy-800);color:#fff}.cta-strip{background:var(--ink-900);color:#fff;border-radius:var(--radius-lg);justify-content:space-between;align-items:center;gap:32px;margin-top:72px;padding:40px 44px;display:flex;position:relative;overflow:hidden}.cta-strip:before{content:"";pointer-events:none;background:radial-gradient(circle at 100%,#ffb0592e,#0000 70%);width:220px;height:100%;position:absolute;top:0;right:0}.cta-strip h3{font-family:var(--display);letter-spacing:-.01em;max-width:22ch;margin:0;font-size:28px;font-weight:300;line-height:1.15}.cta-strip h3 em{color:var(--accent);font-style:italic;font-weight:300}.cta-actions{flex-shrink:0;gap:12px;display:flex}.cta-actions a,.cta-actions button{font-size:14px;font-family:var(--sans);cursor:pointer;border:none;border-radius:999px;align-items:center;gap:8px;padding:13px 22px;text-decoration:none;transition:all .2s;display:inline-flex}.cta-actions .cta-primary{background:var(--accent);color:var(--ink-900);font-weight:500}.cta-actions .cta-primary:hover{filter:brightness(1.05);transform:translateY(-1px)}.cta-actions .cta-ghost{color:#fff;background:0 0;border:1px solid #fff3}.cta-actions .cta-ghost:hover{border-color:#ffffff80}.projects{flex-direction:column;display:flex}.project-row{border-top:1px solid var(--ink-200);cursor:pointer;grid-template-columns:1.5fr 1fr 180px;align-items:center;gap:32px;padding:28px 0;text-decoration:none;transition:all .25s;display:grid;position:relative}.project-row:last-child{border-bottom:1px solid var(--ink-200)}.project-row:hover{background:linear-gradient(90deg,#0000,#ffb0590a 20%,#0000);padding-left:12px;padding-right:12px}.project-row .title{font-family:var(--display);letter-spacing:-.015em;color:var(--ink-900);font-size:26px;font-weight:300;line-height:1.15}.project-row .meta{color:var(--ink-500);flex-wrap:wrap;gap:6px;font-size:14px;display:flex}.project-row .meta .tag{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--ink-200);color:var(--ink-500);border-radius:999px;padding:4px 10px;font-size:10.5px}.project-row .thumb{border-radius:var(--radius-md);background:var(--ink-100);justify-self:end;width:160px;height:96px;transition:transform .3s;overflow:hidden}.project-row .thumb img{object-fit:cover;width:100%;height:100%}.project-row:hover .thumb{transform:scale(1.03)}.project-row .cta-arrow{opacity:0;color:var(--accent-ink);font-size:18px;transition:all .2s;position:absolute;top:50%;right:-28px;transform:translateY(-50%)}.project-row:hover .cta-arrow{opacity:1;right:-12px}.project-detail{max-width:800px}.project-detail .back-link{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-500);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;margin-bottom:32px;padding:0;font-size:11px;text-decoration:none;transition:color .2s;display:inline-flex}.project-detail .back-link:hover{color:var(--accent-ink)}.project-detail .carousel-wrapper{border-radius:var(--radius-lg);background:var(--paper-2);margin-bottom:48px;position:relative;overflow:hidden}.carousel-track{scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;display:flex;overflow-x:auto}.carousel-track::-webkit-scrollbar{display:none}.carousel-slide{scroll-snap-align:start;flex:0 0 100%;justify-content:center;align-items:center;height:500px;display:flex}.carousel-slide img{object-fit:contain;width:100%;max-height:500px;display:block}.carousel-arrow{color:#fff;cursor:pointer;background:#00000059;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:22px;line-height:1;transition:background .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.carousel-arrow:hover{background:#0000008c}.carousel-prev{left:12px}.carousel-next{right:12px}.carousel-dots{gap:8px;display:flex;position:absolute;bottom:14px;left:50%;transform:translate(-50%)}.carousel-dot{cursor:pointer;background:#ffffff80;border:none;border-radius:50%;width:8px;height:8px;padding:0;transition:background .2s}.carousel-dot.active{background:#fff}.project-detail .project-summary{color:var(--ink-700);margin-bottom:48px;font-size:18px;line-height:1.7}.project-detail .project-summary p{margin:0 0 1.2em}.project-detail .project-summary p:last-child{margin-bottom:0}.project-detail .project-summary strong{color:var(--ink-900);font-weight:600}.project-detail .tech-tags{flex-wrap:wrap;gap:8px;margin-bottom:48px;display:flex}.project-detail .references{flex-direction:column;gap:8px;display:flex}.project-detail .references a{color:var(--accent-ink);text-underline-offset:3px;cursor:pointer;font-size:15px;text-decoration:underline;transition:color .2s}.project-detail .references a:hover{color:var(--ink-900)}.feedback-meta{flex-wrap:wrap;align-items:center;gap:20px;margin-bottom:32px;display:flex}.feedback-meta .count{font-family:var(--display);letter-spacing:-.02em;color:var(--ink-900);font-size:48px;font-weight:300;line-height:1}.feedback-meta .count-unit{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-500);font-size:11px}.masonry{columns:3;column-gap:20px}.quote-card{break-inside:avoid;border:1px solid var(--ink-200);border-radius:var(--radius-md);background:#fff;flex-direction:column;gap:18px;margin-bottom:20px;padding:28px 28px 24px;transition:all .25s;display:flex;position:relative}.quote-card:hover{border-color:var(--ink-300);box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.quote-card .mark{font-family:var(--display);color:var(--accent);letter-spacing:-.04em;height:14px;font-size:44px;line-height:.5}.quote-card .body{color:var(--ink-700);margin:0;font-size:15.5px;line-height:1.6}.quote-card .body strong{color:var(--ink-900);font-weight:600}.quote-card .by{border-top:1px solid var(--ink-100);align-items:center;gap:12px;padding-top:16px;display:flex}.quote-card .by .who{flex-direction:column;gap:1px;display:flex}.quote-card .by .role-name{color:var(--ink-900);font-size:13px;font-weight:500}.view{animation:.42s cubic-bezier(.2,.7,.1,1) both fadein}@keyframes fadein{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.reveal{opacity:0;transition:opacity .7s cubic-bezier(.2,.7,.1,1),transform .7s cubic-bezier(.2,.7,.1,1);transform:translateY(16px)}.reveal.in{opacity:1;transform:translateY(0)}@media (width<=1200px){.shell{grid-template-columns:260px 1fr}.sidebar{padding:36px 28px}.sidebar .name{font-size:26px}.avatar-frame{width:96px;height:96px}.main{padding:48px 48px 96px}.page-head h1{font-size:44px}.project-row{grid-template-columns:1fr 140px;gap:20px}.project-row .meta{display:none}.project-row .thumb{width:140px;height:84px}.project-row .title{font-size:22px}.bio{grid-template-columns:1fr;gap:24px}.cta-strip{flex-direction:column;align-items:flex-start;padding:32px}.cta-actions{width:100%}.masonry{columns:2}}@media (width<=760px){.shell{grid-template-columns:1fr}.sidebar{z-index:10;flex-flow:wrap;align-items:center;gap:20px;height:auto;padding:28px 24px;position:sticky;top:0}.main{min-height:100vh}.sidebar-identity{flex-direction:row;flex:1;align-items:center;gap:16px}.avatar-frame{width:56px;height:56px}.sidebar .name{font-size:18px}.sidebar-nav{flex-direction:row;width:100%;margin-top:0}.nav-item{border-top:none;border-bottom:1px solid #ffffff14;flex:1;justify-content:center;padding:10px 0}.nav-item:last-child{border-bottom:1px solid #ffffff14}.nav-item .idx,.nav-item .arrow,.nav-item.active:before,.sidebar-foot{display:none}.main{padding:32px 20px 80px}.page-head h1{font-size:34px}.masonry{columns:1}.topbar{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:32px}.project-row{grid-template-columns:1fr 100px;gap:12px;padding:20px 0}.project-row .thumb{width:100px;height:64px}.project-row .title{font-size:18px}}
