:root{--bg: #000000;--bg-elev: #08080a;--bg-overlay: rgba(0, 0, 0, .72);--ink: #f2ece2;--ink-dim: #8a857c;--ink-mute: #3e3b36;--rule: rgba(242, 236, 226, .09);--rule-strong: rgba(242, 236, 226, .22);--accent: #f5f1ea;--f-display: "Geist", "Inter Tight", system-ui, sans-serif;--f-body: "Geist", "Inter Tight", system-ui, sans-serif;--f-mono: "JetBrains Mono", ui-monospace, Menlo, monospace;--pad-x: clamp(24px, 4.5vw, 88px);--pad-y: clamp(80px, 10vw, 160px);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-io: cubic-bezier(.65, 0, .35, 1);--dur-s: .32s;--dur-m: .56s;--dur-l: .9s}[data-accent=bone]{--accent: #f5f1ea}[data-accent=amber]{--accent: #c9a56b}[data-accent=rust]{--accent: #a0543a}[data-accent=arctic]{--accent: #8aa6b8}[data-display=geist]{--f-display: "Geist", system-ui, sans-serif}[data-display=instrument]{--f-display: "Instrument Serif", "Times New Roman", serif}[data-display=space]{--f-display: "Space Grotesk", system-ui, sans-serif}[data-display=fraunces]{--f-display: "Fraunces", "Times New Roman", serif}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}html{background:var(--bg)}body{background:var(--bg);color:var(--ink);font-family:var(--f-body);font-size:15px;line-height:1.55;font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow:hidden;height:100vh;overscroll-behavior:none}img,video{display:block;max-width:100%}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer}::selection{background:var(--accent);color:#000}.letterbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;pointer-events:none}.letterbox .bar{position:absolute;left:0;right:0;background:#000;height:50vh;transition:transform 1.1s var(--ease-io)}.letterbox .bar.top{top:0;transform:translateY(0)}.letterbox .bar.bottom{bottom:0;transform:translateY(0)}.letterbox.cleared .bar.top{transform:translateY(-100%)}.letterbox.cleared .bar.bottom{transform:translateY(100%)}.nav{position:fixed;top:0;left:0;right:0;z-index:80;display:flex;align-items:center;justify-content:space-between;padding:22px var(--pad-x);mix-blend-mode:difference;color:#fff;font-family:var(--f-body);font-size:12px;letter-spacing:.14em;text-transform:uppercase}.nav .mark{font-weight:500;letter-spacing:.18em}.nav ul{list-style:none;margin:0;padding:0;display:flex;gap:36px}.nav a{position:relative;padding:4px 0;color:inherit;opacity:.82;transition:opacity var(--dur-s) var(--ease-out)}.nav a:hover{opacity:1}.nav a:after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .42s var(--ease-out)}.nav a:hover:after,.nav a.is-active:after{transform:scaleX(1)}@media (max-width: 720px){.nav ul{gap:18px}.nav ul li:nth-child(n+4){display:none}}.hero{position:relative;height:100vh;min-height:640px;overflow:hidden;display:grid;place-items:center}.hero .reel{position:absolute;top:0;right:0;bottom:0;left:0;background:#000}.hero .reel .frame{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;transition:opacity 1.8s var(--ease-io)}.hero .reel .frame.is-active{opacity:1}.hero .reel .frame:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,transparent 40%,rgba(0,0,0,.55) 100%);pointer-events:none}.hero .reel .frame:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.95  0 0 0 0 0.93  0 0 0 0 0.88  0 0 0 0.09 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");mix-blend-mode:overlay;opacity:.5;pointer-events:none}.hero.is-letterbox .reel{top:8vh;right:6vw;bottom:8vh;left:6vw}.hero .copy{position:relative;z-index:2;padding:0 var(--pad-x);text-align:center;color:#fff;max-width:960px}.hero .eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:13px;letter-spacing:.24em;text-transform:uppercase;color:#ffffffb3;margin-bottom:28px}.hero .eyebrow:before,.hero .eyebrow:after{content:"";width:28px;height:1px;background:currentColor}.hero h1{font-family:var(--f-display);font-weight:300;font-size:clamp(36px,6vw,84px);line-height:1.02;letter-spacing:-.02em;margin:0;text-wrap:balance}[data-display=instrument] .hero h1,[data-display=fraunces] .hero h1{font-style:italic;font-weight:400;letter-spacing:-.01em}.hero .meta{margin-top:40px;display:flex;justify-content:center;gap:28px;font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:#ffffff8c}.hero .meta span{display:inline-flex;align-items:center;gap:12px}.hero .meta span+span:before{content:"";width:1px;height:12px;background:#ffffff40;display:inline-block}.hero[data-style=typefirst] .copy h1{font-size:clamp(56px,11vw,180px);letter-spacing:-.03em}.hero[data-style=typefirst] .reel{opacity:.32}.scroll-hint{position:absolute;left:50%;bottom:32px;transform:translate(-50%);color:#ffffff80;font-size:12px;letter-spacing:.28em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:10px}.scroll-hint .tick{width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,.6),transparent);animation:tick 2.4s var(--ease-io) infinite}@keyframes tick{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}to{transform:scaleY(0);transform-origin:bottom}}.section{position:relative;padding:var(--pad-y) var(--pad-x);border-top:1px solid var(--rule)}.section-head{display:grid;grid-template-columns:minmax(120px,1fr) 3fr;gap:48px;margin-bottom:clamp(48px,7vw,96px);align-items:baseline}.section-head .label{font-size:13px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-dim);display:flex;align-items:center;gap:10px}.section-head .label .idx{color:var(--accent);font-family:var(--f-mono);font-size:12px}.section-head h2{font-family:var(--f-display);font-weight:300;font-size:clamp(28px,4vw,56px);line-height:1.08;letter-spacing:-.01em;margin:0;text-wrap:balance;max-width:20ch}[data-display=instrument] .section-head h2,[data-display=fraunces] .section-head h2{font-style:italic;font-weight:400}@media (max-width: 780px){.section-head{grid-template-columns:1fr;gap:20px}}.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}.reveal.is-in{opacity:1;transform:none}.work-index{position:relative}.work-index ol{list-style:none;margin:0;padding:0}.work-index li{position:relative;border-top:1px solid var(--rule)}.work-index li:last-child{border-bottom:1px solid var(--rule)}.work-index .row{position:relative;display:grid;grid-template-columns:60px 1fr auto auto;gap:32px;align-items:baseline;padding:28px 32px;cursor:pointer;transition:color var(--dur-s) var(--ease-out),translate var(--dur-m) var(--ease-out);isolation:isolate}.work-index .row>*:not(.rowbg){position:relative;z-index:1}.work-index .row .rowbg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;opacity:.22;z-index:0}.work-index .row .rowbg:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,#000000c7,#0000008c,#000000c7)}.work-index .row.is-on{translate:24px 0;color:var(--ink)}.work-index .row .num{font-family:var(--f-mono);font-size:13px;color:var(--ink-dim);letter-spacing:.08em}.work-index .row .title{font-family:var(--f-display);font-size:clamp(28px,4.2vw,56px);font-weight:300;letter-spacing:-.01em;color:var(--ink);line-height:1;transition:transform var(--dur-m) var(--ease-out)}[data-display=instrument] .work-index .row .title,[data-display=fraunces] .work-index .row .title{font-style:italic;font-weight:400}.work-index .row.is-on .title{transform:translate(8px);color:var(--accent)}.work-index .row .kind{font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-dim)}.work-index .row .year{font-family:var(--f-mono);font-size:12px;color:var(--ink-dim)}.cursor-preview{position:fixed;width:380px;height:240px;pointer-events:none;z-index:90;--nudge-x: 0px;--scale: .96;opacity:0;transform:translateY(calc(-100% - 56px)) scale(var(--scale));transform-origin:50% 100%;transition:opacity .36s var(--ease-out),transform .42s var(--ease-out);overflow:visible;box-shadow:0 30px 80px #0009;margin-left:-190px;will-change:transform,opacity}.cursor-preview.is-on{opacity:1;--scale: 1}.cursor-preview[data-side=below]{transform:translateY(56px) scale(var(--scale));transform-origin:50% 0%}.cursor-preview .inner{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;transform:translate(var(--nudge-x));transition:transform .18s var(--ease-out)}.cursor-preview .scrub-ticks{position:absolute;left:0;right:0;bottom:-16px;display:flex;gap:4px;justify-content:center;transform:translate(var(--nudge-x));transition:transform .18s var(--ease-out)}.cursor-preview .scrub-ticks span{display:block;width:18px;height:1px;background:#ffffff38;transition:background var(--dur-s) var(--ease-out)}.cursor-preview .scrub-ticks span.is-on{background:var(--accent)}@media (hover: none),(max-width: 860px){.cursor-preview{display:none}}.work-grid{display:grid;grid-template-columns:1fr 1fr;column-gap:48px;row-gap:0}.work-grid .col{display:flex;flex-direction:column;gap:96px}.work-grid .col.shift{padding-top:140px}.work-grid .card{cursor:pointer;display:block}.work-grid .card .media{aspect-ratio:4 / 3;position:relative;overflow:hidden}.work-grid .card.wide .media{aspect-ratio:3 / 2}.work-grid .card.tall .media{aspect-ratio:3 / 4}.work-grid .card .media .fill{position:absolute;top:0;right:0;bottom:0;left:0;transition:transform 1.2s var(--ease-out)}.work-grid .card:hover .media .fill{transform:scale(1.04)}.work-grid .card .meta{margin-top:20px;display:flex;align-items:baseline;justify-content:space-between;gap:16px}.work-grid .card .meta h3{font-family:var(--f-display);font-weight:300;font-size:clamp(20px,1.8vw,26px);margin:0;letter-spacing:-.005em}[data-display=instrument] .work-grid .card .meta h3,[data-display=fraunces] .work-grid .card .meta h3{font-style:italic;font-weight:400}.work-grid .card .meta .sub{font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-dim);white-space:nowrap}@media (max-width: 860px){.work-grid{grid-template-columns:1fr}.work-grid .col.shift{padding-top:0}.work-grid .col{gap:56px}}.work-marquee{display:flex;flex-direction:column;margin:0 calc(var(--pad-x) * -1)}.work-marquee .tile{position:relative;height:82vh;min-height:520px;overflow:hidden;border-top:1px solid var(--rule);cursor:pointer}.work-marquee .tile:last-child{border-bottom:1px solid var(--rule)}.work-marquee .tile .bg{position:absolute;top:-10%;right:0;bottom:-10%;left:0;transform:translateY(var(--parallax, 0px));will-change:transform}.work-marquee .tile .bg:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#00000040,#00000026 40%,#000000b8)}.work-marquee .tile .content{position:absolute;left:0;right:0;bottom:0;padding:48px var(--pad-x);display:grid;grid-template-columns:1fr auto;gap:32px;align-items:end;color:#fff}.work-marquee .tile h3{font-family:var(--f-display);font-weight:300;font-size:clamp(40px,6vw,88px);margin:0;line-height:1;letter-spacing:-.02em}[data-display=instrument] .work-marquee .tile h3,[data-display=fraunces] .work-marquee .tile h3{font-style:italic;font-weight:400}.work-marquee .tile .stats{display:flex;gap:24px;font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:#ffffffb3}.work-marquee .tile .stats span+span:before{content:"·";margin-right:24px;color:#ffffff59}.placeholder-media{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 70% 90% at 30% 40%,var(--pm-light) 0%,transparent 55%),radial-gradient(ellipse 80% 80% at 70% 80%,var(--pm-dark) 0%,transparent 60%),linear-gradient(135deg,var(--pm-base) 0%,var(--pm-dark) 100%)}.placeholder-media:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 0.98  0 0 0 0 0.92  0 0 0 0.08 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");mix-blend-mode:overlay;opacity:.55}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:150;background:#000000f5;opacity:0;pointer-events:none;transition:opacity .52s var(--ease-out);overflow-y:auto;will-change:opacity}.overlay.is-open{opacity:1;pointer-events:auto}.overlay .bars{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.overlay .bars:before,.overlay .bars:after{content:"";position:absolute;left:0;right:0;height:50vh;background:#000;transition:transform .72s var(--ease-io)}.overlay .bars:before{top:0;transform:translateY(-100%)}.overlay .bars:after{bottom:0;transform:translateY(100%)}.overlay:not(.is-open) .bars:before{transform:translateY(0)}.overlay:not(.is-open) .bars:after{transform:translateY(0)}.overlay .close{position:fixed;top:22px;right:var(--pad-x);font-size:13px;letter-spacing:.24em;text-transform:uppercase;color:#fff;display:inline-flex;align-items:center;gap:14px;z-index:4;cursor:pointer}.overlay .close .x{position:relative;width:16px;height:16px;display:inline-block}.overlay .close .x:before,.overlay .close .x:after{content:"";position:absolute;left:0;top:50%;width:100%;height:1px;background:currentColor;transform-origin:center}.overlay .close .x:before{transform:rotate(45deg)}.overlay .close .x:after{transform:rotate(-45deg)}.overlay .close:hover{color:var(--accent)}.overlay .screen{position:relative;padding:120px var(--pad-x) 80px;max-width:1600px;margin:0 auto}.overlay .player{position:relative;width:100%;aspect-ratio:16 / 9;overflow:hidden;background:#000}.overlay .player .ph{position:absolute;top:0;right:0;bottom:0;left:0}.overlay .player .playbtn{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#fff;z-index:2}.overlay .player .playbtn .disc{width:92px;height:92px;border-radius:50%;border:1px solid rgba(255,255,255,.4);display:grid;place-items:center;transition:transform .52s var(--ease-out),border-color var(--dur-s) var(--ease-out),background var(--dur-s) var(--ease-out)}.overlay .player:hover .playbtn .disc{transform:scale(1.08);border-color:#fff;background:#ffffff0f}.overlay .player .triangle{width:0;height:0;border-style:solid;border-width:12px 0 12px 18px;border-color:transparent transparent transparent #fff;margin-left:5px}.overlay .titleblock{display:grid;grid-template-columns:3fr 2fr;gap:64px;margin-top:56px;padding-bottom:48px;border-bottom:1px solid var(--rule)}.overlay .titleblock .kicker{font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:18px}.overlay .titleblock h2{font-family:var(--f-display);font-weight:300;font-size:clamp(40px,6vw,96px);line-height:1;letter-spacing:-.02em;margin:0;text-wrap:balance}[data-display=instrument] .overlay .titleblock h2,[data-display=fraunces] .overlay .titleblock h2{font-style:italic;font-weight:400}.overlay .titleblock .synopsis{font-family:var(--f-display);font-weight:300;font-size:clamp(16px,1.4vw,20px);line-height:1.5;color:var(--ink);margin:0;align-self:end;max-width:36ch;text-wrap:pretty}[data-display=instrument] .overlay .titleblock .synopsis,[data-display=fraunces] .overlay .titleblock .synopsis{font-style:italic}.overlay .specs{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;padding:48px 0;border-bottom:1px solid var(--rule)}.overlay .specs dt{font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:10px}.overlay .specs dd{margin:0;font-size:14px;color:var(--ink)}.overlay .stills{margin-top:64px;display:grid;grid-template-columns:1fr 1fr;gap:24px}.overlay .stills .still{aspect-ratio:16/9;position:relative;overflow:hidden}.overlay .stills .still.full{grid-column:1 / -1;aspect-ratio:21/9}.overlay .credits{margin-top:64px;display:grid;grid-template-columns:1fr 1fr;gap:8px 64px;padding:48px 0;border-top:1px solid var(--rule)}.overlay .credits .row{display:grid;grid-template-columns:140px 1fr;gap:24px;padding:14px 0;border-bottom:1px solid var(--rule);font-size:13px}.overlay .credits .row .k{font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-dim)}@media (max-width: 900px){.overlay .titleblock{grid-template-columns:1fr}.overlay .specs{grid-template-columns:1fr 1fr}.overlay .stills,.overlay .credits{grid-template-columns:1fr}}.about .grid{display:grid;grid-template-columns:5fr 3fr;gap:96px;align-items:start}.about .prose p{font-family:var(--f-display);font-weight:300;font-size:clamp(20px,2.2vw,30px);line-height:1.38;color:var(--ink);margin:0 0 1.2em;max-width:28ch;text-wrap:pretty;letter-spacing:-.005em}[data-display=instrument] .about .prose p,[data-display=fraunces] .about .prose p{font-style:italic;font-weight:400}.about .portrait{position:relative;aspect-ratio:3 / 4;overflow:hidden;background:#0a0a0a}.about .portrait .ph{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 60% 70% at 50% 30%,#2a251f 0%,transparent 55%),linear-gradient(180deg,#0a0908,#141210)}.about .portrait .ph:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 0.97  0 0 0 0 0.9  0 0 0 0.12 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");mix-blend-mode:overlay}.about .portrait .tag{position:absolute;left:16px;bottom:16px;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:#ffffff8c}@media (max-width: 860px){.about .grid{grid-template-columns:1fr;gap:48px}}.clients .wall{display:grid;grid-template-columns:repeat(4,1fr);border-left:1px solid var(--rule);border-top:1px solid var(--rule)}.clients .cell{padding:44px 28px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);font-family:var(--f-display);font-weight:300;font-size:clamp(22px,2.2vw,32px);letter-spacing:-.01em;color:var(--ink);display:flex;align-items:center;transition:background var(--dur-s) var(--ease-out),color var(--dur-s) var(--ease-out);cursor:default;min-height:120px}.clients .cell:hover{background:var(--bg-elev);color:var(--accent)}.clients .cell img{max-width:100%;max-height:44px;width:auto;object-fit:contain;opacity:.5;filter:brightness(0) invert(1);transition:opacity var(--dur-s) var(--ease-out),filter var(--dur-s) var(--ease-out);pointer-events:none;-webkit-user-select:none;user-select:none}.clients .cell:hover img{opacity:1;filter:brightness(0) invert(1) sepia(1) saturate(.6) hue-rotate(0deg)}[data-display=instrument] .clients .cell,[data-display=fraunces] .clients .cell{font-style:italic;font-weight:400}@media (max-width: 860px){.clients .wall{grid-template-columns:repeat(2,1fr)}.clients .wall .cell:nth-child(4n+1):nth-last-child(1),.clients .wall .cell:nth-child(4n+1):nth-last-child(2){grid-column:auto}.clients .wall .cell:nth-child(odd):nth-last-child(1){grid-column:1 / span 2;justify-self:center}}.contact .direct{display:grid;gap:0;padding-top:32px;max-width:760px}.contact .direct .line{display:grid;grid-template-columns:140px 1fr;gap:32px;align-items:baseline;padding:28px 0;font-size:15px}.contact .direct .k{font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-dim)}.contact .email-copy{font-family:var(--f-display);font-weight:300;font-size:clamp(22px,2.4vw,34px);line-height:1.1;letter-spacing:-.01em;color:var(--ink);display:inline-flex;align-items:baseline;gap:18px;cursor:pointer;transition:color var(--dur-s) var(--ease-out);position:relative}[data-display=instrument] .contact .email-copy,[data-display=fraunces] .contact .email-copy{font-style:italic;font-weight:400}.contact .email-copy:hover{color:var(--accent)}.contact .email-copy .email-addr{border-bottom:1px solid currentColor;padding-bottom:2px;transition:border-color var(--dur-s) var(--ease-out)}.contact .email-copy .email-hint{font-family:var(--f-mono, var(--f-body));font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-mute);opacity:0;transform:translateY(2px);transition:opacity var(--dur-s) var(--ease-out),transform var(--dur-s) var(--ease-out),color var(--dur-s) var(--ease-out);white-space:nowrap;font-style:normal;font-weight:400;position:absolute;left:100%;top:50%;transform:translate(16px,-50%);margin-left:0}.contact .email-copy:hover .email-hint,.contact .email-copy:focus-visible .email-hint,.contact .email-copy.is-copied .email-hint{opacity:1;transform:translate(16px,-50%)}.contact .email-copy.is-copied,.contact .email-copy.is-copied .email-hint{color:var(--accent)}@media (max-width: 900px){.contact .direct .line{grid-template-columns:1fr;gap:8px;padding:20px 0}.contact .email-copy{gap:10px;flex-wrap:wrap}}.footer{padding:48px var(--pad-x);border-top:1px solid var(--rule);display:flex;justify-content:space-between;align-items:baseline;gap:24px;font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-dim)}.footer .mono{font-family:var(--f-mono);letter-spacing:.06em;text-transform:none}@media (max-width: 680px){.footer{flex-direction:column;align-items:flex-start}}.tweaks-panel{position:fixed;right:24px;bottom:24px;z-index:120;width:320px;background:#0b0b0d;border:1px solid var(--rule-strong);color:var(--ink);font-family:var(--f-body);font-size:12px;transform:translateY(12px);opacity:0;pointer-events:none;transition:opacity var(--dur-m) var(--ease-out),transform var(--dur-m) var(--ease-out);max-height:calc(100vh - 64px);overflow-y:auto}.tweaks-panel.is-on{opacity:1;transform:none;pointer-events:auto}.tweaks-panel .head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--rule);font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-dim)}.tweaks-panel .head .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);display:inline-block;margin-right:8px;box-shadow:0 0 12px var(--accent)}.tweaks-panel .group{padding:16px 18px;border-bottom:1px solid var(--rule)}.tweaks-panel .group .lbl{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:12px}.tweaks-panel .swatches{display:flex;gap:10px}.tweaks-panel .swatch{width:28px;height:28px;border-radius:50%;position:relative;border:1px solid var(--rule-strong);cursor:pointer;transition:transform var(--dur-s) var(--ease-out)}.tweaks-panel .swatch:hover{transform:scale(1.08)}.tweaks-panel .swatch.is-on:after{content:"";position:absolute;top:-5px;right:-5px;bottom:-5px;left:-5px;border:1px solid var(--ink);border-radius:50%}.tweaks-panel .choices{display:grid;gap:6px}.tweaks-panel .choice{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;background:transparent;border:1px solid transparent;color:var(--ink-dim);cursor:pointer;text-align:left;transition:color var(--dur-s) var(--ease-out),border-color var(--dur-s) var(--ease-out),background var(--dur-s) var(--ease-out)}.tweaks-panel .choice:hover{color:var(--ink);border-color:var(--rule)}.tweaks-panel .choice.is-on{color:var(--ink);border-color:var(--rule-strong);background:#ffffff05}.tweaks-panel .choice .sample{font-size:13px;color:var(--ink);opacity:.7}.tweaks-panel input[type=text]{width:100%;background:transparent;border:1px solid var(--rule);color:var(--ink);font:inherit;padding:10px 12px;outline:none}.tweaks-panel input[type=text]:focus{border-color:var(--accent)}.tweaks-panel .hint{padding:12px 18px;color:var(--ink-mute);font-size:12px;letter-spacing:.18em;text-transform:uppercase}:root{--page-dur: .9s}.pager{position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;touch-action:none}.pager-track{width:100%;height:100vh;transition:transform var(--page-dur) cubic-bezier(.7,0,.2,1);will-change:transform}.page{position:relative;width:100%;height:100vh;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none}.page::-webkit-scrollbar{display:none}.page:not(.is-active){pointer-events:none}.page .section{border-top:none}.page-indicator{position:fixed;right:28px;top:50%;transform:translateY(-50%);z-index:70;display:flex;flex-direction:column;gap:14px;align-items:center}.page-indicator button{display:flex;align-items:center;gap:14px;flex-direction:row-reverse;padding:6px 0;color:var(--ink-dim)}.page-indicator button .dot{width:6px;height:6px;border-radius:50%;background:#ffffff40;transition:background var(--dur-s) var(--ease-out),transform var(--dur-s) var(--ease-out)}.page-indicator button .dot-label{font-size:12px;letter-spacing:.24em;text-transform:uppercase;opacity:0;transform:translate(8px);transition:opacity var(--dur-s) var(--ease-out),transform var(--dur-s) var(--ease-out);white-space:nowrap}.page-indicator button:hover .dot-label,.page-indicator button.is-active .dot-label{opacity:1;transform:translate(0)}.page-indicator button:hover .dot,.page-indicator button.is-active .dot{background:var(--accent);transform:scale(1.4)}@media (max-width: 720px){.page-indicator{right:14px;gap:10px}.page-indicator button .dot-label{display:none}}.page .hero{height:100%}.page[data-page-id=work] .section,.page[data-page-id=about] .section,.page[data-page-id=clients] .section,.page[data-page-id=contact] .section{min-height:0;height:100%;padding-top:clamp(80px,9vh,120px);padding-bottom:clamp(40px,5vh,72px);display:flex;flex-direction:column;overflow:hidden}.page[data-page-id=contact] .section{height:calc(100% - 48px)}.page[data-page-id=work] .section-head,.page[data-page-id=about] .section-head,.page[data-page-id=clients] .section-head,.page[data-page-id=contact] .section-head{margin-bottom:clamp(24px,4vh,48px)}.page[data-page-id=work] .section-head h2,.page[data-page-id=about] .section-head h2,.page[data-page-id=clients] .section-head h2,.page[data-page-id=contact] .section-head h2{font-size:clamp(26px,3.6vw,48px);line-height:1.12}.page[data-page-id=about] .about .grid{display:flex;flex-direction:row;justify-content:center;align-items:center;gap:clamp(80px,10vw,180px);flex:1 1 auto;min-height:0}.page[data-page-id=about] .about .prose{flex:0 1 auto;max-width:52ch}.page[data-page-id=about] .about .prose p{font-size:27px;line-height:1.55;margin:0 0 14px}.page[data-page-id=about] .about .portrait{max-height:88%;height:88%;width:auto;aspect-ratio:3 / 4;flex:0 0 auto}.page[data-page-id=clients] .clients .wall{gap:clamp(8px,1vw,14px)}.page[data-page-id=clients] .clients .cell{padding:clamp(14px,1.6vw,22px) clamp(16px,1.8vw,24px);font-size:clamp(12px,1vw,14px)}.clients .wall .cell:nth-child(4n+1):nth-last-child(1){grid-column:2 / span 2}.clients .wall .cell:nth-child(4n+1):nth-last-child(2){grid-column:2 / span 1}.page[data-page-id=contact] .contact .direct{padding-top:clamp(20px,3vh,32px)}.page[data-page-id=contact] .contact .direct .line{padding:clamp(18px,2.6vh,28px) 0}.page[data-page-id=contact] .contact .email-copy{font-size:clamp(16px,1.6vw,22px)}.page[data-page-id=contact] .section{align-items:center;text-align:center}.page[data-page-id=contact] .section-head{display:flex;flex-direction:column;align-items:stretch;gap:18px;width:100%;max-width:none}.page[data-page-id=contact] .section-head .label{align-self:flex-start}.page[data-page-id=contact] .section-head h2{max-width:22ch;margin:0 auto;text-wrap:balance;text-align:center}.page[data-page-id=contact] .contact .direct{width:100%;max-width:640px;margin:0 auto;text-align:left}.page[data-page-id=contact] .contact .direct .line{grid-template-columns:1fr;justify-items:center;gap:8px;text-align:center}.page[data-page-id=contact] .contact .email-copy{justify-content:center}.page[data-page-id=contact] .footer{padding:14px var(--pad-x);font-size:12px}.site-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:var(--bg);transform:translateZ(0);will-change:opacity}.site-backdrop .reel{position:absolute;top:0;right:0;bottom:0;left:0;background:#000;filter:blur(0px);transition:filter .38s var(--ease-io);transform:translateZ(0);will-change:filter}.site-backdrop .reel .frame{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;transition:opacity 1.6s var(--ease-io);transform:translateZ(0);will-change:opacity}.site-backdrop .reel .frame.is-active{opacity:1}.backdrop-frame{position:absolute;top:0;right:0;bottom:0;left:0}.site-backdrop .reel:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,transparent 55%,rgba(0,0,0,.55) 100%);pointer-events:none}.site-backdrop__veil{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000;transition:background 1.1s var(--ease-io);pointer-events:none}.site-backdrop[data-on-page=top] .reel{filter:blur(0px)}.site-backdrop[data-on-page=top] .site-backdrop__veil{background:#0000}.site-backdrop[data-on-page=work] .reel,.site-backdrop[data-on-page=about] .reel,.site-backdrop[data-on-page=clients] .reel,.site-backdrop[data-on-page=contact] .reel{filter:blur(8px)}.site-backdrop[data-on-page=work] .site-backdrop__veil,.site-backdrop[data-on-page=about] .site-backdrop__veil,.site-backdrop[data-on-page=clients] .site-backdrop__veil,.site-backdrop[data-on-page=contact] .site-backdrop__veil{background:#000000b8}@media (prefers-reduced-motion: reduce){.site-backdrop .reel,.site-backdrop .reel .frame,.site-backdrop__veil{transition:none}}html,body{background:transparent!important}.pager,.page,.page .section,.hero{background:transparent}.pager,.page,.page .section{position:relative;z-index:1}.nav{z-index:80}.page-indicator{z-index:70}.tweaks{z-index:120}.overlay{z-index:100}.letterbox{z-index:90}.site-backdrop{z-index:0}.works-tabs{position:relative;flex:1 1 auto;min-height:0;display:flex;flex-direction:column}.works-tabs-bar{display:flex;align-items:baseline;justify-content:center;gap:clamp(24px,3vw,40px);margin-bottom:clamp(20px,2.4vw,36px)}.works-tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:0;padding:4px 0;margin:0;cursor:pointer;color:inherit;font-family:var(--f-body);font-size:12px;letter-spacing:.14em;text-transform:uppercase;display:inline-flex;align-items:baseline;gap:10px;position:relative;opacity:.82;transition:opacity var(--dur-s) var(--ease-out)}.works-tab:hover{opacity:1}.works-tab:disabled{opacity:.35;cursor:default}.works-tab:focus-visible{outline:1px solid currentColor;outline-offset:6px}.works-tab-count{font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;color:inherit;opacity:.55}.works-tab.is-on{opacity:1}.works-tab.is-on .works-tab-count{opacity:.7}.works-tab:after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .42s var(--ease-out)}.works-tab:hover:after,.works-tab.is-on:after{transform:scaleX(1)}@media (prefers-reduced-motion: reduce){.works-tab:after{transition:none}}.works-pager{position:relative;flex:1 1 auto;min-height:0;display:flex;flex-direction:column}.works-pager-stage{position:relative;flex:1 1 auto;min-height:0}.works-pager-slide{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;animation:works-fade-in .42s var(--ease-io) forwards}@keyframes works-fade-in{0%{opacity:0}to{opacity:1}}.works-pager-probe{position:absolute;left:-9999px;top:0;pointer-events:none;visibility:hidden;width:100%}.works-pager-count{position:absolute;right:0;bottom:0;display:flex;gap:6px;align-items:baseline;font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;color:var(--ink-dim);pointer-events:none;-webkit-user-select:none;user-select:none}.works-pager-count .sep{opacity:.5}@media (prefers-reduced-motion: reduce){.works-pager-slide{animation:none;opacity:1}}.page[data-page-id=contact] .section{min-height:calc(100vh - 48px)!important}
