*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --paper:#F3EFE6;
  --paper-deep:#EAE4D6;
  --ink:#1A130C;
  --accent:#FF4D00;
  --muted:#8A8173;
  --faint:#B9AF9C;
  --line:rgba(22,19,14,.16);
  --mono:'Spline Sans Mono',ui-monospace,monospace;
  --serif:'Fraunces',Georgia,serif;
  --sans:'Archivo',Helvetica,sans-serif;
  color-scheme:light;
}
/* dark roast — applied by the head script from saved choice or OS preference */
html[data-theme="dark"]{
  --paper:#14100B;
  --paper-deep:#0F0C08;
  --ink:#F3EFE6;
  --muted:#9A9082;
  --faint:#5C5345;
  --line:rgba(243,239,230,.16);
  color-scheme:dark;
}
html{scroll-behavior:smooth}
html.lenis{scroll-behavior:auto}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
}
::selection{background:var(--accent);color:var(--paper)}
a{color:inherit;text-decoration:none}
ul{list-style:none}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
.skip{position:fixed;top:-100px;left:16px;z-index:300;background:var(--ink);color:var(--paper);padding:.6rem 1rem;font:500 12px var(--mono)}
.skip:focus{top:12px}

/* grain */
.grain{position:fixed;inset:-50%;width:200%;height:200%;pointer-events:none;z-index:120;opacity:.5;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.05 0'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 7s steps(8) infinite}
html[data-theme="dark"] .grain{filter:invert(1);mix-blend-mode:screen;opacity:.3}
@keyframes grain{0%,100%{transform:translate(0,0)}25%{transform:translate(-2%,3%)}50%{transform:translate(3%,-2%)}75%{transform:translate(-3%,-3%)}}

/* loader */
#loader{position:fixed;inset:0;z-index:200;background:var(--ink);color:var(--paper);display:none;align-items:flex-end;justify-content:space-between;padding:clamp(1.2rem,3vw,2.5rem)}
html.js #loader{display:flex}
#loader .count{font:300 clamp(5rem,16vw,12rem)/0.9 var(--serif);font-variation-settings:'opsz' 144;letter-spacing:-.03em}
#loader .tag{font:400 11px var(--mono);text-transform:uppercase;letter-spacing:.22em;color:var(--faint);padding-bottom:1.2rem}

/* cursor */
.cursor,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:250;border-radius:50%;display:none}
.cursor{width:8px;height:8px;background:var(--accent)}
.cursor-ring{width:36px;height:36px;border:1.5px solid var(--accent);transition:width .25s,height .25s,opacity .25s}
.cursor-ring.is-hover{width:64px;height:64px;opacity:.55}
@media (hover:hover) and (pointer:fine){html.js .cursor,html.js .cursor-ring{display:block}}

/* header */
header{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.1rem clamp(1.2rem,3vw,2.5rem);mix-blend-mode:difference;color:#EDE9DF}
header .logo{font:600 13px var(--mono);letter-spacing:.06em}
header nav{display:flex;gap:clamp(1rem,2.5vw,2.2rem)}
header nav a{font:500 11px var(--mono);text-transform:uppercase;letter-spacing:.18em;position:relative}
header nav a::after{content:'';position:absolute;left:0;bottom:-4px;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .35s cubic-bezier(.76,0,.24,1)}
header nav a:hover::after{transform:scaleX(1);transform-origin:left}
header nav a[aria-current="page"]{color:var(--accent)}
.theme-toggle{display:inline-flex;align-items:center;background:none;border:0;padding:0;cursor:pointer;color:inherit}
.theme-toggle svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transition:transform .35s cubic-bezier(.76,0,.24,1)}
.theme-toggle:hover svg{transform:rotate(-25deg)}
html[data-theme="dark"] .theme-toggle .ico-moon{display:none}
html:not([data-theme="dark"]) .theme-toggle .ico-sun{display:none}

/* hero (home) */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;padding:0 clamp(1.2rem,3vw,2.5rem) clamp(1.4rem,3vh,2.4rem);overflow:clip}
.orb{position:absolute;right:-6vw;top:4vh;width:min(56vw,640px);aspect-ratio:1;z-index:0;pointer-events:none}
.orb canvas{width:100%!important;height:100%!important;display:block}
.hero-edge{position:absolute;left:clamp(1.2rem,3vw,2.5rem);top:50%;transform:rotate(180deg) translateY(50%);writing-mode:vertical-rl;font:400 10px var(--mono);text-transform:uppercase;letter-spacing:.3em;color:var(--muted)}
.hero-titles{position:relative;z-index:1;margin-bottom:clamp(1.5rem,4vh,3rem)}
.hero-line{overflow:clip;display:block}
.hero-line .ch{display:inline-block}
html.js .hero-line .ch{transform:translateY(115%)}
h1{font-weight:normal}
.line-serif{font:900 clamp(3.4rem,13vw,11.5rem)/.88 var(--serif);font-variation-settings:'opsz' 144;letter-spacing:-.035em}
.line-grot{font:900 clamp(4.2rem,16vw,14rem)/.92 var(--sans);font-stretch:115%;letter-spacing:-.01em;color:transparent;-webkit-text-stroke:2.5px var(--ink);text-transform:uppercase;transition:color .5s}
.line-grot:hover{color:var(--accent);-webkit-text-stroke-color:var(--accent)}
.line-grot .reg{font-size:.22em;vertical-align:super;-webkit-text-stroke-width:1.2px}
.hero-meta{position:relative;z-index:1;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:1.5rem;border-top:1px solid var(--line);padding-top:1.1rem}
.hero-meta>div{font:400 11px/1.7 var(--mono);text-transform:uppercase;letter-spacing:.16em;color:var(--muted)}
.hero-meta b{display:block;color:var(--ink);font-weight:500}
.avail{display:inline-flex;align-items:center;gap:.5rem}
.avail i{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}

/* page hero (subpages) */
.page-hero{padding:clamp(7.5rem,18vh,11rem) clamp(1.2rem,3vw,2.5rem) clamp(2rem,5vh,3.5rem)}
.crumb{display:block;font:400 11px var(--mono);text-transform:uppercase;letter-spacing:.22em;color:var(--accent);margin-bottom:1.2rem}
.page-hero .line-serif{font-size:clamp(3rem,11vw,9.5rem)}
.page-hero .sub{margin-top:1.4rem;font:300 italic clamp(1.1rem,1.8vw,1.5rem) var(--serif);color:var(--muted);max-width:46ch}

/* marquee */
.marquee{border-block:1px solid var(--line);padding:.85rem 0;overflow:clip}
.marquee-inner{display:flex;width:max-content;animation:marq 26s linear infinite}
.marquee .grp{display:flex;align-items:center;gap:2.6rem;padding-right:2.6rem;font:800 clamp(1rem,2vw,1.45rem) var(--sans);font-stretch:120%;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
.marquee svg{width:.9em;height:.9em;fill:var(--accent);flex:none}
.marquee svg path{stroke:var(--paper)}
@keyframes marq{to{transform:translateX(-50%)}}

/* sections */
section{padding:clamp(4.5rem,10vh,8rem) clamp(1.2rem,3vw,2.5rem)}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:clamp(2rem,5vh,3.5rem)}
.sec-head h2{font:500 11px var(--mono);text-transform:uppercase;letter-spacing:.22em}
.sec-head h2 em{font-style:normal;color:var(--accent);margin-right:.7em}
.sec-head .cnt{font:300 italic 1.4rem var(--serif);color:var(--muted)}
.sec-head .all{font:500 11px var(--mono);text-transform:uppercase;letter-spacing:.18em;border-bottom:1px solid var(--line);padding-bottom:.2em;transition:color .3s,border-color .3s}
.sec-head .all:hover{color:var(--accent);border-color:var(--accent)}
html.js [data-reveal]{opacity:0;transform:translateY(30px)}

/* work rows (home) */
.rows{border-top:1px solid var(--line)}
.row{position:relative;border-bottom:1px solid var(--line)}
.row::after{content:'';position:absolute;inset:0;background:var(--accent);transform:scaleY(0);transform-origin:bottom;transition:transform .45s cubic-bezier(.76,0,.24,1)}
.row:hover::after{transform:scaleY(1)}
.row a{position:relative;z-index:1;display:grid;grid-template-columns:4ch 1fr auto 6ch;align-items:baseline;gap:1.5rem;padding:clamp(1.4rem,3vh,2.1rem) .4rem}
.row .idx{font:400 12px var(--mono);color:var(--muted);transition:color .3s}
.row h3{font:550 clamp(1.7rem,4.6vw,3.6rem)/1.05 var(--serif);font-variation-settings:'opsz' 90;letter-spacing:-.02em;transition:transform .45s cubic-bezier(.22,1,.36,1)}
.row:hover h3{transform:translateX(14px)}
.row .meta{font:400 11px var(--mono);text-transform:uppercase;letter-spacing:.14em;color:var(--muted);transition:color .3s}
.row .year{font:300 italic 1.05rem var(--serif);color:var(--muted);text-align:right;transition:color .3s}
.row:hover .idx,.row:hover .meta,.row:hover .year{color:var(--ink)}

/* work page projects */
.proj{border-top:1px solid var(--line);padding:clamp(2.5rem,6vh,4rem) 0 clamp(3rem,7vh,5rem)}
.proj-head{display:grid;grid-template-columns:4ch 1fr auto;align-items:baseline;gap:1.5rem;margin-bottom:clamp(1.5rem,3vh,2.2rem)}
.proj-head .idx{font:400 12px var(--mono);color:var(--accent)}
.proj-head h2{font:550 clamp(2.2rem,6vw,4.6rem)/1.02 var(--serif);font-variation-settings:'opsz' 110;letter-spacing:-.025em}
.proj-head .year{font:300 italic 1.1rem var(--serif);color:var(--muted)}
.proj-art{position:relative;aspect-ratio:16/7;overflow:hidden;border-radius:2px;display:flex;align-items:flex-end;padding:clamp(1.2rem,3vw,2.2rem);font:300 italic clamp(4rem,10vw,9rem)/1 var(--serif);color:rgba(243,239,230,.92);margin-bottom:clamp(1.6rem,3.5vh,2.4rem)}
.proj-art::after{content:'';position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.09 0'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)'/%3E%3C/svg%3E")}
.art-1{background:radial-gradient(140% 120% at 20% 10%,#1A6B45 0%,#0E3B2E 55%,#072218 100%)}
.art-1::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(243,239,230,.25) 1px,transparent 1.5px);background-size:22px 22px}
.art-2{background:linear-gradient(160deg,#2438D8 0%,#0A1463 90%)}
.art-2::before{content:'';position:absolute;inset:0;background:repeating-radial-gradient(circle at 70% 30%,transparent 0 34px,rgba(243,239,230,.22) 34px 36px)}
.art-3{background:linear-gradient(135deg,#C9582A 0%,#7A2D12 100%)}
.art-3::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(-45deg,transparent 0 26px,rgba(22,19,14,.18) 26px 28px)}
.art-4{background:linear-gradient(170deg,#3B342A 0%,#1A130C 80%)}
.art-4::before{content:'';position:absolute;top:-25%;right:-12%;width:46%;aspect-ratio:1;border:2px solid rgba(255,77,0,.7);border-radius:50%}
.art-5{background:linear-gradient(180deg,#0E4D5C 0%,#062A33 100%)}
.art-5::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent 0 30px,rgba(243,239,230,.16) 30px 32px)}
.proj-body{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(1.5rem,4vw,4rem)}
.proj-body .lede{font:300 clamp(1.2rem,1.9vw,1.55rem)/1.55 var(--serif);max-width:56ch}
.proj-meta{display:flex;flex-direction:column;gap:1rem}
.proj-meta>div{display:grid;grid-template-columns:9ch 1fr;gap:1rem;border-top:1px solid var(--line);padding-top:.7rem}
.proj-meta dt{font:400 10.5px var(--mono);text-transform:uppercase;letter-spacing:.18em;color:var(--muted);padding-top:.2em}
.proj-meta dd{font-size:14.5px;line-height:1.55}
.proj-meta .hl{color:var(--accent);font-weight:600}

/* manifesto */
.manifesto{max-width:1100px}
.manifesto p{font:300 clamp(1.7rem,4vw,3.3rem)/1.3 var(--serif);font-variation-settings:'opsz' 60;letter-spacing:-.015em}
.manifesto .word{color:var(--faint)}
.manifesto em{font-style:italic;color:var(--accent)!important}
.manifesto .sig{margin-top:2.5rem;font:400 11px var(--mono);text-transform:uppercase;letter-spacing:.2em;color:var(--muted)}

/* about page */
.about-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,5vw,5rem);align-items:start}
.bio p{font-size:clamp(1.02rem,1.35vw,1.18rem);line-height:1.75;color:var(--ink);max-width:58ch}
.bio p+p{margin-top:1.3rem}
.bio p em{font-style:italic;color:var(--accent)}
.facts{display:flex;flex-direction:column;gap:1.1rem;position:sticky;top:7rem}
.facts>div{border-top:1px solid var(--line);padding-top:.7rem}
.facts dt{font:400 10.5px var(--mono);text-transform:uppercase;letter-spacing:.18em;color:var(--muted)}
.facts dd{font-size:15px;margin-top:.25rem}
.cups{border-top:1px solid var(--line)}
.cups li{display:grid;grid-template-columns:8ch 10ch 1fr;gap:1.5rem;align-items:baseline;border-bottom:1px solid var(--line);padding:1.3rem .2rem}
.cups .t{font:400 12px var(--mono);color:var(--muted)}
.cups .cup{font:300 italic 1.3rem var(--serif);color:var(--accent);white-space:nowrap}
.cups .what{font-size:15px;color:var(--ink)}
.cups .what small{display:block;font:400 11px var(--mono);text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-top:.2rem}
.xp li{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid var(--line);padding:1.05rem .2rem;font-size:15px}
.xp li:first-child{border-top:1px solid var(--line)}
.xp .role{font-weight:500}
.xp .at{font:300 italic 1rem var(--serif);color:var(--muted);margin-left:.6rem}
.xp .when{font:400 11px var(--mono);letter-spacing:.14em;color:var(--muted)}

/* services */
.svc{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.5rem,3vw,3rem)}
.svc article{border-top:1px solid var(--ink);padding-top:1.3rem}
.svc .n{font:400 12px var(--mono);color:var(--accent)}
.svc h4{font:300 italic clamp(1.5rem,2.4vw,2.1rem)/1.15 var(--serif);margin:.9rem 0 .8rem}
.svc p{font-size:14.5px;line-height:1.65;color:var(--muted);max-width:34ch}

/* recognition */
.recog li{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid var(--line);padding:1.05rem .2rem;font-size:15px}
.recog li:first-child{border-top:1px solid var(--line)}
.recog .what{font-weight:500}
.recog .who{font:400 11px var(--mono);text-transform:uppercase;letter-spacing:.16em;color:var(--muted)}

/* footer */
footer{background:var(--ink);color:var(--paper);padding:clamp(5rem,12vh,9rem) clamp(1.2rem,3vw,2.5rem) 1.6rem;position:relative}
footer .cta{display:block;text-align:center;margin-bottom:clamp(3rem,8vh,5rem)}
footer .cta .l1{display:block;font:300 italic clamp(2.6rem,8vw,7rem)/1 var(--serif);font-variation-settings:'opsz' 144;color:var(--faint)}
footer .cta .l2{display:block;font:900 clamp(3.4rem,11vw,10rem)/1 var(--sans);font-stretch:118%;text-transform:uppercase;letter-spacing:-.015em;color:transparent;-webkit-text-stroke:2px var(--paper);transition:color .5s,-webkit-text-stroke-color .5s;margin-top:.5rem}
footer .cta:hover .l2{color:var(--accent);-webkit-text-stroke-color:var(--accent)}
footer .email{display:block;text-align:center;font:400 clamp(1rem,2.4vw,1.5rem) var(--mono);color:var(--paper);margin-bottom:clamp(3.5rem,9vh,6rem)}
footer .email span{border-bottom:1px solid color-mix(in srgb,var(--paper) 35%,transparent);padding-bottom:.2em;transition:border-color .3s,color .3s}
footer .email:hover span{color:var(--accent);border-color:var(--accent)}
.foot-grid{display:flex;justify-content:space-between;align-items:flex-end;gap:1.5rem;border-top:1px solid color-mix(in srgb,var(--paper) 18%,transparent);padding-top:1.4rem;font:400 10.5px var(--mono);text-transform:uppercase;letter-spacing:.16em;color:color-mix(in srgb,var(--paper) 55%,transparent)}
.foot-grid .socials{display:flex;gap:1.6rem}
.foot-grid .socials a:hover{color:var(--accent)}
#top{cursor:pointer}
#top:hover{color:var(--accent)}

@media (prefers-reduced-motion:reduce){
  .marquee-inner,.grain,.avail i{animation:none}
  html.js [data-reveal]{opacity:1;transform:none}
  html.js .hero-line .ch{transform:none}
}
@media (max-width:1023px){
  .svc{grid-template-columns:1fr;gap:2.2rem}
  .svc p{max-width:60ch}
  .about-grid{grid-template-columns:1fr}
  .facts{position:static}
}
@media (max-width:767px){
  .orb{width:80vw;right:-22vw;top:1vh;opacity:.9}
  .hero-edge{display:none}
  .hero-meta{grid-template-columns:1fr;gap:.9rem}
  .row a{grid-template-columns:3ch 1fr;grid-template-rows:auto auto;gap:.3rem 1rem}
  .row .meta{grid-column:2}
  .row .year{display:none}
  .proj-head{grid-template-columns:3ch 1fr;gap:.3rem 1rem}
  .proj-head .year{grid-column:2}
  .proj-art{aspect-ratio:4/3}
  .proj-body{grid-template-columns:1fr;gap:1.6rem}
  .cups li{grid-template-columns:1fr;gap:.25rem}
  .foot-grid{flex-direction:column;align-items:flex-start;gap:1rem}
}
@media (max-width:480px){
  header nav a.opt{display:none}
}
/* test hook: ?flat collapses the 100svh hero so tall-viewport screenshots capture all sections */
html.flat .hero{min-height:640px}
