/* =========================================================================
   PROJECT SHOKKHOM — Krishi-First Edition
   Design System / Core Stylesheet
   Author: Creaa Think Designs
   A sovereign-grade, editorial, futuristic agri-tech aesthetic.
   ========================================================================= */

/* ---------- 1. Design Tokens ---------- */
:root{
  /* Neutral foundation */
  --paper:        #fbfaf4;   /* premium ivory background */
  --paper-2:      #f3efe3;   /* warm sand */
  --ivory:        #f7f4ea;
  --ink:          #15211b;   /* rich charcoal-green text */
  --ink-soft:     #46544c;
  --ink-faint:    #76837b;
  --line:         rgba(21,33,27,.12);
  --line-soft:    rgba(21,33,27,.07);

  /* Brand greens */
  --forest:       #0e3a2c;
  --forest-deep:  #0a2a20;
  --forest-2:     #12513b;
  --moss:         #1f7a58;
  --leaf:         #2f9b6e;

  /* Accents */
  --gold:         #c2a04e;
  --gold-soft:    #e3cf9c;
  --gold-deep:    #a07f33;
  --blue:         #2f6bed;
  --blue-deep:    #1c3f8f;
  --blue-soft:    #9cb8f6;
  --teal:         #1d8a8a;

  /* Dynamic accent (overridden per-section via [data-accent]) */
  --accent:       var(--gold);
  --accent-2:     var(--gold-soft);
  --accent-ink:   var(--gold-deep);
  --accent-glow:  rgba(194,160,78,.30);

  /* Dark surfaces */
  --night:        #0b1813;
  --night-2:      #102018;
  --night-line:   rgba(255,255,255,.10);
  --on-night:     #eef3ee;
  --on-night-soft:#aeb9b1;

  /* Type */
  --font-sans: "Manrope", "Segoe UI", system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;
  --font-display: "Fraunces", "Iowan Old Style", Georgia, "Times New Roman", serif;
  --tracking-eyebrow: .22em;

  /* Spacing / radius */
  --r-sm: 10px;
  --r-md: 18px;
  --r-lg: 28px;
  --r-xl: 40px;
  --shadow-sm: 0 2px 10px rgba(11,24,19,.06);
  --shadow-md: 0 18px 50px -22px rgba(11,24,19,.40);
  --shadow-lg: 0 40px 90px -40px rgba(11,24,19,.55);

  --maxw: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
  --nav-h: 76px;
}

/* Per-section accent themes */
[data-accent="gold"]   { --accent:#c2a04e; --accent-2:#e3cf9c; --accent-ink:#8e6e23; --accent-glow:rgba(194,160,78,.30); }
[data-accent="green"]  { --accent:#2f9b6e; --accent-2:#bfe6d3; --accent-ink:#196848; --accent-glow:rgba(47,155,110,.26); }
[data-accent="moss"]   { --accent:#1f7a58; --accent-2:#a9dcc5; --accent-ink:#155c42; --accent-glow:rgba(31,122,88,.26); }
[data-accent="blue"]   { --accent:#2f6bed; --accent-2:#bcd0fb; --accent-ink:#1c3f8f; --accent-glow:rgba(47,107,237,.24); }
[data-accent="teal"]   { --accent:#1d8a8a; --accent-2:#a8e0e0; --accent-ink:#0f5f5f; --accent-glow:rgba(29,138,138,.24); }
[data-accent="slate"]  { --accent:#4d6075; --accent-2:#c3cedd; --accent-ink:#33455a; --accent-glow:rgba(77,96,117,.22); }
[data-accent="amber"]  { --accent:#cf8a3c; --accent-2:#f0d3ad; --accent-ink:#9a5f1d; --accent-glow:rgba(207,138,60,.26); }

/* ---------- 2. Reset & Base ---------- */
*,*::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;
  font-family:var(--font-sans);
  background:var(--paper);
  color:var(--ink);
  font-size:clamp(16px,1.05vw,17.5px);
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
ul,ol{ margin:0; padding:0; list-style:none; }
:focus-visible{ outline:3px solid var(--accent); outline-offset:3px; border-radius:4px; }

/* Skip link */
.skip-link{
  position:absolute; left:-999px; top:8px; z-index:2000;
  background:var(--forest); color:#fff; padding:10px 18px; border-radius:8px;
}
.skip-link:focus{ left:12px; }

/* ---------- 3. Typography ---------- */
h1,h2,h3,h4{ font-family:var(--font-display); font-weight:560; line-height:1.07; letter-spacing:-.012em; color:var(--ink); margin:0; }
.display{ font-size:clamp(2.6rem,6.4vw,5.2rem); font-weight:540; line-height:1.02; letter-spacing:-.02em; }
h1{ font-size:clamp(2.2rem,4.6vw,3.6rem); }
h2{ font-size:clamp(1.8rem,3.4vw,2.8rem); }
h3{ font-size:clamp(1.3rem,2vw,1.7rem); }
h4{ font-size:clamp(1.1rem,1.5vw,1.28rem); }
p{ margin:0 0 1.1em; }
.lead{ font-size:clamp(1.12rem,1.7vw,1.42rem); line-height:1.55; color:var(--ink-soft); font-weight:380; }
strong{ font-weight:650; color:var(--ink); }
em{ font-style:italic; }

.eyebrow{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--font-sans); font-size:.74rem; font-weight:700;
  letter-spacing:var(--tracking-eyebrow); text-transform:uppercase;
  color:var(--accent-ink);
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--accent); border-radius:2px; }
.eyebrow.center::after{ content:""; width:26px; height:2px; background:var(--accent); border-radius:2px; }
.eyebrow.center{ justify-content:center; }

.serif-accent{ font-family:var(--font-display); font-style:italic; color:var(--accent-ink); font-weight:480; }

/* ---------- 4. Layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.wrap-wide{ max-width:1440px; }
.wrap-narrow{ max-width:840px; }
section{ position:relative; }
.section{ padding-block:clamp(64px,9vw,128px); }
.section-sm{ padding-block:clamp(44px,6vw,80px); }
.bg-paper2{ background:var(--paper-2); }
.bg-ivory{ background:linear-gradient(180deg,var(--ivory),var(--paper)); }
.bg-night{ background:var(--night); color:var(--on-night); }
.bg-night h1,.bg-night h2,.bg-night h3,.bg-night h4{ color:#fff; }
.bg-night .lead{ color:var(--on-night-soft); }
.divider-top{ border-top:1px solid var(--line); }

.grid{ display:grid; gap:clamp(18px,2.4vw,34px); }
.g-2{ grid-template-columns:repeat(2,1fr); }
.g-3{ grid-template-columns:repeat(3,1fr); }
.g-4{ grid-template-columns:repeat(4,1fr); }
@media (max-width:980px){ .g-3,.g-4{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:620px){ .g-2,.g-3,.g-4{ grid-template-columns:1fr; } }

.section-head{ max-width:760px; margin-bottom:clamp(34px,5vw,64px); }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head .lead{ margin-top:.7em; }

/* ---------- 5. Buttons ---------- */
.btn{
  --bg:var(--forest); --fg:#fff;
  display:inline-flex; align-items:center; gap:.6em;
  padding:.92em 1.5em; border-radius:100px;
  font-weight:650; font-size:.94rem; letter-spacing:.01em;
  background:var(--bg); color:var(--fg); border:1px solid transparent;
  transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s, background .3s, color .3s;
  box-shadow:0 10px 30px -14px rgba(14,58,44,.7);
  position:relative; overflow:hidden;
}
.btn svg{ width:.82em; height:.82em; flex:none; }
.btn:hover{ transform:translateY(-3px); box-shadow:0 18px 40px -16px rgba(14,58,44,.8); }
.btn .arrow{ transition:transform .35s; }
.btn:hover .arrow{ transform:translateX(4px); }
.btn-gold{ --bg:var(--gold); --fg:#231c08; box-shadow:0 10px 30px -14px var(--accent-glow); }
.btn-ghost{ --bg:transparent; --fg:var(--ink); border-color:var(--line); box-shadow:none; }
.btn-ghost:hover{ border-color:var(--accent); color:var(--accent-ink); }
.btn-light{ --bg:rgba(255,255,255,.12); --fg:#fff; border-color:rgba(255,255,255,.28); backdrop-filter:blur(8px); box-shadow:none; }
.btn-light:hover{ --bg:rgba(255,255,255,.22); }
.btn-sm{ padding:.6em 1.1em; font-size:.84rem; }
.btn-row{ display:flex; flex-wrap:wrap; gap:14px; }

/* Explore / link arrow — compact, balanced, responsive (scales with text) */
.arrow{ width:.78em; height:.78em; flex:none; }
.go .arrow{ width:.82em; height:.82em; }
.totop svg{ width:20px; height:20px; }

.txtlink{ display:inline-flex; align-items:center; gap:.45em; font-weight:650; color:var(--accent-ink); border-bottom:1px solid transparent; transition:.3s; }
.txtlink .arrow{ transition:transform .3s; }
.txtlink:hover{ border-color:var(--accent); }
.txtlink:hover .arrow{ transform:translateX(4px); }

/* ---------- 6. Navbar ---------- */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:1000; height:var(--nav-h);
  display:flex; align-items:center;
  transition:background .4s, box-shadow .4s, border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(251,250,244,.82); backdrop-filter:saturate(1.4) blur(16px);
  border-color:var(--line); box-shadow:0 8px 30px -22px rgba(11,24,19,.5);
}
.nav.on-dark:not(.scrolled){ color:#fff; }
.nav.on-dark:not(.scrolled) .brand-text small{ color:rgba(255,255,255,.7); }
.nav-inner{ width:100%; max-width:1440px; margin-inline:auto; padding-inline:var(--gutter);
  display:flex; align-items:center; gap:24px; justify-content:space-between; }
.brand{ display:flex; align-items:center; gap:12px; font-weight:700; }
.brand-mark{ width:38px; height:38px; flex:none; filter:drop-shadow(0 4px 10px var(--accent-glow)); }
.brand-text{ display:flex; flex-direction:column; line-height:1.05; }
.brand-text b{ font-family:var(--font-display); font-size:1.18rem; font-weight:600; letter-spacing:-.01em; }
.brand-text small{ font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-faint); font-weight:700; }

.nav-links{ display:flex; align-items:center; gap:4px; }
.nav-links > li > a, .nav-links > li > button{
  display:inline-flex; align-items:center; gap:.3em; padding:.5em .58em; border-radius:10px;
  font-size:.875rem; font-weight:600; color:inherit; background:none; border:none; transition:.25s; white-space:nowrap;
}
.nav-links > li > a:hover, .nav-links > li > button:hover{ color:var(--accent-ink); background:rgba(21,33,27,.05); }
/* scoped to TOP-LEVEL links only — must NOT cascade into the light mega submenu panel */
.nav.on-dark:not(.scrolled) .nav-links > li > a:hover,
.nav.on-dark:not(.scrolled) .nav-links > li > button:hover{ background:rgba(255,255,255,.12); color:#fff; }
.nav-links .caret{ width:.7em; height:.7em; transition:transform .3s; opacity:.6; }
.has-mega:hover .caret{ transform:rotate(180deg); }

.nav-actions{ display:flex; align-items:center; gap:10px; }
.lang-toggle{ display:inline-flex; border:1px solid var(--line); border-radius:100px; overflow:hidden; font-size:.78rem; font-weight:700; }
.lang-toggle button{ padding:.45em .8em; background:none; border:none; color:inherit; opacity:.6; transition:.25s; }
.lang-toggle button.active{ background:var(--forest); color:#fff; opacity:1; }
.nav.on-dark:not(.scrolled) .lang-toggle{ border-color:rgba(255,255,255,.3); }
.nav.on-dark:not(.scrolled) .lang-toggle button.active{ background:#fff; color:var(--forest); }

/* Mega menu */
.mega{
  position:absolute; top:calc(var(--nav-h) - 4px); left:50%; transform:translateX(-50%) translateY(12px);
  width:min(1180px, calc(100vw - 32px));
  background:rgba(251,250,244,.97); backdrop-filter:blur(20px);
  border:1px solid var(--line); border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg); padding:28px;
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .22s ease, transform .3s cubic-bezier(.2,.8,.2,1), visibility 0s linear .22s;
  z-index:1100;
}
/* Invisible hover bridge — fills the gap between the trigger and the panel so the
   cursor never crosses a dead zone (the cause of submenus closing prematurely). */
.has-mega > a::before, .has-mega > button::before{
  content:""; position:absolute; left:-10px; right:-10px; top:100%; height:26px; pointer-events:auto;
}
.has-mega:hover > .mega,
.has-mega.is-open > .mega,
.mega:hover,
.has-mega:focus-within > .mega{
  opacity:1; visibility:visible; pointer-events:auto; transform:translateX(-50%) translateY(0);
  transition:opacity .22s ease, transform .3s cubic-bezier(.2,.8,.2,1), visibility 0s;
}
.has-mega:hover .caret, .has-mega.is-open .caret{ transform:rotate(180deg); }
.mega-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:8px 26px; }
.mega-col h5{ font-family:var(--font-sans); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--accent-ink); margin:6px 0 10px; font-weight:800; }
.mega-col a, .mega-col a:link, .mega-col a:visited{ display:block; padding:7px 10px; border-radius:9px; font-size:.86rem; color:var(--ink-soft); font-weight:550; transition:background .2s, color .2s, transform .2s; }
.mega-col a:hover, .mega-col a:focus-visible{ background:rgba(21,33,27,.06); color:var(--ink); transform:translateX(3px); }
.mega-col a:active{ background:rgba(21,33,27,.1); color:var(--ink); transform:none; }
.mega-feature{ grid-column:span 1; background:linear-gradient(160deg,var(--forest),var(--forest-2)); color:#fff; border-radius:var(--r-md); padding:20px; display:flex; flex-direction:column; justify-content:space-between; min-height:160px; }
.mega-feature h4{ color:#fff; font-size:1.15rem; }
.mega-feature p{ color:rgba(255,255,255,.78); font-size:.84rem; margin:.4em 0 0; }

.burger{ display:none; width:46px; height:46px; border-radius:12px; border:1px solid var(--line); background:rgba(255,255,255,.5); position:relative; }
.burger span,.burger span::before,.burger span::after{ content:""; position:absolute; left:50%; top:50%; width:18px; height:2px; background:currentColor; border-radius:2px; transform:translate(-50%,-50%); transition:.3s; }
.burger span::before{ transform:translate(-50%,-7px); }
.burger span::after{ transform:translate(-50%,5px); }
body.menu-open .burger span{ background:transparent; }
body.menu-open .burger span::before{ transform:translate(-50%,-1px) rotate(45deg); }
body.menu-open .burger span::after{ transform:translate(-50%,-1px) rotate(-45deg); }

/* Mobile drawer */
.drawer{ position:fixed; inset:0; z-index:1090; background:var(--night); color:var(--on-night);
  transform:translateY(-100%); transition:transform .5s cubic-bezier(.7,0,.2,1); overflow-y:auto; padding:calc(var(--nav-h) + 20px) var(--gutter) 60px; }
body.menu-open .drawer{ transform:translateY(0); }
.drawer details{ border-bottom:1px solid var(--night-line); }
.drawer summary{ list-style:none; cursor:pointer; padding:16px 4px; font-family:var(--font-display); font-size:1.3rem; display:flex; justify-content:space-between; align-items:center; }
.drawer summary::-webkit-details-marker{ display:none; }
.drawer summary .pl{ color:var(--accent-2); transition:transform .3s; }
.drawer details[open] summary .pl{ transform:rotate(45deg); }
.drawer .sub{ padding:0 4px 14px; }
.drawer .sub a{ display:block; padding:9px 0; color:var(--on-night-soft); font-size:.96rem; }
.drawer .sub a:hover{ color:#fff; }
.drawer-cta{ margin-top:26px; display:flex; flex-direction:column; gap:12px; }

/* active nav state (current page / section) */
.nav-links > li > a, .nav-links > li > button{ position:relative; }
.nav-links > li.is-active > a, .nav-links > li.is-active > button,
.nav-links > li > a[aria-current="page"]{ color:var(--accent-ink); }
.nav-links > li.is-active > a::after, .nav-links > li.is-active > button::after{
  content:""; position:absolute; left:.7em; right:.7em; bottom:1px; height:2px; background:var(--accent); border-radius:2px; }
.nav.on-dark:not(.scrolled) .nav-links > li.is-active > a,
.nav.on-dark:not(.scrolled) .nav-links > li.is-active > button{ color:#fff; }
.nav.on-dark:not(.scrolled) .nav-links > li.is-active > a::after,
.nav.on-dark:not(.scrolled) .nav-links > li.is-active > button::after{ background:var(--gold); }
.mega-col a[aria-current="page"],
.mega-col a[aria-current="page"]:link,
.mega-col a[aria-current="page"]:visited,
.mega-col a[aria-current="page"]:hover,
.mega-col a[aria-current="page"]:focus-visible{
  background:var(--accent-glow); color:var(--ink); font-weight:700; box-shadow:inset 3px 0 0 var(--accent); transform:none;
}
.mega-feature[aria-current="page"]{ box-shadow:0 0 0 2px var(--accent) inset; }

/* mobile drawer — parent link + toggle pattern */
.drawer-personas{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:22px; }
.drawer-personas .pill{ background:rgba(255,255,255,.05); border-color:var(--night-line); color:var(--gold-soft); }
.drawer-personas .pill:hover{ color:#fff; border-color:var(--gold); }
.drawer-item{ border-bottom:1px solid var(--night-line); }
.drawer-row{ display:flex; align-items:center; }
.drawer-parent{ flex:1; padding:15px 4px; font-family:var(--font-display); font-size:1.22rem; color:var(--on-night); }
.drawer-parent:hover{ color:#fff; }
.drawer-item.is-active .drawer-parent{ color:var(--accent-2); }
.drawer-toggle{ width:48px; height:48px; flex:none; background:none; border:none; color:var(--accent-2); display:grid; place-items:center; border-radius:10px; }
.drawer-toggle:hover{ background:rgba(255,255,255,.06); }
.drawer-toggle .pl{ position:relative; display:block; width:16px; height:16px; }
.drawer-toggle .pl::before, .drawer-toggle .pl::after{ content:""; position:absolute; background:currentColor; border-radius:2px; }
.drawer-toggle .pl::before{ left:0; right:0; top:7px; height:2px; }
.drawer-toggle .pl::after{ top:0; bottom:0; left:7px; width:2px; transition:opacity .3s, transform .3s; }
.drawer-toggle[aria-expanded="true"] .pl::after{ opacity:0; transform:rotate(90deg); }
.drawer-sub{ padding:2px 4px 16px; }
.drawer-sub[hidden]{ display:none; }
.drawer-sub a{ display:block; padding:9px 0 9px 0; color:var(--on-night-soft); font-size:.96rem; transition:color .2s, padding .2s; }
.drawer-sub a:hover{ color:#fff; }
.drawer-sub a[aria-current="page"]{ color:#fff; border-left:2px solid var(--accent); padding-left:10px; }

@media (max-width:1120px){
  .nav-links, .nav-actions .lang-toggle, .nav-actions .btn{ display:none; }
  .burger{ display:block; }
}

/* ---------- 7. Hero variants ---------- */
.hero{ position:relative; padding-top:calc(var(--nav-h) + clamp(40px,8vw,90px)); padding-bottom:clamp(56px,9vw,120px); overflow:hidden; }
.hero-art{ position:absolute; inset:0; z-index:0; }
.hero-art svg{ width:100%; height:100%; }
.hero .wrap{ position:relative; z-index:2; }
.hero-eyebrow{ margin-bottom:18px; }
.hero h1, .hero .display{ max-width:16ch; }
.hero .lead{ max-width:60ch; margin-top:1.1em; }
.hero-cta{ margin-top:34px; }

/* Variant A — cinematic dark, full art */
.hero-cinematic{ background:var(--night); color:var(--on-night); }
.hero-cinematic h1,.hero-cinematic .display{ color:#fff; }
.hero-cinematic .lead{ color:var(--on-night-soft); }
.hero-cinematic .hero-art{ opacity:.9; }
.hero-cinematic::after{ content:""; position:absolute; inset:0; z-index:1;
  background:radial-gradient(120% 90% at 80% 10%, transparent 30%, var(--night) 78%),
             linear-gradient(180deg, rgba(11,24,19,.2), rgba(11,24,19,.6)); }

/* Variant B — editorial light, split */
.hero-split .wrap{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(24px,4vw,60px); align-items:center; }
.hero-split .hero-visual{ aspect-ratio:4/3; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-md); border:1px solid var(--line); background:var(--paper-2); }
.hero-split .hero-visual svg{ width:100%; height:100%; display:block; }
@media (max-width:880px){ .hero-split .wrap{ grid-template-columns:1fr; } .hero-split .hero-visual{ aspect-ratio:16/10; order:-1; } }

/* Variant C — centered statement */
.hero-center{ text-align:center; }
.hero-center .wrap{ max-width:920px; }
.hero-center .hero-eyebrow{ justify-content:center; }
.hero-center h1,.hero-center .display{ max-width:none; margin-inline:auto; }
.hero-center .lead{ margin-inline:auto; }
.hero-center .hero-cta{ display:flex; justify-content:center; }

/* Variant D — minimal band (interior pages) */
.hero-band{ padding-top:calc(var(--nav-h) + clamp(50px,7vw,90px)); padding-bottom:clamp(36px,5vw,64px);
  background:linear-gradient(165deg,var(--forest-deep),var(--forest-2)); color:var(--on-night); }
.hero-band h1{ color:#fff; max-width:20ch; }
.hero-band .lead{ color:rgba(238,243,238,.82); }
.hero-band .hero-art{ opacity:.5; }
.hero-band::after{ content:""; position:absolute; inset:0; background:radial-gradient(100% 120% at 90% 0%, rgba(255,255,255,.07), transparent 60%); z-index:1; }
.hero-band .wrap{ z-index:2; }

.breadcrumb{ display:flex; flex-wrap:wrap; gap:.5em; align-items:center; font-size:.8rem; font-weight:600; margin-bottom:18px; opacity:.85; }
.breadcrumb a{ opacity:.8; transition:.2s; } .breadcrumb a:hover{ opacity:1; }
.breadcrumb .sep{ opacity:.45; }

/* Glass stat capsules over hero */
.hero-stats{ display:flex; flex-wrap:wrap; gap:14px; margin-top:40px; }
.hero-stat{ background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.16); backdrop-filter:blur(10px);
  border-radius:var(--r-md); padding:16px 20px; min-width:150px; }
.hero-stat b{ font-family:var(--font-display); font-size:1.7rem; display:block; color:#fff; }
.hero-stat span{ font-size:.76rem; color:var(--on-night-soft); letter-spacing:.04em; }
.hero-split .hero-stats .hero-stat,
.hero-center .hero-stat{ background:#fff; border-color:var(--line); box-shadow:var(--shadow-sm); }
.hero-split .hero-stat b,.hero-center .hero-stat b{ color:var(--forest); }
.hero-split .hero-stat span,.hero-center .hero-stat span{ color:var(--ink-faint); }

/* ---------- 8. Content Blocks ---------- */

/* prose */
.prose{ max-width:760px; }
.prose.wide{ max-width:880px; }
.prose p{ font-size:1.06rem; color:var(--ink-soft); }
.prose h3{ margin-top:1.6em; margin-bottom:.4em; }
.prose ul.dash li{ position:relative; padding-left:1.5em; margin-bottom:.7em; color:var(--ink-soft); }
.prose ul.dash li::before{ content:""; position:absolute; left:0; top:.62em; width:14px; height:2px; background:var(--accent); }

/* feature cards */
.card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:clamp(22px,2.6vw,32px);
  transition:transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .4s, border-color .4s; position:relative; overflow:hidden; height:100%; }
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:var(--accent-2); }
.card .ic{ width:52px; height:52px; border-radius:14px; display:grid; place-items:center; background:linear-gradient(150deg,var(--accent),var(--accent-ink)); color:#fff; margin-bottom:18px; }
.card .ic svg{ width:26px; height:26px; }
.card h3{ font-size:1.22rem; margin-bottom:.4em; }
.card h4{ font-size:1.05rem; margin-bottom:.35em; }
.card p{ color:var(--ink-soft); font-size:.96rem; margin:0; }
.card .kicker{ font-size:.72rem; font-weight:800; letter-spacing:.16em; text-transform:uppercase; color:var(--accent-ink); display:block; margin-bottom:10px; }
.card-num::before{ content:attr(data-num); position:absolute; top:14px; right:20px; font-family:var(--font-display);
  font-size:2.6rem; color:var(--accent-2); opacity:.5; }
.bg-night .card{ background:rgba(255,255,255,.04); border-color:var(--night-line); }
.bg-night .card:hover{ background:rgba(255,255,255,.07); }
.bg-night .card p{ color:var(--on-night-soft); }

/* link cards (navigation grids) */
.linkcard{ display:flex; flex-direction:column; gap:10px; background:#fff; border:1px solid var(--line);
  border-radius:var(--r-md); padding:24px; transition:.4s; height:100%; position:relative; overflow:hidden; }
.linkcard::after{ content:""; position:absolute; left:0; bottom:0; height:3px; width:0; background:var(--accent); transition:width .45s; }
.linkcard:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.linkcard:hover::after{ width:100%; }
.linkcard .lc-index{ font-family:var(--font-display); color:var(--accent-ink); font-size:.95rem; }
.linkcard h3{ font-size:1.18rem; }
.linkcard p{ color:var(--ink-soft); font-size:.92rem; margin:0; flex:1; }
.linkcard .go{ display:inline-flex; align-items:center; gap:.4em; font-weight:700; color:var(--accent-ink); font-size:.86rem; margin-top:6px; }
.linkcard:hover .go .arrow{ transform:translateX(4px); }
.linkcard .go .arrow{ transition:transform .3s; }

/* stat strip / counters */
.stats{ display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:clamp(20px,3vw,40px); }
.stat{ position:relative; }
.stat .num{ font-family:var(--font-display); font-weight:560; font-size:clamp(2.4rem,4.6vw,3.6rem); line-height:1; color:var(--forest); letter-spacing:-.02em; }
.bg-night .stat .num{ color:#fff; }
.stat .num .suf{ color:var(--accent); }
.stat .lbl{ margin-top:.6em; font-size:.92rem; color:var(--ink-soft); max-width:24ch; }
.bg-night .stat .lbl{ color:var(--on-night-soft); }
.stat::before{ content:""; display:block; width:32px; height:3px; background:var(--accent); margin-bottom:18px; border-radius:3px; }

/* two-column feature (text + art) */
.feature2{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,72px); align-items:center; }
.feature2.flip .f2-media{ order:2; }
.feature2 .f2-media{ border-radius:var(--r-lg); overflow:hidden; aspect-ratio:4/3; box-shadow:var(--shadow-md); border:1px solid var(--line); background:var(--paper-2); }
.feature2 .f2-media.tall{ aspect-ratio:4/3; }
.feature2 .f2-media svg{ width:100%; height:100%; display:block; }
@media (max-width:880px){ .feature2{ grid-template-columns:1fr; } .feature2 .f2-media{ aspect-ratio:16/10; order:-1 !important; } }

/* numbered steps / order flow */
.steps{ counter-reset:step; display:grid; gap:18px; }
.step{ counter-increment:step; display:grid; grid-template-columns:auto 1fr; gap:22px; align-items:start;
  background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:24px 28px; transition:.35s; }
.step:hover{ box-shadow:var(--shadow-md); transform:translateX(4px); }
.step .s-no{ font-family:var(--font-display); font-size:1.4rem; width:54px; height:54px; flex:none; border-radius:50%;
  display:grid; place-items:center; background:var(--forest); color:#fff; }
.step .s-no::before{ content:counter(step,decimal-leading-zero); }
.step h4{ margin-bottom:.3em; }
.step p{ margin:0; color:var(--ink-soft); font-size:.96rem; }

/* timeline */
.timeline{ position:relative; padding-left:36px; }
.timeline::before{ content:""; position:absolute; left:9px; top:6px; bottom:6px; width:2px; background:linear-gradient(var(--accent),transparent); }
.tl-item{ position:relative; margin-bottom:34px; }
.tl-item::before{ content:""; position:absolute; left:-32px; top:5px; width:14px; height:14px; border-radius:50%;
  background:var(--paper); border:3px solid var(--accent); box-shadow:0 0 0 4px var(--accent-glow); }
.tl-item .tl-phase{ font-size:.74rem; font-weight:800; letter-spacing:.16em; text-transform:uppercase; color:var(--accent-ink); }
.tl-item h4{ margin:.25em 0 .35em; }
.tl-item p{ color:var(--ink-soft); margin:0; }
.bg-night .timeline::before{ background:linear-gradient(var(--accent),transparent); }
.bg-night .tl-item::before{ background:var(--night); }
.bg-night .tl-item p{ color:var(--on-night-soft); }

/* table */
.tablewrap{ overflow-x:auto; border:1px solid var(--line); border-radius:var(--r-md); box-shadow:var(--shadow-sm); background:#fff; }
table.data{ width:100%; border-collapse:collapse; min-width:560px; }
table.data th,table.data td{ text-align:left; padding:16px 20px; border-bottom:1px solid var(--line-soft); vertical-align:top; font-size:.95rem; }
table.data thead th{ background:var(--forest); color:#fff; font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; font-weight:700; }
table.data tbody tr:last-child td{ border-bottom:none; }
table.data tbody tr:hover{ background:var(--paper-2); }
table.data .pct{ font-family:var(--font-display); font-size:1.5rem; color:var(--accent-ink); white-space:nowrap; }

/* accordion (FAQ / glossary) */
.accordion details{ border:1px solid var(--line); border-radius:var(--r-md); margin-bottom:12px; background:#fff; overflow:hidden; transition:.3s; }
.accordion details[open]{ box-shadow:var(--shadow-sm); border-color:var(--accent-2); }
.accordion summary{ list-style:none; cursor:pointer; padding:20px 26px; font-weight:650; font-size:1.02rem; display:flex; justify-content:space-between; gap:18px; align-items:center; }
.accordion summary::-webkit-details-marker{ display:none; }
.accordion summary .pl{ flex:none; width:26px; height:26px; border-radius:50%; border:1px solid var(--accent); color:var(--accent-ink); display:grid; place-items:center; transition:.3s; position:relative; }
.accordion summary .pl::before,.accordion summary .pl::after{ content:""; position:absolute; background:currentColor; border-radius:2px; }
.accordion summary .pl::before{ width:11px; height:2px; } .accordion summary .pl::after{ width:2px; height:11px; transition:.3s; }
.accordion details[open] summary .pl{ background:var(--accent); color:#fff; }
.accordion details[open] summary .pl::after{ transform:rotate(90deg); opacity:0; }
.accordion .acc-body{ padding:0 26px 22px; color:var(--ink-soft); font-size:.98rem; }
.accordion .acc-body p:last-child{ margin-bottom:0; }

/* callout / quote */
.callout{ background:linear-gradient(150deg,var(--forest),var(--forest-2)); color:#fff; border-radius:var(--r-lg); padding:clamp(30px,5vw,56px); position:relative; overflow:hidden; }
.callout::before{ content:"“"; position:absolute; right:30px; top:-10px; font-family:var(--font-display); font-size:10rem; color:rgba(255,255,255,.08); }
.callout .q{ font-family:var(--font-display); font-size:clamp(1.4rem,2.6vw,2.1rem); line-height:1.3; font-weight:480; max-width:24ch; }
.callout .cite{ margin-top:20px; font-size:.9rem; color:var(--gold-soft); font-weight:600; letter-spacing:.02em; }

.pledge{ border-left:3px solid var(--accent); padding:6px 0 6px 24px; font-family:var(--font-display); font-style:italic;
  font-size:clamp(1.15rem,2vw,1.5rem); line-height:1.4; color:var(--ink); }

/* pill list / tags */
.pills{ display:flex; flex-wrap:wrap; gap:10px; }
.pill{ display:inline-flex; align-items:center; gap:.5em; padding:.5em 1em; border-radius:100px;
  background:#fff; border:1px solid var(--line); font-size:.85rem; font-weight:600; color:var(--ink-soft); transition:.25s; }
.pill:hover{ border-color:var(--accent); color:var(--accent-ink); transform:translateY(-2px); }
.bg-night .pill{ background:rgba(255,255,255,.05); border-color:var(--night-line); color:var(--on-night-soft); }

/* definition / spec list */
.deflist{ display:grid; gap:0; border-top:1px solid var(--line); }
.deflist .row{ display:grid; grid-template-columns:.8fr 1.6fr; gap:24px; padding:20px 0; border-bottom:1px solid var(--line); }
.deflist dt{ font-weight:700; color:var(--ink); }
.deflist dd{ margin:0; color:var(--ink-soft); }
@media (max-width:640px){ .deflist .row{ grid-template-columns:1fr; gap:6px; } }

/* dashboard / metric cards */
.dash{ background:var(--night-2); border-radius:var(--r-lg); padding:clamp(22px,3vw,38px); color:var(--on-night); border:1px solid var(--night-line); }
.dash-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr)); gap:16px; }
.metric{ background:linear-gradient(160deg,rgba(255,255,255,.06),rgba(255,255,255,.02)); border:1px solid var(--night-line); border-radius:var(--r-md); padding:22px; position:relative; overflow:hidden; }
.metric .mlabel{ font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--on-night-soft); }
.metric .mval{ font-family:var(--font-display); font-size:clamp(1.8rem,3vw,2.5rem); color:#fff; margin-top:8px; line-height:1; }
.metric .mval .suf{ color:var(--accent-2); font-size:.6em; }
.metric .mtrend{ font-size:.78rem; margin-top:10px; color:var(--leaf); display:inline-flex; align-items:center; gap:.3em; }
.metric .spark{ position:absolute; right:0; bottom:0; left:0; height:40px; opacity:.5; }
.metric .spark path{ fill:none; stroke:var(--accent); stroke-width:2; }
.metric .live{ position:absolute; top:18px; right:18px; width:8px; height:8px; border-radius:50%; background:var(--leaf); box-shadow:0 0 0 0 rgba(47,155,110,.6); animation:pulse 2s infinite; }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(47,155,110,.5);} 70%{box-shadow:0 0 0 10px rgba(47,155,110,0);} 100%{box-shadow:0 0 0 0 rgba(47,155,110,0);} }

/* progress bars */
.bars{ display:grid; gap:18px; }
.bar-item .bar-top{ display:flex; justify-content:space-between; font-size:.9rem; margin-bottom:8px; font-weight:600; }
.bar-track{ height:10px; border-radius:100px; background:rgba(21,33,27,.08); overflow:hidden; }
.bg-night .bar-track{ background:rgba(255,255,255,.1); }
.bar-fill{ height:100%; width:0; border-radius:100px; background:linear-gradient(90deg,var(--accent),var(--accent-ink)); transition:width 1.6s cubic-bezier(.2,.8,.2,1); }

/* equity donut */
.ownership{ display:grid; grid-template-columns:auto 1fr; gap:40px; align-items:center; }
@media(max-width:720px){ .ownership{ grid-template-columns:1fr; } }
.donut{ width:240px; height:240px; }
.legend{ display:grid; gap:14px; }
.legend .li{ display:grid; grid-template-columns:auto auto 1fr; gap:14px; align-items:baseline; padding-bottom:14px; border-bottom:1px solid var(--line); }
.legend .sw{ width:14px; height:14px; border-radius:4px; align-self:center; }
.legend .pc{ font-family:var(--font-display); font-size:1.5rem; }
.legend .nm b{ display:block; } .legend .nm span{ font-size:.86rem; color:var(--ink-soft); }

/* map / constituency */
.mapsearch{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(24px,3vw,40px); box-shadow:var(--shadow-sm); }
.searchbox{ display:flex; gap:10px; flex-wrap:wrap; margin-top:18px; }
.searchbox input,.searchbox select{ flex:1; min-width:150px; padding:.85em 1.1em; border:1px solid var(--line); border-radius:100px; font-family:inherit; font-size:.95rem; background:var(--paper); }
.searchbox input:focus,.searchbox select:focus{ outline:none; border-color:var(--accent); }

/* CTA band */
.cta-band{ background:linear-gradient(135deg,var(--forest-deep),var(--forest-2) 60%,var(--moss)); color:#fff; border-radius:var(--r-xl); padding:clamp(38px,6vw,80px); text-align:center; position:relative; overflow:hidden; }
.cta-band h2{ color:#fff; max-width:18ch; margin-inline:auto; }
.cta-band .lead{ color:rgba(255,255,255,.82); max-width:52ch; margin:1em auto 0; }
.cta-band .btn-row{ justify-content:center; margin-top:30px; }
.cta-band .grain{ position:absolute; inset:0; opacity:.4; }

/* notice / disclaimer box */
.notice{ border:1px dashed var(--line); border-radius:var(--r-md); padding:22px 26px; background:var(--paper-2); font-size:.92rem; color:var(--ink-soft); }
.notice strong{ color:var(--ink); }

/* logos / partner strip */
.logostrip{ display:flex; flex-wrap:wrap; gap:14px; }
.logochip{ display:inline-flex; align-items:center; gap:.6em; padding:.7em 1.2em; border:1px solid var(--line); border-radius:12px; background:#fff; font-weight:650; font-size:.9rem; color:var(--ink-soft); }
.logochip .dot{ width:10px; height:10px; border-radius:50%; background:var(--accent); }
.bg-night .logochip{ background:rgba(255,255,255,.04); border-color:var(--night-line); color:var(--on-night-soft); }

/* media / figures (scene images) */
figure.fig{ margin:0; }
.media{ position:relative; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow-md); background:var(--paper-2); }
.media svg{ width:100%; height:100%; display:block; }
.media.wide{ aspect-ratio:16/9; }
.media.short{ aspect-ratio:21/9; }
.media.square{ aspect-ratio:4/3; }
.media .media-cap{ position:absolute; left:0; right:0; bottom:0; padding:clamp(16px,2.4vw,26px); color:#fff;
  background:linear-gradient(transparent, rgba(8,18,14,.78)); }
.media .media-cap b{ display:block; font-family:var(--font-display); font-size:clamp(1.05rem,2vw,1.4rem); color:#fff; }
.media .media-cap span{ font-size:.84rem; color:rgba(255,255,255,.82); }
.bg-night .media{ border-color:var(--night-line); }
figure.fig figcaption{ margin-top:12px; font-size:.84rem; color:var(--ink-faint); display:flex; gap:.55em; align-items:flex-start; font-style:italic; }
figure.fig figcaption::before{ content:""; width:18px; height:2px; background:var(--accent); flex:none; margin-top:.6em; }
.bg-night figure.fig figcaption{ color:var(--on-night-soft); }

/* ---------- 9. Footer ---------- */
.footer{ background:var(--night); color:var(--on-night-soft); padding-top:clamp(56px,7vw,90px); }
.footer a{ transition:.2s; }
.footer a:hover{ color:#fff; }
.f-top{ display:grid; grid-template-columns:1.4fr repeat(4,1fr); gap:40px 30px; padding-bottom:50px; border-bottom:1px solid var(--night-line); }
@media(max-width:1024px){ .f-top{ grid-template-columns:1fr 1fr; } }
@media(max-width:560px){ .f-top{ grid-template-columns:1fr; } }
.f-brand .brand-text b{ color:#fff; }
.f-brand p{ margin-top:16px; font-size:.92rem; max-width:34ch; }
.f-newsletter{ margin-top:22px; }
.f-newsletter form{ display:flex; gap:8px; background:rgba(255,255,255,.06); border:1px solid var(--night-line); border-radius:100px; padding:5px 5px 5px 18px; max-width:340px; }
.f-newsletter input{ flex:1; background:none; border:none; color:#fff; font-family:inherit; font-size:.9rem; }
.f-newsletter input::placeholder{ color:var(--on-night-soft); }
.f-newsletter button{ border:none; border-radius:100px; padding:.6em 1em; background:var(--gold); color:#231c08; font-weight:700; }
.f-col h6{ color:#fff; font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; margin:0 0 16px; font-weight:800; }
.f-col a{ display:block; padding:6px 0; font-size:.9rem; }
.f-trust{ display:flex; flex-wrap:wrap; gap:12px; padding:26px 0; border-bottom:1px solid var(--night-line); }
.f-badge{ display:inline-flex; align-items:center; gap:.5em; font-size:.76rem; color:var(--on-night-soft); border:1px solid var(--night-line); border-radius:100px; padding:.5em .9em; }
.f-badge .dot{ width:7px; height:7px; border-radius:50%; background:var(--leaf); }
.f-social{ display:flex; gap:10px; }
.f-social a{ width:40px; height:40px; border-radius:50%; border:1px solid var(--night-line); display:grid; place-items:center; }
.f-social a:hover{ background:var(--gold); color:#231c08; border-color:var(--gold); transform:translateY(-3px); }
.f-social svg{ width:18px; height:18px; }
.f-bottom{ display:flex; flex-wrap:wrap; gap:18px; justify-content:space-between; align-items:center; padding:26px 0 40px; font-size:.84rem; }
.f-contact{ display:flex; flex-wrap:wrap; gap:18px; }
.f-contact a{ color:var(--on-night); border-bottom:1px solid transparent; }
.f-contact a:hover{ border-color:var(--gold); }
.f-credit{ font-size:.84rem; }
.f-credit a{ color:var(--gold-soft); font-weight:700; }
.f-legal-links{ display:flex; flex-wrap:wrap; gap:16px; }

/* ---------- 10. Motion / reveal ---------- */
[data-reveal]{ opacity:0; transform:translateY(26px); transition:opacity .9s cubic-bezier(.2,.8,.2,1), transform .9s cubic-bezier(.2,.8,.2,1); will-change:opacity,transform; }
[data-reveal].in{ opacity:1; transform:none; }
[data-reveal="left"]{ transform:translateX(-30px); } [data-reveal="left"].in{ transform:none; }
[data-reveal="right"]{ transform:translateX(30px); } [data-reveal="right"].in{ transform:none; }
[data-reveal="scale"]{ transform:scale(.94); } [data-reveal="scale"].in{ transform:none; }
[data-stagger] > *{ opacity:0; transform:translateY(24px); transition:opacity .8s, transform .8s; }
[data-stagger].in > *{ opacity:1; transform:none; }
.parallax{ will-change:transform; }
@media (prefers-reduced-motion: reduce){
  [data-reveal],[data-stagger] > *{ opacity:1 !important; transform:none !important; transition:none !important; }
  .metric .live{ animation:none; }
}

/* grain + glow overlays */
.grain{ pointer-events:none; 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='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E"); mix-blend-mode:overlay; opacity:.06; }
.glow{ position:absolute; border-radius:50%; filter:blur(70px); pointer-events:none; z-index:0; }

/* ---------- 11. Utilities ---------- */
.center{ text-align:center; }
.mt-0{ margin-top:0; } .mb-0{ margin-bottom:0; }
.mt-2{ margin-top:1.5rem; } .mt-3{ margin-top:2.4rem; } .mt-4{ margin-top:3.4rem; }
.muted{ color:var(--ink-faint); }
.maxw-60{ max-width:60ch; } .maxw-50{ max-width:50ch; }
.flex{ display:flex; } .between{ justify-content:space-between; } .items-center{ align-items:center; }
.gap-1{ gap:8px; } .gap-2{ gap:16px; } .gap-3{ gap:24px; } .flexwrap{ flex-wrap:wrap; }
.relative{ position:relative; } .z2{ position:relative; z-index:2; }
.tag{ display:inline-block; font-size:.72rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--accent-ink); background:var(--accent-glow); padding:.4em .8em; border-radius:100px; }
.hr{ height:1px; background:var(--line); border:none; margin-block:clamp(40px,6vw,72px); }
.imgcap{ font-size:.8rem; color:var(--ink-faint); margin-top:10px; text-align:center; font-style:italic; }
.col-span-2{ grid-column:span 2; } @media(max-width:620px){ .col-span-2{ grid-column:auto; } }

/* page progress bar */
.progress{ position:fixed; top:0; left:0; height:3px; width:0; background:linear-gradient(90deg,var(--gold),var(--leaf)); z-index:1200; transition:width .1s linear; }

/* back to top */
.totop{ position:fixed; right:22px; bottom:22px; width:48px; height:48px; border-radius:50%; background:var(--forest); color:#fff; border:none; display:grid; place-items:center; box-shadow:var(--shadow-md); opacity:0; transform:translateY(20px); pointer-events:none; transition:.4s; z-index:900; }
.totop.show{ opacity:1; transform:none; pointer-events:auto; }
.totop:hover{ background:var(--moss); }

/* ---------- 12. Responsive refinements (tablet / mobile / small) ---------- */
@media (max-width:1120px){
  .hero-stats{ gap:10px; }
  .mega{ display:none; } /* mega is desktop-only; drawer covers tablet/mobile */
}
@media (max-width:760px){
  :root{ --nav-h:64px; }
  .hero{ padding-top:calc(var(--nav-h) + 36px); }
  .hero h1,.hero .display{ max-width:none; }
  .display{ font-size:clamp(2.1rem,8.5vw,3rem); }
  .hero-stat{ min-width:0; flex:1 1 42%; }
  .hero-stat b{ font-size:1.35rem; }
  .feature2{ gap:26px; }
  .step{ padding:20px; gap:16px; }
  .step .s-no{ width:46px; height:46px; font-size:1.15rem; }
  .callout::before{ font-size:7rem; right:14px; }
  .ownership{ gap:26px; }
  .donut{ width:200px; height:200px; margin-inline:auto; }
  .deflist .row{ grid-template-columns:1fr; gap:4px; }
  .f-bottom{ flex-direction:column; align-items:flex-start; }
}
@media (max-width:480px){
  :root{ --gutter:18px; }
  .hero-cta.btn-row{ flex-direction:column; align-items:stretch; }
  .hero-cta .btn{ justify-content:center; width:100%; }
  .cta-band .btn-row{ flex-direction:column; }
  .cta-band .btn{ justify-content:center; }
  .searchbox{ flex-direction:column; }
  .searchbox input,.searchbox select,.searchbox .btn{ width:100%; }
  .hero-stat{ flex:1 1 100%; }
  .lead{ font-size:1.08rem; }
  table.data th,table.data td{ padding:12px 14px; }
  .drawer summary{ font-size:1.15rem; }
}
/* very wide screens — keep content centred and comfortable */
@media (min-width:1700px){ :root{ --maxw:1320px; } }

/* print */
@media print{
  .nav,.drawer,.totop,.progress,.cta-band,.hero-art{ display:none !important; }
  body{ color:#000; background:#fff; }
}

/* ---------- 13. Smooth page transitions ---------- */
@view-transition{ navigation: auto; }
@media (prefers-reduced-motion: no-preference){
  body{ animation: pageIn .4s ease both; }
  @keyframes pageIn{ from{ opacity:0; } to{ opacity:1; } }
}
