/* =====================================================================
   William R. Eubanks Interior Design, Inc.
   Bespoke design system. Heritage luxury, editorial, Palm Beach.
   Palette keeps the original black / white / grey, warmed into
   ivory paper, warm ink, and a whisper of antique brass.
   ===================================================================== */

/* ---------- Tokens ---------- */
:root{
  /* Paper & ink (warmed monochrome, faithful to the original B/W) */
  --paper:        #f5efe6;   /* warm ivory ground */
  --paper-2:      #efe7da;   /* slightly deeper ivory for bands */
  --paper-card:   #fbf7f0;   /* near-white plate */
  --ink:          #1c1a17;   /* warm near-black (replaces #000) */
  --ink-soft:     #2e2a25;
  --muted:        #6b635a;   /* warm grey (echoes original #666) */
  --muted-2:      #8c8377;
  --line:         #ddd3c4;   /* hairline */
  --line-strong:  #c8bca8;

  /* Antique brass accent, used sparingly */
  --brass:        #a9854e;
  --brass-deep:   #8a6a3a;
  --brass-tint:   rgba(169,133,78,.16);

  /* Dark ground for hero / footer */
  --night:        #1a1714;
  --night-2:      #221e1a;
  --on-night:     #efe7d8;
  --on-night-mut: #b3a892;

  /* Type */
  --display: 'Cormorant Garamond', 'Georgia', serif;
  --serif:   'Spectral', 'Georgia', serif;
  --sans:    'Montserrat', 'Helvetica Neue', Arial, sans-serif;

  --fs-body: 1.1875rem;      /* 19px base, sized for comfortable reading at 50+ */
  --lh-body: 1.72;
  --measure: 64ch;

  --container: 1280px;
  --gutter: clamp(1.25rem, 5vw, 5rem);

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

  --shadow-soft: 0 18px 50px -28px rgba(28,26,23,.45);
  --shadow-deep: 0 40px 90px -40px rgba(28,26,23,.6);
}

/* ---------- 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;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--serif);
  font-size:var(--fs-body);
  line-height:var(--lh-body);
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background:var(--brass-tint); color:var(--ink); }

/* ---------- Type ---------- */
h1,h2,h3,h4{ font-family:var(--display); font-weight:600; line-height:1.08; margin:0; letter-spacing:.004em; }
h1{ font-size:clamp(2.6rem, 6.5vw, 5.6rem); font-weight:500; line-height:1.04; }
h2{ font-size:clamp(2rem, 4.4vw, 3.6rem); font-weight:600; }
h3{ font-size:clamp(1.5rem, 2.6vw, 2.15rem); font-weight:600; }
p{ margin:0 0 1.2em; max-width:var(--measure); }
strong{ font-weight:600; }
em{ font-style:italic; }

.eyebrow{
  font-family:var(--sans);
  font-size:.74rem;
  font-weight:600;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--brass-deep);
  margin:0 0 1.4rem;
  display:inline-flex; align-items:center; gap:.9rem;
}
.eyebrow::before{ content:""; width:34px; height:1px; background:var(--brass); opacity:.7; }
.eyebrow.center{ justify-content:center; }
.eyebrow.center::after{ content:""; width:34px; height:1px; background:var(--brass); opacity:.7; }

.lede{ font-size:clamp(1.2rem,1.8vw,1.5rem); line-height:1.6; color:var(--ink-soft); font-weight:300; }
.serif-italic{ font-family:var(--display); font-style:italic; }

/* ---------- Layout ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }
.container--wide{ max-width:1600px; }
.container--narrow{ max-width:880px; }
.section{ padding-block:clamp(4.5rem, 9vw, 9rem); }
.section--tight{ padding-block:clamp(3rem,6vw,5.5rem); }
.bleed{ width:100%; }

/* palmette flourish divider */
.flourish{ display:flex; align-items:center; justify-content:center; gap:1.4rem; color:var(--brass); }
.flourish::before,.flourish::after{ content:""; height:1px; width:min(120px,18vw); background:linear-gradient(90deg,transparent,var(--line-strong)); }
.flourish::after{ background:linear-gradient(90deg,var(--line-strong),transparent); }
.flourish img{ width:34px; height:auto; opacity:.85; }

/* ---------- Buttons ---------- */
.btn{
  --c:var(--ink);
  display:inline-flex; align-items:center; gap:.85rem;
  font-family:var(--sans); font-size:.76rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase; color:var(--c);
  padding:1.05rem 2rem; border:1px solid var(--line-strong);
  background:transparent; position:relative; overflow:hidden;
  transition:color .5s var(--ease), border-color .5s var(--ease);
}
.btn .arrow{ transition:transform .5s var(--ease); }
.btn::after{ content:""; position:absolute; inset:0; background:var(--ink); transform:translateY(101%); transition:transform .55s var(--ease-out); z-index:-1; }
.btn:hover{ color:var(--paper); border-color:var(--ink); }
.btn:hover .arrow{ transform:translateX(6px); }
.btn:hover::after{ transform:translateY(0); }
.btn--ghost-light{ --c:var(--on-night); border-color:rgba(239,231,216,.4); }
.btn--ghost-light::after{ background:var(--on-night); }
.btn--ghost-light:hover{ color:var(--night); border-color:var(--on-night); }
.btn--solid{ color:var(--paper); border-color:var(--ink); }
.btn--solid::after{ transform:translateY(0); background:var(--ink); }
.btn--solid:hover{ color:var(--paper); }
.btn--solid:hover::after{ background:var(--brass-deep); }

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

/* =====================================================================
   Header
   ===================================================================== */
.site-header{
  position:fixed; top:0; left:0; width:100%; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.5rem var(--gutter);
  transition:background .55s var(--ease), padding .55s var(--ease), box-shadow .55s var(--ease), border-color .55s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header.is-solid{
  background:rgba(245,239,230,.9);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  padding-block:.95rem;
  border-bottom:1px solid var(--line);
  box-shadow:0 10px 40px -30px rgba(28,26,23,.5);
}
.brand{ display:flex; align-items:center; gap:.85rem; z-index:2; }
.brand__mark{ width:30px; height:auto; transition:opacity .5s var(--ease); }
.brand__name{ display:flex; flex-direction:column; line-height:1; }
.brand__name b{ font-family:var(--display); font-weight:600; font-size:1.18rem; letter-spacing:.06em; color:var(--brand-fg, var(--ink)); transition:color .5s var(--ease); }
.brand__name span{ font-family:var(--sans); font-weight:600; font-size:.52rem; letter-spacing:.34em; text-transform:uppercase; color:var(--brand-sub, var(--muted)); margin-top:.42rem; transition:color .5s var(--ease); }

.nav{ display:flex; align-items:center; gap:1.65rem; }
.nav a{
  font-family:var(--sans); font-size:.685rem; font-weight:600; letter-spacing:.15em;
  text-transform:uppercase; color:var(--nav-fg, var(--ink)); position:relative; padding:.4rem 0;
  transition:color .45s var(--ease); white-space:nowrap;
}
.nav a::after{ content:""; position:absolute; left:0; bottom:-2px; height:1px; width:100%; background:currentColor; transform:scaleX(0); transform-origin:right; transition:transform .45s var(--ease); opacity:.8; }
.nav a:hover::after,.nav a[aria-current="page"]::after{ transform:scaleX(1); transform-origin:left; }
.nav a[aria-current="page"]{ color:var(--brass-deep); }
.nav .nav-cta{ margin-left:.6rem; }

/* over-hero (dark) header state */
.site-header.on-dark{ --brand-fg:var(--on-night); --brand-sub:var(--on-night-mut); --nav-fg:var(--on-night); }
.site-header.on-dark.is-solid{ --brand-fg:var(--ink); --brand-sub:var(--muted); --nav-fg:var(--ink); }
.site-header.on-dark .brand__mark{ filter:brightness(0) invert(1); }
.site-header.on-dark.is-solid .brand__mark{ filter:none; }

.nav-toggle{ display:none; }

/* mobile menu */
.mobile-menu{
  position:fixed; inset:0; z-index:99; background:var(--night); color:var(--on-night);
  display:flex; flex-direction:column; justify-content:flex-start; padding:5.5rem var(--gutter) 2.5rem;
  overflow-y:auto; -webkit-overflow-scrolling:touch;
  transform:translateY(-100%); transition:transform .7s var(--ease-out); visibility:hidden;
}
.mobile-menu nav{ margin-block:auto; width:100%; }
.mobile-menu.open{ transform:translateY(0); visibility:visible; }
.mobile-menu a{ font-family:var(--display); font-size:clamp(2rem,9vw,3.2rem); padding:.5rem 0; border-bottom:1px solid rgba(239,231,216,.12); display:flex; justify-content:space-between; align-items:baseline; }
.mobile-menu a span{ font-family:var(--sans); font-size:.7rem; letter-spacing:.2em; color:var(--on-night-mut); }
.mobile-menu .mm-foot{ margin-top:2.5rem; font-family:var(--sans); font-size:.78rem; letter-spacing:.06em; color:var(--on-night-mut); line-height:2; }

/* =====================================================================
   Hero
   ===================================================================== */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; color:var(--on-night); overflow:hidden; }
.hero__media{ position:absolute; inset:0; z-index:0; }
.hero__media img{ width:100%; height:100%; object-fit:cover; transform:scale(1.06); animation:settle 1.6s var(--ease-out) .15s forwards; }
@keyframes settle{ to{ transform:scale(1); } }
.hero__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(20,18,15,.42) 0%, rgba(20,18,15,.12) 38%, rgba(20,18,15,.62) 100%); }
.hero__inner{ position:relative; z-index:2; width:100%; padding-bottom:clamp(3.5rem,7vw,6rem); }
.hero__inner .container{ display:flex; flex-direction:column; }
.hero h1{ max-width:16ch; }
.hero .eyebrow{ color:var(--on-night); }
.hero .eyebrow::before,.hero .eyebrow::after{ background:var(--brass); opacity:.9; }
.hero__sub{ max-width:46ch; margin-top:1.6rem; color:var(--on-night); font-weight:300; font-size:clamp(1.05rem,1.5vw,1.3rem); line-height:1.7; }
.hero__cta{ margin-top:2.4rem; display:flex; flex-wrap:wrap; gap:1rem; }
.hero__scroll{ position:absolute; bottom:1.8rem; right:var(--gutter); z-index:2; display:flex; align-items:center; gap:.8rem; font-family:var(--sans); font-size:.62rem; letter-spacing:.26em; text-transform:uppercase; color:var(--on-night-mut); writing-mode:vertical-rl; }
.hero__scroll .line{ width:1px; height:54px; background:linear-gradient(var(--on-night-mut),transparent); animation:scrolldown 2.4s var(--ease) infinite; transform-origin:top; }
@keyframes scrolldown{ 0%{ transform:scaleY(0); } 40%{ transform:scaleY(1); } 100%{ transform:scaleY(0); transform-origin:bottom; } }

/* page hero (interior pages, shorter) */
.page-hero{ position:relative; min-height:72vh; display:flex; align-items:flex-end; color:var(--on-night); overflow:hidden; }
.page-hero__media{ position:absolute; inset:0; }
.page-hero__media img{ width:100%; height:100%; object-fit:cover; transform:scale(1.05); animation:settle 1.5s var(--ease-out) .1s forwards; }
.page-hero__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(20,18,15,.34),rgba(20,18,15,.66)); }
.page-hero__inner{ position:relative; z-index:2; width:100%; padding-bottom:clamp(2.6rem,5vw,4.5rem); }
.page-hero .eyebrow{ color:var(--on-night); }
.page-hero .breadcrumb{ margin-bottom:1rem; }

/* breadcrumb */
.breadcrumb{ font-family:var(--sans); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--on-night-mut); display:flex; gap:.6rem; flex-wrap:wrap; }
.breadcrumb a:hover{ color:var(--on-night); }
.breadcrumb .sep{ opacity:.5; }

/* =====================================================================
   Statement / editorial blocks
   ===================================================================== */
.statement{ display:grid; grid-template-columns:1fr; gap:2rem; }
.statement .lede{ max-width:30ch; }
@media(min-width:900px){
  .statement{ grid-template-columns:0.42fr 0.58fr; gap:clamp(2rem,6vw,6rem); align-items:start; }
}
.dropcap::first-letter{ font-family:var(--display); font-size:4.1em; line-height:.72; float:left; padding:.06em .12em 0 0; color:var(--brass-deep); font-weight:500; }

.quote{ font-family:var(--display); font-style:italic; font-size:clamp(1.6rem,3.2vw,2.6rem); line-height:1.32; color:var(--ink); max-width:24ch; }
.quote-block{ text-align:center; max-width:none; }
.quote-block .quote{ margin-inline:auto; max-width:20ch; }

/* =====================================================================
   Editorial portfolio "plates" (asymmetric, indexed, captioned)
   ===================================================================== */
.plates{ display:flex; flex-direction:column; gap:clamp(3.5rem,8vw,8rem); }
.plate{ display:grid; grid-template-columns:1fr; gap:1.6rem; align-items:center; }
.plate__media{ position:relative; overflow:hidden; }
.plate__media img{ width:100%; aspect-ratio:4/3; object-fit:cover; transition:transform 1.3s var(--ease); }
.plate__media::after{ content:""; position:absolute; inset:0; background:rgba(20,18,15,0); transition:background .6s var(--ease); }
.plate:hover .plate__media img{ transform:scale(1.05); }
.plate__index{ font-family:var(--display); font-size:clamp(2.4rem,5vw,4rem); color:var(--brass); line-height:1; opacity:.55; }
.plate__num{ font-family:var(--sans); font-size:.72rem; letter-spacing:.3em; color:var(--muted); }
.plate__body h3{ margin:.6rem 0 1rem; }
.plate__body p{ color:var(--muted); }
.plate__tags{ display:flex; flex-wrap:wrap; gap:.5rem; margin:1.3rem 0 1.6rem; }
.plate__tags span{ font-family:var(--sans); font-size:.64rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); border:1px solid var(--line); padding:.4rem .8rem; border-radius:100px; }
@media(min-width:900px){
  .plate{ grid-template-columns:1.15fr 1fr; gap:clamp(2.5rem,5vw,5rem); }
  .plate--rev .plate__media{ order:2; }
  .plate__media img{ aspect-ratio:5/4; }
}

/* =====================================================================
   Galleries (justified rows, lazy, lightbox)
   ===================================================================== */
.gallery-intro{ display:flex; justify-content:space-between; align-items:flex-end; gap:2rem; flex-wrap:wrap; margin-bottom:2.6rem; }
.gallery-count{ font-family:var(--sans); font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }

.gallery{ columns: 3; column-gap: clamp(.7rem,1.4vw,1.3rem); }
@media(max-width:1100px){ .gallery{ columns:2; } }
@media(max-width:560px){ .gallery{ columns:1; } }
.gallery .tile{
  break-inside:avoid; margin-bottom:clamp(.7rem,1.4vw,1.3rem); position:relative; overflow:hidden;
  background:var(--paper-2); cursor:zoom-in; display:block;
}
.gallery .tile img{ width:100%; height:auto; transition:transform 1.2s var(--ease), filter 1.2s var(--ease); }
.gallery .tile::after{
  content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(20,18,15,.5));
  opacity:0; transition:opacity .5s var(--ease);
}
.gallery .tile:hover img{ transform:scale(1.045); }
.gallery .tile:hover::after{ opacity:1; }
.gallery .tile .tile__zoom{
  position:absolute; right:.9rem; bottom:.9rem; z-index:2; width:38px; height:38px; border:1px solid rgba(239,231,216,.6);
  border-radius:50%; display:grid; place-items:center; color:var(--on-night); opacity:0; transform:translateY(8px);
  transition:opacity .5s var(--ease), transform .5s var(--ease); pointer-events:none;
}
.gallery .tile:hover .tile__zoom{ opacity:1; transform:translateY(0); }

/* lightbox */
.lightbox{ position:fixed; inset:0; z-index:200; background:rgba(18,16,13,.96); display:none; align-items:center; justify-content:center; }
.lightbox.open{ display:flex; }
.lightbox img{ max-width:92vw; max-height:86vh; object-fit:contain; box-shadow:var(--shadow-deep); }
.lightbox__close,.lightbox__nav{ position:absolute; background:none; border:none; color:var(--on-night-mut); transition:color .4s var(--ease); }
.lightbox__close{ top:1.6rem; right:1.8rem; font-size:1.8rem; }
.lightbox__nav{ top:50%; transform:translateY(-50%); font-size:2.4rem; padding:1rem; }
.lightbox__nav.prev{ left:1rem; } .lightbox__nav.next{ right:1rem; }
.lightbox__close:hover,.lightbox__nav:hover{ color:var(--on-night); }
.lightbox__counter{ position:absolute; bottom:1.6rem; left:50%; transform:translateX(-50%); font-family:var(--sans); font-size:.72rem; letter-spacing:.2em; color:var(--on-night-mut); }

/* =====================================================================
   Press
   ===================================================================== */
/* Publications masthead: a static, catalogue-style index (no looping marquee) */
.pub-masthead{
  display:grid; grid-template-columns:repeat(auto-fill, minmax(210px,1fr));
  gap:.2rem 2.4rem; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  padding-block:2.4rem;
}
.pub-masthead li{ list-style:none; }
.pub-masthead .pub{
  font-family:var(--display); font-style:italic; font-size:1.18rem; color:var(--ink-soft);
  padding:.55rem 0; border-bottom:1px solid transparent; display:block; transition:color .4s var(--ease);
}
.pub-masthead .pub:hover{ color:var(--brass-deep); }

.tearsheets{ columns:4; column-gap:1rem; }
@media(max-width:1100px){ .tearsheets{ columns:3; } }
@media(max-width:760px){ .tearsheets{ columns:2; } }
@media(max-width:420px){ .tearsheets{ columns:1; } }
.tearsheets .tile{ break-inside:avoid; margin-bottom:1rem; border:1px solid var(--line); background:#fff; box-shadow:var(--shadow-soft); }

/* =====================================================================
   Journal
   ===================================================================== */
.journal-grid{ display:grid; gap:clamp(2rem,4vw,3.4rem); }
@media(min-width:760px){ .journal-grid{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:860px){ .journal-grid--3{ grid-template-columns:repeat(3,1fr); } }
.post-card{ display:flex; flex-direction:column; }
.post-card__media{ overflow:hidden; aspect-ratio:3/2; background:var(--paper-2); }
.post-card__media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.2s var(--ease); }
.post-card:hover .post-card__media img{ transform:scale(1.05); }
.post-card__meta{ font-family:var(--sans); font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--brass-deep); margin:1.4rem 0 .7rem; }
.post-card h3{ font-size:clamp(1.4rem,2.2vw,1.9rem); }
.post-card p{ color:var(--muted); margin-top:.7rem; }

.article-body{ max-width:72ch; margin-inline:auto; }
.article-body p{ margin-bottom:1.4em; }
.tag-row{ display:flex; flex-wrap:wrap; gap:.6rem; }
.tag-row a,.tag-row span{ font-family:var(--sans); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); border:1px solid var(--line); padding:.45rem .9rem; border-radius:100px; transition:.4s var(--ease); }
.tag-row a:hover{ color:var(--ink); border-color:var(--line-strong); }

/* =====================================================================
   Contact
   ===================================================================== */
.contact-grid{ display:grid; gap:clamp(2rem,5vw,4rem); }
@media(min-width:900px){ .contact-grid{ grid-template-columns:1fr 1fr; } }
.contact-detail{ border-top:1px solid var(--line); padding-top:1.4rem; margin-bottom:2rem; }
.contact-detail .label{ font-family:var(--sans); font-size:.66rem; letter-spacing:.24em; text-transform:uppercase; color:var(--brass-deep); margin-bottom:.6rem; }
.contact-detail .value{ font-family:var(--display); font-size:clamp(1.3rem,2.2vw,1.8rem); line-height:1.3; }
.contact-detail .value a:hover{ color:var(--brass-deep); }

.field{ display:flex; flex-direction:column; margin-bottom:1.5rem; }
.field label{ font-family:var(--sans); font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-bottom:.6rem; }
.field input,.field textarea,.field select{
  font-family:var(--serif); font-size:1.05rem; color:var(--ink); background:transparent;
  border:none; border-bottom:1px solid var(--line-strong); padding:.7rem 0; transition:border-color .4s var(--ease);
}
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--brass); }
.field textarea{ resize:vertical; min-height:120px; }

/* map / scent feature */
.scent{ display:grid; gap:2rem; align-items:center; }
@media(min-width:760px){ .scent{ grid-template-columns:1fr 1fr; } }

/* =====================================================================
   FAQ (Contact) and honors strip
   ===================================================================== */
.faq{ border-top:1px solid var(--line); }
.faq__item{ border-bottom:1px solid var(--line); }
.faq__q{
  width:100%; text-align:left; background:none; border:none; padding:1.6rem 0; display:flex;
  justify-content:space-between; align-items:center; gap:2rem; color:var(--ink);
  font-family:var(--display); font-size:clamp(1.2rem,2vw,1.55rem); font-weight:600; line-height:1.25;
}
.faq__q .pm{ position:relative; width:18px; height:18px; flex:0 0 18px; }
.faq__q .pm::before,.faq__q .pm::after{ content:""; position:absolute; background:var(--brass-deep); transition:transform .45s var(--ease); }
.faq__q .pm::before{ top:50%; left:0; width:100%; height:1.5px; transform:translateY(-50%); }
.faq__q .pm::after{ left:50%; top:0; width:1.5px; height:100%; transform:translateX(-50%); }
.faq__item.open .pm::after{ transform:translateX(-50%) scaleY(0); }
.faq__a{ overflow:hidden; max-height:0; transition:max-height .55s var(--ease); }
.faq__a p{ padding:0 0 1.6rem; color:var(--ink-soft); max-width:68ch; }

/* honors / credentials strip */
.honors{ display:grid; grid-template-columns:1fr; gap:0; }
.honors li{ list-style:none; display:flex; gap:1.4rem; align-items:baseline; padding:1.3rem 0; border-top:1px solid var(--line); }
.honors li:last-child{ border-bottom:1px solid var(--line); }
.honors .h-num{ font-family:var(--sans); font-size:.7rem; letter-spacing:.2em; color:var(--brass); min-width:2.6rem; }
.honors .h-text{ font-family:var(--display); font-size:clamp(1.15rem,1.8vw,1.5rem); line-height:1.3; color:var(--ink); }

/* facts / definition lead with a left keyline */
.def-lead{ border-left:2px solid var(--brass); padding-left:clamp(1.2rem,2.5vw,2.2rem); }
.def-lead p{ font-size:clamp(1.18rem,1.7vw,1.42rem); line-height:1.6; color:var(--ink-soft); font-weight:300; max-width:54ch; }

/* portfolio folio index (alt nav between portfolios) */
.folio-index{ display:grid; gap:0; }
.folio-index a{ display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:1.6rem; padding:1.7rem 0; border-top:1px solid var(--line); transition:padding .5s var(--ease); }
.folio-index a:last-child{ border-bottom:1px solid var(--line); }
.folio-index a:hover{ padding-left:1rem; }
.folio-index .fi-num{ font-family:var(--sans); font-size:.72rem; letter-spacing:.2em; color:var(--brass); }
.folio-index .fi-name{ font-family:var(--display); font-size:clamp(1.6rem,3vw,2.6rem); font-weight:600; }
.folio-index .fi-go{ font-family:var(--sans); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); opacity:0; transform:translateX(-8px); transition:.5s var(--ease); }
.folio-index a:hover .fi-go{ opacity:1; transform:none; }

/* =====================================================================
   Footer
   ===================================================================== */
.site-footer{ background:var(--night); color:var(--on-night-mut); padding-block:clamp(3.5rem,7vw,6rem) 2.5rem; }
.site-footer a:hover{ color:var(--on-night); }
.footer-top{ display:grid; gap:2.6rem; padding-bottom:3rem; border-bottom:1px solid rgba(239,231,216,.12); }
@media(min-width:900px){ .footer-top{ grid-template-columns:1.4fr 1fr 1fr; } }
.footer-brand img{ width:200px; filter:brightness(0) invert(.92); margin-bottom:1.6rem; }
.footer-brand p{ color:var(--on-night-mut); max-width:34ch; font-weight:300; }
.footer-col h4{ font-family:var(--sans); font-weight:600; font-size:.68rem; letter-spacing:.24em; text-transform:uppercase; color:var(--on-night); margin-bottom:1.4rem; }
.footer-col ul{ list-style:none; margin:0; padding:0; }
.footer-col li{ margin-bottom:.8rem; }
.footer-col a{ font-family:var(--sans); font-size:.84rem; letter-spacing:.04em; }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; padding-top:2rem; font-family:var(--sans); font-size:.7rem; letter-spacing:.08em; color:var(--on-night-mut); }
.footer-bottom .palmette{ width:24px; opacity:.7; }

/* =====================================================================
   Reveal-on-scroll
   ===================================================================== */
/* Initial-hidden states apply ONLY when JS is present (no-JS users see everything) */
.reveal{ transition:opacity 1s var(--ease-out), transform 1s var(--ease-out); }
.js .reveal{ opacity:0; transform:translateY(26px); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }
.reveal-img{ overflow:hidden; }
.reveal-img img{ transition:transform 1.4s var(--ease-out); }
.js .reveal-img img{ transform:scale(1.12); }
.reveal-img.in img{ transform:scale(1); }
.line-rise{ display:block; overflow:hidden; }
.line-rise > span{ display:block; transition:transform 1s var(--ease-out); }
.js .line-rise > span{ transform:translateY(100%); }
.line-rise.in > span{ transform:translateY(0); }
/* QA hook: ?qa in the URL renders all reveals in their final state */
.js.qa .reveal,.js.qa .reveal.in{ opacity:1 !important; transform:none !important; }
.js.qa .reveal-img img{ transform:none !important; }
.js.qa .line-rise > span{ transform:none !important; }
@media (prefers-reduced-motion: reduce){
  .reveal,.reveal-img img,.line-rise>span,.hero__media img,.page-hero__media img{ opacity:1 !important; transform:none !important; animation:none !important; transition:none !important; }
}

/* =====================================================================
   Utilities & responsive
   ===================================================================== */
.center{ text-align:center; }
.mt-s{ margin-top:1rem; } .mt-m{ margin-top:2rem; } .mt-l{ margin-top:3rem; }
.band{ background:var(--paper-2); }
.band-dark{ background:var(--night); color:var(--on-night); }
.band-dark .eyebrow{ color:var(--brass); }
.band-dark h2,.band-dark h3{ color:var(--on-night); }
.band-dark p{ color:var(--on-night-mut); }
.split-head{ display:grid; gap:1.5rem; align-items:end; margin-bottom:clamp(2.4rem,5vw,4rem); }
@media(min-width:860px){ .split-head{ grid-template-columns:1fr auto; } }
.maxw-head{ max-width:18ch; }

@media(max-width:1150px){
  .nav{ display:none; }
  .nav-toggle{ display:flex; flex-direction:column; gap:5px; background:none; border:none; padding:.4rem; z-index:101; }
  .nav-toggle span{ width:26px; height:1.5px; background:var(--tg,var(--ink)); transition:.4s var(--ease); }
  .site-header.on-dark:not(.is-solid) .nav-toggle span{ --tg:var(--on-night); }
  .nav-toggle.open span{ background:var(--on-night); }
  .nav-toggle.open span:nth-child(1){ transform:translateY(6.5px) rotate(45deg); }
  .nav-toggle.open span:nth-child(2){ opacity:0; }
  .nav-toggle.open span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg); }
}
