/* LuxLiving Concept — warm-luxe interior finishes (cabinetry / flooring / wall design)
   Fraunces (display serif) + Mulish (body). Cream / espresso / brass. Editorial, art-directed.
   Method 3: principles inherited (oversized serif hero / art-directed lifestyle rows /
   museum-plate framed work / manifesto footer); execution re-solved. 0 copied instances. */

:root{
  /* white / bright palette (2026-06-26 user: 白色 亮色). Warm cream/espresso/brass banned.
     accent = graphite on light sections; --accent-dark = light, for accents over the dark opener. */
  --cream:#FFFFFF; --cream-2:#F5F5F3; --cream-3:#ECECEA;
  --ink:#19191A; --ink-2:#3C3D3F; --muted:#6C6E72; --muted-2:#9A9CA0;
  --brass:#2E2E31; --brass-bright:#55565B; --brass-deep:#1C1C1E;
  --espresso:#19191A; --espresso-2:#141415;
  --line:#E7E7E4; --line-2:#D9D9D5;
  --paper:#FFFFFF; --accent-dark:#D8D9DD;
  --disp:"Fraunces",Georgia,serif; --body:"Mulish",system-ui,sans-serif;
  --maxw:1280px; --header-h:84px; --r:3px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--cream);line-height:1.65;
  font-size:17px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--disp);font-weight:400;line-height:1.04;letter-spacing:-.01em;color:var(--ink)}
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(22px,5vw,56px)}

/* ---------- shared bits ---------- */
.eyebrow{font-family:var(--body);font-weight:600;font-size:.72rem;letter-spacing:.32em;
  text-transform:uppercase;color:var(--brass-deep)}
.eyebrow--light{color:var(--brass-bright)}
.serif-lede{font-family:var(--disp);font-weight:400;font-size:clamp(1.3rem,2.4vw,1.9rem);
  line-height:1.32;color:var(--ink-2)}
.btn{display:inline-flex;align-items:center;gap:.6em;font-family:var(--body);font-weight:600;
  font-size:.84rem;letter-spacing:.06em;text-transform:uppercase;padding:1.02em 1.7em;border-radius:var(--r);
  border:1px solid transparent;cursor:pointer;transition:.3s var(--ease)}
.btn--brass{background:var(--brass);color:var(--paper)}
.btn--brass:hover{background:var(--brass-deep)}
.btn--ink{background:var(--ink);color:var(--cream)}
.btn--ink:hover{background:#000}
.btn--ghost{background:transparent;border-color:currentColor;color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.btn--on-dark{border-color:rgba(255,255,255,.5);color:var(--cream)}
.btn--on-dark:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.tlink{font-family:var(--body);font-weight:600;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--brass-deep);display:inline-flex;align-items:center;gap:.5em;transition:gap .3s var(--ease)}
.tlink::after{content:"\2192";transition:transform .3s var(--ease)}
.tlink:hover::after{transform:translateX(4px)}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;transition:.4s var(--ease)}
.site-header .header__inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h)}
.brand{display:flex;align-items:center;gap:.7rem}
.brand__logo{width:42px;height:42px;flex:none}
.brand__txt{display:flex;flex-direction:column;line-height:1.05}
.brand__txt b{font-family:var(--disp);font-weight:500;font-size:1.32rem;letter-spacing:.01em;color:var(--ink)}
.brand__txt small{font-family:var(--body);font-weight:600;font-size:.56rem;letter-spacing:.34em;
  text-transform:uppercase;color:var(--brass-deep);margin-top:2px}
.nav{display:flex;align-items:center;gap:2.1rem}
.nav a{font-family:var(--body);font-weight:600;font-size:.82rem;letter-spacing:.04em;color:var(--ink-2);
  position:relative;padding:.3em 0;transition:color .25s}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1.5px;background:var(--brass);transition:right .3s var(--ease)}
.nav a:hover{color:var(--ink)}
.nav a:hover::after,.nav a.active::after,.nav a[aria-current=page]::after{right:0}
.nav a.active,.nav a[aria-current=page]{color:var(--brass-deep)}
.header__cta{padding:.78em 1.4em}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.hamburger span{width:24px;height:2px;background:var(--ink);transition:.3s}
/* transparent over hero, solid on scroll */
.site-header.over-hero .brand__txt b,.site-header.over-hero .nav a,.site-header.over-hero .brand__txt small{color:var(--cream)}
.site-header.over-hero .nav a{color:rgba(255,255,255,.85)}
.site-header.over-hero .hamburger span{background:var(--cream)}
.site-header.over-hero .header__cta{color:var(--cream);border-color:rgba(255,255,255,.5)}
.site-header.scrolled{background:var(--paper);box-shadow:0 1px 0 var(--line),0 12px 40px -28px rgba(42,36,29,.4)}
.site-header.scrolled .brand__txt b,.site-header.scrolled .nav a{color:var(--ink-2)}
.site-header.scrolled .brand__txt small{color:var(--brass-deep)}
.site-header.scrolled .hamburger span{background:var(--ink)}
/* keep current-page highlight visible in BOTH header states (R9) */
.site-header.over-hero .nav a.active,.site-header.over-hero .nav a[aria-current=page]{color:var(--brass-bright)}
.site-header.scrolled .nav a.active,.site-header.scrolled .nav a[aria-current=page]{color:var(--brass-deep)}

.mobile-nav{display:none;flex-direction:column;gap:.2rem;background:var(--paper);
  padding:1rem clamp(22px,5vw,56px) 1.6rem;border-top:1px solid var(--line)}
.mobile-nav a{font-family:var(--body);font-weight:600;padding:.7rem 0;border-bottom:1px solid var(--line);color:var(--ink-2)}
.mobile-nav .btn{margin-top:1rem;justify-content:center}

/* ---------- hero (oversized serif owns negative space) ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden}
.hero__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero__scrim{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,16,11,.46) 0%,rgba(20,16,11,.12) 32%,rgba(20,16,11,.30) 64%,rgba(20,16,11,.74) 100%)}
.hero__inner{position:relative;width:100%;padding-block:clamp(2.2rem,5vh,3.4rem) clamp(3rem,7vh,5rem)}
.hero .eyebrow{color:var(--brass-bright)}
.hero h1{color:var(--paper);font-size:clamp(2.7rem,6.4vw,5.6rem);font-weight:300;line-height:1.0;margin:1.1rem 0 0;max-width:16ch}
.hero h1 em{font-style:italic;color:var(--brass-bright)}
.hero__lead{color:rgba(251,248,242,.9);font-size:clamp(1.02rem,1.5vw,1.2rem);max-width:46ch;margin-top:1.5rem}
.hero__cta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.2rem}
.hero__meta{display:flex;gap:2.4rem;margin-top:3rem;flex-wrap:wrap}
.hero__meta div{color:var(--cream)}
.hero__meta b{display:block;font-family:var(--disp);font-size:1.7rem;font-weight:500;color:var(--brass-bright)}
.hero__meta span{font-family:var(--body);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(251,248,242,.72)}

/* ---------- section scaffolding ---------- */
.section{padding-block:clamp(4.5rem,9vw,8rem)}
.section--cream2{background:var(--cream-2)}
.section--espresso{background:var(--espresso);color:var(--cream)}
.section--espresso h2,.section--espresso h3{color:var(--paper)}
.shead{max-width:62ch}
.shead h2{font-size:clamp(2rem,4vw,3.2rem);font-weight:300;margin:1rem 0 .8rem}
.shead h2 em{font-style:italic;color:var(--brass-deep)}
.shead p{color:var(--muted);font-size:1.06rem;max-width:54ch}
.shead--center{margin-inline:auto;text-align:center}
.shead--center p{margin-inline:auto}

/* manifesto strip (large serif statement) */
.manifesto{padding-block:clamp(4rem,8vw,7rem);text-align:center}
.manifesto p{font-family:var(--disp);font-weight:300;font-size:clamp(1.7rem,4vw,3rem);line-height:1.28;
  max-width:20ch;margin-inline:auto;color:var(--ink)}
.manifesto p em{font-style:italic;color:var(--brass-deep)}

/* ---------- craft: alternating image+text rows (art-directed lifestyle) ---------- */
.craft-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center;
  padding-block:clamp(2.2rem,4vw,3.4rem)}
.craft-row + .craft-row{border-top:1px solid var(--line)}
.craft-row__media{position:relative}
.craft-row:nth-child(even) .craft-row__media{order:2}
.craft-figure{position:relative;border:1px solid var(--line-2);padding:10px;background:var(--paper)}
.craft-figure img{width:100%;aspect-ratio:4/3;object-fit:cover}
.craft-row__no{font-family:var(--disp);font-style:italic;font-size:1.1rem;color:var(--brass);font-weight:500}
.craft-row__body h3{font-size:clamp(1.7rem,3vw,2.5rem);font-weight:300;margin:.5rem 0 .9rem}
.craft-row__body p{color:var(--muted);margin-bottom:1rem}
.craft-row__body ul{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem .9rem;margin:0 0 1.5rem}
.craft-row__body li{font-size:.82rem;font-weight:600;letter-spacing:.04em;color:var(--ink-2);
  background:var(--cream-2);border:1px solid var(--line);border-radius:999px;padding:.4em 1em}

/* ---------- portfolio gallery (museum-plate framed) ---------- */
.gallery__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2.4vw,2rem);margin-top:3rem}
.gallery__item{margin:0;position:relative;border:1px solid var(--line-2);padding:9px;background:var(--paper);
  cursor:pointer;transition:.4s var(--ease)}
.gallery__item img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:.6s var(--ease)}
.gallery__item:hover{box-shadow:0 26px 50px -30px rgba(42,36,29,.5)}
.gallery__item:hover img{transform:scale(1.03)}
.gallery__item figcaption{font-family:var(--body);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);padding:.9rem .2rem .3rem;display:flex;justify-content:space-between;gap:1rem}
.gallery__item figcaption span:last-child{color:var(--brass-deep)}
.gallery__item--wide{grid-column:span 2}

/* ---------- process steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1.4rem,3vw,2.6rem);margin-top:3.2rem}
.step{position:relative}
.step__no{font-family:var(--disp);font-style:italic;font-size:2.6rem;font-weight:300;color:var(--brass);line-height:1}
.step h3{font-size:1.32rem;font-weight:500;margin:.7rem 0 .5rem}
.step p{color:var(--muted);font-size:.95rem}
.section--espresso .step p{color:rgba(246,241,232,.66)}
.section--espresso .step__no{color:var(--brass-bright)}

/* quote / promise */
.promise{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.promise__q{font-family:var(--disp);font-weight:300;font-style:italic;font-size:clamp(1.6rem,3vw,2.4rem);line-height:1.32}
.promise__q cite{display:block;font-style:normal;font-family:var(--body);font-size:.8rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:var(--brass-deep);margin-top:1.4rem}
.promise__img{border:1px solid var(--line-2);padding:10px;background:var(--paper)}
.promise__img img{width:100%;aspect-ratio:4/5;object-fit:cover}

/* ---------- CTA band ---------- */
.cta{background:var(--espresso);color:var(--cream);text-align:center;padding-block:clamp(4rem,8vw,6.5rem)}
.cta h2{color:var(--paper);font-size:clamp(2rem,4.4vw,3.4rem);font-weight:300;max-width:18ch;margin:1rem auto 1.2rem}
.cta h2 em{font-style:italic;color:var(--brass-bright)}
.cta p{color:rgba(246,241,232,.72);max-width:50ch;margin:0 auto 2.2rem}
.cta__btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ---------- page-hero (inner banner) ---------- */
.page-hero{position:relative;min-height:54vh;display:flex;align-items:flex-end;overflow:hidden;background:var(--espresso)}
.page-hero__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.62}
.page-hero__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,16,11,.5),rgba(20,16,11,.2) 40%,rgba(20,16,11,.82))}
.page-hero__inner{position:relative;width:100%;padding-block:clamp(2.6rem,7vh,4.5rem)}
.crumb{display:flex;align-items:center;gap:.5rem;font-family:var(--body);font-weight:600;font-size:.7rem;
  letter-spacing:.16em;text-transform:uppercase;color:rgba(246,241,232,.6);margin-bottom:1.2rem}
.crumb a{color:rgba(246,241,232,.6)}.crumb a:hover{color:var(--cream)}
.crumb b{color:var(--brass-bright);font-weight:700}
.page-hero h1{color:var(--paper);font-size:clamp(2.3rem,5vw,4rem);font-weight:300}
.page-hero h1 em{font-style:italic;color:var(--brass-bright)}
.page-hero__lead{color:rgba(251,248,242,.85);font-size:clamp(1rem,1.4vw,1.15rem);max-width:54ch;margin-top:1.1rem}

/* contact */
.contact__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4.5rem)}
.vcard{display:flex;flex-direction:column;gap:1.1rem}
.vcard li{list-style:none;display:flex;gap:1rem;align-items:flex-start;padding-bottom:1.1rem;border-bottom:1px solid var(--line)}
.vcard .ic{width:22px;height:22px;flex:none;color:var(--brass-deep);margin-top:3px}
.vcard a,.vcard span{color:var(--ink-2)}
.vcard small{display:block;color:var(--muted-2);font-size:.8rem;margin-top:2px}
.note{font-size:.86rem;color:var(--muted-2);font-style:italic;margin-top:1.4rem}

/* ---------- footer (centered manifesto) ---------- */
.site-footer{background:var(--espresso-2);color:rgba(246,241,232,.7);padding-block:clamp(3.5rem,7vw,5.5rem) 2rem}
.footer__manifesto{text-align:center;max-width:30ch;margin:0 auto clamp(2.5rem,5vw,4rem);
  font-family:var(--disp);font-weight:300;font-size:clamp(1.5rem,3vw,2.3rem);line-height:1.3;color:var(--cream)}
.footer__manifesto em{font-style:italic;color:var(--brass-bright)}
.footer__cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;border-top:1px solid rgba(246,241,232,.14);padding-top:2.6rem}
.footer__brand b{font-family:var(--disp);font-size:1.3rem;color:var(--cream);font-weight:500}
.footer__brand p{font-size:.9rem;margin-top:.6rem;max-width:34ch}
.footer__col h4{font-family:var(--body);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--brass-bright);margin-bottom:1rem;font-weight:700}
.footer__col a,.footer__col span{display:block;font-size:.92rem;color:rgba(246,241,232,.7);padding:.28rem 0}
.footer__col a:hover{color:var(--cream)}
.footer__base{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.6rem;
  margin-top:2.6rem;padding-top:1.6rem;border-top:1px solid rgba(246,241,232,.14);font-size:.8rem;color:rgba(246,241,232,.5)}
.footer__base a{color:var(--brass-bright)}

/* ---------- lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(20,16,11,.93);display:none;
  align-items:center;justify-content:center;padding:5vw}
.lightbox.open{display:flex}
.lightbox__img{max-width:90vw;max-height:84vh;object-fit:contain;border:10px solid var(--paper)}
.lightbox__cap{position:absolute;bottom:4vh;left:0;right:0;text-align:center;color:rgba(246,241,232,.8);
  font-size:.8rem;letter-spacing:.12em;text-transform:uppercase}
.lightbox button{position:absolute;background:none;border:0;color:var(--cream);cursor:pointer;font-size:2rem;
  width:54px;height:54px;opacity:.8;transition:.2s}.lightbox button:hover{opacity:1}
.lightbox__close{top:3vh;right:3vw}
.lightbox__nav--prev{left:2vw;top:50%;transform:translateY(-50%)}
.lightbox__nav--next{right:2vw;top:50%;transform:translateY(-50%)}

/* ---------- floating WhatsApp ---------- */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:60;width:58px;height:58px;border-radius:50%;
  background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 14px 30px -8px rgba(37,211,102,.6);transition:transform .3s var(--ease)}
.wa-float:hover{transform:scale(1.07)}
.wa-float svg{width:30px;height:30px}
.wa-float__pulse{position:absolute;inset:0;border-radius:50%;background:#25D366;opacity:.5;
  animation:wapulse 2.4s var(--ease) infinite;z-index:-1}
@keyframes wapulse{0%{transform:scale(1);opacity:.5}70%{transform:scale(1.7);opacity:0}100%{opacity:0}}
@media (prefers-reduced-motion:reduce){.wa-float__pulse{display:none}}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .nav,.header__cta{display:none}
  .hamburger{display:flex}
  .site-header.nav-open .mobile-nav{display:flex}
  .craft-row{grid-template-columns:1fr;gap:1.6rem}
  .craft-row:nth-child(even) .craft-row__media{order:0}
  .promise{grid-template-columns:1fr;gap:2rem}
  .contact__grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .gallery__grid{grid-template-columns:repeat(2,1fr)}
  .gallery__item--wide{grid-column:span 1}
  .footer__cols{grid-template-columns:1fr 1fr}
  .footer__brand{grid-column:1/-1}
}
@media (max-width:560px){
  body{font-size:16px}
  .hero h1{font-size:clamp(2.2rem,8.6vw,3rem)}
  .hero__lead{margin-top:.9rem;font-size:1rem}
  .hero__cta{margin-top:1.4rem;gap:.7rem}
  .hero__cta .btn{padding:.9em 1.3em}
  .hero__meta{margin-top:1.6rem;gap:.9rem 1.5rem}
  .hero__meta b{font-size:1.3rem}
  .hero__inner{padding-block:1.4rem 1.8rem}
  .steps{grid-template-columns:1fr}
  .gallery__grid{grid-template-columns:1fr}
  .footer__cols{grid-template-columns:1fr}
  .footer__base{flex-direction:column;text-align:center}
}

/* ============================================================
   EDITORIAL redesign — refine #30: break repeated template,
   darker hero. Keeps the warm design system; changes the
   shared template tells (overlay-hero+stats / eyebrow-h2-lead
   headers / dark CTA band / dark inner banner) → editorial.
   ============================================================ */

/* opener — asymmetric editorial cover, darker scrim, no stat row */
.opener{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}
.opener__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.opener__scrim{position:absolute;inset:0;background:linear-gradient(125deg,rgba(18,14,9,.84) 0%,rgba(18,14,9,.5) 48%,rgba(18,14,9,.66) 100%)}
.opener .wrap{position:relative;width:100%}
.opener__top{padding-top:calc(var(--header-h) + clamp(2.2rem,7vh,4.6rem))}
.opener__label{color:var(--brass-bright)}
.opener h1{color:var(--paper);font-weight:300;font-size:clamp(2.9rem,7vw,6rem);line-height:.98;margin-top:1.2rem;max-width:15ch;letter-spacing:-.015em}
.opener h1 em{font-style:italic;color:var(--brass-bright)}
.opener__cta{margin-top:2.2rem}
.opener__foot{padding-bottom:clamp(2.2rem,5vh,3.6rem);display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap}
.opener__intro{font-family:var(--disp);font-style:italic;font-weight:300;font-size:clamp(1.1rem,1.7vw,1.45rem);color:rgba(251,248,242,.92);max-width:38ch;line-height:1.42}
.opener__scroll{color:var(--brass-bright);font-family:var(--body);font-weight:600;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;display:flex;align-items:center;gap:.6rem;white-space:nowrap}
.opener__scroll::after{content:"";width:46px;height:1px;background:var(--brass-bright)}

/* ed-head — editorial section header with margin index number */
.ed-head{display:grid;grid-template-columns:auto 1fr;gap:clamp(1.2rem,3vw,2.8rem);align-items:start;margin-bottom:clamp(2.4rem,5vw,3.8rem)}
.ed-num{font-family:var(--disp);font-style:italic;font-weight:300;font-size:clamp(2.2rem,4vw,3.4rem);color:var(--brass);line-height:.9;padding-top:.15em}
.ed-head__t{max-width:34ch}
.ed-head__t .eyebrow{display:block;margin-bottom:.9rem}
.ed-head__t h2{font-size:clamp(2rem,4vw,3.1rem);font-weight:300}
.ed-head__t h2 em{font-style:italic;color:var(--brass-deep)}
.ed-head__t p{color:var(--muted);margin-top:1rem;font-size:1.05rem}

/* triptych — 3 craft panels with overlaid labels */
.triptych{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(.8rem,1.6vw,1.4rem)}
.tri{position:relative;display:block;overflow:hidden;aspect-ratio:3/4;border:1px solid var(--line-2)}
.tri img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.tri:hover img{transform:scale(1.05)}
.tri__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,14,9,.06) 38%,rgba(18,14,9,.76))}
.tri__body{position:absolute;left:0;right:0;bottom:0;padding:clamp(1.2rem,2vw,1.9rem);color:var(--paper)}
.tri__no{font-family:var(--disp);font-style:italic;color:var(--brass-bright);font-size:1.1rem}
.tri h3{color:var(--paper);font-size:clamp(1.4rem,2.2vw,1.9rem);font-weight:400;margin:.2rem 0 .4rem}
.tri p{color:rgba(251,248,242,.82);font-size:.9rem;max-width:30ch}
.tri__more{display:inline-block;margin-top:.9rem;font-family:var(--body);font-weight:600;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brass-bright)}

/* spread — asymmetric editorial work gallery */
.spread{display:grid;grid-template-columns:1.55fr 1fr;gap:clamp(1rem,2.4vw,2rem);align-items:stretch}
.spread__col{display:flex;flex-direction:column;gap:clamp(1rem,2.4vw,2rem)}
.spread figure{margin:0;position:relative;overflow:hidden;border:1px solid var(--line-2);padding:9px;background:var(--paper);cursor:pointer}
.spread figure img{width:100%;object-fit:cover;transition:transform .6s var(--ease);aspect-ratio:4/3;display:block}
/* big image fills its column height to balance the two stacked images on the right */
.spread__big{display:flex;flex-direction:column}
.spread__big img{aspect-ratio:auto;flex:1 1 auto;min-height:0;height:auto}
.spread figure:hover img{transform:scale(1.03)}
.spread figcaption{display:flex;justify-content:space-between;gap:1rem;font-family:var(--body);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);padding:.8rem .2rem .2rem}
.spread figcaption span:last-child{color:var(--brass-deep)}

/* flowsteps — editorial numbered approach (cream, no dark band) */
.flowsteps{border-top:1px solid var(--line);margin-top:.5rem}
.flowstep{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(1.2rem,4vw,3.5rem);align-items:baseline;
  padding:clamp(1.5rem,3vw,2.3rem) 0;border-bottom:1px solid var(--line)}
.flowstep__no{font-family:var(--disp);font-style:italic;font-weight:300;font-size:clamp(1.8rem,3vw,2.6rem);color:var(--brass)}
.flowstep h3{font-size:clamp(1.4rem,2.4vw,2rem);font-weight:400}
.flowstep p{color:var(--muted);max-width:48ch;font-size:1rem;margin-top:.3rem}
.flowstep__k{font-family:var(--body);font-weight:600;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);white-space:nowrap;text-align:right}

/* invite — editorial closing (warm cream, replaces dark CTA band) */
.invite{background:var(--cream-3);padding-block:clamp(4.5rem,9vw,7.5rem);text-align:center}
.invite h2{font-size:clamp(2.2rem,5vw,3.8rem);font-weight:300;max-width:16ch;margin:1rem auto 2rem}
.invite h2 em{font-style:italic;color:var(--brass-deep)}
.invite__links{display:flex;gap:2.2rem;justify-content:center;align-items:center;flex-wrap:wrap}
.invite__note{margin-top:2rem;font-family:var(--body);font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2)}
.link-lg{font-family:var(--disp);font-style:italic;font-size:1.45rem;color:var(--ink);border-bottom:1px solid var(--brass);padding-bottom:3px;transition:color .3s}
.link-lg:hover{color:var(--brass-deep)}

/* ptitle — editorial inner-page title block (cream, replaces dark banner) */
.ptitle{padding-top:calc(var(--header-h) + clamp(2.6rem,7vh,5rem));padding-bottom:clamp(2.2rem,5vw,3.6rem);
  border-bottom:1px solid var(--line);background:var(--cream)}
.ptitle .crumb{color:var(--muted-2);margin-bottom:0}
.ptitle .crumb a{color:var(--muted-2)}.ptitle .crumb a:hover{color:var(--ink)}
.ptitle .crumb b{color:var(--brass-deep)}
.ptitle__rule{width:54px;height:2px;background:var(--brass);margin:1.3rem 0}
.ptitle h1{font-size:clamp(2.4rem,5.4vw,4.2rem);font-weight:300;max-width:18ch}
.ptitle h1 em{font-style:italic;color:var(--brass-deep)}
.ptitle__lead{color:var(--muted);font-size:clamp(1.05rem,1.5vw,1.2rem);max-width:54ch;margin-top:1.2rem}

@media (max-width:980px){
  .triptych{grid-template-columns:1fr;gap:1rem}
  .tri{aspect-ratio:16/10}
  .spread{grid-template-columns:1fr}
  .spread__big{display:block}
  .spread__big img{aspect-ratio:4/3;flex:none;height:auto}
  .ed-head{grid-template-columns:1fr;gap:.4rem}
  .ed-num{font-size:2rem}
  .flowstep{grid-template-columns:auto 1fr;gap:1rem .9rem}
  .flowstep__k{grid-column:2;text-align:left;margin-top:.2rem}
}
@media (max-width:560px){
  .opener h1{font-size:clamp(2.5rem,11vw,3.4rem)}
  .opener__intro{font-size:1.05rem}
  .invite__links{gap:1.2rem}
}

/* ===== white palette: accents OVER the dark opener stay light (graphite is invisible on dark) ===== */
.opener__label,.opener__scroll{color:var(--accent-dark)}
.opener__scroll::after{background:var(--accent-dark)}
.opener h1 em{color:#fff}
.site-header.over-hero .nav a.active,.site-header.over-hero .nav a[aria-current=page]{color:#fff}
.opener__cta .btn--brass{background:#fff;color:var(--ink)}
.opener__cta .btn--brass:hover{background:var(--cream-3);color:var(--ink)}
