/* ============================================================
   Van Aken Design - bespoke design system
   Heritage atelier / luxury craft. Warm walnut · Carrara · brass.
   Authored for clarity (legible at 50+) and quiet luxury.
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* Surfaces */
  --paper:      #f6f1e8;   /* warm alabaster */
  --paper-2:    #efe6d7;   /* deeper section */
  --cream:      #fbf8f2;
  --espresso:   #221b14;   /* dark sections */
  --espresso-2: #2c2419;

  /* Ink */
  --ink:        #211c15;   /* warm near-black */
  --ink-soft:   #463f33;   /* body text on light */
  --ink-mute:   #6c6354;   /* captions / meta */
  --on-dark:    #efe7d8;
  --on-dark-mute:#b6ab97;

  /* Accents - walnut + brass */
  --walnut:     #6c4527;
  --walnut-2:   #8a5a33;
  --brass:      #ad8950;
  --brass-2:    #c8a86c;
  --brass-deep: #7d5f33;

  /* Lines */
  --line:       rgba(33,28,21,.14);
  --line-2:     rgba(33,28,21,.08);
  --line-dark:  rgba(239,231,216,.18);

  /* Type */
  --serif: 'Fraunces', 'Hoefler Text', Georgia, 'Times New Roman', serif;
  --sans:  'Hanken Grotesk', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;

  /* Rhythm */
  --wrap: 1240px;
  --wrap-narrow: 780px;
  --gut: clamp(1.25rem, 4vw, 3.25rem);
  --sec-y: clamp(4.5rem, 9vw, 9rem);

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --radius: 2px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{ margin:0; }
img,svg,video{ display:block; max-width:100%; height:auto; }
button,input,select,textarea{ font:inherit; color:inherit; }
a{ color:inherit; text-decoration:none; }
ul,ol{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4,p,figure,blockquote{ margin:0; }
:focus-visible{ outline:3px solid var(--ink); outline-offset:2px; border-radius:1px; }
.section--dark :focus-visible, .site-footer :focus-visible, .hero :focus-visible{ outline-color:var(--brass-2); }

/* ---------- Base ---------- */
body{
  font-family:var(--sans);
  font-size:clamp(1.06rem, .55vw + .95rem, 1.2rem);
  line-height:1.75;
  color:var(--ink-soft);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
::selection{ background:var(--brass); color:var(--cream); }

/* Decorative grain + a faint marble wash for depth (very subtle) */
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(120% 80% at 80% -10%, rgba(173,137,80,.06), transparent 60%),
    radial-gradient(100% 70% at -10% 110%, rgba(108,69,39,.05), transparent 55%);
}
main, header, footer{ position:relative; z-index:1; }

/* Quiet gallery-mat frame on large screens (signature detail) */
.frame{ position:fixed; inset:14px; border:1px solid var(--brass); opacity:.32;
  pointer-events:none; z-index:60; mix-blend-mode:multiply; }
@media (max-width:700px){ .frame{ inset:8px; } }

/* ---------- Typography ---------- */
h1,h2,h3,h4,.display{
  font-family:var(--serif);
  color:var(--ink);
  font-weight:430;
  line-height:1.06;
  letter-spacing:-.015em;
  font-optical-sizing:auto;
}
.h-hero{ font-size:clamp(2.7rem, 6.4vw, 5.7rem); font-weight:420; line-height:1.02; }
h2,.h2{ font-size:clamp(2rem, 4.2vw, 3.4rem); }
h3,.h3{ font-size:clamp(1.4rem, 2.4vw, 2rem); line-height:1.14; }
.lede{ font-size:clamp(1.2rem, 1.1vw + 1rem, 1.55rem); line-height:1.6; color:var(--ink-soft);
  font-weight:400; }
p{ margin:0 0 1.1em; max-width:64ch; }
strong{ color:var(--ink); font-weight:600; }
em{ font-style:italic; }

.serif-italic{ font-family:var(--serif); font-style:italic; font-weight:380; }

/* Eyebrow / kicker label */
.eyebrow{
  font-family:var(--sans); font-weight:600;
  font-size:.74rem; letter-spacing:.26em; text-transform:uppercase;
  color:var(--brass-deep);
  display:inline-flex; align-items:center; gap:.7rem;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--brass); display:inline-block; }
.eyebrow--center::after{ content:""; width:26px; height:1px; background:var(--brass); display:inline-block; }
.eyebrow--plain::before{ display:none; }

.section-no{ font-family:var(--serif); font-style:italic; color:var(--brass-deep);
  font-size:1.05rem; font-weight:500; letter-spacing:.02em; }
.section--dark .section-no{ color:var(--brass-2); }

/* ---------- Layout ---------- */
.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--gut); }
.wrap-narrow{ max-width:var(--wrap-narrow); }
.section{ padding-block:var(--sec-y); }
.section--tight{ padding-block:clamp(3rem,6vw,5.5rem); }
.section--dark{ background:var(--espresso); color:var(--on-dark); }
.section--dark h1,.section--dark h2,.section--dark h3{ color:var(--cream); }
.section--paper2{ background:var(--paper-2); }
.rule{ height:1px; background:var(--line); border:0; margin:0; }
.center{ text-align:center; }
.measure{ max-width:60ch; }
.mt-s{ margin-top:1rem; } .mt-m{ margin-top:1.8rem; } .mt-l{ margin-top:3rem; }

.grid{ display:grid; gap:clamp(1.5rem,3vw,3rem); }
.two{ grid-template-columns:1fr 1fr; }
.split{ grid-template-columns:1.05fr .95fr; align-items:center; }
@media (max-width:860px){ .two,.split{ grid-template-columns:1fr; } }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--ink); --fg:var(--cream);
  display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--sans); font-weight:600; font-size:.82rem;
  letter-spacing:.16em; text-transform:uppercase;
  padding:1.05em 1.9em; background:var(--bg); color:var(--fg);
  border:1px solid var(--bg); border-radius:var(--radius);
  cursor:pointer; position:relative; overflow:hidden; isolation:isolate;
  transition:color .5s var(--ease), border-color .5s var(--ease);
}
.btn::after{ content:""; position:absolute; inset:0; z-index:-1; background:var(--brass);
  transform:translateY(101%); transition:transform .5s var(--ease); }
.btn:hover{ color:var(--ink); border-color:var(--brass); }
.btn:hover::after{ transform:translateY(0); }
.btn .arrow{ transition:transform .5s var(--ease); }
.btn:hover .arrow{ transform:translateX(4px); }
.btn--ghost{ --bg:transparent; --fg:var(--ink); border-color:var(--line); color:var(--ink); }
.btn--ghost:hover{ color:var(--ink); border-color:var(--brass); }
.btn--light{ --bg:var(--cream); --fg:var(--ink); }
.btn--onbrass{ --bg:var(--brass); --fg:var(--cream); border-color:var(--brass); }
.btn--onbrass::after{ background:var(--cream); }
.btn--onbrass:hover{ color:var(--ink); }

/* Text link with brass draw */
.tlink{ font-family:var(--sans); font-weight:600; font-size:.82rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--ink); display:inline-flex; gap:.6em; align-items:center;
  padding-bottom:.35em; background-image:linear-gradient(var(--brass),var(--brass));
  background-size:0% 1.5px; background-position:0 100%; background-repeat:no-repeat;
  transition:background-size .5s var(--ease), color .4s var(--ease); }
.tlink:hover{ background-size:100% 1.5px; color:var(--walnut); }
.section--dark .tlink{ color:var(--cream); }

/* ============================================================
   Header / Nav
   ============================================================ */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:50;
  padding:clamp(.7rem,1.4vw,1.15rem) 0;
  transition:background .5s var(--ease), box-shadow .5s var(--ease), padding .5s var(--ease);
}
.site-header__inner{ display:flex; align-items:center; justify-content:space-between; gap:1.5rem; }
.site-header.is-solid{
  background:rgba(246,241,232,.86); backdrop-filter:blur(12px) saturate(1.1);
  box-shadow:0 1px 0 var(--line);
}
.site-header.is-solid .nav__link, .site-header.is-solid .brand{ color:var(--ink); }

.brand{ display:flex; align-items:baseline; gap:.62rem; color:var(--ink); }
.brand__mark{ font-family:var(--serif); font-weight:500; font-size:1.05rem; letter-spacing:.04em;
  width:2.05rem; height:2.05rem; display:grid; place-items:center; flex:none;
  border:1px solid var(--brass); color:var(--brass-deep); border-radius:50%; }
.brand__name{ font-family:var(--serif); font-size:1.32rem; font-weight:500; letter-spacing:.01em; line-height:1; }
.brand__name b{ font-weight:500; }
.brand__sub{ display:block; font-family:var(--sans); font-weight:600; font-size:.62rem;
  letter-spacing:.26em; text-transform:uppercase; color:var(--brass-deep); margin-top:.34em; }

.nav{ display:flex; align-items:center; gap:clamp(1.1rem,2vw,2.1rem); }
.nav__link{ position:relative; font-family:var(--sans); font-weight:500; font-size:.84rem;
  letter-spacing:.12em; text-transform:uppercase; color:var(--ink); padding:.7em 0; }
.nav__link::after{ content:""; position:absolute; left:0; bottom:-2px; height:1.5px; width:0;
  background:var(--brass); transition:width .4s var(--ease); }
.nav__link:hover::after, .nav__link.is-active::after{ width:100%; }
.nav__link.is-active{ color:var(--walnut); }

/* hero-overlay (transparent) header text in light */
.site-header:not(.is-solid).on-hero .brand,
.site-header:not(.is-solid).on-hero .nav__link{ color:var(--cream); }
.site-header:not(.is-solid).on-hero .brand__mark{ border-color:rgba(255,255,255,.6); color:var(--cream); }
.site-header:not(.is-solid).on-hero .brand__sub{ color:var(--brass-2); }

.nav-toggle{ display:none; }
.menu-btn{ display:none; }

/* Mobile menu */
@media (max-width:1000px){
  .nav__cta{ display:none; }
}
@media (max-width:880px){
  .nav{ position:fixed; inset:0; flex-direction:column; justify-content:center;
    gap:1.4rem; background:var(--espresso); color:var(--cream);
    transform:translateY(-100%); transition:transform .6s var(--ease); padding:5rem var(--gut) 3rem; }
  .nav.is-open{ transform:translateY(0); }
  .nav__link{ color:var(--cream) !important; font-size:1.5rem; font-family:var(--serif);
    text-transform:none; letter-spacing:0; font-weight:430; }
  .nav__link::after{ display:none; }
  .nav__cta{ display:inline-flex !important; margin-top:1rem; }
  .menu-btn{ display:inline-flex; align-items:center; gap:.6rem; background:none; border:0;
    cursor:pointer; z-index:55; font-family:var(--sans); font-weight:600; font-size:.78rem;
    letter-spacing:.18em; text-transform:uppercase; color:var(--ink); }
  .site-header.on-hero:not(.is-solid) .menu-btn{ color:var(--cream); }
  .menu-btn.is-open{ color:var(--cream); position:fixed; right:var(--gut); top:1.1rem; }
  .menu-ico{ width:26px; height:11px; position:relative; display:inline-block; }
  .menu-ico span{ position:absolute; left:0; height:1.5px; width:100%; background:currentColor;
    transition:transform .4s var(--ease), opacity .3s; }
  .menu-ico span:nth-child(1){ top:0; } .menu-ico span:nth-child(2){ bottom:0; }
  .menu-btn.is-open .menu-ico span:nth-child(1){ top:5px; transform:rotate(45deg); }
  .menu-btn.is-open .menu-ico span:nth-child(2){ bottom:5px; transform:rotate(-45deg); }
}

/* ============================================================
   Hero
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end;
  color:var(--cream); overflow:hidden; }
.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(18,13,8,.58) 0%, rgba(18,13,8,.18) 30%, rgba(18,13,8,.82) 100%); }
.hero__inner{ position:relative; z-index:2; width:100%; padding-block:clamp(7rem,16vh,11rem) clamp(3rem,7vh,5rem);
  text-shadow:0 1px 12px rgba(0,0,0,.32); }
.hero .eyebrow{ color:var(--brass-2); }
.hero .eyebrow::before{ background:var(--brass-2); }
.hero__title{ color:var(--cream); max-width:16ch; margin-top:1.3rem; }
.hero__title .ital{ color:var(--brass-2); }
.hero__sub{ color:rgba(245,238,225,.92); max-width:46ch; margin-top:1.6rem; font-size:1.15rem; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:1rem; margin-top:2.4rem; }
.hero__meta{ display:flex; gap:2.4rem; margin-top:3.2rem; flex-wrap:wrap; border-top:1px solid rgba(255,255,255,.18);
  padding-top:1.6rem; }
.hero__meta b{ display:block; font-family:var(--serif); font-size:1.7rem; color:var(--cream); font-weight:430; line-height:1; }
.hero__meta span{ font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--brass-2); }
.scroll-cue{ position:absolute; right:var(--gut); bottom:2.2rem; z-index:2; display:flex; align-items:center; gap:.8rem;
  font-size:.68rem; letter-spacing:.24em; text-transform:uppercase; color:rgba(245,238,225,.8); writing-mode:vertical-rl; }
.scroll-cue i{ width:1px; height:54px; background:linear-gradient(var(--brass-2),transparent); display:block; 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;} }
@media (max-width:680px){ .scroll-cue{ display:none; } }

/* ---------- Marquee strip ---------- */
.marquee{ border-block:1px solid var(--line); background:var(--cream); overflow:hidden; padding:1.15rem 0; }
.marquee__track{ display:flex; gap:3.5rem; width:max-content; animation:marq 38s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee__item{ font-family:var(--serif); font-style:italic; font-size:1.4rem; color:var(--walnut);
  display:inline-flex; align-items:center; gap:3.5rem; white-space:nowrap; }
.marquee__item::after{ content:"✦"; font-style:normal; color:var(--brass); font-size:.7em; }
@keyframes marq{ to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion: reduce){ .marquee__track{ animation:none; } }

/* ============================================================
   Reveal animations
   ============================================================ */
.js .reveal{ opacity:0; transform:translateY(26px); transition:opacity 1s var(--ease-out), transform 1s var(--ease-out); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.1s; } .reveal[data-d="2"]{ transition-delay:.2s; }
.reveal[data-d="3"]{ transition-delay:.3s; } .reveal[data-d="4"]{ transition-delay:.4s; }
.reveal[data-d="5"]{ transition-delay:.5s; }

/* Image curtain reveal */
.img-reveal{ position:relative; overflow:hidden; }
.js .img-reveal img{ transform:scale(1.12); transition:transform 1.5s var(--ease-out); will-change:transform; }
.js .img-reveal::after{ content:""; position:absolute; inset:0; background:var(--paper); transform-origin:bottom;
  transition:transform 1.15s var(--ease-out); z-index:2; }
.img-reveal.in img{ transform:scale(1); }
.img-reveal.in::after{ transform:scaleY(0); }
.img-reveal.on-dark::after{ background:var(--espresso); }

@media (prefers-reduced-motion: reduce){
  .js .reveal{ opacity:1; transform:none; transition:none; }
  .js .img-reveal img{ transform:none; } .js .img-reveal::after{ display:none; }
  .hero__media img{ transform:none; }
}

/* ============================================================
   Intro overlay
   ============================================================ */
.intro{ position:fixed; inset:0; z-index:200; background:var(--espresso); display:grid; place-items:center;
  transition:opacity .8s var(--ease), visibility .8s; }
html:not(.js) .intro{ display:none; }  /* never trap content if JS is off */
.intro.done{ opacity:0; visibility:hidden; }
.intro__mark{ text-align:center; color:var(--cream); }
.intro__mark .n{ font-family:var(--serif); font-size:clamp(2rem,6vw,3.4rem); font-weight:430; overflow:hidden; }
.intro__mark .n span{ display:inline-block; transform:translateY(110%); animation:introUp .9s var(--ease-out) forwards; }
.intro__mark .s{ font-family:var(--sans); font-weight:600; font-size:.66rem; letter-spacing:.4em; text-transform:uppercase;
  color:var(--brass-2); margin-top:1rem; opacity:0; animation:introFade .7s ease .5s forwards; }
.intro__bar{ height:1px; width:0; background:var(--brass); margin:1.4rem auto 0; animation:introBar 1.1s var(--ease) .3s forwards; }
@keyframes introUp{ to{ transform:none; } }
@keyframes introFade{ to{ opacity:1; } }
@keyframes introBar{ to{ width:160px; } }
@media (prefers-reduced-motion: reduce){ .intro{ display:none; } }

/* ============================================================
   Featured / project grid
   ============================================================ */
.work-grid{ display:grid; grid-template-columns:repeat(12,1fr); gap:clamp(1.4rem,2.4vw,2.6rem); }
.work-card{ position:relative; display:block; color:inherit; }
.work-card__media{ position:relative; overflow:hidden; background:var(--paper-2); aspect-ratio:4/5; }
.work-card__media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ease-out); }
.work-card:hover .work-card__media img{ transform:scale(1.06); }
.work-card__media::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 45%, rgba(20,15,10,.42)); opacity:.0; transition:opacity .5s; }
.work-card:hover .work-card__media::after{ opacity:1; }
.work-card__no{ position:absolute; top:1rem; left:1.1rem; z-index:2; font-family:var(--serif); font-style:italic;
  color:var(--cream); font-size:1rem; mix-blend-mode:difference; }
.work-card__cap{ display:flex; align-items:baseline; justify-content:space-between; gap:1rem;
  padding-top:1rem; border-top:1px solid var(--line); margin-top:1.1rem; }
.work-card__title{ font-family:var(--serif); font-size:1.45rem; font-weight:450; color:var(--ink); line-height:1.1;
  transition:color .4s; }
.work-card:hover .work-card__title{ color:var(--walnut); }
.work-card__tag{ font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute); white-space:nowrap; }
.work-card__view{ font-family:var(--sans); font-weight:600; font-size:.76rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--brass-deep); display:inline-flex; gap:.5em; opacity:0; transform:translateX(-6px);
  transition:opacity .4s, transform .4s; }
.work-card:hover .work-card__view{ opacity:1; transform:none; }

/* spans for editorial rhythm (desktop) */
.col-6{ grid-column:span 6; } .col-5{ grid-column:span 5; } .col-7{ grid-column:span 7; }
.col-4{ grid-column:span 4; } .col-8{ grid-column:span 8; } .col-12{ grid-column:span 12; }
.tall .work-card__media{ aspect-ratio:3/4; }
.wide .work-card__media{ aspect-ratio:3/2; }
.offset{ margin-top:clamp(2rem,6vw,5rem); }
@media (max-width:860px){
  .work-grid{ grid-template-columns:repeat(2,1fr); }
  .col-6,.col-5,.col-7,.col-4,.col-8,.col-12{ grid-column:span 1; }
  .offset{ margin-top:0; }
}
@media (max-width:520px){ .work-grid{ grid-template-columns:1fr; } }

/* ============================================================
   Editorial figure / split blocks
   ============================================================ */
.figure{ position:relative; }
.figure img{ width:100%; height:100%; object-fit:cover; }
.figure__cap{ font-size:.8rem; color:var(--ink-mute); margin-top:.8rem; letter-spacing:.02em; }
.figure--frame{ padding:.7rem; background:var(--cream); box-shadow:0 30px 60px -40px rgba(33,28,21,.5); }
.stack-imgs{ position:relative; }
.stack-imgs .s2{ position:absolute; width:46%; right:-6%; bottom:-12%; border:7px solid var(--cream);
  box-shadow:0 30px 50px -30px rgba(33,28,21,.6); }
@media (max-width:560px){ .stack-imgs .s2{ position:static; width:64%; margin:-18% 0 0 auto; } }

/* ---------- Values / pillars ---------- */
.pillars{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-top:1px solid var(--line); }
.pillar{ padding:2.4rem clamp(1.2rem,2vw,2rem); border-bottom:1px solid var(--line); }
.pillar:not(:last-child){ border-right:1px solid var(--line); }
.pillar__no{ font-family:var(--serif); font-style:italic; color:var(--brass-deep); font-size:1.1rem; }
.pillar h3{ margin:.7rem 0 .6rem; font-size:1.5rem; }
.pillar p{ font-size:1rem; color:var(--ink-soft); margin:0; }
@media (max-width:780px){ .pillars{ grid-template-columns:1fr; }
  .pillar:not(:last-child){ border-right:0; } }

/* ---------- Stats ---------- */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; }
.stat__n{ font-family:var(--serif); font-size:clamp(2.6rem,5vw,4rem); font-weight:420; color:var(--ink); line-height:1; }
.section--dark .stat__n{ color:var(--cream); }
.stat__l{ font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-mute); margin-top:.7rem; }
.section--dark .stat__l{ color:var(--on-dark-mute); }
.stat .amp{ color:var(--brass); }
@media (max-width:680px){ .stats{ grid-template-columns:repeat(2,1fr); gap:2.2rem; } }

/* ============================================================
   Process steps
   ============================================================ */
.steps{ display:grid; gap:0; }
.step{ display:grid; grid-template-columns:auto 1fr auto; gap:clamp(1.5rem,4vw,4rem); align-items:start;
  padding:clamp(2rem,4vw,3.4rem) 0; border-top:1px solid var(--line); }
.step:last-child{ border-bottom:1px solid var(--line); }
.step__no{ font-family:var(--serif); font-style:italic; font-size:clamp(1.6rem,3vw,2.4rem); color:var(--brass); line-height:1; }
.step__body h3{ font-size:clamp(1.5rem,2.4vw,2.1rem); margin-bottom:.6rem; }
.step__body p{ margin:0; color:var(--ink-soft); }
.step__meta{ font-size:.76rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-mute); text-align:right; white-space:nowrap; }
@media (max-width:720px){ .step{ grid-template-columns:auto 1fr; } .step__meta{ display:none; } }

/* ============================================================
   Project detail
   ============================================================ */
.pj-hero{ padding-top:clamp(7rem,14vh,10rem); }
.pj-hero__top{ display:flex; align-items:flex-end; justify-content:space-between; gap:2rem; flex-wrap:wrap; }
.pj-hero h1{ font-size:clamp(2.4rem,5.5vw,4.6rem); max-width:18ch; }
.pj-meta{ display:flex; gap:2.2rem; flex-wrap:wrap; margin-top:1.6rem; }
.pj-meta div{ }
.pj-meta dt{ font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-mute); }
.pj-meta dd{ margin:.3rem 0 0; font-family:var(--serif); font-size:1.2rem; color:var(--ink); }
.pj-gallery{ display:grid; grid-template-columns:repeat(12,1fr); gap:clamp(1rem,2vw,2rem); }
.pj-gallery .g{ overflow:hidden; background:var(--paper-2); }
.pj-gallery .g img{ width:100%; height:100%; object-fit:cover; }
.pj-lead{ font-family:var(--serif); font-size:clamp(1.4rem,2.4vw,2rem); line-height:1.4; color:var(--ink);
  font-weight:380; max-width:24ch; }
.pj-nav{ display:flex; justify-content:space-between; gap:1rem; border-top:1px solid var(--line);
  padding-top:1.6rem; flex-wrap:wrap; }
.pj-nav a{ display:flex; flex-direction:column; gap:.3rem; }
.pj-nav .l{ font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-mute); }
.pj-nav .t{ font-family:var(--serif); font-size:1.4rem; color:var(--ink); transition:color .3s; }
.pj-nav a:hover .t{ color:var(--walnut); }
.pj-nav .next{ text-align:right; align-items:flex-end; margin-left:auto; }

/* ============================================================
   Quote / testimonial
   ============================================================ */
.quote{ max-width:30ch; }
.quote__mark{ font-family:var(--serif); font-size:4rem; color:var(--brass); line-height:.4; display:block; }
.bigquote{ font-family:var(--serif); font-size:clamp(1.7rem,3.4vw,2.9rem); line-height:1.32; font-weight:380;
  color:var(--ink); max-width:22ch; }
.section--dark .bigquote{ color:var(--cream); }
.cite{ margin-top:1.6rem; font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute); }
.section--dark .cite{ color:var(--on-dark-mute); }
.cite b{ color:var(--brass-2); font-weight:600; }

.tcards{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.2rem,2vw,1.8rem); }
.tcard{ background:var(--cream); border:1px solid var(--line); padding:2rem 1.9rem; display:flex; flex-direction:column; gap:1rem; }
.tcard__stars{ color:var(--brass); letter-spacing:.2em; font-size:.9rem; }
.tcard p{ font-family:var(--serif); font-size:1.2rem; line-height:1.45; color:var(--ink); margin:0; font-weight:380; }
.tcard__who{ margin-top:auto; font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-mute); }
.tcard--add{ background:transparent; border-style:dashed; align-items:flex-start; justify-content:center; }
@media (max-width:820px){ .tcards{ grid-template-columns:1fr; } }

/* ============================================================
   Accordion (FAQ)
   ============================================================ */
.acc{ border-top:1px solid var(--line); }
.acc__item{ border-bottom:1px solid var(--line); }
.acc__q{ width:100%; text-align:left; background:none; border:0; cursor:pointer;
  display:flex; gap:1.5rem; align-items:center; justify-content:space-between;
  padding:1.6rem 0; font-family:var(--serif); font-size:clamp(1.2rem,2vw,1.55rem); color:var(--ink); }
.acc__q:hover{ color:var(--walnut); }
.acc__ico{ flex:none; width:24px; height:24px; position:relative; }
.acc__ico::before,.acc__ico::after{ content:""; position:absolute; background:var(--brass); transition:transform .4s var(--ease); }
.acc__ico::before{ top:50%; left:0; width:100%; height:1.5px; transform:translateY(-50%); }
.acc__ico::after{ left:50%; top:0; height:100%; width:1.5px; transform:translateX(-50%); }
.acc__item.is-open .acc__ico::after{ transform:translateX(-50%) scaleY(0); }
.acc__panel{ overflow:hidden; height:0; transition:height .5s var(--ease); }
.acc__panel-inner{ padding:0 0 1.8rem; max-width:68ch; color:var(--ink-soft); }
.acc__panel-inner p{ margin:0 0 .8em; }

/* ============================================================
   Contact
   ============================================================ */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:start; }
@media (max-width:860px){ .contact-grid{ grid-template-columns:1fr; } }
.cinfo dt{ font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--brass-deep); }
.cinfo dd{ margin:.4rem 0 1.8rem; font-family:var(--serif); font-size:1.45rem; color:var(--ink); }
.cinfo dd a:hover{ color:var(--walnut); }
.field{ margin-bottom:1.5rem; }
.field label{ display:block; font-size:.74rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-mute); margin-bottom:.55rem; }
.field input,.field select,.field textarea{ width:100%; background:var(--cream); border:1px solid var(--line);
  padding:.95em 1em; border-radius:var(--radius); color:var(--ink); transition:border-color .3s; font-size:1rem; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--brass);
  box-shadow:0 0 0 3px rgba(125,95,51,.30); }
.field textarea{ min-height:140px; resize:vertical; }
.form-note{ font-size:.84rem; color:var(--ink-mute); }

/* ============================================================
   Footer
   ============================================================ */
.site-footer{ background:var(--espresso); color:var(--on-dark); position:relative; overflow:hidden; }
.site-footer__marble{ position:absolute; inset:0; opacity:.05; object-fit:cover; width:100%; height:100%; z-index:0; mix-blend-mode:screen; }
.site-footer__in{ position:relative; z-index:1; padding-block:clamp(4rem,8vw,7rem); }
.foot-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:2.5rem; padding-bottom:3rem; border-bottom:1px solid var(--line-dark); }
@media (max-width:820px){ .foot-top{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .foot-top{ grid-template-columns:1fr; gap:2rem; } }
.foot-brand .brand__name{ color:var(--cream); }
.foot-brand p{ color:var(--on-dark-mute); max-width:36ch; margin-top:1.2rem; }
.foot-col h4{ font-family:var(--sans); font-weight:600; font-size:.74rem; letter-spacing:.2em; text-transform:uppercase;
  color:var(--brass-2); margin-bottom:1.2rem; }
.foot-col a{ display:block; color:var(--on-dark); padding:.5rem 0; transition:color .3s, padding-left .3s; }
.foot-col a:hover{ color:var(--cream); padding-left:.4rem; }
.foot-bottom{ display:flex; justify-content:space-between; align-items:center; gap:1.5rem; flex-wrap:wrap;
  padding-top:2rem; font-size:.82rem; color:var(--on-dark-mute); }
.social{ display:flex; gap:.8rem; }
.social a{ width:40px; height:40px; border:1px solid var(--line-dark); border-radius:50%; display:grid; place-items:center;
  color:var(--on-dark); transition:background .4s, color .4s, border-color .4s; }
.social a:hover{ background:var(--brass); color:var(--espresso); border-color:var(--brass); }
.social svg{ width:17px; height:17px; }
.foot-cta{ display:flex; align-items:center; justify-content:space-between; gap:2rem; flex-wrap:wrap;
  padding-block:clamp(2.6rem,5vw,4rem); border-bottom:1px solid var(--line-dark); }
.foot-cta h2{ color:var(--cream); max-width:18ch; }

/* ---------- breadcrumb ---------- */
.crumb{ font-size:.8rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-mute); display:flex; gap:.6rem; flex-wrap:wrap; }
.crumb a:hover{ color:var(--walnut); } .crumb span{ color:var(--walnut); }

/* ---------- utilities ---------- */
.skip{ position:absolute; left:-999px; top:0; background:var(--ink); color:var(--cream); padding:.8rem 1.2rem; z-index:300; }
.skip:focus{ left:1rem; top:1rem; }
.vh{ position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; }
.txt-brass{ color:var(--brass); } .txt-walnut{ color:var(--walnut); }

/* ---------- CTA band (light marble; sits above the dark footer) ---------- */
.cta{ position:relative; overflow:hidden; background:var(--paper-2); border-top:1px solid var(--line); }
.cta__marble{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.14;
  z-index:0; mix-blend-mode:multiply; }
.cta__in{ position:relative; z-index:1; display:flex; align-items:center; justify-content:space-between;
  gap:2.5rem; flex-wrap:wrap; padding-block:clamp(3.2rem,6vw,5.5rem); }
.cta__head{ max-width:22ch; }
.cta__head h2{ color:var(--ink); margin-top:1rem; }

@media print{ .site-header,.site-footer,.intro,.frame,.scroll-cue,.cta{ display:none; } body{ color:#000; background:#fff; } }
