:root{
  --bg:#ffffff;
  --text:#1E1E1E;
  --accent:#EEB468;
  --muted:rgba(30,30,30,.58);
  --hairline:rgba(30,30,30,.18);
  --panel:rgba(30,30,30,.04);
  --panel-strong:rgba(30,30,30,.08);

  --container-max:1512px;
  --grid-cols:12;
  --grid-gutter:24px;
  --container-pad:24px;

  --lh:1.06;
  --body:15px;
  --h1:clamp(52px,7.6vw,124px);
  --h2:clamp(22px,2vw,34px);
  --statement:clamp(30px,4.6vw,68px);
}

@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]){
    --bg:#1E1E1E;
    --text:#ffffff;
    --muted:rgba(255,255,255,.62);
    --hairline:rgba(255,255,255,.18);
    --panel:rgba(255,255,255,.055);
    --panel-strong:rgba(255,255,255,.10);
    --accent:#F3CC98;
  }
}

:root[data-theme="dark"]{
  --bg:#1E1E1E;
  --text:#ffffff;
  --muted:rgba(255,255,255,.62);
  --hairline:rgba(255,255,255,.18);
  --panel:rgba(255,255,255,.055);
  --panel-strong:rgba(255,255,255,.10);
  --accent:#F3CC98;
}

:root[data-theme="light"]{
  --bg:#ffffff;
  --text:#1E1E1E;
  --muted:rgba(30,30,30,.58);
  --hairline:rgba(30,30,30,.18);
  --panel:rgba(30,30,30,.04);
  --panel-strong:rgba(30,30,30,.08);
  --accent:#EEB468;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--bg)}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:"Instrument Sans",ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  font-weight:400;
  font-size:var(--body);
  line-height:1.45;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}
body.menu-is-open{overflow:hidden}

::selection{background:var(--accent);color:#1E1E1E}

.container{
  width:100%;
  max-width:var(--container-max);
  margin:0 auto;
  padding-left:var(--container-pad);
  padding-right:var(--container-pad);
}

.grid-12{
  display:grid;
  grid-template-columns:repeat(var(--grid-cols),minmax(0,1fr));
  column-gap:var(--grid-gutter);
}

.page{opacity:0}
.page.is-loaded{opacity:1;transition:opacity 560ms ease}
main{padding-top:70px}

img{max-width:100%;height:auto}
a{color:inherit}

/* Typography */
.h1{
  font-weight:560;
  font-size:var(--h1);
  line-height:1.04;
  letter-spacing:-.025em;
  margin:0;
}
.h2{
  font-weight:560;
  font-size:var(--h2);
  line-height:1.08;
  letter-spacing:-.02em;
  margin:0 0 16px;
}
.body{
  font-size:var(--body);
  line-height:1.55;
  margin:0;
  color:var(--muted);
}
.lede{
  font-size:clamp(19px,2vw,28px);
  line-height:1.36;
  letter-spacing:-.01em;
  margin:0;
  color:var(--text);
}
.statement{
  font-weight:540;
  font-size:var(--statement);
  line-height:1.08;
  letter-spacing:-.025em;
  margin:0;
  color:var(--text);
}
.muted{color:var(--muted)}
.eyebrow,
.section-label,
.service-index,
.method-step,
.project-kicker,
.contact-label,
.nav-link,
.nav-role,
.theme-toggle,
.nav-menu-button,
.menu-link,
.footer-role,
.footer-link,
.note-meta{
  font-size:12px;
  line-height:1.1;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:680;
}

/* Header */
.site-header{
  position:fixed;
  z-index:30;
  top:0;
  left:0;
  width:100%;
  padding:16px 0;
  background:rgba(255,255,255,.88);
  border-bottom:1px solid var(--hairline);
  transform:translateY(0);
  transition:transform 260ms ease, background 260ms ease, border-color 260ms ease;
  backdrop-filter:blur(16px);
  will-change:transform;
}
:root[data-theme="dark"] .site-header{background:rgba(30,30,30,.88)}
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]) .site-header{background:rgba(30,30,30,.88)}
}
.site-header.is-hidden{transform:translateY(-100%)}
.nav{align-items:center}
.nav-brand{grid-column:1/span 2;display:inline-flex;align-items:center;text-decoration:none}
.brand-logo{display:block;width:200px;height:auto;max-height:48px}
.brand-logo--dark{display:none}
:root[data-theme="dark"] .brand-logo--light{display:none}
:root[data-theme="dark"] .brand-logo--dark{display:block}
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]) .brand-logo--light{display:none}
  :root:not([data-theme="light"]) .brand-logo--dark{display:block}
}
.nav-role{grid-column:3/span 3;color:var(--muted)}
.nav-links{grid-column:7/span 4;display:flex;gap:28px;justify-content:flex-start;align-items:center}
.nav-link{text-decoration:none;color:var(--muted);transition:color 180ms ease}
.nav-link:hover{color:var(--text)}
.theme-toggle{
  grid-column:11/span 1;
  justify-self:end;
  border:1px solid var(--hairline);
  background:transparent;
  color:var(--text);
  border-radius:999px;
  padding:10px 13px;
  cursor:pointer;
}
.theme-toggle:hover{background:var(--panel)}
.nav-menu-button{
  display:none;
  grid-column:12/span 1;
  justify-self:end;
  border:1px solid var(--hairline);
  background:transparent;
  color:var(--text);
  border-radius:999px;
  padding:10px 13px;
  cursor:pointer;
}

/* Menu overlay */
.menu-overlay{position:fixed;inset:0;background:var(--bg);z-index:60;color:var(--text)}
.menu-panel{padding-top:18px}
.menu-top{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--hairline);padding-bottom:18px}
.menu-logo{width:200px;height:auto}
.menu-close{border:1px solid var(--hairline);background:transparent;color:var(--text);border-radius:999px;padding:10px 13px;cursor:pointer}
.menu-links{display:flex;flex-direction:column;gap:18px;margin-top:48px}
.menu-link{text-decoration:none;font-size:clamp(34px,11vw,76px);letter-spacing:-.025em;text-transform:none;line-height:1.04;color:var(--text)}

/* Buttons and links */
.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
  border-radius:999px;
  padding:13px 18px 12px;
  font-size:14px;
  line-height:1;
  text-decoration:none;
  border:1px solid var(--hairline);
  transition:transform 180ms ease, background 180ms ease, color 180ms ease, border-color 180ms ease;
}
.button:hover{transform:translateY(-1px)}
.button--primary{background:var(--accent);border-color:var(--accent);color:#1E1E1E}
.button--secondary{background:transparent;color:var(--text)}
.button--secondary:hover{background:var(--panel)}
.text-link{display:inline-flex;margin-top:24px;color:var(--text);text-decoration:none;border-bottom:1px solid var(--accent);padding-bottom:4px}
.text-link:hover{color:var(--muted)}

/* Hero */
.hero{min-height:calc(100vh - 70px);align-content:center;row-gap:28px;padding-top:56px;padding-bottom:72px}
.hero-eyebrow{grid-column:1/span 12;color:var(--accent);margin-bottom:12px}
.hero-eyebrow,.service-index,.method-step{font-weight:760}
.hero-heading{grid-column:1/span 9;max-width:1180px}
.hero-copy{grid-column:7/span 5;display:grid;gap:24px;align-self:end;margin-top:28px}
.hero-actions{display:flex;flex-wrap:wrap;gap:10px}
.hero-meta{grid-column:1/span 6;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));column-gap:16px;align-self:end;margin-top:36px;border-top:1px solid var(--hairline);padding-top:16px}
.meta-line{font-size:13px;line-height:1.7;letter-spacing:-.01em}

/* Shared sections */
.section-reveal{opacity:0;transform:translateY(16px);transition:opacity 650ms ease,transform 650ms ease}
.section-reveal.is-visible{opacity:1;transform:translateY(0)}
.mask-line{display:block;overflow:hidden}
.mask-line-inner{display:block;transform:translateY(110%);transition:transform 760ms cubic-bezier(.2,.9,.2,1)}
.h1-mask.is-revealed .mask-line-inner{transform:translateY(0)}
.section-label{grid-column:1/span 3;color:var(--muted);scroll-margin-top:120px}
.section-intro{max-width:680px;margin:0 0 24px;color:var(--muted);font-size:15px;line-height:1.55}

/* Thesis */
.thesis{padding-top:96px;padding-bottom:96px;align-items:start;border-top:1px solid var(--hairline)}
.thesis-text{grid-column:4 / -1;display:grid;gap:28px}
.thesis-text .body{max-width:580px}

/* Services */
.services{padding-top:96px;padding-bottom:96px;border-top:1px solid var(--hairline);align-items:start}
.services .section-intro{grid-column:4 / span 6;max-width:760px;margin:0;color:var(--muted);font-size:clamp(22px,2.3vw,32px);line-height:1.38;letter-spacing:-.01em}
.services-grid{grid-column:1 / -1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--grid-gutter);margin-top:72px}
.service-card{min-height:360px;border:0;border-radius:24px;background:var(--panel);padding:24px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;transition:background 180ms ease, transform 180ms ease}
.service-card:hover{background:var(--panel-strong);transform:translateY(-2px)}
.service-index{color:var(--accent)}
.service-card .body{max-width:420px}

/* Work */
.work-section{padding-top:96px;padding-bottom:96px;border-top:1px solid var(--hairline)}
.work-section .section-label{margin-bottom:20px}
.work{display:grid;margin-top:28px}
.project-card{text-decoration:none;color:inherit;display:block;min-width:0}
.work .project-card:nth-child(1){grid-column:1/span 3}
.work .project-card:nth-child(2){grid-column:4/span 3}
.work .project-card:nth-child(3){grid-column:7/span 3}
.work .project-card:nth-child(4){grid-column:10/span 3}
.project-media{width:100%;aspect-ratio:3 / 4;overflow:hidden;position:relative;background:var(--panel);border:0;border-radius:24px}
.project-media::before,
.project-media::after{content:none}
.project-media img{display:block;width:100%;height:100%;object-fit:cover;object-position:center;transition:transform 220ms ease}
.project-card:hover .project-media{background:var(--panel-strong)}
.project-card:hover .project-media img{transform:scale(1.025)}
.project-info{padding-top:14px}
.project-kicker{color:var(--muted);margin-bottom:8px}
.project-title{font-weight:560;font-size:clamp(22px,2vw,32px);line-height:1.08;letter-spacing:-.02em;color:var(--text);margin-bottom:8px}
.project-subtitle{font-size:14px;line-height:1.45;color:var(--muted);max-width:94%}
.project-card:hover .project-media{background:var(--panel-strong)}

/* Method */
.method{padding-top:96px;padding-bottom:96px;border-top:1px solid var(--hairline);align-items:start}
.method-list{grid-column:4 / -1;border-top:1px solid var(--hairline)}
.method-item{display:grid;grid-template-columns:96px minmax(0,1fr) minmax(220px,420px);column-gap:24px;padding:28px 0;border-bottom:1px solid var(--hairline);align-items:start}
.method-step{color:var(--accent)}
.method-item .h2{margin:0}

/* About */
.about{padding-top:96px;padding-bottom:96px;border-top:1px solid var(--hairline);align-items:start}
.about-primary{grid-column:4/span 5}
.about-secondary{grid-column:10/span 3}

/* Notes */
.notes{padding-top:96px;padding-bottom:96px;border-top:1px solid var(--hairline)}
.notes-list{grid-column:4 / -1;display:grid;border-top:1px solid var(--hairline)}
.note-item{display:block;text-decoration:none;color:var(--text);font-weight:540;font-size:clamp(30px,4vw,68px);line-height:1.06;letter-spacing:-.025em;padding:26px 0;border-bottom:1px solid var(--hairline);transition:color 180ms ease, transform 180ms ease}
.note-item:hover{color:var(--muted);transform:translateX(4px)}
.note-meta{display:block;margin-top:14px;letter-spacing:.08em;color:var(--muted)}

/* Contact */
.contact{padding:96px 0;background:var(--accent);color:#1E1E1E}
.contact-inner{align-items:start}
.contact-label{grid-column:1/span 3;color:rgba(30,30,30,.65);font-size:12px;line-height:1.1;letter-spacing:.08em;text-transform:uppercase}
.contact-heading{grid-column:4/span 5;margin:0;font-weight:560;font-size:clamp(42px,5vw,88px);line-height:1.04;letter-spacing:-.025em}
.contact-copy{grid-column:10/span 3;display:grid;gap:24px}.contact .body{color:rgba(30,30,30,.72)}
.contact .button--primary{background:#1E1E1E;border-color:#1E1E1E;color:#ffffff}
.contact .button--secondary{border-color:rgba(30,30,30,.24);color:#1E1E1E}
.contact .button--secondary:hover{background:rgba(30,30,30,.06)}
.contact-actions{display:flex;gap:10px;flex-wrap:wrap}

/* Footer */
.site-footer{padding:22px 0;border-top:1px solid var(--hairline)}
.footer{align-items:center}
.footer-brand{grid-column:1/span 2;display:inline-flex;text-decoration:none}
.footer-logo{width:200px;height:auto}
.footer-role{grid-column:3/span 3;color:var(--muted)}
.footer-links{grid-column:8/span 5;display:flex;justify-content:flex-end;gap:32px}
.footer-link{text-decoration:none;color:var(--muted)}
.footer-link:hover{color:var(--text)}

/* Tablet */
@media (max-width:1100px){
  :root{--grid-cols:6;--container-pad:22px}
  .nav-brand{grid-column:1/span 3}.brand-logo{width:180px}
  .nav-role,.nav-links{display:none}.theme-toggle{grid-column:5/span 1}.nav-menu-button{display:inline-block;grid-column:6/span 1}
  .hero{min-height:auto;padding-top:86px}.hero-heading{grid-column:1/-1}.hero-copy{grid-column:1/-1;max-width:720px}.hero-meta{grid-column:1/-1}
  .section-label{grid-column:1/-1;margin-bottom:22px}
  .thesis-text,.method-list,.notes-list{grid-column:1/-1}
  .services .section-intro{grid-column:1/-1;max-width:720px;margin-bottom:0}
  .services-grid{grid-template-columns:1fr;margin-top:36px}.service-card{min-height:260px}
  .work{display:flex;gap:var(--grid-gutter);overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:20px;margin-right:calc(-1 * var(--container-pad));padding-right:var(--container-pad)}
  .work .project-card{width:calc((100vw - (var(--container-pad) * 2) - var(--grid-gutter) - 32px) / 2);flex:0 0 auto;scroll-snap-align:start}
  .method-item{grid-template-columns:70px minmax(0,1fr);row-gap:14px}.method-item .body{grid-column:2}.about-primary{grid-column:1/span 4}.about-secondary{grid-column:1/span 4;margin-top:28px}
  .contact-label{grid-column:1/-1;margin-bottom:22px}.contact-heading{grid-column:1/-1}.contact-copy{grid-column:1/span 4;margin-top:28px}
  .footer-brand{grid-column:1/span 3}.footer-role{display:none}.footer-links{grid-column:4/span 3;gap:18px}
}

/* Mobile */
@media (max-width:640px){
  :root{--grid-cols:4;--container-pad:16px;--body:16px;--h1:clamp(42px,12vw,68px);--statement:clamp(28px,9vw,46px)}
  main{padding-top:64px}.site-header{padding:12px 0}.nav-brand{grid-column:1/span 2}.brand-logo{width:162px}.theme-toggle{grid-column:3/span 1;padding:9px 11px}.nav-menu-button{grid-column:4/span 1;padding:9px 11px}
  .h1{line-height:1.06;letter-spacing:-.015em}.h2{line-height:1.12;letter-spacing:-.01em}.lede{font-size:19px;line-height:1.42;letter-spacing:0}.body{line-height:1.62}.statement{line-height:1.12;letter-spacing:-.015em}.project-subtitle{font-size:15px;line-height:1.55}.section-intro{font-size:16px;line-height:1.6}.button{font-size:15px}.meta-line{font-size:14px}
  .hero{padding-top:64px;padding-bottom:64px;row-gap:22px}.hero-eyebrow,.hero-heading,.hero-copy,.hero-meta{grid-column:1/-1}.hero-meta{grid-template-columns:1fr;gap:8px}
  .hero-meta-col{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));column-gap:8px}
  .hero-actions,.contact-actions{flex-direction:column}.button{width:100%}
  .thesis,.services,.work-section,.method,.about,.notes{padding-top:68px;padding-bottom:68px}
  .work .project-card{width:calc(100vw - (var(--container-pad) * 2) - 20px)}
  .method-item{grid-template-columns:1fr}.method-item .body{grid-column:1}.method-step{margin-bottom:10px}
  .about-primary,.about-secondary,.contact-copy{grid-column:1/-1}.contact{padding:68px 0}.contact-heading{font-size:clamp(40px,13vw,62px)}
  .footer{row-gap:18px}.footer-brand{grid-column:1/-1}.footer-links{grid-column:1/-1;justify-content:flex-start;flex-wrap:wrap}.footer-logo{width:162px}
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;scroll-behavior:auto !important;transition-duration:.01ms !important}
  .section-reveal{opacity:1;transform:none}.mask-line-inner{transform:none}
}
