/* =====================================================================
   C&C ASSET ADVISORS — Design system + immersive layout
   ===================================================================== */
:root{
  --paper:#F4F2ED; --paper-2:#ECE8DF; --paper-3:#E4DFD3; --paper-4:#DAD3C4;
  --ink:#15130F; --ink-2:#1C1A15; --ink-3:#2C2925; --ink-4:#3A3733;
  --taupe:#7E7468; --taupe-2:#9A8F80; --stone:#C4BBAD;
  --gold:#9C8456; --gold-deep:#836E45; --gold-soft:#C7B186;
  --line:rgba(26,25,22,0.13); --line-soft:rgba(26,25,22,0.07); --line-2:rgba(26,25,22,0.22); --line-gold:rgba(156,132,86,0.42);
  --on-ink:#EDE6D7; --on-ink-soft:rgba(237,230,215,0.62); --on-ink-faint:rgba(237,230,215,0.36);
  --line-ink:rgba(237,230,215,0.13); --line-ink-2:rgba(237,230,215,0.22);
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,"SFMono-Regular",monospace;
  --ease:cubic-bezier(0.22,1,0.36,1); --ease-2:cubic-bezier(0.65,0,0.35,1);
  --gutter:clamp(20px,5vw,84px); --maxw:1480px;
}
*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; background:var(--ink); }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{ background:var(--paper); color:var(--ink); font-family:var(--sans); font-weight:400; line-height:1.55; font-size:17px; letter-spacing:0.005em; overflow-x:hidden; }
::selection{ background:var(--gold-soft); color:var(--ink); }
img{ max-width:100%; display:block; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
a{ color:inherit; text-decoration:none; }

/* ---------- Type ---------- */
.serif{ font-family:var(--serif); }
.mono{ font-family:var(--mono); }
.display{ font-family:var(--serif); font-weight:400; line-height:0.95; letter-spacing:-0.02em; font-size:clamp(46px,7vw,108px); }
.h1{ font-family:var(--serif); font-weight:400; line-height:1.0; letter-spacing:-0.014em; font-size:clamp(40px,6vw,88px); }
.h2{ font-family:var(--serif); font-weight:400; line-height:1.04; letter-spacing:-0.01em; font-size:clamp(30px,4.2vw,58px); }
.h3{ font-family:var(--serif); font-weight:500; line-height:1.12; letter-spacing:-0.005em; font-size:clamp(22px,2.3vw,33px); }
.lede{ font-family:var(--serif); font-weight:400; font-size:clamp(20px,2.4vw,30px); line-height:1.36; letter-spacing:-0.004em; color:var(--ink-3); }
.italic{ font-style:italic; }
.gold-text{ color:var(--gold-deep); }
.label{ font-family:var(--mono); font-weight:500; font-size:11px; letter-spacing:0.22em; text-transform:uppercase; color:var(--taupe); }
.label-sm{ font-size:10px; letter-spacing:0.26em; }
.kicker{ font-family:var(--sans); font-weight:600; font-size:12px; letter-spacing:0.16em; text-transform:uppercase; color:var(--taupe); }
.body-lg{ font-size:clamp(17px,1.25vw,19px); line-height:1.62; color:var(--ink-3); }
.body{ font-size:16px; line-height:1.62; color:var(--ink-4); }
.body-sm{ font-size:14px; line-height:1.58; color:var(--taupe); }
.measure{ max-width:40rem; } .measure-sm{ max-width:30rem; } .measure-lg{ max-width:54rem; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter); }
section{ position:relative; }
.section-pad{ padding-block:clamp(80px,11vw,170px); }
.section-pad-sm{ padding-block:clamp(56px,7vw,110px); }

/* ---------- Per-division themes ---------- */
.theme-warm{ --accent:#9C6F4E; --accent-soft:#C8A77F; --accent-deep:#7E5A3E; }
.theme-gold{ --accent:#9C8456; --accent-soft:#C7B186; --accent-deep:#836E45; }
.theme-cool{ --accent:#5E6E72; --accent-soft:#9DB0B4; --accent-deep:#48565A; }
.accent{ color:var(--accent-deep); }

/* ---------- Backgrounds ---------- */
.paper-section{ background:var(--paper); }
.paper-warm{ background:#F1EAE0; }
.paper-cool{ background:#EAEEEE; }
.ink-section{ background:var(--ink); color:var(--on-ink); }
.ink-section .lede,.ink-section .body,.ink-section .body-lg{ color:var(--on-ink-soft); }
.ink-section .label,.ink-section .kicker{ color:var(--on-ink-faint); }
.ink-section .gold-text{ color:var(--gold-soft); }

/* ---------- The fixed WebGL canvas ---------- */
#world{ position:fixed; inset:0; width:100%; height:100%; z-index:0; pointer-events:none; opacity:1; }
.no-webgl #world{ display:none; }
/* fallback poster behind everything for no-webgl */
#poster{ position:fixed; inset:0; z-index:0; display:none;
  background:radial-gradient(ellipse 80% 70% at 50% 36%, #241f17, #100e0a 80%); }
.no-webgl #poster{ display:block; }

/* all content rides above the canvas */
.page{ position:relative; z-index:1; }

/* ---------- Section heading ---------- */
.sec-head{ display:flex; align-items:center; gap:16px; margin-bottom:clamp(34px,4.5vw,64px); }
.sec-num{ font-size:clamp(38px,3.8vw,60px); line-height:0.8; color:var(--gold-deep); opacity:.34; flex:none; letter-spacing:0.02em; font-weight:500; }
.ink-section .sec-num{ color:var(--gold-soft); opacity:.4; }
@supports (-webkit-text-stroke: 1px black){
  .sec-num{ color:transparent; -webkit-text-stroke:1.1px var(--stone); opacity:1; }
  .ink-section .sec-num{ color:transparent; -webkit-text-stroke-color:rgba(199,177,134,0.5); opacity:1; }
}

/* drawing-sheet grid behind editorial sections */
.paper-arch{ position:relative; }
.paper-arch > .wrap{ position:relative; z-index:1; }
.paper-arch::before{ content:""; position:absolute; inset:0; pointer-events:none; opacity:.55;
  background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);
  background-size:clamp(72px,8vw,120px) clamp(72px,8vw,120px);
  -webkit-mask-image:radial-gradient(ellipse 95% 85% at 72% 12%, #000, transparent 78%);
  mask-image:radial-gradient(ellipse 95% 85% at 72% 12%, #000, transparent 78%); }

/* pull-quote closers */
.pull{ border-left:2px solid var(--gold-deep); padding-left:clamp(20px,2.4vw,34px); }
.kicker-dot{ width:6px; height:6px; border-radius:50%; background:var(--accent,var(--gold)); flex:none; }
.sec-rule{ flex:1; height:1px; background:var(--line); }
.ink-section .sec-rule{ background:var(--line-ink); }
.dot{ width:5px; height:5px; border-radius:50%; background:var(--gold); flex:none; }
.eyebrow-row{ display:flex; align-items:center; gap:14px; }

/* ---------- Buttons / links ---------- */
.btn{ display:inline-flex; align-items:center; gap:12px; font-family:var(--sans); font-weight:600; font-size:13px; letter-spacing:0.08em; text-transform:uppercase; padding:16px 28px; position:relative; white-space:nowrap; transition:color .4s var(--ease),background .4s var(--ease),border-color .4s var(--ease); }
.btn .arrow{ transition:transform .45s var(--ease); display:inline-block; }
.btn:hover .arrow{ transform:translateX(5px); }
.btn-solid{ background:var(--ink); color:var(--paper); }
.btn-solid:hover{ background:var(--gold-deep); }
.btn-outline{ border:1px solid var(--line-2); color:var(--ink); }
.btn-outline:hover{ border-color:var(--gold-deep); color:var(--gold-deep); }
.hero .btn-outline{ border-color:var(--line-ink-2); color:var(--on-ink); }
.hero .btn-outline:hover{ border-color:var(--gold-soft); color:var(--gold-soft); }
.on-dark .btn-solid{ background:var(--gold-soft); color:var(--ink); }
.on-dark .btn-solid:hover{ background:var(--paper); }
.on-dark .btn-outline{ border-color:var(--line-ink-2); color:var(--on-ink); }
.on-dark .btn-outline:hover{ border-color:var(--gold-soft); color:var(--gold-soft); }
.link-u{ display:inline-flex; align-items:center; gap:9px; font-family:var(--sans); font-weight:600; font-size:13px; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink); position:relative; padding-bottom:4px; white-space:nowrap; }
.link-u::after{ content:""; position:absolute; left:0; bottom:0; height:1px; width:100%; background:currentColor; transform-origin:left; transition:transform .5s var(--ease); }
.link-u .arrow{ transition:transform .45s var(--ease); }
.link-u:hover{ color:var(--gold-deep); }
.link-u:hover .arrow{ transform:translateX(4px); }
.on-dark .link-u{ color:var(--on-ink); }
.on-dark .link-u:hover{ color:var(--gold-soft); }

/* ---------- Reveal ---------- */
.reveal{ opacity:1; transform:none; }
html.anim-ok .reveal{ opacity:0; transform:translateY(28px); transition:opacity 1s var(--ease),transform 1.05s var(--ease); }
html.anim-ok .reveal.in{ opacity:1; transform:none; }
html.anim-ok .reveal.d1{ transition-delay:.08s; } html.anim-ok .reveal.d2{ transition-delay:.16s; }
html.anim-ok .reveal.d3{ transition-delay:.24s; } html.anim-ok .reveal.d4{ transition-delay:.32s; }
html.anim-ok .reveal.d5{ transition-delay:.40s; } html.anim-ok .reveal.d6{ transition-delay:.48s; }
@media (prefers-reduced-motion: reduce){ html.anim-ok .reveal{ opacity:1; transform:none; transition:none; } }

/* =====================================================================
   NAV
   ===================================================================== */
.nav{ position:fixed; top:0; left:0; right:0; z-index:120; display:flex; align-items:center; justify-content:space-between; padding:18px var(--gutter); transition:background .5s var(--ease),padding .5s var(--ease),border-color .5s var(--ease),color .5s var(--ease); border-bottom:1px solid transparent; color:var(--on-ink); }
.nav.solid{ background:rgba(21,19,15,0.72); backdrop-filter:blur(16px); border-bottom-color:var(--line-ink); padding-block:13px; }
.nav.on-light{ color:var(--ink); }
.nav.on-light.solid{ background:rgba(244,242,237,0.82); border-bottom-color:var(--line); }
.brand{ display:flex; align-items:center; gap:13px; }
.brand-mark{ font-family:var(--serif); font-weight:500; font-size:24px; letter-spacing:-0.01em; line-height:1; display:flex; align-items:center; }
.brand-mark i{ color:var(--gold-soft); font-style:italic; padding:0 1px; }
.nav.on-light .brand-mark i{ color:var(--gold-deep); }
.brand-sub{ font-family:var(--mono); font-size:9.5px; letter-spacing:0.24em; text-transform:uppercase; color:var(--on-ink-faint); line-height:1.3; }
.nav.on-light .brand-sub{ color:var(--taupe); }
.nav-links{ display:flex; align-items:center; gap:34px; }
.nav-link{ font-family:var(--sans); font-weight:500; font-size:13.5px; letter-spacing:0.02em; position:relative; padding:6px 0; color:inherit; opacity:.82; transition:opacity .3s var(--ease); }
.nav-link::after{ content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--gold-soft); transition:width .4s var(--ease); }
.nav.on-light .nav-link::after{ background:var(--gold-deep); }
.nav-link:hover{ opacity:1; } .nav-link:hover::after{ width:100%; }
.nav-cta{ font-family:var(--sans); font-weight:600; font-size:12.5px; letter-spacing:0.06em; text-transform:uppercase; padding:11px 21px; border:1px solid var(--line-ink-2); transition:all .4s var(--ease); }
.nav.on-light .nav-cta{ border-color:var(--line-2); }
.nav-cta:hover{ background:var(--gold-soft); color:var(--ink); border-color:var(--gold-soft); }
.nav-burger{ display:none; flex-direction:column; gap:5px; padding:8px; }
.nav-burger span{ width:24px; height:1.5px; background:currentColor; transition:all .4s var(--ease); }
@media (max-width:920px){
  .nav-links{ position:fixed; inset:0; background:var(--ink); color:var(--on-ink); flex-direction:column; justify-content:center; gap:28px; transform:translateY(-100%); transition:transform .6s var(--ease); z-index:130; }
  .nav-links.open{ transform:none; }
  .nav-links .nav-link{ font-size:26px; font-family:var(--serif); opacity:1; }
  .nav-burger{ display:flex; z-index:140; }
  .nav-burger.open span:nth-child(1){ transform:translateY(6.5px) rotate(45deg); }
  .nav-burger.open span:nth-child(2){ opacity:0; }
  .nav-burger.open span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg); }
}

/* =====================================================================
   HERO
   ===================================================================== */
#hero{ min-height:100svh; position:relative; display:flex; flex-direction:column; color:var(--on-ink); }
.hero-inner{ flex:1; display:flex; flex-direction:column; justify-content:center; padding-top:120px; padding-bottom:28px; position:relative; z-index:3; }
.hero-grid{ display:grid; grid-template-columns:1.05fr 0.95fr; gap:clamp(28px,4vw,72px); align-items:center; }
.hero-eyebrow{ margin-bottom:26px; }
.hero h1{ color:var(--on-ink); }
.hero-line{ display:block; }
html.anim-ok .hero-line{ opacity:0; transform:translateY(38px); transition:opacity 1.1s var(--ease),transform 1.1s var(--ease); }
html.anim-ok .hero-line.in{ opacity:1; transform:none; }
.hero-lede{ color:var(--on-ink-soft); margin-top:34px; }
.hero-actions{ display:flex; gap:14px; margin-top:38px; flex-wrap:wrap; }
.hero-foot{ position:relative; z-index:3; padding-bottom:22px; }
.hero-foot-row{ display:flex; justify-content:space-between; align-items:center; border-top:1px solid var(--line-ink); padding-top:16px; flex-wrap:wrap; gap:12px; }

/* practice index (replaces door cards) */
.practice-index{ display:flex; flex-direction:column; justify-content:center; }
.pidx-head{ color:var(--on-ink-faint); padding-bottom:10px; }
.pidx{ display:flex; align-items:center; gap:clamp(16px,2vw,30px); text-align:left; padding:clamp(20px,3vh,32px) 0; border-top:1px solid var(--line-ink); color:var(--on-ink); transition:padding-left .45s var(--ease); }
.pidx:last-child{ border-bottom:1px solid var(--line-ink); }
.pidx:hover{ padding-left:14px; }
.pidx:focus-visible{ outline:1px solid var(--gold-soft); outline-offset:4px; }
.pidx-num{ font-family:var(--serif); font-style:italic; font-size:clamp(17px,1.5vw,22px); color:var(--gold-soft); min-width:2.2ch; }
.pidx-body{ display:flex; flex-direction:column; gap:7px; flex:1; }
.pidx-name{ font-family:var(--serif); font-size:clamp(27px,2.7vw,42px); line-height:1; letter-spacing:-0.014em; transition:color .4s var(--ease); }
.pidx:hover .pidx-name{ color:var(--gold-soft); }
.pidx-tag{ color:var(--on-ink-faint); }
.pidx-arrow{ font-size:21px; color:var(--gold-soft); opacity:0; transform:translateX(-10px); transition:opacity .45s var(--ease),transform .45s var(--ease); }
.pidx:hover .pidx-arrow{ opacity:1; transform:none; }
@media (max-width:980px){ .hero-grid{ grid-template-columns:1fr; gap:40px; } .pidx{ padding-block:18px; } }

/* =====================================================================
   IMMERSIVE DIVISION SECTIONS
   ===================================================================== */
.division{ position:relative; height:300vh; }
.division .pin{ position:sticky; top:0; height:100svh; display:flex; align-items:center; overflow:hidden; }
.division .stage{ position:relative; z-index:2; width:100%; }
/* veil to keep text legible over the 3D */
.division .veil{ position:absolute; inset:0; z-index:1; pointer-events:none; }
.div-warm .veil{ background:linear-gradient(90deg, rgba(22,16,9,0.88) 0%, rgba(22,16,9,0.6) 40%, rgba(22,16,9,0.2) 64%, rgba(22,16,9,0) 82%); }
.div-light .veil{ background:linear-gradient(90deg, rgba(246,242,234,0.96) 0%, rgba(246,242,234,0.78) 42%, rgba(246,242,234,0.36) 68%, rgba(246,242,234,0.14) 100%); }
.div-dark .veil{ background:linear-gradient(90deg, rgba(8,7,5,0.94) 0%, rgba(8,7,5,0.72) 46%, rgba(8,7,5,0.3) 76%, rgba(8,7,5,0.1) 100%); }
.div-cool .veil{ background:linear-gradient(90deg, rgba(12,16,18,0.93) 0%, rgba(12,16,18,0.72) 44%, rgba(12,16,18,0.38) 72%, rgba(12,16,18,0.18) 100%); }

.div-label{ color:var(--accent-soft); font-family:var(--sans); font-weight:600; letter-spacing:0.2em; font-size:11.5px; text-transform:uppercase; }
.div-light .div-label{ color:var(--accent-deep); }

/* light division (residential — daylight scene): dark type, airy veil */
.div-light .div-index{ color:var(--accent-deep); text-shadow:none; }
.div-light .div-rule{ background:var(--accent-deep); opacity:.55; }
.div-light .div-stage .label{ text-shadow:0 1px 12px rgba(246,242,234,0.9); }
.div-light .div-name{ color:var(--ink); text-shadow:0 2px 30px rgba(246,242,234,0.85), 0 1px 2px rgba(246,242,234,0.6); }
.div-light .div-tag{ color:var(--accent-deep); text-shadow:0 1px 12px rgba(246,242,234,0.9); }
.div-light .div-statement{ color:var(--ink-2); border-top-color:var(--line-2); text-shadow:0 2px 18px rgba(246,242,234,0.8), 0 1px 2px rgba(246,242,234,0.5); }
.div-light .div-statement::before{ background:var(--accent-deep); }
.div-light .div-scroll-hint{ color:var(--taupe); }
.div-light .div-point{ background:rgba(252,250,245,0.86); backdrop-filter:blur(10px); border-color:var(--line); border-top-color:var(--accent-deep); }
.div-light .div-point h3{ color:var(--ink); }
.div-light .div-point p{ color:var(--ink-4); }
.div-light .div-serve-list{ border-top-color:var(--line-2); }
.div-light .div-serve-list li{ color:var(--ink); border-bottom-color:var(--line-2); text-shadow:0 1px 12px rgba(246,242,234,0.85); }
.div-light .div-serve-list li .sn{ color:var(--accent-deep); }
.div-light .div-cta-card h3{ color:var(--ink); text-shadow:0 2px 18px rgba(246,242,234,0.8); }

.div-stages{ position:relative; }
.div-stage{ position:absolute; inset:0; z-index:2; display:flex; align-items:center; opacity:0; pointer-events:none; will-change:opacity; }
.div-stage.on{ opacity:1; pointer-events:auto; }
.div-stage.s-title{ position:relative; } /* title is the anchor; others absolutely overlay it */

.div-meta{ display:flex; align-items:baseline; gap:20px; margin-bottom:24px; }
.div-index{ font-family:var(--serif); font-weight:500; font-size:clamp(46px,4.8vw,80px); color:var(--accent-soft); line-height:0.8; letter-spacing:0; text-shadow:0 1px 12px rgba(0,0,0,0.5); }
@supports (-webkit-text-stroke: 1px black){
  .div-index{ color:transparent; -webkit-text-stroke:1.3px var(--accent-soft); text-shadow:none; }
  .div-light .div-index{ color:transparent; -webkit-text-stroke-color:var(--accent-deep); text-shadow:none; }
}
.div-rule{ width:56px; height:1px; background:var(--accent-soft); opacity:.5; }
.div-stage .label{ text-shadow:0 1px 10px rgba(0,0,0,0.75); }
.div-name{ font-family:var(--serif); color:var(--on-ink); font-size:clamp(54px,9vw,140px); line-height:0.92; letter-spacing:-0.02em; text-shadow:0 4px 34px rgba(0,0,0,0.5), 0 1px 2px rgba(0,0,0,0.4); }
.div-tag{ font-family:var(--serif); font-style:italic; font-size:clamp(19px,2vw,27px); color:var(--accent-soft); margin-top:16px; display:block; text-shadow:0 1px 12px rgba(0,0,0,0.65); }
.div-statement{ position:relative; color:var(--on-ink); opacity:.95; max-width:42rem; margin-top:30px; padding-top:22px; border-top:1px solid rgba(237,230,215,0.2); font-family:var(--serif); font-style:italic; font-weight:400; font-size:clamp(20px,2.2vw,30px); line-height:1.42; text-shadow:0 2px 20px rgba(0,0,0,0.6), 0 1px 2px rgba(0,0,0,0.4); }
.div-statement::before{ content:""; position:absolute; top:-1px; left:0; width:46px; height:2px; background:var(--accent-soft); }
.div-scroll-hint{ position:absolute; bottom:30px; left:0; display:flex; align-items:baseline; gap:14px; color:var(--on-ink-faint); }
.div-part{ font-size:clamp(17px,1.5vw,21px); color:var(--accent-soft); white-space:nowrap; }
.div-light .div-part{ color:var(--accent-deep); }

/* points stage */
.div-points{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,40px); width:100%; }
.div-point{ background:rgba(10,8,5,0.66); backdrop-filter:blur(9px); border:1px solid var(--line-ink); border-top:2px solid var(--accent-soft); padding:clamp(22px,2.2vw,32px); }
.div-point .pnum{ font-size:clamp(20px,1.8vw,26px); color:var(--accent-soft); line-height:1; }
.div-light .div-point .pnum{ color:var(--accent-deep); }
.div-point h3{ color:var(--on-ink); margin:12px 0 12px; }
.div-point p{ color:var(--on-ink-soft); font-size:15.5px; line-height:1.6; }

/* services stage */
.div-serve-grid{ display:grid; grid-template-columns:1.1fr 0.9fr; gap:clamp(28px,4vw,72px); align-items:center; width:100%; }
.div-serve-list{ list-style:none; border-top:1px solid var(--line-ink); }
.div-serve-list li{ display:flex; align-items:center; gap:16px; padding:18px 0; border-bottom:1px solid var(--line-ink); color:var(--on-ink); font-size:clamp(17px,1.6vw,22px); text-shadow:0 1px 14px rgba(0,0,0,0.6); }
.div-serve-list li .sn{ font-size:clamp(17px,1.5vw,21px); color:var(--accent-soft); min-width:1.9em; }
.div-cta-card h3{ color:var(--on-ink); text-shadow:0 2px 20px rgba(0,0,0,0.6), 0 1px 2px rgba(0,0,0,0.4); }

@media (max-width:860px){
  .division{ height:auto; }
  .division .pin{ height:auto; min-height:auto; position:relative; padding-block:0; display:block; }
  .div-stage{ position:relative; inset:auto; opacity:1; transform:none; pointer-events:auto; padding-block:clamp(64px,12vh,110px); min-height:60vh; }
  .div-stage.s-title{ min-height:100svh; }
  .div-scroll-hint{ display:none; }
  .div-points{ grid-template-columns:1fr; }
  .div-serve-grid{ grid-template-columns:1fr; gap:30px; }
}

/* =====================================================================
   INTERSTITIAL (covers canvas during scene swap)
   ===================================================================== */
.interstitial{ position:relative; z-index:1; background:var(--ink); color:var(--on-ink); padding-block:clamp(90px,15vh,170px); overflow:hidden; }
.interstitial .wrap{ position:relative; z-index:2; }
.interstitial .q{ font-family:var(--serif); font-size:clamp(28px,4vw,56px); line-height:1.18; letter-spacing:-0.01em; color:var(--on-ink); max-width:30ch; }
.interstitial .q .accent{ color:var(--gold-soft); font-style:italic; }
.inter-grid{ position:absolute; inset:0; z-index:1; opacity:.5;
  background-image:linear-gradient(var(--line-ink) 1px,transparent 1px),linear-gradient(90deg,var(--line-ink) 1px,transparent 1px);
  background-size:clamp(60px,7vw,110px) clamp(60px,7vw,110px);
  -webkit-mask-image:radial-gradient(ellipse 100% 80% at 30% 50%,#000,transparent 80%);
  mask-image:radial-gradient(ellipse 100% 80% at 30% 50%,#000,transparent 80%); }
