/* =============================================================
   STEPHEN PAPPAS INTERIORS
   Design system — editorial luxury, warm-neutral, legible.
   Type: Fraunces (display serif) + Hanken Grotesk (text sans).
   ============================================================= */

/* ---------- Tokens ---------- */
:root{
  /* Warm-neutral palette (keeps the original black/white/neutral mood,
     enriched with paper warmth + a single restrained bronze accent) */
  --paper:      #F4EFE6;   /* warm ivory ground */
  --paper-2:    #FBF8F1;   /* lighter card / panel */
  --paper-3:    #ECE4D6;   /* subtle inset */
  --ink:        #211C16;   /* warm near-black text */
  --ink-soft:   #4D453B;   /* secondary text */
  --muted:      #8A7F6E;   /* captions / meta */
  --line:       #DDD3C2;   /* hairlines */
  --line-2:     #C9BCA5;
  --bronze:     #9A7A49;   /* metallic accent */
  --bronze-dp:  #7C6038;
  --char:       #181410;   /* dark dramatic sections */
  --char-2:     #221C15;
  --on-char:    #EDE6D8;   /* text on dark */
  --on-char-mut:#A99C86;

  /* Fluid type scale */
  --fs-eyebrow: clamp(0.72rem, 0.68rem + 0.2vw, 0.82rem);
  --fs-small:   clamp(0.92rem, 0.88rem + 0.2vw, 1.0rem);
  --fs-body:    clamp(1.06rem, 1.0rem + 0.35vw, 1.22rem);
  --fs-lead:    clamp(1.25rem, 1.1rem + 0.8vw, 1.6rem);
  --fs-h3:      clamp(1.4rem, 1.2rem + 1vw, 1.9rem);
  --fs-h2:      clamp(2rem, 1.5rem + 2.4vw, 3.4rem);
  --fs-h1:      clamp(2.7rem, 1.8rem + 4.4vw, 6rem);
  --fs-display: clamp(3.4rem, 2rem + 7vw, 9rem);

  /* Rhythm */
  --space-section: clamp(5rem, 4rem + 6vw, 10rem);
  --gutter: clamp(1.25rem, 0.6rem + 3vw, 3.5rem);
  --maxw: 1500px;
  --measure: 62ch;

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-soft: cubic-bezier(0.65, 0.05, 0.36, 1);
  --dur: 0.8s;

  --radius: 2px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  font-family:"Hanken Grotesk", system-ui, -apple-system, "Segoe UI", sans-serif;
  font-size:var(--fs-body);
  line-height:1.72;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"kern" 1, "liga" 1;
  overflow-x:hidden;
}
img,picture,svg,video{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }
ul,ol{ list-style:none; padding:0; }
input,textarea,select,button{ font:inherit; }
::selection{ background:var(--bronze); color:var(--paper-2); }

/* ---------- Typography ---------- */
h1,h2,h3,h4{
  font-family:"Fraunces", Georgia, "Times New Roman", serif;
  font-weight:380;
  line-height:1.04;
  letter-spacing:-0.012em;
  font-optical-sizing:auto;
  color:var(--ink);
}
h1,h2,h3,h4,p,.lead,.fr-quote,.nav-link{ overflow-wrap:break-word; }
.serif{ font-family:"Fraunces", Georgia, serif; }
p{ max-width:var(--measure); }
strong{ font-weight:600; }
em{ font-style:italic; }

.eyebrow{
  font-family:"Hanken Grotesk", sans-serif;
  font-size:var(--fs-eyebrow);
  letter-spacing:0.34em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--bronze-dp);
  display:inline-flex;
  align-items:center;
  gap:0.9em;
}
.eyebrow::before{
  content:"";
  width:2.4em; height:1px; background:var(--line-2);
  display:inline-block;
}
.eyebrow.center::after{
  content:""; width:2.4em; height:1px; background:var(--line-2); display:inline-block;
}
.eyebrow.center{ justify-content:center; }
.eyebrow.plain::before{ display:none; }

.lead{
  font-size:var(--fs-lead);
  line-height:1.5;
  color:var(--ink-soft);
  font-weight:380;
  max-width:46ch;
}

.fr-quote{
  font-family:"Fraunces", serif;
  font-weight:330;
  font-size:clamp(1.5rem, 1rem + 2.4vw, 3rem);
  line-height:1.22;
  letter-spacing:-0.012em;
}
.fr-quote em{ font-style:italic; color:var(--bronze-dp); }

/* ---------- Layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.wrap-narrow{ max-width:1040px; margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:var(--space-section); }
.section--tight{ padding-block:clamp(3rem,2rem + 4vw,6rem); }
.bleed{ position:relative; }
.center{ text-align:center; }
.dark{ background:var(--char); color:var(--on-char); }
.dark h1,.dark h2,.dark h3{ color:var(--on-char); }
.dark .lead{ color:var(--on-char-mut); }
.dark .eyebrow{ color:var(--bronze); }
.dark .eyebrow::before,.dark .eyebrow.center::after{ background:rgba(255,255,255,.18); }
.panel{ background:var(--paper-2); }

.grid{ display:grid; gap:var(--gutter); }
.divider{ height:1px; background:var(--line); border:0; }

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:100;
  padding-block:clamp(1rem,0.6rem + 1vw,1.6rem);
  transition:background var(--dur) var(--ease), padding var(--dur) var(--ease), border-color var(--dur) var(--ease);
  border-bottom:1px solid transparent;
}
.site-header .wrap{ display:flex; align-items:center; justify-content:space-between; gap:1.5rem; }
.site-header.scrolled{
  background:color-mix(in srgb, var(--paper) 86%, transparent);
  backdrop-filter:saturate(120%) blur(14px);
  -webkit-backdrop-filter:saturate(120%) blur(14px);
  padding-block:0.75rem;
  border-bottom-color:var(--line);
}
/* dark-hero pages: header text is light until scrolled */
.site-header.on-dark:not(.scrolled){ color:var(--on-char); }
.site-header.on-dark:not(.scrolled) .nav-link::after{ background:var(--on-char); }

.brand{ display:flex; flex-direction:column; line-height:1; gap:.28rem; z-index:2; }
.brand .brand-mark{
  font-family:"Fraunces", serif; font-weight:400;
  font-size:clamp(1.15rem,0.9rem + 0.9vw,1.5rem);
  letter-spacing:0.02em;
}
.brand .brand-sub{
  font-size:0.6rem; letter-spacing:0.42em; text-transform:uppercase;
  font-weight:600; color:var(--muted); padding-left:.12em;
}
.on-dark .brand .brand-sub{ color:var(--on-char-mut); }

.nav{ display:flex; align-items:center; gap:clamp(1.4rem,1rem + 1.4vw,2.8rem); }
.nav-link{
  position:relative; font-size:0.82rem; letter-spacing:0.18em; text-transform:uppercase;
  font-weight:600; padding-block:.4rem;
}
.nav-link::after{
  content:""; position:absolute; left:0; bottom:.1rem; height:1px; width:100%;
  background:currentColor; transform:scaleX(0); transform-origin:right;
  transition:transform .5s var(--ease);
}
.nav-link:hover::after,.nav-link[aria-current="page"]::after{ transform:scaleX(1); transform-origin:left; }
.nav-link[aria-current="page"]{ color:var(--bronze-dp); }

.nav-cta{
  font-size:0.78rem; letter-spacing:0.16em; text-transform:uppercase; font-weight:600;
  border:1px solid currentColor; padding:.7rem 1.3rem; border-radius:100px;
  transition:background .4s var(--ease), color .4s var(--ease), border-color .4s var(--ease);
}
.nav-cta:hover{ background:var(--ink); color:var(--paper-2); border-color:var(--ink); }
.on-dark:not(.scrolled) .nav-cta:hover{ background:var(--on-char); color:var(--char); border-color:var(--on-char); }

/* Mobile nav */
.nav-toggle{ display:none; width:44px; height:44px; position:relative; z-index:120; }
.nav-toggle span{ position:absolute; left:9px; right:9px; height:1.5px; background:currentColor; transition:transform .45s var(--ease), opacity .3s; }
.nav-toggle span:nth-child(1){ top:16px; }
.nav-toggle span:nth-child(2){ bottom:16px; }
.nav-open .nav-toggle span:nth-child(1){ top:21px; transform:rotate(45deg); }
.nav-open .nav-toggle span:nth-child(2){ bottom:21px; transform:rotate(-45deg); }

@media (max-width: 920px){
  .nav-toggle{ display:block; }
  .nav{
    position:fixed; inset:0; flex-direction:column; justify-content:center;
    gap:1.6rem; background:var(--paper); color:var(--ink);
    transform:translateY(-100%); transition:transform .7s var(--ease);
    padding:2rem;
  }
  .nav-open .nav{ transform:translateY(0); }
  .nav-link{ font-size:1.4rem; letter-spacing:0.12em; }
  .nav-link, .nav-cta{ opacity:0; transform:translateY(14px); transition:opacity .5s var(--ease), transform .5s var(--ease); }
  .nav-open .nav-link, .nav-open .nav-cta{ opacity:1; transform:none; transition-delay:calc(var(--i,0) * 70ms + 150ms); }
  .nav-cta{ font-size:0.9rem; }
}

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; color:var(--on-char); }
.hero__media{ position:absolute; inset:0; z-index:0; }
.hero__media img{ width:100%; height:100%; object-fit:cover; transform:scale(1.08); will-change:transform; }
.hero__media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(10,8,6,.34) 0%, rgba(10,8,6,.05) 32%, rgba(10,8,6,.12) 60%, rgba(10,8,6,.72) 100%);
}
.hero__inner{ position:relative; z-index:2; width:100%; padding-bottom:clamp(3rem,2rem + 5vw,7rem); }
.hero__inner .wrap{ display:grid; gap:1.6rem; }
.hero h1{
  color:#fff; max-width:16ch; font-weight:360;
  text-shadow:0 2px 40px rgba(0,0,0,.25);
}
.hero h1 .it{ font-style:italic; }
.hero__meta{ display:flex; flex-wrap:wrap; gap:1rem 2.4rem; align-items:center; color:var(--on-char-mut); }
.hero__meta .eyebrow{ color:#e9dcc4; }
.hero .lead{ color:#efe7d8; max-width:50ch; }
.scroll-cue{
  position:absolute; left:50%; bottom:1.6rem; transform:translateX(-50%); z-index:3;
  font-size:0.62rem; letter-spacing:0.34em; text-transform:uppercase; color:#e9dcc4;
  display:flex; flex-direction:column; align-items:center; gap:.6rem;
}
.scroll-cue::after{ content:""; width:1px; height:46px; background:linear-gradient(var(--on-char-mut), transparent); animation:cue 2.4s var(--ease) infinite; }
@keyframes cue{ 0%{ transform:scaleY(0); transform-origin:top; } 45%{ transform:scaleY(1); transform-origin:top; } 55%{ transform:scaleY(1); transform-origin:bottom; } 100%{ transform:scaleY(0); transform-origin:bottom; } }

/* Page hero (interior pages) */
.page-hero{ padding-top:clamp(8rem,6rem + 8vw,13rem); padding-bottom:clamp(2.5rem,2rem + 3vw,4.5rem); }
.page-hero .eyebrow{ margin-bottom:1.6rem; }
.page-hero h1{ max-width:18ch; }
.page-hero .lead{ margin-top:1.8rem; }

/* ============================================================
   BUTTONS / LINKS
   ============================================================ */
.btn{
  display:inline-flex; align-items:center; gap:.8em;
  font-size:0.82rem; letter-spacing:0.16em; text-transform:uppercase; font-weight:600;
  padding:1.05em 2em; border-radius:100px; border:1px solid var(--ink);
  background:var(--ink); color:var(--paper-2);
  transition:background .5s var(--ease), color .5s var(--ease), border-color .5s var(--ease);
}
.btn .arr{ transition:transform .5s var(--ease); }
.btn:hover{ background:transparent; color:var(--ink); }
.btn:hover .arr{ transform:translateX(5px); }
.btn--ghost{ background:transparent; color:var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:var(--paper-2); }
.dark .btn{ background:var(--on-char); color:var(--char); border-color:var(--on-char); }
.dark .btn:hover{ background:transparent; color:var(--on-char); }

.link-arrow{
  display:inline-flex; align-items:center; gap:.6em;
  font-size:0.8rem; letter-spacing:0.16em; text-transform:uppercase; font-weight:600;
  color:var(--ink); padding-bottom:.35rem; position:relative;
}
.link-arrow::after{ content:""; position:absolute; left:0; bottom:0; height:1px; width:100%; background:var(--ink); transform:scaleX(.18); transform-origin:left; transition:transform .55s var(--ease); }
.link-arrow:hover::after{ transform:scaleX(1); }
.link-arrow .arr{ transition:transform .5s var(--ease); }
.link-arrow:hover .arr{ transform:translateX(5px); }

/* ============================================================
   SECTION HEADINGS
   ============================================================ */
.sec-head{ display:grid; gap:1.2rem; margin-bottom:clamp(2.5rem,2rem + 2vw,4.5rem); }
.sec-head h2{ max-width:18ch; }
.sec-head--split{ grid-template-columns:1fr; }
@media (min-width:900px){
  .sec-head--split{ grid-template-columns:1.1fr .9fr; align-items:end; gap:2.5rem; }
  .sec-head--split .sec-head__aside{ padding-bottom:.4rem; }
}

/* ============================================================
   INTRO / STATEMENT
   ============================================================ */
.statement{ display:grid; gap:clamp(2rem,1rem + 3vw,3.5rem); }
@media (min-width:900px){ .statement{ grid-template-columns:1fr 1fr; align-items:center; } }
.statement__fig{ position:relative; overflow:hidden; aspect-ratio:4/5; }
.statement__fig img{ width:100%; height:100%; object-fit:cover; }

/* ============================================================
   FEATURED PROJECTS (home)
   ============================================================ */
.feature{ display:grid; gap:clamp(1.5rem,1rem + 2vw,3rem); align-items:center; }
@media (min-width:900px){
  .feature{ grid-template-columns:1fr 1fr; }
  .feature:nth-child(even) .feature__fig{ order:2; }
}
.feature + .feature{ margin-top:var(--space-section); }
.feature__fig{ position:relative; overflow:hidden; aspect-ratio:5/4; }
.feature__fig img{ width:100%; height:100%; object-fit:cover; transition:transform 1.4s var(--ease); }
.feature:hover .feature__fig img{ transform:scale(1.045); }
.feature__num{ font-family:"Fraunces",serif; font-size:0.9rem; color:var(--bronze-dp); letter-spacing:.04em; }
.feature__body{ display:grid; gap:1.1rem; }
.feature__body h3{ font-size:var(--fs-h2); }
.feature__loc{ font-size:var(--fs-small); letter-spacing:0.22em; text-transform:uppercase; color:var(--muted); font-weight:600; }

/* ============================================================
   PORTFOLIO GRID (index pages)
   ============================================================ */
.proj-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(min(100%, 360px), 1fr)); gap:clamp(1.5rem,1rem + 2vw,3.2rem) clamp(1.2rem,0.8rem + 1.6vw,2.4rem); }
.proj-grid.two{ grid-template-columns:repeat(auto-fill, minmax(min(100%, 520px), 1fr)); }
.proj-card{ display:block; }
.proj-card__fig{ position:relative; overflow:hidden; aspect-ratio:4/5; background:var(--paper-3); }
.proj-card.wide .proj-card__fig{ aspect-ratio:4/3; }
.proj-card__fig img{ width:100%; height:100%; object-fit:cover; transition:transform 1.5s var(--ease), filter 1s var(--ease); }
.proj-card:hover .proj-card__fig img{ transform:scale(1.06); }
.proj-card__overlay{
  position:absolute; inset:0; display:flex; align-items:flex-end; padding:1.4rem;
  background:linear-gradient(0deg, rgba(15,11,8,.55), transparent 55%);
  opacity:0; transition:opacity .6s var(--ease);
}
.proj-card:hover .proj-card__overlay{ opacity:1; }
.proj-card__overlay .view{ color:#fff; font-size:0.72rem; letter-spacing:0.24em; text-transform:uppercase; font-weight:600; display:inline-flex; gap:.6em; align-items:center; }
.proj-card__cap{ padding-top:1.1rem; display:grid; gap:.35rem; }
.proj-card__cap h3{ font-size:var(--fs-h3); }
.proj-card__cap .meta{ font-size:var(--fs-small); letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); font-weight:600; }

/* ============================================================
   EDITORIAL LOGOS
   ============================================================ */
.press-row{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
@media (min-width:760px){ .press-row{ grid-template-columns:repeat(4,1fr); } }
.press-row a{ background:var(--paper-2); display:flex; align-items:center; justify-content:center; padding:clamp(2rem,1.5rem + 3vw,4rem) 1.5rem; transition:background .5s var(--ease); aspect-ratio:3/2; }
.press-row a:hover{ background:var(--paper-3); }
.press-row img{ max-height:62px; width:auto; object-fit:contain; filter:grayscale(1) contrast(.9); opacity:.8; transition:opacity .5s var(--ease), filter .5s var(--ease); }
.press-row a:hover img{ opacity:1; filter:grayscale(0); }

.marquee{ overflow:hidden; border-block:1px solid var(--line); padding-block:1.4rem; }
.marquee__track{ display:flex; gap:4rem; width:max-content; animation:marq 38s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee__item{ font-family:"Fraunces",serif; font-size:clamp(1.4rem,1rem + 1.6vw,2.4rem); color:var(--ink-soft); display:inline-flex; align-items:center; gap:4rem; white-space:nowrap; }
.marquee__item::after{ content:"✦"; color:var(--bronze); font-size:.7em; }
@keyframes marq{ to{ transform:translateX(-50%); } }

/* ============================================================
   GALLERY (project detail)
   ============================================================ */
.gallery{ display:grid; gap:clamp(1rem,0.6rem + 1.4vw,2rem); }
.gallery--single{ grid-template-columns:1fr; }
.gallery--mixed{ grid-template-columns:repeat(2, 1fr); }
@media (max-width:680px){ .gallery--mixed{ grid-template-columns:1fr; } }
.gfig{ position:relative; overflow:hidden; background:var(--paper-3); }
.gfig img{ width:100%; height:100%; object-fit:cover; transition:transform 1.6s var(--ease); }
.gfig.tall{ aspect-ratio:4/5; }
.gfig.wide{ grid-column:1 / -1; aspect-ratio:16/9; }
.gfig.full{ grid-column:1 / -1; }
.gfig:hover img{ transform:scale(1.04); }
.gfig figcaption{ position:absolute; left:0; right:0; bottom:0; padding:1.4rem; color:#fff; font-size:var(--fs-small); background:linear-gradient(0deg, rgba(10,8,6,.6), transparent); opacity:0; transition:opacity .5s var(--ease); }
.gfig:hover figcaption{ opacity:1; }

/* Project meta strip */
.proj-meta{ display:grid; gap:1.6rem 3rem; }
@media (min-width:760px){ .proj-meta{ grid-template-columns:repeat(3, auto); justify-content:start; } }
.proj-meta dt{ font-size:0.7rem; letter-spacing:0.24em; text-transform:uppercase; color:var(--muted); font-weight:600; margin-bottom:.4rem; }
.proj-meta dd{ font-family:"Fraunces",serif; font-size:1.2rem; }

/* Prev/next */
.pager{ display:flex; justify-content:space-between; gap:1rem; border-top:1px solid var(--line); padding-top:2rem; flex-wrap:wrap; }
.pager a{ display:grid; gap:.3rem; }
.pager .dir{ font-size:0.7rem; letter-spacing:0.24em; text-transform:uppercase; color:var(--muted); font-weight:600; }
.pager .ttl{ font-family:"Fraunces",serif; font-size:1.3rem; }
.pager .next{ text-align:right; }

/* ============================================================
   ABOUT
   ============================================================ */
.about-hero{ display:grid; gap:clamp(2rem,1rem + 3vw,4rem); align-items:center; }
@media (min-width:900px){ .about-hero{ grid-template-columns:.9fr 1.1fr; } }
.about-hero__fig{ position:relative; overflow:hidden; aspect-ratio:4/5; }
.about-hero__fig img{ width:100%; height:100%; object-fit:cover; }
.bio{ display:grid; gap:1.4rem; }
.bio p{ max-width:56ch; }

.values{ display:grid; gap:1px; background:var(--line); border-block:1px solid var(--line); }
@media (min-width:820px){ .values{ grid-template-columns:repeat(3,1fr); } }
.values .val{ background:var(--paper); padding:clamp(2rem,1.5rem + 2vw,3.2rem); display:grid; gap:1rem; }
.values .val .n{ font-family:"Fraunces",serif; color:var(--bronze-dp); font-size:1rem; }
.values .val h3{ font-size:var(--fs-h3); }

.testi{ display:grid; gap:2rem; }
@media (min-width:820px){ .testi{ grid-template-columns:repeat(2,1fr); gap:clamp(2rem,1rem + 3vw,4rem); } }
.testi blockquote{ display:grid; gap:1.2rem; }
.testi .fr-quote{ font-size:clamp(1.2rem,1rem + 1vw,1.6rem); }
.testi cite{ font-style:normal; font-size:var(--fs-small); letter-spacing:0.16em; text-transform:uppercase; color:var(--muted); font-weight:600; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{ display:grid; gap:clamp(2.5rem,2rem + 3vw,5rem); }
@media (min-width:900px){ .contact-grid{ grid-template-columns:1fr 1fr; } }
.field{ display:grid; gap:.6rem; margin-bottom:1.6rem; }
.field label{ font-size:0.72rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); font-weight:600; }
.field input,.field textarea,.field select{
  background:transparent; border:0; border-bottom:1px solid var(--line-2);
  padding:.7rem .1rem; color:var(--ink); border-radius:0;
  transition:border-color .4s var(--ease);
}
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-bottom-color:var(--bronze); }
.field textarea{ resize:vertical; min-height:120px; }
.contact-detail{ display:grid; gap:1.8rem; align-content:start; }
.contact-detail .ci{ display:grid; gap:.4rem; }
.contact-detail .ci .k{ font-size:0.72rem; letter-spacing:0.22em; text-transform:uppercase; color:var(--muted); font-weight:600; }
.contact-detail .ci a, .contact-detail .ci .v{ font-family:"Fraunces",serif; font-size:clamp(1.3rem,1rem + 1.4vw,2rem); }
.contact-detail .ci a:hover{ color:var(--bronze-dp); }

/* ============================================================
   AREAS SERVED (SEO)
   ============================================================ */
.areas{ display:flex; flex-wrap:wrap; gap:.7rem; }
.areas span{ border:1px solid var(--line-2); border-radius:100px; padding:.55rem 1.1rem; font-size:0.82rem; letter-spacing:0.04em; color:var(--ink-soft); transition:background .4s var(--ease), color .4s var(--ease); }
.areas span:hover{ background:var(--ink); color:var(--paper-2); }
.dark .areas span{ border-color:rgba(255,255,255,.2); color:var(--on-char-mut); }
.dark .areas span:hover{ background:var(--on-char); color:var(--char); }

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band{ text-align:center; display:grid; gap:1.8rem; justify-items:center; }
.cta-band h2{ max-width:20ch; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:var(--char); color:var(--on-char); padding-block:clamp(3.5rem,3rem + 3vw,6rem) 2rem; }
.footer-top{ display:grid; gap:clamp(2rem,1rem + 3vw,4rem); padding-bottom:clamp(2.5rem,2rem + 2vw,4rem); border-bottom:1px solid rgba(255,255,255,.12); }
@media (min-width:820px){ .footer-top{ grid-template-columns:1.4fr 1fr 1fr; } }
.footer-brand .brand-mark{ font-family:"Fraunces",serif; font-size:clamp(1.8rem,1.4rem + 1.6vw,2.8rem); font-weight:380; color:var(--on-char); }
.footer-brand p{ color:var(--on-char-mut); margin-top:1rem; max-width:34ch; }
.footer-col h4{ font-size:0.72rem; letter-spacing:0.24em; text-transform:uppercase; color:var(--on-char-mut); font-weight:600; margin-bottom:1.2rem; font-family:"Hanken Grotesk",sans-serif; }
.footer-col ul{ display:grid; gap:.7rem; }
.footer-col a{ color:var(--on-char); opacity:.82; transition:opacity .4s var(--ease), color .4s var(--ease); }
.footer-col a:hover{ opacity:1; color:var(--bronze); }
.footer-bottom{ display:flex; flex-wrap:wrap; gap:1rem 2rem; justify-content:space-between; align-items:center; padding-top:2rem; color:var(--on-char-mut); font-size:0.82rem; letter-spacing:0.02em; }
.footer-social{ display:flex; gap:1.4rem; }
.footer-social a{ color:var(--on-char-mut); transition:color .4s var(--ease); letter-spacing:0.14em; text-transform:uppercase; font-size:0.74rem; font-weight:600; }
.footer-social a:hover{ color:var(--bronze); }

/* ============================================================
   MOTION — reveal system
   ============================================================ */
[data-reveal]{ opacity:0; transform:translateY(26px); transition:opacity 1s var(--ease), transform 1.1s var(--ease); will-change:opacity, transform; }
[data-reveal].in{ opacity:1; transform:none; }
[data-reveal="fade"]{ transform:none; }
[data-reveal] [data-reveal-child]{ opacity:0; transform:translateY(18px); transition:opacity .9s var(--ease), transform 1s var(--ease); }
[data-reveal].in [data-reveal-child]{ opacity:1; transform:none; }
[data-reveal].in [data-reveal-child]:nth-child(2){ transition-delay:.08s; }
[data-reveal].in [data-reveal-child]:nth-child(3){ transition-delay:.16s; }
[data-reveal].in [data-reveal-child]:nth-child(4){ transition-delay:.24s; }
[data-reveal].in [data-reveal-child]:nth-child(5){ transition-delay:.32s; }

/* image clip reveal */
.reveal-img{ overflow:hidden; }
.reveal-img img{ clip-path:inset(0 0 100% 0); transform:scale(1.12); transition:clip-path 1.3s var(--ease-soft), transform 1.6s var(--ease-soft); }
.reveal-img.in img{ clip-path:inset(0 0 0 0); transform:scale(1); }

/* delays utility */
.d1{ transition-delay:.1s; } .d2{ transition-delay:.2s; } .d3{ transition-delay:.3s; } .d4{ transition-delay:.4s; }

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
  [data-reveal],[data-reveal] [data-reveal-child]{ opacity:1 !important; transform:none !important; }
  .reveal-img img{ clip-path:none !important; transform:none !important; }
  .hero__media img{ transform:none !important; }
}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{ position:fixed; inset:0; z-index:200; background:rgba(15,11,8,.94); display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity .5s var(--ease); padding:clamp(1rem,3vw,3rem); }
.lightbox.open{ opacity:1; pointer-events:auto; }
.lightbox img{ max-width:92vw; max-height:88vh; object-fit:contain; box-shadow:0 30px 80px rgba(0,0,0,.5); transform:scale(.96); transition:transform .6s var(--ease); }
.lightbox.open img{ transform:scale(1); }
.lightbox__close,.lightbox__nav{ position:absolute; color:#fff; opacity:.8; transition:opacity .3s; font-size:.8rem; letter-spacing:.2em; text-transform:uppercase; }
.lightbox__close{ top:1.4rem; right:1.6rem; font-size:1.6rem; }
.lightbox__nav{ top:50%; transform:translateY(-50%); font-size:2rem; padding:1rem; }
.lightbox__nav.prev{ left:1rem; } .lightbox__nav.next{ right:1rem; }
.lightbox__close:hover,.lightbox__nav:hover{ opacity:1; }
.lightbox__count{ position:absolute; bottom:1.4rem; left:50%; transform:translateX(-50%); color:#fff; opacity:.7; font-size:.8rem; letter-spacing:.2em; }

/* ============================================================
   PROGRESS + MISC
   ============================================================ */
.scroll-progress{ position:fixed; top:0; left:0; height:2px; width:0; background:var(--bronze); z-index:130; transition:width .1s linear; }
.skip-link{ position:absolute; left:-9999px; top:0; background:var(--ink); color:var(--paper-2); padding:.8rem 1.2rem; z-index:300; }
.skip-link:focus{ left:1rem; top:1rem; }
:focus-visible{ outline:2px solid var(--bronze); outline-offset:3px; }

/* small caption under images on detail */
.fig-credit{ font-size:var(--fs-small); color:var(--muted); margin-top:.8rem; letter-spacing:.02em; }
