*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{overflow:hidden;height:100vh}body{font-family:Inter,-apple-system,sans-serif;background:#f8f8f8;color:#111;-webkit-font-smoothing:antialiased;overflow:hidden;height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font:inherit}:root{--font-display: "Space Grotesk", sans-serif;--font-body: "Inter", sans-serif;--font-mono: "JetBrains Mono", monospace;--bg: #f8f8f8;--black: #111;--gray-300: #ccc;--gray-400: #999;--gray-600: #555;--nav-height: 80px;--sidebar-width: 110px}.scroll-container{width:100vw;height:100vh;overflow:hidden;-webkit-mask-image:linear-gradient(to right,black 0%,black calc(100% - 205px),transparent calc(100% - 85px));mask-image:linear-gradient(to right,black 0%,black calc(100% - 205px),transparent calc(100% - 85px))}.scroll-track{display:flex;height:100vh;will-change:transform}.panel{flex:0 0 100vw;height:100vh;overflow-y:auto;position:relative}.content-fade-overlay{position:fixed;top:0;right:0;width:calc(var(--sidebar-width) + 48px + 105px);height:100vh;background:linear-gradient(to right,transparent 0%,rgba(248,248,248,.5) 10%,rgba(248,248,248,.8) 20%,rgba(248,248,248,.95) 35%,#f8f8f8 48%,#f8f8f8 100%);pointer-events:none;z-index:95}.panel-inner{padding:var(--nav-height) calc(var(--sidebar-width) + 48px + 240px) 40px 80px;min-height:100vh;display:flex;align-items:center}.btn{display:inline-block;padding:16px 32px;background:var(--black);color:#fff;font-family:var(--font-display);font-weight:500;font-size:.95rem;border-radius:4px;letter-spacing:.02em;transition:opacity .2s}.btn:hover{opacity:.8}.btn-light{background:#fff;color:var(--black)}.blink{animation:blink-k 1s step-end infinite}@keyframes blink-k{50%{opacity:0}}.social-fixed{position:fixed;left:30px;bottom:30px;z-index:50;display:flex;flex-direction:column;gap:12px}.social-fixed a{width:36px;height:36px;border:1.5px solid var(--gray-300);border-radius:6px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:.75rem;font-weight:600;transition:border-color .2s}.social-fixed a:hover{border-color:var(--black)}.spectrum-border{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99;pointer-events:none;border:16px solid transparent;border-image:linear-gradient(135deg,var(--spectrum-color, #6366f1),var(--spectrum-color-2, #818cf8)) 1}.nav-logo{position:fixed;top:24px;left:30px;z-index:100;font-family:var(--font-display);font-size:1.4rem;font-weight:700}.logo-dot{color:var(--gray-400)}.sidebar{position:fixed;right:48px;top:0;bottom:0;z-index:100;width:var(--sidebar-width);display:flex;flex-direction:column;align-items:stretch;padding:32px 0;pointer-events:auto}.bar-readout{position:fixed;bottom:36px;left:50%;transform:translate(-50%);z-index:100;font-family:var(--font-mono);font-size:.75rem;font-weight:600;letter-spacing:.06em;white-space:nowrap;color:var(--gray-400);pointer-events:none}.nav-seg{position:absolute;left:0;right:0;cursor:pointer;display:flex;align-items:center;justify-content:flex-start;border-bottom:2px solid rgba(0,0,0,.25);transition:background .2s,opacity .2s;top:var(--seg-top, 0);height:var(--seg-height, 16.66%);text-decoration:none;overflow:visible}.nav-seg:last-of-type{border-bottom:none}.nav-seg:hover{background:#ffffff1f;opacity:.7}.nav-seg.active{background:#00000059}.seg-label{position:absolute;right:calc(100% + 14px);white-space:nowrap;font-family:var(--font-display);font-size:.7rem;font-weight:800;letter-spacing:.13em;color:var(--gray-500, #6b7280);transition:color .2s,text-shadow .2s;-webkit-user-select:none;user-select:none}.nav-seg.active .seg-label{color:var(--black);font-weight:900;text-shadow:0 0 1px rgba(0,0,0,.15)}.nav-seg:hover .seg-label{color:var(--gray-600)}.nav-seg:after{content:"";position:absolute;left:0;right:0;top:0;height:var(--fill-w, 0%);background:#0003;pointer-events:none;transition:height .15s ease}.spectrum-border{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99;pointer-events:none;border:4px solid transparent}.bar-track{flex:1;width:88px;margin:0 auto;border-radius:0;border:3.4px solid #000;background:linear-gradient(180deg,#70f,#04f 12%,#08f 20%,#0ca 32%,#0f4,#af0 52%,#fe0 60%,#f80 72%,#f20 85%,#c00);position:relative;cursor:pointer;min-height:200px;overflow:visible}.bar-indicator{position:absolute;left:0;right:0;height:3px;background:#fff;box-shadow:0 0 6px #fffc,0 0 12px #fff6;top:0;pointer-events:none;z-index:5;transition:top .06s linear}.bar-plot{position:absolute;left:0;right:0;height:1px;background:#0000004d;pointer-events:auto;cursor:pointer;transition:height .1s,background .1s;z-index:3}.bar-plot:hover{background:#fff9;height:2px}.bar-plot .plot-tip{position:absolute;right:calc(100% + 10px);top:50%;transform:translateY(-50%);white-space:nowrap;background:#111;color:#fff;padding:5px 10px;font-family:var(--font-mono);font-size:.6rem;border-radius:4px;opacity:0;pointer-events:none;transition:opacity .15s;box-shadow:0 2px 8px #0000004d}.bar-plot:hover .plot-tip{opacity:1}.wl-ruler{position:absolute;top:0;bottom:0;left:calc(100% + 14px);width:40px;pointer-events:none;z-index:2}.wl-tick{position:absolute;left:0;transform:translateY(-50%);font-family:var(--font-mono);font-size:.6rem;font-weight:700;letter-spacing:.04em;color:var(--gray-500, #6b7280);white-space:nowrap;line-height:1}.wl-tick:before{content:"";position:absolute;right:calc(100% + 3px);top:50%;transform:translateY(-50%);width:5px;height:1px;background:var(--gray-300, #d1d5db)}.panel-home-inner{flex-direction:column;align-items:flex-start;justify-content:center;padding-left:80px;gap:20px}.home-label{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gray-400)}.home-title{font-family:var(--font-display);font-size:clamp(4rem,10vw,8rem);font-weight:700;line-height:.95;letter-spacing:-.03em}.home-sub{font-size:1.1rem;line-height:1.6;color:var(--gray-600);max-width:480px}.panel-statement{padding:var(--nav-height) calc(var(--sidebar-width) + 24px) 40px 80px;justify-content:center}.statement-text{font-family:var(--font-display);font-size:clamp(2.2rem,5vw,4.2rem);font-weight:400;line-height:1.2;letter-spacing:-.02em;max-width:900px}.statement-text strong{font-weight:700}.panel-projects{flex:0 0 auto;width:auto}.projects-flow{display:flex;gap:0;align-items:flex-start;padding:calc(var(--nav-height) + 40px) 60px 40px 0;height:100vh}.project{width:460px;flex:0 0 460px;padding:0 60px;display:flex;flex-direction:column;justify-content:center;height:100%}.project-band{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.08em;color:var(--gray-400);margin-bottom:12px}.project-title{font-family:var(--font-display);font-size:1.6rem;font-weight:700;line-height:1.2;margin-bottom:16px;letter-spacing:-.01em}.project-desc{font-size:.95rem;line-height:1.65;color:var(--gray-600);margin-bottom:20px}.project-meta{font-family:var(--font-mono);font-size:.7rem;color:var(--gray-400);line-height:1.5}.project+.project{border-left:1px solid rgba(0,0,0,.06)}.project-artwork-link{position:absolute;top:50%;right:24px;transform:translateY(-50%);display:block;border-radius:8px;overflow:hidden;box-shadow:0 2px 12px #0000001a;transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s cubic-bezier(.22,1,.36,1),width .5s cubic-bezier(.22,1,.36,1),height .5s cubic-bezier(.22,1,.36,1),top .5s cubic-bezier(.22,1,.36,1);width:72px;height:72px;flex-shrink:0;z-index:2}.project-artwork-link:hover{transform:translateY(-50%) scale(1.05);box-shadow:0 4px 20px #0000002e}.project-artwork{width:100%;height:100%;object-fit:cover;display:block;transition:filter .3s ease}.project-artwork-link:hover .project-artwork{filter:brightness(1.05)}.project--expanded .project-artwork-link{top:40px;transform:none;width:100px;height:100px;border-radius:10px;box-shadow:0 4px 24px #0000001f}.project--expanded .project-artwork-link:hover{transform:scale(1.05)}.project:has(.project-artwork-link) .project-band,.project:has(.project-artwork-link) .project-title,.project:has(.project-artwork-link) .project-desc{padding-right:90px}.project--expanded:has(.project-artwork-link) .project-band,.project--expanded:has(.project-artwork-link) .project-title,.project--expanded:has(.project-artwork-link) .project-desc{padding-right:120px}.project-artwork--visual{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%;border-radius:0;box-shadow:none;opacity:0;transform:none;z-index:0;pointer-events:none;transition:opacity .5s cubic-bezier(.22,1,.36,1)}.project-artwork--visual .project-artwork{width:100%;height:100%;object-fit:cover;filter:brightness(.35) saturate(1.1);transition:filter .5s ease,transform .8s cubic-bezier(.22,1,.36,1);transform:scale(1.05)}.project-artwork--visual:hover{transform:none;box-shadow:none}.project:not(.project--expanded):hover .project-artwork--visual{opacity:1}.project:not(.project--expanded):hover .project-artwork--visual .project-artwork{transform:scale(1)}.project:has(.project-artwork--visual):not(.project--expanded):hover{background:transparent}.project:has(.project-artwork--visual):not(.project--expanded):hover .project-band{color:#fff9;position:relative;z-index:1}.project:has(.project-artwork--visual):not(.project--expanded):hover .project-title{color:#fff;opacity:1;position:relative;z-index:1;text-shadow:0 1px 8px rgba(0,0,0,.3)}.project:has(.project-artwork--visual):not(.project--expanded):hover .project-desc{color:#ffffffbf;position:relative;z-index:1}.project:has(.project-artwork--visual):not(.project--expanded):hover .project-meta{color:#ffffff80;position:relative;z-index:1}.project:has(.project-artwork--visual) .project-band,.project:has(.project-artwork--visual) .project-title,.project:has(.project-artwork--visual) .project-desc{padding-right:0}.project:has(.project-artwork--visual):not(.project--expanded):hover:after{color:#ffffff80}.project--expanded .project-artwork--visual{position:absolute;top:40px;left:auto;right:24px;bottom:auto;width:100px;height:100px;border-radius:10px;opacity:1;box-shadow:0 4px 24px #0000001f;pointer-events:auto}.project--expanded .project-artwork--visual .project-artwork{filter:none;transform:scale(1)}.project--expanded:has(.project-artwork--visual) .project-band,.project--expanded:has(.project-artwork--visual) .project-title,.project--expanded:has(.project-artwork--visual) .project-desc{padding-right:120px}.project{position:relative;cursor:pointer;transition:background .5s cubic-bezier(.22,1,.36,1),color .5s cubic-bezier(.22,1,.36,1),border-color .5s cubic-bezier(.22,1,.36,1)}.project:not(.project--expanded):hover{background:#00000004}.project:not(.project--expanded):hover .project-title{opacity:.7}.project:after{content:"+";position:absolute;top:50%;right:20px;transform:translateY(-50%);font-family:var(--font-mono);font-size:.7rem;color:var(--gray-300);opacity:0;transition:opacity .3s ease}.project:not(.project--expanded):hover:after{opacity:1}.project--expanded:after{content:"−";opacity:.5;top:32px;transform:none;color:var(--gray-400)}.project-header{transition:transform .6s cubic-bezier(.22,1,.36,1)}.project-band,.project-title,.project-desc,.project-meta{transition:opacity .3s ease,transform .4s cubic-bezier(.22,1,.36,1)}.project--expanded{justify-content:flex-start;padding-top:40px;background:linear-gradient(to bottom,transparent 0%,rgba(235,238,245,.55) 6%,rgba(235,238,245,.6) 12%,rgba(235,238,245,.6) 88%,rgba(235,238,245,.55) 94%,transparent 100%);border-left:3px solid transparent!important;border-image:linear-gradient(to bottom,transparent 0%,var(--black) 10%,var(--black) 90%,transparent 100%) 1;box-shadow:0 8px 32px #0000000a,0 2px 8px #00000005}.project--expanded .project-band{transform:translateY(0);color:var(--gray-600)}.project--expanded .project-title{font-size:1.3rem;margin-bottom:10px;color:var(--black)}.project--expanded .project-desc{font-size:.85rem;line-height:1.5;margin-bottom:12px;max-height:60px;overflow:hidden;color:var(--gray-600)}.project--expanded .project-meta{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid rgba(0,0,0,.08);color:var(--gray-400)}.project--expanded .psr-text{color:#333}.project-casestudy{display:none;flex-direction:column;gap:0;opacity:0;transform:translateY(12px)}.project--expanded .project-casestudy{display:flex;animation:caseStudyIn .6s cubic-bezier(.22,1,.36,1) forwards;animation-delay:.15s}@keyframes caseStudyIn{to{opacity:1;transform:translateY(0)}}.psr-block{margin-bottom:20px;opacity:0;transform:translateY(8px);animation:psrIn .5s cubic-bezier(.22,1,.36,1) forwards}.psr-block:nth-child(1){animation-delay:.2s}.psr-block:nth-child(2){animation-delay:.35s}.psr-block:nth-child(3){animation-delay:.5s}@keyframes psrIn{to{opacity:1;transform:translateY(0)}}.psr-label{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px;display:flex;align-items:center;gap:8px}.psr-label:before{content:"";display:inline-block;width:12px;height:1px}.psr-label--problem{color:#ef4444}.psr-label--problem:before{background:#ef4444}.psr-label--solution{color:#3b82f6}.psr-label--solution:before{background:#3b82f6}.psr-label--results{color:#22c55e}.psr-label--results:before{background:#22c55e}.psr-text{font-size:.82rem;line-height:1.6;color:var(--gray-600)}.results-metrics{display:flex;gap:20px;margin-top:10px;flex-wrap:wrap}.metric{display:flex;flex-direction:column;gap:2px;opacity:0;animation:metricIn .4s cubic-bezier(.22,1,.36,1) forwards}.metric:nth-child(1){animation-delay:.6s}.metric:nth-child(2){animation-delay:.7s}.metric:nth-child(3){animation-delay:.8s}@keyframes metricIn{to{opacity:1}}.metric-value{font-family:var(--font-display);font-size:1.4rem;font-weight:700;letter-spacing:-.02em;line-height:1}.metric-label{font-family:var(--font-mono);font-size:.55rem;color:var(--gray-400);letter-spacing:.06em;text-transform:uppercase}.project--expanded .project-casestudy:after{content:"";display:block;height:40px;flex-shrink:0}.project--expanded{overflow-y:auto;scrollbar-width:none}.project--expanded::-webkit-scrollbar{display:none}.section-group{display:flex;position:relative;height:100vh;flex-shrink:0}.section-group .hero-anchor{position:absolute;top:0;left:0;width:100vw;height:100vh;display:flex;align-items:center;padding:var(--nav-height) calc(var(--sidebar-width) + 24px) 40px 80px;z-index:10;pointer-events:none;transform-origin:top left;will-change:transform,opacity;--hero-scale: 1;--hero-tx: 0px;--hero-ty: 0px;--hero-opacity: 1;transform:translate(var(--hero-tx),var(--hero-ty)) scale(var(--hero-scale));opacity:var(--hero-opacity);transition:none}.section-group .hero-anchor.is-pinned{pointer-events:none}.hero-anchor .statement-text{max-width:900px;transform-origin:top left}.hero-section-label{position:absolute;top:14px;left:0;font-family:var(--font-mono);font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gray-400);opacity:0;transform:translateY(4px);transition:opacity .4s ease,transform .4s ease}.hero-anchor.is-pinned .hero-section-label{opacity:1;transform:translateY(0)}.section-group .projects-scroll{display:flex;flex-shrink:0;height:100vh}.section-group .panel-projects{position:relative;z-index:5}.hero-anchor:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:1px;background:#0000;transition:background .5s ease}.hero-anchor.is-pinned:after{background:#0000000a}.panel-dark{background:var(--black);color:#fff}.panel-contact-inner{flex-direction:column;align-items:flex-start;justify-content:center;gap:24px}.contact-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3.2rem);font-weight:700;letter-spacing:-.02em}.contact-sub{font-size:1rem;color:var(--gray-400);max-width:420px;line-height:1.6}.contact-links{display:flex;gap:24px;margin-top:8px}.contact-links a{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.06em;color:var(--gray-400);border-bottom:1px solid rgba(255,255,255,.15);padding-bottom:2px;transition:color .2s,border-color .2s}.contact-links a:hover{color:#fff;border-color:#fff}.footer{position:absolute;bottom:16px;left:80px;display:flex;gap:20px;font-family:var(--font-mono);font-size:.6rem;color:var(--gray-400);letter-spacing:.06em}
