/* ==========================================================================
   CSC Innovations — flagship design system (single source of truth)
   Palette: "Midnight Emerald" — near-black green-tinted base + crisp near-white
   type (~15:1) + a single emerald accent. Dark, high-contrast, easy on the eyes.
   Fraunces (serif display) + Inter (sans body). The Dara knot wears the accent.
   Every marketing page <link>s this one file. Token tweaks propagate once.
   ========================================================================== */

/* ---- Self-hosted fonts (no network at render time) ---------------------- */
@font-face{font-family:'Fraunces';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/Fraunces-400.ttf') format('truetype');}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/Fraunces-500.ttf') format('truetype');}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/Fraunces-600.ttf') format('truetype');}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/Fraunces-700.ttf') format('truetype');}
@font-face{font-family:'Inter';font-style:normal;font-weight:300;font-display:swap;src:url('fonts/Inter-300.ttf') format('truetype');}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/Inter-400.ttf') format('truetype');}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/Inter-500.ttf') format('truetype');}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/Inter-600.ttf') format('truetype');}
/* IBM Plex Mono (OFL, self-hosted) — the "art-school tell": eyebrows, specs, indices,
   meta labels. Regular 400 + Bold 700; weight 500 maps to Regular (legible tracked caps). */
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/IBMPlexMono-Regular.ttf') format('truetype');}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/IBMPlexMono-Bold.ttf') format('truetype');}
/* Metric-matched fallbacks — prevent the font-swap reflow/overflow the deploy
   regression guard exists for. Tuned so the fallback occupies ~the same width. */
@font-face{font-family:'Fraunces Fallback';src:local('Georgia'),local('Times New Roman');size-adjust:97%;ascent-override:92%;descent-override:24%;line-gap-override:0%;}
@font-face{font-family:'Inter Fallback';src:local('Segoe UI'),local('Arial'),local('Helvetica');size-adjust:106%;ascent-override:96%;descent-override:24%;line-gap-override:0%;}

/* ---- Tokens ------------------------------------------------------------- */
:root{
  /* Midnight Emerald palette — COLOR v2: deeper green-black base + jewel spring-emerald */
  --bg:#0A1410; --bg-2:#071009; --surface:#14211A; --surface-2:#21342B;
  --panel:#0C3320;                              /* emerald-tinted deep panel for feature/CTA bands */
  /* readability floor raised v3 — muted/faint nudged up a notch so secondary copy
     never drops below comfortable on the dark bases (verified in-render, not just tokens). */
  --text:#F2F7F4; --text-muted:rgba(242,247,244,.82); --text-faint:rgba(242,247,244,.64);
  --accent:#3DD68C; --accent-deep:#1FA862; --accent-glow:#9DEFC2; --on-accent:#04140B;
  --line:rgba(228,247,237,.11); --line-strong:rgba(228,247,237,.20);
  --accent-12:rgba(61,214,140,.12); --accent-18:rgba(61,214,140,.18);

  /* legacy aliases → kept so any selector not individually re-toned still reads dark.
     (surface/text-only roles are set explicitly per-rule below; these cover accents.) */
  --forest:var(--accent); --forest-deep:var(--accent-deep); --moss:var(--accent); --moss-soft:var(--accent-glow);
  --forest-tint:var(--accent-12); --charcoal:var(--text); --ink:var(--text); --char-60:var(--text-faint);
  --char-12:var(--line-strong); --white:var(--surface); --bone:var(--text); --bone-2:var(--surface);

  /* type */
  --serif:'Fraunces','Fraunces Fallback',Georgia,'Times New Roman',serif;
  --sans:'Inter','Inter Fallback','Segoe UI',system-ui,Arial,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,'Cascadia Code','SFMono-Regular',Consolas,Menlo,monospace;
  --fs-display:clamp(46px,6.4vw,88px);
  --fs-h1:clamp(36px,4.6vw,62px);
  --fs-h2:clamp(28px,3.4vw,44px);
  --fs-h3:clamp(21px,2vw,27px);
  --fs-lead:clamp(18px,1.55vw,22px);
  --fs-body:17px;
  --fs-sm:15px;
  --fs-xs:13px;

  /* spacing (8px scale) */
  --s1:8px; --s2:16px; --s3:24px; --s4:32px; --s5:48px; --s6:64px; --s7:96px; --s8:128px;
  --container:1180px; --container-narrow:880px;
  --gutter:clamp(20px,5vw,40px);

  /* radii */
  --r-sm:8px; --r-md:12px; --r-lg:18px; --r-pill:999px;

  /* layered shadows — deep on dark, with a faint emerald ring on the strong one */
  --sh-1:0 1px 2px rgba(0,0,0,.40), 0 2px 6px rgba(0,0,0,.30);
  --sh-2:0 2px 6px rgba(0,0,0,.45), 0 10px 26px rgba(0,0,0,.40);
  --sh-3:0 8px 20px rgba(0,0,0,.50), 0 24px 56px rgba(0,0,0,.55);
  --sh-forest:0 14px 40px rgba(0,0,0,.55), 0 0 0 1px rgba(61,214,140,.14);

  /* motion */
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-spring:cubic-bezier(.34,1.3,.5,1);
  --t-fast:.18s; --t:.32s; --t-slow:.6s;
}

/* ---- Reset / base ------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth;overflow-x:clip;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
body{
  margin:0;font-family:var(--sans);font-size:var(--fs-body);line-height:1.65;
  color:var(--text);background:var(--bg);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:clip;
}
img,svg,video{max-width:100%;height:auto;display:block;}
h1,h2,h3,h4,h5{margin:0;font-family:var(--serif);font-weight:600;color:var(--text);line-height:1.12;letter-spacing:-.025em;text-wrap:balance;}
h1{font-size:var(--fs-h1);line-height:1.08;} h2{font-size:var(--fs-h2);line-height:1.1;} h3{font-size:var(--fs-h3);letter-spacing:-.015em;line-height:1.18;}
/* Readable measure: cap body paragraphs near the ideal 66ch. Cards/grids are already
   narrower so the cap is a no-op there; it only reins in full-width section copy. */
p{margin:0 0 1.05em;max-width:66ch;} p:last-child{margin-bottom:0;}
.center p,.center .lead{margin-inline:auto;}
a{color:var(--accent);text-decoration:none;}
em{font-style:italic;color:var(--accent);} /* the one accent move */
strong{font-weight:600;color:var(--text);}
ul{margin:0;padding:0;list-style:none;}
:focus-visible{outline:3px solid var(--accent);outline-offset:3px;border-radius:4px;}
::selection{background:var(--accent);color:var(--on-accent);}

/* ---- Layout primitives -------------------------------------------------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter);}
.narrow{max-width:var(--container-narrow);}
.section{padding-block:clamp(56px,8vw,112px);}
.section-sm{padding-block:clamp(40px,5vw,72px);}
.bg-bone{background:var(--bg-2);}
.bg-bone-2{background:var(--surface);}
.bg-forest{background:var(--panel);color:var(--text);}
.bg-ink{background:var(--bg-2);color:var(--text);}
.grain{position:relative;}
.grain::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ---- Eyebrow + section headers ----------------------------------------- */
/* Eyebrows + micro-labels speak in IBM Plex Mono — the quiet art-school signal. */
.eyebrow{display:inline-flex;align-items:center;gap:.6em;font-family:var(--mono);
  font-size:var(--fs-xs);font-weight:500;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);margin:0 0 var(--s2);}
.eyebrow::before{content:"";width:24px;height:1.5px;background:var(--accent);display:inline-block;}
.bg-forest .eyebrow,.bg-ink .eyebrow{color:var(--accent-glow);}
.bg-forest .eyebrow::before,.bg-ink .eyebrow::before{background:var(--accent-glow);}
/* Reusable mono micro-label (specs, indices, captions, kickers). */
.label{font-family:var(--mono);font-size:var(--fs-xs);font-weight:500;letter-spacing:.2em;
  text-transform:uppercase;color:var(--accent);}
.label-faint{color:var(--text-faint);}
.index-num{font-family:var(--mono);font-weight:500;font-feature-settings:"tnum" 1;letter-spacing:.02em;color:var(--accent);}
.display{font-size:var(--fs-display);letter-spacing:-.035em;line-height:1.04;}
.lead{font-size:var(--fs-lead);line-height:1.58;color:var(--text-muted);max-width:64ch;}
.bg-forest .lead,.bg-ink .lead{color:var(--text-muted);}
.muted{color:var(--text-faint);}
.center{text-align:center;} .center .lead{margin-inline:auto;}
.kicker{max-width:60ch;}

/* ==========================================================================
   HOUSE LEGIBILITY STANDARD (v3) — text over media/gradient ALWAYS reads.
   THE LOCKED FLOOR: no label, caption, or headline that sits on an image,
   poster, or rich gradient is allowed to go soft. These are reusable utilities
   AND the treatment is baked into the over-media components below. Pick the
   variant by what the text sits ON; always pair it with a real scrim under the
   block (outline + emboss is the belt, the scrim is the suspenders).
     .on-media         default — light text on dark / busy art. Heavier weight,
                       a fine dark contour (paint-order keeps glyphs crisp), and
                       a layered emboss-lift shadow.
     .on-media--strong dialed up for big poster titles sitting over photography.
     .on-media--ink    DARK text on LIGHT art — a white halo instead of a dark one.
   -webkit-text-stroke is supported in every modern engine (incl. FF + Safari);
   where paint-order is unsupported the shadow still carries the contrast.
   ========================================================================== */
.on-media{
  font-weight:600;
  paint-order:stroke fill;
  -webkit-text-stroke:.55px rgba(3,7,5,.45);
  text-shadow:0 1px 2px rgba(0,0,0,.6), 0 2px 9px rgba(0,0,0,.5), 0 0 1px rgba(0,0,0,.55);
}
.on-media--strong{
  font-weight:700;
  -webkit-text-stroke:.85px rgba(3,7,5,.5);
  text-shadow:0 1px 2px rgba(0,0,0,.72), 0 3px 14px rgba(0,0,0,.6), 0 0 2px rgba(0,0,0,.6);
}
.on-media--ink{
  font-weight:650;
  paint-order:stroke fill;
  -webkit-text-stroke:.6px rgba(255,255,255,.6);
  text-shadow:0 1px 2px rgba(255,255,255,.5), 0 0 7px rgba(255,255,255,.4);
}

/* ---- Buttons ------------------------------------------------------------ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  min-height:48px;padding:13px 26px;border-radius:var(--r-pill);
  font-family:var(--sans);font-size:var(--fs-sm);font-weight:600;letter-spacing:.01em;
  border:1.5px solid transparent;cursor:pointer;text-align:center;
  transition:transform var(--t-fast) var(--ease),background var(--t-fast) var(--ease),
             color var(--t-fast) var(--ease),border-color var(--t-fast) var(--ease),box-shadow var(--t) var(--ease);}
.btn:active{transform:translateY(1px) scale(.99);}
.btn-primary{background:var(--accent);color:var(--on-accent);box-shadow:var(--sh-2);}
.btn-primary:hover{background:var(--accent-glow);box-shadow:var(--sh-forest);transform:translateY(-2px);}
.btn-ghost{background:transparent;color:var(--accent);border-color:var(--line-strong);}
.btn-ghost:hover{border-color:var(--accent);background:var(--accent-12);transform:translateY(-2px);}
.btn-quiet{display:inline-flex;align-items:center;gap:.4em;min-height:44px;background:transparent;color:var(--accent);padding:8px 2px;border:0;font-weight:600;}
.btn-quiet .arrow{transition:transform var(--t) var(--ease);}
.btn-quiet:hover .arrow{transform:translateX(5px);}
.bg-forest .btn-primary,.bg-ink .btn-primary{background:var(--accent);color:var(--on-accent);}
.bg-forest .btn-primary:hover,.bg-ink .btn-primary:hover{background:var(--accent-glow);}
.bg-forest .btn-ghost,.bg-ink .btn-ghost{color:var(--text);border-color:rgba(242,246,243,.35);}
.bg-forest .btn-ghost:hover{border-color:var(--text);background:rgba(242,246,243,.08);}
.btn-row{display:flex;flex-wrap:wrap;gap:var(--s2);}

/* ---- Header (sticky, blurred) + checkbox-hack mobile overlay ----------- */
.site-head{position:sticky;top:0;z-index:60;background:rgba(14,21,18,.72);
  -webkit-backdrop-filter:blur(14px) saturate(1.3);backdrop-filter:blur(14px) saturate(1.3);
  border-bottom:1px solid var(--line);}
.head-inner{display:flex;align-items:center;gap:var(--s3);min-height:72px;}
.brand{display:inline-flex;align-items:center;gap:11px;margin-right:auto;min-height:44px;}
.brand-mark{width:34px;height:34px;flex:0 0 auto;
  background:radial-gradient(circle at 35% 30%,var(--accent-glow),var(--accent) 60%,var(--accent-deep));
  -webkit-mask:url('dara-knot.svg') center/contain no-repeat;mask:url('dara-knot.svg') center/contain no-repeat;}
.brand-word{display:flex;flex-direction:column;line-height:1;font-family:var(--serif);
  font-weight:600;font-size:18px;color:var(--text);letter-spacing:-.02em;}
.brand-word small{font-family:var(--sans);font-weight:500;font-size:10.5px;letter-spacing:.13em;
  text-transform:uppercase;color:var(--text-faint);margin-top:4px;}
.nav-desktop{display:flex;align-items:center;gap:4px;}
.nav-desktop a{position:relative;padding:10px 14px;border-radius:var(--r-sm);font-size:16px;font-weight:500;
  color:var(--text-muted);transition:background var(--t-fast),color var(--t-fast);}
.nav-desktop a::after{content:"";position:absolute;left:14px;right:14px;bottom:5px;height:2px;border-radius:2px;
  background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform var(--t) var(--ease);}
.nav-desktop a:hover{color:var(--text);background:var(--accent-12);}
.nav-desktop a:hover::after,.nav-desktop a[aria-current="page"]::after{transform:scaleX(1);}
.nav-desktop a[aria-current="page"]{color:var(--accent);font-weight:600;}
.head-cta{flex:0 0 auto;}
.nav-toggle,.nav-scrim,.nav-overlay{display:none;}
.nav-burger{display:none;}

@media (max-width:920px){
  .nav-desktop,.head-cta{display:none;}
  .nav-burger{display:inline-flex;align-items:center;justify-content:center;
    width:48px;height:48px;margin-left:auto;border-radius:var(--r-sm);cursor:pointer;color:var(--text);}
  .nav-burger span,.nav-burger span::before,.nav-burger span::after{
    content:"";display:block;width:24px;height:2px;background:currentColor;border-radius:2px;
    transition:transform var(--t) var(--ease),opacity var(--t-fast) var(--ease);}
  .nav-burger span{position:relative;}
  .nav-burger span::before{position:absolute;top:-7px;left:0;}
  .nav-burger span::after{position:absolute;top:7px;left:0;}
  .nav-scrim{display:block;position:fixed;inset:0;z-index:55;background:rgba(0,0,0,.6);
    opacity:0;visibility:hidden;transition:opacity var(--t) var(--ease),visibility var(--t);}
  .nav-overlay{display:flex;flex-direction:column;gap:6px;position:fixed;top:0;right:0;z-index:58;
    width:min(86vw,360px);height:100%;padding:84px 26px 32px;background:var(--surface);
    box-shadow:var(--sh-3);transform:translateX(105%);transition:transform var(--t-slow) var(--ease);
    overflow-y:auto;-webkit-overflow-scrolling:touch;border-left:1px solid var(--line);}
  .nav-overlay a{display:flex;align-items:center;min-height:56px;padding:8px 12px;border-radius:var(--r-sm);
    font-family:var(--serif);font-size:21px;font-weight:500;color:var(--text);
    border-bottom:1px solid var(--line);}
  .nav-overlay a[aria-current="page"]{color:var(--accent);}
  .nav-overlay .btn{margin-top:var(--s3);min-height:56px;}
  .nav-close{position:absolute;top:18px;right:18px;width:48px;height:48px;display:inline-flex;
    align-items:center;justify-content:center;font-size:30px;line-height:1;color:var(--text);cursor:pointer;border-radius:var(--r-sm);}
  .nav-toggle:checked ~ .nav-scrim{opacity:1;visibility:visible;}
  .nav-toggle:checked ~ .nav-overlay{transform:translateX(0);}
  .nav-toggle:checked ~ .head-inner .nav-burger span{background:transparent;}
  .nav-toggle:checked ~ .head-inner .nav-burger span::before{transform:translateY(7px) rotate(45deg);}
  .nav-toggle:checked ~ .head-inner .nav-burger span::after{transform:translateY(-7px) rotate(-45deg);}
}

/* ---- Footer ------------------------------------------------------------- */
.site-foot{background:var(--bg-2);color:var(--text-muted);padding-block:clamp(48px,6vw,80px) 28px;border-top:1px solid var(--line);}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:var(--s5) var(--s4);}
.site-foot .brand-word{color:var(--text);}
.site-foot .brand-word small{color:var(--text-faint);}
.site-foot .brand-mark{background:var(--accent);}
.foot-about{max-width:34ch;margin-top:var(--s3);font-size:var(--fs-sm);line-height:1.6;}
.foot-col h5{font-family:var(--mono);font-size:var(--fs-xs);font-weight:500;letter-spacing:.18em;
  text-transform:uppercase;color:var(--accent-glow);margin:0 0 var(--s2);}
.foot-col a{display:flex;align-items:center;min-height:44px;color:var(--text-muted);font-size:var(--fs-sm);
  transition:color var(--t-fast),transform var(--t-fast);}
.foot-col a:hover{color:var(--text);transform:translateX(3px);}
.foot-legal{display:flex;flex-wrap:wrap;justify-content:space-between;gap:var(--s2);
  margin-top:var(--s6);padding-top:var(--s3);border-top:1px solid var(--line);
  font-size:var(--fs-xs);color:var(--text-faint);}
.foot-legal a{display:inline-flex;align-items:center;min-height:44px;padding-inline:8px;color:var(--text-faint);}
.foot-legal a:hover{color:var(--text);}
@media (max-width:760px){.foot-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:480px){.foot-grid{grid-template-columns:1fr;}}

/* ---- Cards (emerald top hairline; never loud colored borders) ---------- */
.card{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:var(--s4);box-shadow:var(--sh-1);overflow:hidden;
  transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease),border-color var(--t) var(--ease);}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--accent),var(--accent-glow));transform:scaleX(0);transform-origin:left;
  transition:transform var(--t-slow) var(--ease);}
.card:hover{transform:translateY(-4px);box-shadow:var(--sh-3);border-color:var(--line-strong);}
.card:hover::before{transform:scaleX(1);}
.card h3{margin-bottom:.4em;}
.bg-bone .card{background:var(--surface);}
.bg-bone-2 .card{background:var(--surface-2);}
.grid{display:grid;gap:var(--s3);}
.grid-2{grid-template-columns:repeat(2,1fr);}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}
@media (max-width:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr);}}
@media (max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr;}}

/* feature list with check ticks */
.ticks li{position:relative;padding:6px 0 6px 28px;font-size:var(--fs-sm);line-height:1.5;border-bottom:1px solid var(--line);}
.ticks li:last-child{border-bottom:0;}
.ticks li::before{content:"";position:absolute;left:2px;top:12px;width:13px;height:8px;
  border-left:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:rotate(-45deg);}
.bg-forest .ticks li,.bg-ink .ticks li{border-color:rgba(242,246,243,.16);}
.bg-forest .ticks li::before,.bg-ink .ticks li::before{border-color:var(--accent-glow);}

/* ---- Hero --------------------------------------------------------------- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(120% 90% at 88% 8%,rgba(61,214,140,.12),transparent 55%),
  radial-gradient(90% 70% at 6% 100%,rgba(61,214,140,.08),transparent 60%),
  var(--bg);}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:var(--s6);align-items:center;
  padding-block:clamp(56px,8vw,116px);}
.hero h1{font-size:var(--fs-display);letter-spacing:-.035em;margin-bottom:var(--s3);}
.hero .lead{margin-bottom:var(--s4);}
.hero-meta{display:flex;flex-wrap:wrap;gap:var(--s2) var(--s5);margin-top:var(--s5);
  padding-top:var(--s4);border-top:1px solid var(--line);}
.hero-meta div{min-width:0;}
.hero-meta dt{font-family:var(--mono);font-size:var(--fs-xs);font-weight:500;letter-spacing:.16em;
  text-transform:uppercase;color:var(--text-faint);margin-bottom:5px;}
.hero-meta dd{margin:0;font-family:var(--serif);font-size:18px;color:var(--text);}

/* hero knot emblem — static-first; restrained motion only off-touch */
.hero-emblem{position:relative;width:min(420px,40vw);aspect-ratio:1;margin-inline:auto;justify-self:center;}
.hero-emblem .ring{position:absolute;inset:0;border-radius:50%;border:1px solid var(--line-strong);}
.hero-emblem .ring.r2{inset:7%;border-color:rgba(61,214,140,.22);}
.hero-emblem .ring.r3{inset:15%;border-style:dashed;border-color:rgba(61,214,140,.18);}
.hero-emblem .knot{position:absolute;inset:18%;
  background:radial-gradient(circle at 38% 30%,var(--accent-glow),var(--accent) 58%,var(--accent-deep));
  -webkit-mask:url('dara-knot.svg') center/contain no-repeat;mask:url('dara-knot.svg') center/contain no-repeat;
  filter:drop-shadow(0 12px 30px rgba(0,0,0,.55));}
.hero-emblem .glow{position:absolute;inset:6%;border-radius:50%;
  background:radial-gradient(circle,rgba(61,214,140,.26),transparent 68%);filter:blur(8px);z-index:-1;}
@media (prefers-reduced-motion:no-preference){
  @media (pointer:fine){
    .hero-emblem .ring.r3{animation:spin 60s linear infinite;}
    .hero-emblem .knot{animation:breathe 9s var(--ease) infinite;}
  }
}
@keyframes spin{to{transform:rotate(360deg);}}
@keyframes breathe{0%,100%{transform:scale(1);}50%{transform:scale(1.025);}}
@media (max-width:860px){
  .hero-grid{grid-template-columns:1fr;gap:var(--s5);padding-block:clamp(44px,9vw,72px);}
  .hero-emblem{width:min(300px,68vw);order:-1;}
}

/* ---- Page HERO (inner pages) — the .page-hero FAMILY -------------------- */
/* Replaces the old flat .page-head band. One recurring motif (the Dara knot in
   THIS page's accent), composed differently per page, paired with a real proof
   image where one exists. Mirrors the home hero's asymmetric grid so it's family,
   never a clone. Static-first; reduced-motion + JS-off safe; no scroll-jacking. */
.page-hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,var(--bg),var(--bg-2));}
.page-hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;}
/* (I) richer layered wash — a 3rd soft central bloom gives every hero decals-style
   depth/glow without changing the page's hue. Lift, not replace. */
.ph-wash{position:absolute;inset:0;
  background:
    radial-gradient(115% 130% at 90% -12%,var(--accent-18),transparent 58%),
    radial-gradient(58% 58% at 52% 40%,var(--accent-12),transparent 72%),
    radial-gradient(80% 90% at 6% 110%,var(--accent-12),transparent 60%);}
/* huge faint accent knot watermark — the traced 13.6KB vector, NOT the 200KB raster */
.ph-knot-wm{position:absolute;top:-16%;right:-12%;width:min(560px,52vw);aspect-ratio:1;opacity:.10;
  background:var(--accent);
  -webkit-mask:url('dara-knot-path.svg') center/contain no-repeat;
          mask:url('dara-knot-path.svg') center/contain no-repeat;}
.page-hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr .9fr;
  gap:clamp(32px,5vw,72px);align-items:center;
  padding-block:clamp(64px,9vw,128px) clamp(48px,6vw,88px);}
.page-hero .ph-copy{min-width:0;}
.page-hero h1{font-size:clamp(40px,5.4vw,74px);letter-spacing:-.035em;line-height:1.05;margin-bottom:var(--s3);}
.page-hero h1 em{color:var(--accent-glow);}
.page-hero .lead{margin-bottom:0;}
.page-hero-meta{display:flex;flex-wrap:wrap;gap:var(--s2) var(--s5);margin-top:var(--s5);
  padding-top:var(--s4);border-top:1px solid var(--line);}
.page-hero-meta div{min-width:0;}
.page-hero-meta dt{font-family:var(--mono);font-size:var(--fs-xs);font-weight:500;letter-spacing:.16em;
  text-transform:uppercase;color:var(--text-faint);margin-bottom:5px;}
.page-hero-meta dd{margin:0;font-family:var(--serif);font-size:18px;color:var(--text);}
.page-hero .ph-focal{position:relative;justify-self:center;width:100%;}

/* archetype A — ACCENT EMBLEM. (C) The 3 rings are GONE — just the knot + a soft
   glow, larger now that it owns the frame, with a gentle spring wobble on hover. */
.ph-emblem{position:relative;width:min(420px,82%);aspect-ratio:1;margin-inline:auto;}
.ph-emblem .ring{display:none;}                 /* rings retired — knot stands alone */
.ph-emblem .knot{position:absolute;inset:9%;
  background:radial-gradient(circle at 38% 30%,var(--accent-glow),var(--accent) 58%,var(--accent-deep));
  -webkit-mask:url('dara-knot-path.svg') center/contain no-repeat;
          mask:url('dara-knot-path.svg') center/contain no-repeat;
  filter:drop-shadow(0 12px 30px rgba(0,0,0,.55));
  transition:transform .55s var(--ease-spring),filter .4s var(--ease);}
.ph-emblem .glow{position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle,var(--accent-18),transparent 66%);filter:blur(14px);z-index:-1;}
@media (hover:hover) and (prefers-reduced-motion:no-preference){
  .ph-emblem:hover .knot{transform:rotate(8deg) scale(1.05);
    filter:drop-shadow(0 16px 36px rgba(0,0,0,.6)) drop-shadow(0 0 18px var(--accent-18));animation-play-state:paused;}
}

/* archetype B — DEVICE / PROOF (real image in a browser frame) */
.ph-device{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line-strong);
  box-shadow:var(--sh-3);background:var(--surface);}
.ph-device .bar{display:flex;align-items:center;gap:7px;padding:10px 13px;background:var(--surface);
  border-bottom:1px solid var(--line);}
.ph-device .bar .dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto;background:var(--line-strong);}
.ph-device .bar .dot:nth-child(1){background:#ff5f57;}
.ph-device .bar .dot:nth-child(2){background:#febc2e;}
.ph-device .bar .dot:nth-child(3){background:#28c840;}
.ph-device .bar .url{margin-left:8px;font-family:var(--mono);font-size:11px;color:var(--text-faint);
  background:var(--bg-2);padding:4px 11px;border-radius:var(--r-pill);flex:1;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;}
.ph-device img{display:block;width:100%;aspect-ratio:16/11;object-fit:cover;object-position:center top;
  background:var(--surface);}

/* archetype C — CENTERED WATERMARK (no right column; giant faint knot behind copy) */
.page-hero.ph-center .page-hero-grid{grid-template-columns:1fr;text-align:center;justify-items:center;}
.page-hero.ph-center .ph-knot-wm{inset:0;top:auto;right:auto;margin:auto;
  width:min(640px,86vw);height:min(640px,86vw);aspect-ratio:auto;opacity:.08;}
.page-hero.ph-center .lead{margin-inline:auto;}
.page-hero.ph-center .page-hero-meta{justify-content:center;}

@media (max-width:920px){
  .page-hero-grid{grid-template-columns:1fr;gap:var(--s5);
    padding-block:clamp(48px,9vw,80px) clamp(32px,6vw,56px);}
  .page-hero .ph-focal{order:-1;width:min(380px,78vw);justify-self:center;}
}
/* ambient drift — restrained, off touch + reduced-motion */
@media (prefers-reduced-motion:no-preference){
  @media (pointer:fine){
    .ph-emblem .knot{animation:breathe 9s var(--ease) infinite;}   /* idle breathe; hover wobble overrides */
    .page-hero:not(.ph-center) .ph-knot-wm{animation:phDrift 26s var(--ease) infinite;}
    /* (D) the centered-watermark heroes (contact / faq) get a slow drift+pulse too */
    .page-hero.ph-center .ph-knot-wm{animation:phPulse 22s var(--ease) infinite;}
  }
}
@keyframes phPulse{0%,100%{opacity:.08;transform:scale(1) rotate(0deg);}50%{opacity:.13;transform:scale(1.04) rotate(-3deg);}}
@keyframes phDrift{0%,100%{transform:translate(0,0) rotate(0deg);}50%{transform:translate(-12px,9px) rotate(4deg);}}

/* ---- Pricing / tier cards ---------------------------------------------- */
.tier{display:flex;flex-direction:column;}
.tier .price{font-family:var(--serif);font-size:clamp(30px,3.4vw,40px);color:var(--accent);letter-spacing:-.03em;margin:.1em 0 .15em;}
.tier .price small{font-family:var(--sans);font-size:14px;font-weight:500;color:var(--text-faint);}
.tier .tagline{font-size:var(--fs-sm);color:var(--text-faint);margin-bottom:var(--s3);}
.tier .btn{margin-top:auto;}
.tier .ticks{margin-bottom:var(--s3);}
.tag{display:inline-block;align-self:flex-start;font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent);background:var(--accent-12);
  padding:5px 12px;border-radius:var(--r-pill);margin-bottom:var(--s2);}
.card.featured{border-color:var(--accent);box-shadow:var(--sh-3);}
.card.featured::before{transform:scaleX(1);}
.card.featured .tag{background:var(--accent);color:var(--on-accent);}

/* ---- Media / gallery ---------------------------------------------------- */
.shot{border-radius:var(--r-md);border:1px solid var(--line);box-shadow:var(--sh-2);background:var(--surface);overflow:hidden;}
.gallery{display:grid;gap:var(--s3);grid-template-columns:repeat(4,1fr);}
.gallery img{border-radius:var(--r-md);border:1px solid var(--line);box-shadow:var(--sh-1);
  transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease);}
.gallery a:hover img{transform:translateY(-3px) scale(1.01);box-shadow:var(--sh-2);}
@media (max-width:900px){.gallery{grid-template-columns:repeat(3,1fr);}}
@media (max-width:560px){.gallery{grid-template-columns:repeat(2,1fr);gap:var(--s2);}}
.figure-cap{font-family:var(--mono);font-size:var(--fs-xs);letter-spacing:.04em;color:var(--text-faint);margin-top:8px;text-align:center;}

/* doorway poster cards (Work) */
.poster{position:relative;display:flex;flex-direction:column;justify-content:flex-end;
  min-height:300px;border-radius:var(--r-lg);overflow:hidden;color:var(--text);padding:var(--s4);
  border:1px solid var(--line);box-shadow:var(--sh-2);isolation:isolate;
  transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease);}
.poster:hover{transform:translateY(-4px);box-shadow:var(--sh-3);}
.poster::before{content:"";position:absolute;inset:0;z-index:-2;background:#0a1a11;}
/* CALM THE ART — the screenshot/gradient behind the text is dimmed + desaturated
   a touch so the title always wins. (B: "the text, image, and panels read as one
   thing" → separate them.) */
.poster .poster-art{position:absolute;inset:0;z-index:-1;background-size:cover;background-position:center;
  filter:saturate(.9) brightness(.82);
  transition:transform var(--t-slow) var(--ease),filter var(--t) var(--ease);}
.poster:hover .poster-art{transform:scale(1.04);filter:saturate(.96) brightness(.9);}
/* DEFINED BOTTOM PLATE (not a wash) — the lower third reads as a solid panel the
   text sits ON, so the demo title/price separate cleanly from the screenshot. */
.poster::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,transparent 0%,rgba(6,12,9,.18) 34%,rgba(5,10,8,.74) 66%,rgba(3,7,5,.95) 100%);}
/* a hairline of the page accent caps the plate — quiet structure, distinct per page */
.poster .kind{position:relative;display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--mono);font-size:var(--fs-xs);font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent-glow);
  paint-order:stroke fill;-webkit-text-stroke:.5px rgba(3,7,5,.4);
  text-shadow:0 1px 2px rgba(0,0,0,.7),0 0 2px rgba(0,0,0,.6);}
.poster .kind::before{content:"";width:18px;height:2px;border-radius:2px;background:currentColor;flex:0 0 auto;
  box-shadow:0 0 8px currentColor;}
.poster h3{color:#fff;margin:.3em 0 .18em;font-weight:700;
  paint-order:stroke fill;-webkit-text-stroke:.85px rgba(3,7,5,.5);
  text-shadow:0 1px 2px rgba(0,0,0,.78),0 3px 14px rgba(0,0,0,.6),0 0 2px rgba(0,0,0,.6);}
.poster p{font-size:var(--fs-sm);color:rgba(255,255,255,.88);margin-bottom:.7em;font-weight:500;
  text-shadow:0 1px 2px rgba(0,0,0,.72),0 0 2px rgba(0,0,0,.55);}
.poster .go{display:inline-flex;align-items:center;gap:.4em;font-weight:700;font-size:var(--fs-sm);color:#fff;
  text-shadow:0 1px 2px rgba(0,0,0,.7),0 0 2px rgba(0,0,0,.55);}
.poster .go .arrow{transition:transform var(--t) var(--ease);}
.poster:hover .go .arrow{transform:translateX(5px);}
/* gradient "posters" for 3D doorways (no screenshot dependency) */
.poster.gp1 .poster-art{background:radial-gradient(120% 100% at 20% 10%,#2a6b3e,transparent 60%),linear-gradient(160deg,#143821,#0c2418);}
.poster.gp2 .poster-art{background:radial-gradient(120% 100% at 80% 10%,#356f4a,transparent 55%),linear-gradient(160deg,#10301d,#081a10);}
.poster.gp3 .poster-art{background:radial-gradient(100% 120% at 50% 0%,#3a6b4a,transparent 60%),linear-gradient(200deg,#15351f,#0a1d11);}
.poster.gp4 .poster-art{background:radial-gradient(120% 90% at 30% 90%,#2f6442,transparent 55%),linear-gradient(140deg,#123019,#07160d);}
.poster.gp5 .poster-art{background:radial-gradient(110% 110% at 70% 20%,#43795a,transparent 55%),linear-gradient(180deg,#16361f,#091c10);}
.poster .knot-wm{position:absolute;top:-10%;right:-8%;width:55%;aspect-ratio:1;z-index:-1;opacity:.16;
  background:var(--accent-glow);-webkit-mask:url('dara-knot.svg') center/contain no-repeat;mask:url('dara-knot.svg') center/contain no-repeat;}

/* ---- Steps (process / operating model) --------------------------------- */
.steps{counter-reset:step;display:grid;gap:var(--s3);grid-template-columns:repeat(4,1fr);}
@media (max-width:900px){.steps{grid-template-columns:repeat(2,1fr);}}
@media (max-width:520px){.steps{grid-template-columns:1fr;}}
.step{position:relative;padding-top:var(--s4);}
.step::before{counter-increment:step;content:"0" counter(step);font-family:var(--serif);font-size:34px;
  color:var(--accent);opacity:.7;display:block;margin-bottom:8px;letter-spacing:-.02em;}
.step h3{font-size:var(--fs-h3);margin-bottom:.3em;}
.step p{font-size:var(--fs-sm);color:var(--text-muted);}
.bg-forest .step::before{color:var(--accent-glow);opacity:1;}
.bg-forest .step p{color:var(--text-muted);}

/* ---- Stat band ---------------------------------------------------------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s3);text-align:center;}
@media (max-width:600px){.stats{grid-template-columns:repeat(2,1fr);}}
.stat .num{font-family:var(--serif);font-size:clamp(38px,5vw,58px);color:var(--accent);letter-spacing:-.03em;line-height:1;}
.bg-forest .stat .num,.bg-ink .stat .num{color:var(--text);}
.stat .lbl{font-size:var(--fs-sm);color:var(--text-faint);margin-top:8px;}
.bg-forest .stat .lbl{color:var(--text-muted);}

/* ---- FAQ accordion (keyboard-accessible <button>) ---------------------- */
.faq{max-width:var(--container-narrow);margin-inline:auto;}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:var(--s3);width:100%;
  background:none;border:0;cursor:pointer;text-align:left;padding:22px 4px;
  font-family:var(--serif);font-size:var(--fs-h3);font-weight:600;color:var(--text);min-height:48px;}
.faq-q .pm{flex:0 0 auto;width:26px;height:26px;position:relative;color:var(--accent);transition:transform var(--t) var(--ease);}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;top:50%;left:50%;width:14px;height:2px;
  background:currentColor;transform:translate(-50%,-50%);}
.faq-q .pm::after{transform:translate(-50%,-50%) rotate(90deg);transition:opacity var(--t-fast);}
.faq-q[aria-expanded="true"] .pm::after{opacity:0;}
.faq-a{overflow:hidden;max-height:0;transition:max-height var(--t-slow) var(--ease);}
.faq-q[aria-expanded="true"] + .faq-a{max-height:560px;}
.faq-a-inner{padding:0 4px 24px;color:var(--text-muted);font-size:var(--fs-body);max-width:70ch;}
.no-js .faq-a{max-height:none;} /* JS-off: answers visible */
.no-js .faq-q .pm{display:none;}

/* ---- Callout / CTA band ------------------------------------------------- */
.callout{position:relative;overflow:hidden;border-radius:var(--r-lg);padding:clamp(36px,5vw,64px);
  background:linear-gradient(135deg,#114e30,#0a2516);color:var(--text);box-shadow:var(--sh-forest);
  border:1px solid rgba(61,214,140,.18);}
.callout::after{content:"";position:absolute;top:-30%;right:-12%;width:46%;aspect-ratio:1;opacity:.14;
  background:var(--accent-glow);-webkit-mask:url('dara-knot.svg') center/contain no-repeat;mask:url('dara-knot.svg') center/contain no-repeat;}
.callout h2{color:var(--text);max-width:18ch;}
.callout .lead{color:var(--text-muted);margin:var(--s3) 0 var(--s4);}

/* ---- Prose (about, legal) ---------------------------------------------- */
.prose{max-width:66ch;}
.prose h2{margin:1.4em 0 .5em;}
.prose p{font-size:var(--fs-lead);line-height:1.7;max-width:none;}

/* ---- Split / two-column ------------------------------------------------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:center;}
@media (max-width:820px){.split{grid-template-columns:1fr;gap:var(--s5);}}

/* ---- Reveal-on-scroll (progressive; JS-off = fully visible) ------------ */
[data-rv]{opacity:1;}
.js [data-rv]{opacity:0;transform:translateY(16px);
  transition:opacity var(--t-slow) var(--ease),transform var(--t-slow) var(--ease);}
.js [data-rv].in{opacity:1;transform:none;}
.js [data-rv][data-rv-d="1"]{transition-delay:.08s;}
.js [data-rv][data-rv-d="2"]{transition-delay:.16s;}
.js [data-rv][data-rv-d="3"]{transition-delay:.24s;}
@media (prefers-reduced-motion:reduce){
  .js [data-rv]{opacity:1!important;transform:none!important;transition:none!important;}
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;}
}

/* ---- Helpers ------------------------------------------------------------ */
.mt-0{margin-top:0;}.mb-0{margin-bottom:0;}
.maxw-sm{max-width:46ch;}.maxw-md{max-width:60ch;}
.stack-lg>*+*{margin-top:var(--s4);}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--accent);color:var(--on-accent);padding:10px 16px;z-index:100;border-radius:0 0 8px 0;font-weight:600;}
.skip-link:focus{left:0;}

/* ---- Forms (contact / inquiry) ----------------------------------------- */
.contact-form{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:clamp(22px,3vw,36px);box-shadow:var(--sh-2);}
.contact-form .title{font-family:var(--serif);font-size:var(--fs-h3);color:var(--text);font-weight:600;letter-spacing:-.02em;}
.contact-form .sub{color:var(--text-faint);font-size:var(--fs-sm);margin:6px 0 var(--s3);}
.inq-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s3);margin-bottom:var(--s2);}
.inq-row-full{margin-bottom:var(--s2);}
@media (max-width:560px){.inq-row{grid-template-columns:1fr;}}
.contact-form label{display:block;font-family:var(--mono);font-size:var(--fs-xs);font-weight:500;letter-spacing:.1em;
  text-transform:uppercase;color:var(--text-faint);margin-bottom:6px;}
.contact-form input,.contact-form select,.contact-form textarea{
  width:100%;min-height:48px;padding:12px 14px;font-family:var(--sans);font-size:var(--fs-body);color:var(--text);
  background:var(--bg-2);border:1.5px solid var(--line);border-radius:var(--r-sm);
  transition:border-color var(--t-fast),background var(--t-fast),box-shadow var(--t-fast);}
.contact-form textarea{min-height:96px;resize:vertical;line-height:1.5;}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{
  outline:none;border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px rgba(61,214,140,.20);}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--text-faint);}
#inq-submit{width:100%;margin-top:var(--s2);min-height:52px;border:0;border-radius:var(--r-pill);
  background:var(--accent);color:var(--on-accent);font-family:var(--sans);font-weight:600;font-size:var(--fs-body);cursor:pointer;
  transition:background var(--t-fast),transform var(--t-fast),box-shadow var(--t);box-shadow:var(--sh-2);}
#inq-submit:hover{background:var(--accent-glow);transform:translateY(-2px);box-shadow:var(--sh-forest);}
#inq-submit:active{transform:translateY(0);}
#inq-submit:disabled{opacity:.7;cursor:default;transform:none;}
.contact-fine{font-size:var(--fs-xs);color:var(--text-faint);margin-top:10px;text-align:center;}
.contact-rows{display:flex;flex-direction:column;gap:var(--s3);}
.contact-row{display:flex;gap:var(--s3);align-items:flex-start;padding:var(--s3);background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--sh-1);}
.contact-row .ic{flex:0 0 auto;width:42px;height:42px;border-radius:11px;background:var(--accent-12);
  display:flex;align-items:center;justify-content:center;}
.contact-row .ic span{width:20px;height:20px;background:var(--accent);
  -webkit-mask:url('dara-knot.svg') center/contain no-repeat;mask:url('dara-knot.svg') center/contain no-repeat;}
.contact-row h4{font-family:var(--mono);font-size:var(--fs-xs);font-weight:500;letter-spacing:.14em;
  text-transform:uppercase;color:var(--text-faint);margin:0 0 4px;}
.contact-row a,.contact-row .big{font-family:var(--serif);font-size:18px;color:var(--text);margin:0;display:block;}
.contact-row a:hover{color:var(--accent);}
.contact-row .sub2{font-family:var(--sans);font-size:var(--fs-sm);color:var(--text-faint);margin-top:2px;}
.contact-split{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(28px,4vw,56px);align-items:start;}
@media (max-width:860px){.contact-split{grid-template-columns:1fr;gap:var(--s5);}}

/* ==========================================================================
   FLAGSHIP-TIER POLISH (flair.js) — makes the 8 colored pages feel like one
   living organism. All additive; degrades to nothing under reduced-motion / JS-off.
   ========================================================================== */
/* 1) scroll-progress hairline in the page accent */
.scroll-rail{position:fixed;top:0;left:0;right:0;height:2px;z-index:80;transform:scaleX(0);transform-origin:left;
  background:linear-gradient(90deg,var(--accent),var(--accent-glow));box-shadow:0 0 12px var(--accent-18);
  will-change:transform;pointer-events:none;}

/* 2) color-travel — a wipe in the DESTINATION accent announces the next room */
.page-wipe{position:fixed;inset:0;z-index:200;pointer-events:none;opacity:0;
  background:radial-gradient(125% 125% at 50% 62%,var(--wipe,var(--accent)) 0%,
            color-mix(in srgb,var(--wipe,var(--accent)) 52%,#05070a) 100%);
  clip-path:circle(0% at 50% 100%);}
.page-wipe.go{pointer-events:all;opacity:1;clip-path:circle(150% at 50% 100%);
  transition:clip-path .33s cubic-bezier(.5,0,.2,1),opacity .33s ease;}
@media (prefers-reduced-motion:reduce){.page-wipe{display:none;}}

/* 3) first-paint choreography — the hero accent ignites once flair-ready.
   Non-conflicting with the data-rv copy cascade (it only touches atmosphere + the
   accent word's glow, never the reveal transform/opacity). */
@media (prefers-reduced-motion:no-preference){
  .flair-ready .page-hero .ph-wash{animation:phWashBloom 1.15s var(--ease) both;}
  .flair-ready .page-hero h1 em{animation:phEmIgnite 1.3s var(--ease) .22s both;}
}
@keyframes phWashBloom{from{opacity:.18;}to{opacity:1;}}
@keyframes phEmIgnite{0%{text-shadow:0 0 0 transparent;}38%{text-shadow:0 0 26px var(--accent-18);}100%{text-shadow:0 0 0 transparent;}}

/* 4) capped pointer-tilt micro-interaction — hero focals only (no hover-lift clash) */
.tilt{transform:perspective(1100px) rotateX(var(--tx,0deg)) rotateY(var(--ty,0deg));
  transition:transform .35s var(--ease);transform-style:preserve-3d;}

/* 5) FAQ accent flash when a question opens */
.faq-q.faq-flash{animation:faqFlash .5s var(--ease);}
@keyframes faqFlash{0%{background:var(--accent-12);}100%{background:transparent;}}
