/* ============================================================================
   Clear Cited — shared stylesheet for the multipage site.

   BRAND RECAST (dark-mode-first): premium near-black surfaces + one electric-blue
   accent, Geist (UI/headings) + JetBrains Mono (every metric/prompt/code), sharp
   1px hairlines (no blurred shadows), editorial whitespace. Merged from the
   finalized Clear Cited Design System — :root names and component class names from
   the prior light-only sheet are PRESERVED so every existing page keeps working.

   Dark is the default (:root). Add `.theme-light` or [data-theme="light"] to
   <html>/<body> for the clean light/print brand.

   Fonts are SELF-HOSTED (assets/fonts/*.woff2, @font-face below) — no CDN
   dependency; remove any Google/Bunny Fonts <link> from page <head>.
   ============================================================================ */

/* ============================================================================
   WEBFONTS — self-hosted (Geist UI/headings · JetBrains Mono metrics/code)
   ============================================================================ */
@font-face{font-family:"Geist";font-style:normal;font-weight:400;font-display:swap;src:url("assets/fonts/Geist-Regular.woff2") format("woff2")}
@font-face{font-family:"Geist";font-style:normal;font-weight:500;font-display:swap;src:url("assets/fonts/Geist-Medium.woff2") format("woff2")}
@font-face{font-family:"Geist";font-style:normal;font-weight:600;font-display:swap;src:url("assets/fonts/Geist-SemiBold.woff2") format("woff2")}
@font-face{font-family:"Geist";font-style:normal;font-weight:700;font-display:swap;src:url("assets/fonts/Geist-Bold.woff2") format("woff2")}
@font-face{font-family:"Geist";font-style:normal;font-weight:800;font-display:swap;src:url("assets/fonts/Geist-ExtraBold.woff2") format("woff2")}
@font-face{font-family:"JetBrains Mono";font-style:normal;font-weight:400;font-display:swap;src:url("assets/fonts/JetBrainsMono-Regular.woff2") format("woff2")}
@font-face{font-family:"JetBrains Mono";font-style:normal;font-weight:500;font-display:swap;src:url("assets/fonts/JetBrainsMono-Medium.woff2") format("woff2")}
@font-face{font-family:"JetBrains Mono";font-style:normal;font-weight:600;font-display:swap;src:url("assets/fonts/JetBrainsMono-SemiBold.woff2") format("woff2")}

/* ============================================================================
   TOKENS — dark-mode-first (:root). Legacy names kept; new names added.
   ============================================================================ */
:root{
  /* ---- elevation ramp (ascending = closer to viewer) ---- */
  --surface-0:#0a0e13;     /* page canvas — near-black                         */
  --surface-1:#11161d;     /* card / default raised panel                      */
  --surface-2:#161d27;     /* raised: hover, secondary panels, active rows     */
  --surface-3:#1f2731;     /* popover / menu / tooltip — highest               */
  --well:#070a0e;          /* sunken inset: code, inputs, table head, tracks   */
  /* legacy aliases */
  --bg:var(--surface-0); --surface:var(--surface-1);
  --soft:#0f151c;          /* subtle section band (dark cousin of #f4f7fb)     */

  /* ---- text ---- */
  --ink:#e9eef4;           /* PRIMARY TEXT — 16.6:1 on --bg                    */
  --muted:#94a2b0;         /* secondary — 7.4:1                                */
  --faint:#65727f;         /* tertiary — 3.9:1 (UI/large only)                 */

  /* ---- lines / borders (sharp 1px, no blur) ---- */
  --line:#1e2630; --line-2:#2a333e;

  /* ---- brand: one restrained electric blue ---- */
  --brand:#3b82f6; --brand-strong:#5c9cff; --brandink:#a9c8ff;
  --brand-tint:rgba(59,130,246,.14); --brand-tint-2:rgba(59,130,246,.10);
  --brand-faint:rgba(59,130,246,.07); --on-brand:#ffffff;
  /* Filled-button background: a deeper blue so WHITE label text clears WCAG AA
     (white on #3b82f6 is only 3.68:1; #2563eb=5.17:1, hover #1e5fd6=5.73:1). The
     brand accent itself stays #3b82f6 for text/emblem/links. */
  --btn:#2563eb; --btn-hover:#1e5fd6;

  /* ---- state (always paired with dot + label) ---- */
  --ok:#34d399; --warn:#f5b545; --danger:#f87171;
  --ok-tint:rgba(52,211,153,.14); --warn-tint:rgba(245,181,69,.14); --danger-tint:rgba(248,113,113,.14);

  /* ---- data-viz language (one chart style everywhere) ---- */
  --grid:var(--line); --bar-track:var(--well); --bar-you:var(--brand);
  --bar-other:#39434f; --tick:var(--ink); --band:rgba(59,130,246,.16);

  /* ---- focus / glow ---- */
  --ring:rgba(59,130,246,.45); --glow:rgba(59,130,246,.06);

  /* ---- type ---- */
  --sans:"Geist",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,"Liberation Mono",monospace;
  --fw-reg:400; --fw-med:500; --fw-semi:600; --fw-bold:700; --fw-black:800;
  --fs-display:clamp(40px,6vw,76px); --fs-h1:clamp(32px,4.6vw,52px);
  --fs-h2:clamp(25px,3.2vw,36px); --fs-h3:clamp(19px,2vw,22px); --fs-h4:16px;
  --fs-lead:clamp(17px,1.7vw,20px); --fs-body:16px; --fs-small:13px; --fs-eyebrow:12px;
  --fs-metric-xl:clamp(44px,5vw,64px); --fs-metric:clamp(28px,3vw,40px);
  --fs-metric-sm:20px; --fs-mono:13px;
  --lh-body:1.6; --lh-tight:1.12; --lh-snug:1.3; --lh-metric:1.0;
  --tr-display:-.035em; --tr-tight:-.02em; --tr-eyebrow:.14em;

  /* ---- spacing / radii / motion / layout ---- */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px; --s-6:32px;
  --s-7:48px; --s-8:64px; --s-9:96px; --s-10:128px;
  --space:24px; --gap:18px; --section-y:clamp(48px,7vw,104px);
  --maxw:1120px; --measure:68ch; --measure-narrow:60ch;
  --radius:10px; --radius-sm:6px; --radius-lg:14px; --radius-pill:999px;
  --dur-1:120ms; --dur-2:200ms; --dur-3:340ms;
  --ease-out:cubic-bezier(.22,.61,.36,1); --ease-in-out:cubic-bezier(.65,0,.35,1);
  --ease-spring:cubic-bezier(.34,1.4,.64,1);

  color-scheme:dark;
}

/* ============================================================================
   LIGHT / PRINT THEME — the clean brand (.theme-light / [data-theme="light"]).
   ============================================================================ */
.theme-light,[data-theme="light"]{
  --surface-0:#ffffff; --surface-1:#ffffff; --surface-2:#f4f7fb; --surface-3:#ffffff;
  --well:#eef2f7; --bg:var(--surface-0); --surface:var(--surface-1); --soft:#f4f7fb;
  --ink:#0f1720; --muted:#5b6b7a; --faint:#8a98a6;
  --line:#e4ebf2; --line-2:#d3dde9;
  --brand:#155fd1; --brand-strong:#0b3d91; --brandink:#0b3d91;
  --brand-tint:#eaf1fe; --brand-tint-2:#eef4fe; --brand-faint:#f4f8ff; --on-brand:#ffffff;
  --ok:#0a7d4d; --warn:#b4690e; --danger:#c23b3b;
  --ok-tint:#e6f6ee; --warn-tint:#fbf0e0; --danger-tint:#fbeaea;
  --grid:var(--line); --bar-track:#eef2f7; --bar-you:var(--brand); --bar-other:#c2cedb;
  --tick:var(--ink); --band:rgba(21,95,209,.14);
  --ring:rgba(21,95,209,.30); --glow:rgba(21,95,209,.05);
  --btn:#155fd1; --btn-hover:#0b3d91;   /* light: white-on-#155fd1 = 5.85:1 (AA) */
  color-scheme:light;
}

/* ============================================================================
   BASE / element typography
   ============================================================================ */
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;font-family:var(--sans);font-size:var(--fs-body);font-weight:var(--fw-reg);line-height:var(--lh-body);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-feature-settings:"ss01","cv01"}

h1,h2,h3,h4,h5{font-family:var(--sans);color:var(--ink);line-height:var(--lh-tight);letter-spacing:var(--tr-tight);text-wrap:balance;margin:0 0 var(--s-4)}
h1{font-size:var(--fs-h1);font-weight:var(--fw-bold);letter-spacing:var(--tr-display)}
h2{font-size:var(--fs-h2);font-weight:var(--fw-bold)}
h3{font-size:var(--fs-h3);font-weight:var(--fw-semi);margin-bottom:var(--s-2)}
h4{font-size:var(--fs-h4);font-weight:var(--fw-semi);margin-bottom:var(--s-2)}
.display{font-size:var(--fs-display);font-weight:var(--fw-bold);letter-spacing:var(--tr-display);line-height:1.02;margin:0 0 var(--s-4)}
p{margin:0 0 var(--s-4);max-width:var(--measure)}
ul,ol{margin:0 0 var(--s-4);padding-left:22px;max-width:var(--measure)}
li{margin:0 0 var(--s-2);line-height:var(--lh-body)}
li>ul,li>ol{margin-top:var(--s-2)}
strong,b{font-weight:var(--fw-semi);color:var(--ink)}
em{font-style:italic}
hr{border:0;border-top:1px solid var(--line);margin:var(--s-6) 0}
img{max-width:100%;height:auto}
::selection{background:var(--brand);color:#fff}

code,kbd,samp,pre{font-family:var(--mono)}
:not(pre)>code{background:var(--brand-tint);color:var(--brand-strong);padding:1px 6px;border-radius:5px;font-size:.9em;font-weight:var(--fw-med)}
kbd{background:var(--well);border:1px solid var(--line);border-bottom-width:2px;border-radius:5px;padding:1px 6px;color:var(--ink);font-size:.85em}
pre{overflow:auto;background:var(--well);border:1px solid var(--line);border-radius:var(--radius);padding:var(--s-4);font-size:var(--fs-mono);line-height:1.6;color:var(--ink)}
pre code{background:none;color:inherit;padding:0;font-weight:var(--fw-reg)}
.mono{font-family:var(--mono);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}

a{color:var(--brand);text-decoration:none;transition:color var(--dur-1) var(--ease-out)}
a:hover{color:var(--brand-strong)}
.prose a:not(.btn),main p a:not(.btn),section p a:not(.btn),main li a:not(.btn),
.lead a:not(.btn),.answer a:not(.btn),.band a:not(.btn){text-decoration:underline;text-underline-offset:2px;text-decoration-color:color-mix(in srgb,var(--brand) 45%,transparent)}

/* ---- accessibility utilities ---- */
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:-9999px;top:0;z-index:1000;background:var(--brand);color:var(--on-brand);padding:10px 16px;border-radius:0 0 8px 0;font-weight:600}
.skip-link:focus{left:0;text-decoration:none;outline:3px solid var(--brand-strong);outline-offset:-3px}
:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:3px}
.btn:focus-visible,a.btn:focus-visible,nav a.cta:focus-visible{outline-offset:3px}

/* ---- layout helpers ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.measure{max-width:var(--measure)}
.measure-narrow{max-width:var(--measure-narrow)}
.full-measure{max-width:none}
.tnum{font-variant-numeric:tabular-nums}
.right{margin-left:auto}
[hidden]{display:none!important}
section{padding:var(--section-y) 0;border-top:1px solid var(--line)}

/* ---- eyebrow / lead / sub / hero ---- */
.eyebrow{display:inline-block;font-size:var(--fs-eyebrow);font-weight:var(--fw-bold);letter-spacing:var(--tr-eyebrow);text-transform:uppercase;color:var(--brand);margin:0 0 var(--s-3)}
.eyebrow+h1,.eyebrow+h2{margin-top:0}
.lead,.lede{color:var(--muted);max-width:var(--measure);font-size:var(--fs-lead);line-height:1.55;font-weight:var(--fw-reg)}
.sub{font-size:var(--fs-lead);line-height:1.55;color:var(--muted);max-width:min(640px,var(--measure));margin:0 0 var(--s-5);font-weight:var(--fw-reg)}
p.big{font-size:clamp(19px,2vw,24px);line-height:1.45;max-width:var(--measure)}
.small,.hint{font-size:var(--fs-small);color:var(--muted);line-height:1.5}
.muted{color:var(--muted)}
.faint{color:var(--faint)}
.hero{padding:clamp(48px,8vw,88px) 0 var(--s-6)}

/* ============================================================================
   COMPONENTS
   ============================================================================ */

/* ---- Buttons ---- */
.btn,a.btn,button.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--sans);font-weight:var(--fw-semi);font-size:15px;line-height:1;background:var(--btn);color:var(--on-brand);padding:12px 18px;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;text-align:center;text-decoration:none;white-space:nowrap;-webkit-appearance:none;appearance:none;transition:background var(--dur-1) var(--ease-out),transform var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out)}
.btn:hover,a.btn:hover,button.btn:hover{background:var(--btn-hover);color:var(--on-brand);text-decoration:none}
.btn:active,a.btn:active,button.btn:active{transform:translateY(1px)}
.btn.alt,a.btn.alt,button.btn.alt{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn.alt:hover,a.btn.alt:hover,button.btn.alt:hover{background:var(--surface);border-color:var(--ink);color:var(--ink)}
.btn.ghost,a.btn.ghost,button.btn.ghost{background:transparent;color:var(--muted);border-color:transparent;padding-left:10px;padding-right:10px}
.btn.ghost:hover{color:var(--ink);background:var(--surface)}
.btn.sm{padding:8px 12px;font-size:13px;border-radius:var(--radius-sm)}
.btn.lg{padding:15px 24px;font-size:16px}
.btn:disabled,button.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
p .btn{margin:4px 8px 4px 0}

/* ---- Header / nav ---- */
header.site{position:sticky;top:0;z-index:20;background:color-mix(in srgb,var(--bg) 86%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:14px;padding-bottom:14px}
header.site nav{display:flex;align-items:center;gap:22px;flex-wrap:wrap;justify-content:flex-end}
header.site nav a{color:var(--muted);font-size:14px;font-weight:var(--fw-med)}
header.site nav a:hover{color:var(--ink);text-decoration:none}
header.site nav a[aria-current="page"]{color:var(--ink);font-weight:var(--fw-semi)}
nav a.cta{background:var(--btn);color:var(--on-brand);padding:9px 14px;border-radius:var(--radius-sm);font-weight:var(--fw-semi);font-size:14px}
nav a.cta:hover{background:var(--btn-hover);color:var(--on-brand);text-decoration:none}
/* Resources dropdown — native <details> disclosure (keyboard-accessible). */
.nav-dd{position:relative;border:0;padding:0;margin:0;background:none}
.nav-dd>summary{list-style:none;cursor:pointer;color:var(--muted);font-size:14px;font-weight:var(--fw-med);display:inline-flex;align-items:center;gap:5px;padding:0}
.nav-dd>summary::-webkit-details-marker{display:none}
.nav-dd>summary::after{content:"▾";font-size:10px;color:var(--faint)}
.nav-dd>summary:hover{color:var(--ink)}
.nav-dd[open]>summary{color:var(--ink)}
.nav-dd .dd-panel{position:absolute;top:calc(100% + 12px);right:0;min-width:210px;background:var(--surface-1);border:1px solid var(--line);border-radius:var(--radius);padding:8px;display:flex;flex-direction:column;gap:2px;z-index:30}
.nav-dd .dd-panel a{color:var(--muted);font-size:14px;padding:8px 10px;border-radius:var(--radius-sm);margin:0}
.nav-dd .dd-panel a:hover{color:var(--ink);background:var(--surface-2);text-decoration:none}
@media(max-width:860px){
  .nav-dd{width:100%}
  .nav-dd>summary{padding:9px 0;font-size:15px}
  .nav-dd .dd-panel{position:static;border:0;padding:2px 0 6px 14px;min-width:0;background:none}
}
/* text wordmark (until the SVG lockup is dropped in per page) */
.logo{font-family:var(--sans);font-weight:800;font-size:20px;letter-spacing:-.03em;color:var(--ink);white-space:nowrap;display:inline-flex;align-items:center;flex:0 0 auto}
.logo b{color:var(--brand);font-weight:800}
.logo img{height:26px;width:auto;display:block}
header.site .brand{display:inline-flex;align-items:center;flex:0 0 auto}
/* mobile menu (when .site-nav + .nav-toggle present) */
.nav-toggle{display:none;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-1);color:var(--ink);cursor:pointer}
.nav-toggle:hover{border-color:var(--line-2)}
@media(max-width:860px){
  .nav-toggle{display:inline-flex}
  header.site .site-nav{position:absolute;top:100%;left:0;right:0;display:none;flex-direction:column;align-items:stretch;gap:4px;background:var(--surface-1);border-bottom:1px solid var(--line);border-top:1px solid var(--line);padding:14px 24px 18px;justify-content:flex-start}
  header.site .site-nav.open{display:flex}
  header.site .site-nav a{padding:9px 0;font-size:15px}
  header.site .site-nav a.cta{text-align:center;padding:11px 14px;margin-top:6px}
  header.site .wrap{position:relative}
}
/* legacy non-.site-nav header: stack nav on small screens */
@media(max-width:720px){
  header.site nav:not(.site-nav){width:100%;justify-content:flex-start;margin-top:4px;gap:16px}
  header.site nav:not(.site-nav) a{font-size:14px}
  .logo{font-size:18px}
}

/* ---- Cards / grids ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--gap)}
.grid.three{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--gap)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;transition:border-color var(--dur-2) var(--ease-out),background var(--dur-2) var(--ease-out)}
.card.hover:hover,a.card:hover{border-color:var(--line-2)}
.card h3{margin-top:0}
.card p:last-child{margin-bottom:0}
.card p+p{margin-top:10px}
.card .muted,p.muted{color:var(--muted)}

/* ---- Answer / band / pullstat ---- */
.answer{background:var(--soft);border:1px solid var(--line);border-left:3px solid var(--brand);padding:var(--s-4) var(--s-5);border-radius:var(--radius-sm);margin:var(--s-5) 0;font-size:16px;line-height:var(--lh-body);max-width:var(--measure)}
.answer p{max-width:none;margin-bottom:var(--s-3)}
.answer p:last-child{margin-bottom:0}
.answer strong{color:var(--ink)}
.band{background:var(--soft);border:1px solid var(--line);border-radius:var(--radius);padding:var(--s-6);text-align:center;margin-top:var(--s-5)}
.band p{max-width:none;margin-left:auto;margin-right:auto}
.band a:last-child{margin-bottom:0}
.pullstat{font-size:20px;line-height:1.5;font-weight:var(--fw-med);color:var(--ink);border:1px solid var(--line);border-left:3px solid var(--brand);background:var(--soft);padding:var(--s-4) var(--s-5);border-radius:var(--radius-sm);margin:var(--s-5) 0;max-width:var(--measure)}

/* ---- Tag / badge ---- */
.tag{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-eyebrow);font-weight:var(--fw-bold);letter-spacing:.06em;text-transform:uppercase;color:var(--brand);background:var(--brand-tint);border-radius:var(--radius-pill);padding:4px 11px;margin-bottom:var(--s-2)}
.badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:var(--fw-semi);letter-spacing:.01em;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-pill);padding:3px 10px}
.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex:0 0 auto}
.badge.ok{color:var(--ok);border-color:color-mix(in srgb,var(--ok) 35%,var(--line));background:var(--ok-tint)}
.badge.warn{color:var(--warn);border-color:color-mix(in srgb,var(--warn) 35%,var(--line));background:var(--warn-tint)}
.badge.danger{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 35%,var(--line));background:var(--danger-tint)}
.badge.brand{color:var(--brand);border-color:color-mix(in srgb,var(--brand) 35%,var(--line));background:var(--brand-tint)}

/* ---- Metrics / scores ---- */
.gauge,.big{font-family:var(--mono);font-size:var(--fs-metric-xl);font-weight:var(--fw-bold);color:var(--brand);line-height:var(--lh-metric);letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.num{font-family:var(--mono);font-size:var(--fs-metric);font-weight:var(--fw-bold);color:var(--brand);line-height:1;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.metric-label{font-size:var(--fs-small);color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:var(--fw-semi)}
.price{font-weight:var(--fw-bold);white-space:nowrap;font-variant-numeric:tabular-nums}

/* ---- Tables ---- */
table{border-collapse:collapse;width:100%;margin:8px 0 4px;font-size:15px;font-variant-numeric:tabular-nums}
caption{text-align:left;color:var(--muted);font-size:14px;margin-bottom:6px}
th,td{border:1px solid var(--line);padding:11px 14px;text-align:left;vertical-align:top}
th{background:var(--well);font-weight:var(--fw-semi);color:var(--ink)}
tbody tr:nth-child(even) td,table tr:nth-child(even) td{background:color-mix(in srgb,var(--surface) 50%,transparent)}
td .small{display:inline}
@media(max-width:640px){table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:normal}}

/* ---- Forms ---- */
label{font-weight:var(--fw-semi);color:var(--ink)}
input,textarea,select{font:inherit;color:var(--ink)}
input[type=text],input[type=email],input[type=url],input[type=number],input[type=search],input[type=tel],textarea,select{width:100%;max-width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);color:var(--ink);transition:border-color var(--dur-1),box-shadow var(--dur-1)}
input:focus,textarea:focus,select:focus{outline:0;border-color:var(--brand);box-shadow:0 0 0 3px var(--ring)}
input::placeholder,textarea::placeholder{color:var(--faint)}
textarea{min-height:96px;line-height:1.5}
fieldset{border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;margin:0 0 16px}
legend{font-weight:700;padding:0 6px;color:var(--ink)}
.field{margin:14px 0}
.field label{display:block;margin-bottom:6px}
.field input,.field textarea{width:100%}
.hint{font-size:var(--fs-small);color:var(--muted);margin:5px 0 0}
input[type=checkbox],input[type=radio]{accent-color:var(--brand);width:17px;height:17px}

/* ---- Form states (validation / required / success / error) ---- */
.field .req{color:var(--brand);margin-left:2px}
.field .req-note{font-weight:var(--fw-reg);color:var(--faint);font-size:12px;margin-left:6px;text-transform:none;letter-spacing:0}
input[aria-invalid="true"],textarea[aria-invalid="true"],select[aria-invalid="true"]{border-color:var(--danger)}
input[aria-invalid="true"]:focus,textarea[aria-invalid="true"]:focus,select[aria-invalid="true"]:focus{box-shadow:0 0 0 3px color-mix(in srgb,var(--danger) 25%,transparent)}
.field-error{display:none;align-items:center;gap:6px;color:var(--danger);font-size:var(--fs-small);margin:6px 0 0;font-weight:var(--fw-med)}
.field.invalid .field-error{display:flex}
.field.valid input,.field.valid textarea{border-color:color-mix(in srgb,var(--ok) 55%,var(--line))}
.form-alert{display:flex;gap:10px;align-items:flex-start;padding:13px 15px;border-radius:var(--radius-sm);font-size:14px;border:1px solid;margin-bottom:18px}
.form-alert.error{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 40%,var(--line));background:color-mix(in srgb,var(--danger) 8%,transparent)}
.form-alert .ico{flex:0 0 auto;margin-top:1px}
.form-success{text-align:center;padding:32px 24px;border:1px solid color-mix(in srgb,var(--ok) 35%,var(--line));border-radius:var(--radius-lg);background:color-mix(in srgb,var(--ok) 6%,transparent)}
.form-success .check{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:50%;background:var(--ok);color:#03130a;margin-bottom:16px}
.form-success h3{margin:0 0 8px}
.btn.is-loading{position:relative;color:transparent!important;pointer-events:none}
.btn.is-loading::after{content:"";position:absolute;width:16px;height:16px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;color:var(--on-brand);animation:cc-spin .6s linear infinite}
@keyframes cc-spin{to{transform:rotate(360deg)}}
@media(prefers-reduced-motion:reduce){.btn.is-loading::after{animation-duration:1.6s}}

/* ---- Details / FAQ ---- */
details{border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px 16px;margin:8px 0;background:var(--surface);transition:border-color var(--dur-2)}
details[open]{border-color:var(--line-2)}
summary{font-weight:var(--fw-semi);cursor:pointer;list-style:revert;color:var(--ink)}
summary::-webkit-details-marker{color:var(--brand)}
summary:hover{color:var(--brand)}
details>p{margin:10px 0 4px;color:var(--muted)}
details>ul{margin-top:10px}

/* ---- Toolbar / code chip ---- */
.toolbar{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}
code.k{background:var(--brand-tint);color:var(--brand-strong);padding:1px 6px;border-radius:5px;font-size:.92em}

/* ---- Footer ---- */
footer.site{border-top:1px solid var(--line);background:var(--soft);margin-top:var(--s-9);padding:var(--s-8) 0 var(--s-6)}
footer.site .cols{display:grid;grid-template-columns:1.5fr repeat(4,1fr);gap:28px;align-items:start}
footer.site nav{display:flex;flex-direction:column;gap:8px}
footer.site nav strong{display:block;color:var(--faint);font-size:12px;margin-bottom:4px;text-transform:uppercase;letter-spacing:.08em;font-weight:var(--fw-bold)}
footer.site nav a{color:var(--muted);font-size:14px}
footer.site nav a:hover{color:var(--ink)}
footer.site .logo{font-size:18px;margin-bottom:6px}
footer.site .small{margin-top:6px}
footer.site .foot-brand .small{margin-top:12px;max-width:34ch}
footer.site .foot-social{margin-top:18px}
footer.site .foot-news{margin-top:14px}
footer.site .foot-bottom{margin-top:36px;padding-top:18px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
footer.site .foot-bottom .small{margin:0}
footer.site>.wrap>.small{margin-top:24px;padding-top:18px;border-top:1px solid var(--line)}
@media(max-width:900px){footer.site .cols{grid-template-columns:1fr 1fr}}
@media(max-width:560px){footer.site .cols{grid-template-columns:1fr}}

/* ============================================================================
   DATA-VIZ LANGUAGE — one chart style everywhere.
   ============================================================================ */
.cc-figure{background:var(--surface-1);border:1px solid var(--line);border-radius:var(--radius-lg);padding:20px 24px}
.cc-figure .cap{font-size:var(--fs-small);color:var(--muted);margin:0 0 14px;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}
.cc-figure .cap .mono,.cc-num{font-family:var(--mono);font-variant-numeric:tabular-nums}

/* article rich-media blocks */
figure.cc-mediafig{margin:var(--s-6) 0}
figure.cc-mediafig img{display:block;width:100%;height:auto;border:1px solid var(--line);border-radius:var(--radius-lg)}
figure.cc-mediafig figcaption{margin-top:10px;font-size:var(--fs-small);color:var(--muted);display:flex;gap:10px;align-items:baseline}
figure.cc-mediafig figcaption .src{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--faint);white-space:nowrap}
img.cc-inline{display:block;width:100%;height:auto;border:1px solid var(--line);border-radius:var(--radius);margin:var(--s-4) 0}
.cc-video{position:relative;margin:var(--s-6) 0}
.cc-video .frame{position:relative;aspect-ratio:16/9;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--surface-2)}
.cc-video .frame img,.cc-video .frame iframe,.cc-video .frame video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border:0}
.cc-video .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;cursor:pointer;background:linear-gradient(180deg,rgba(10,14,19,.05),rgba(10,14,19,.45));border:0}
.cc-video .play span{width:64px;height:64px;border-radius:50%;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;border:1px solid color-mix(in srgb,#fff 25%,transparent)}
.cc-video figcaption{margin-top:10px;font-size:var(--fs-small);color:var(--muted)}

/* signature inline citation highlight */
.cc-cite{background:var(--brand-tint);color:var(--brand-strong);padding:1px 7px;border-radius:5px;font-weight:var(--fw-semi);border:1px solid color-mix(in srgb,var(--brand) 40%,transparent);white-space:nowrap}
mark.cc-cite{color:var(--brand-strong)}

/* horizontal bar rows (ShareBar mirror) */
.cc-bars{display:flex;flex-direction:column}
.cc-bar{display:grid;grid-template-columns:var(--cc-label,150px) 1fr var(--cc-val,92px);gap:14px;align-items:center;padding:8px 0}
.cc-bar .nm{font-size:14px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cc-bar.you .nm{color:var(--ink);font-weight:var(--fw-semi)}
.cc-bar .track{position:relative;height:10px;background:var(--bar-track);border:1px solid var(--line);border-radius:var(--radius-pill);overflow:hidden}
.cc-bar .track>i{position:absolute;inset:0 auto 0 0;height:100%;border-radius:var(--radius-pill);background:var(--bar-other);width:0;transition:width var(--dur-3) var(--ease-out)}
.cc-bar.you .track>i{background:var(--bar-you)}
.cc-bar .val{font-family:var(--mono);font-size:14px;font-weight:var(--fw-semi);text-align:right;color:var(--muted);font-variant-numeric:tabular-nums}
.cc-bar.you .val{color:var(--brand)}
.cc-bar .val small{color:var(--faint);font-weight:var(--fw-reg)}

/* signature ±variance band */
.cc-dist{position:relative;height:14px;border-radius:var(--radius-pill);background:var(--bar-track);border:1px solid var(--line);overflow:hidden}
.cc-dist .band{position:absolute;top:0;bottom:0;background:var(--band)}
.cc-dist .tick{position:absolute;top:-2px;bottom:-2px;width:2px;background:var(--tick);border-radius:2px}

/* glow flourish (≤6%, never behind text) */
.cc-glow{position:relative;isolation:isolate}
.cc-glow::before{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;background:radial-gradient(900px 460px at var(--glow-x,88%) var(--glow-y,-12%),var(--glow),transparent 60%)}

/* skeleton / shimmer */
.skeleton{position:relative;overflow:hidden;background:var(--well);border-radius:var(--radius-sm)}
.skeleton::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--line-2) 60%,transparent),transparent);animation:cc-shimmer 1.3s var(--ease-in-out) infinite}
@keyframes cc-shimmer{100%{transform:translateX(100%)}}

/* "What's included" clarity layer */
.cc-incl{display:flex;flex-direction:column;gap:14px}
.cc-incl-pillar{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface-1);padding:20px 22px}
.cc-incl-pillar.primary{border-color:var(--brand);box-shadow:inset 0 0 0 1px var(--brand);background:color-mix(in srgb,var(--brand) 6%,var(--surface-1))}
.cc-incl-head{display:flex;align-items:flex-start;gap:13px;margin-bottom:13px}
.cc-incl-head .ic{flex:0 0 auto;width:38px;height:38px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:var(--surface-2);border:1px solid var(--line);color:var(--brand)}
.cc-incl-pillar.primary .cc-incl-head .ic{background:var(--brand);border-color:transparent;color:var(--on-brand)}
.cc-incl-head h3{margin:0 0 2px;font-size:17px;letter-spacing:-.01em}
.cc-incl-pillar.primary .cc-incl-head h3{font-size:20px}
.cc-incl-head p{margin:0;font-size:13.5px;color:var(--muted)}
.cc-incl-head .tag{margin-left:auto;margin-bottom:0}
.cc-incl-grp{margin-top:12px}
.cc-incl-grp .gl{font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);font-weight:600;margin:0 0 7px;display:flex;align-items:center;gap:7px}
.cc-chips{display:flex;flex-wrap:wrap;gap:6px}
.cc-chip{font-size:12.5px;padding:4px 10px;border:1px solid var(--line);border-radius:999px;color:var(--muted);background:var(--surface-0);font-weight:500;white-space:nowrap}
.cc-chip.brand{color:var(--brand);border-color:color-mix(in srgb,var(--brand) 35%,var(--line));background:var(--brand-tint)}
.cc-chip.count{color:var(--faint);border-style:dashed;cursor:default}
details.cc-more{margin-top:8px;border:0;padding:0;background:none}
details.cc-more>summary{list-style:none;cursor:pointer;font-size:12.5px;color:var(--brand);font-weight:600;display:inline-flex;align-items:center;gap:5px;padding:2px 0}
details.cc-more>summary::-webkit-details-marker{display:none}
details.cc-more>summary::after{content:"+ more";font-family:var(--mono);font-size:11px;color:var(--faint)}
details.cc-more[open]>summary::after{content:"show less"}
details.cc-more .cc-chips{margin-top:9px}
.cc-incl-others{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.cc-cadence{display:flex;align-items:center;gap:11px;padding:13px 16px;border:1px dashed color-mix(in srgb,var(--ok) 40%,var(--line));border-radius:var(--radius);background:color-mix(in srgb,var(--ok) 5%,transparent);font-size:13.5px;color:var(--muted)}
.cc-cadence b{color:var(--ink);font-weight:600}
@media(max-width:820px){.cc-incl-others{grid-template-columns:1fr}}

/* empty / at-risk states */
.cc-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:10px;padding:var(--s-7) var(--s-5);border:1px dashed var(--line-2);border-radius:var(--radius);color:var(--muted)}
.cc-state .mono{font-family:var(--mono);font-size:12px;color:var(--faint)}

/* FAQ accordion (cc-faq) */
.cc-faq details{border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 18px;margin:0 0 8px;background:var(--surface-1);transition:border-color var(--dur-2)}
.cc-faq details[open]{border-color:var(--line-2)}
.cc-faq summary{font-weight:var(--fw-semi);cursor:pointer;color:var(--ink);list-style:none;display:flex;align-items:center;justify-content:space-between;gap:16px}
.cc-faq summary::-webkit-details-marker{display:none}
.cc-faq summary::after{content:"+";font-family:var(--mono);font-size:18px;color:var(--brand);flex:0 0 auto;transition:transform var(--dur-2) var(--ease-out)}
.cc-faq details[open] summary::after{content:"\2212"}
.cc-faq summary:hover{color:var(--brand)}

/* AI Visibility Index leaderboard (cc-lb) */
.cc-lb-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.cc-lb{width:100%;border-collapse:collapse;font-size:14px}
.cc-lb th{text-align:left;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--faint);font-weight:600;padding:0 14px 10px;border-bottom:1px solid var(--line);background:none}
.cc-lb td{padding:13px 14px;border-bottom:1px solid var(--line);border-left:0;border-right:0;border-top:0;vertical-align:middle}
.cc-lb tbody tr:last-child td{border-bottom:0}
.cc-lb tbody tr:nth-child(even) td{background:none}
.cc-lb .rk{font-family:var(--mono);font-variant-numeric:tabular-nums;color:var(--faint);width:38px}
.cc-lb .nm{font-weight:600;color:var(--ink)}
.cc-lb .nm.you{color:var(--brand)}
.cc-lb tr.you td{background:var(--brand-tint)}
.cc-lb .bar{display:block;position:relative;height:9px;min-width:120px;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;overflow:hidden}
.cc-lb .bar i{position:absolute;inset:0;border-radius:999px;background:var(--line-2)}
.cc-lb .bar i.you{background:var(--brand)}
.cc-lb .num{font-family:var(--mono);font-variant-numeric:tabular-nums;text-align:right;white-space:nowrap;color:var(--ink)}
.cc-lb .mv{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:12.5px;white-space:nowrap}
.cc-lb .mv.up{color:var(--ok)}.cc-lb .mv.down{color:var(--danger)}.cc-lb .mv.flat{color:var(--faint)}
.cc-cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.cc-cat-card{display:block;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface-1);padding:18px 20px;transition:border-color var(--dur-2)}
.cc-cat-card:hover{border-color:var(--line-2)}
.cc-cat-card .top{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.cc-cat-card h3{margin:0;font-size:16px}
.cc-cat-card .lead-line{font-size:13px;color:var(--muted);margin:0}
@media(max-width:820px){.cc-cat-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.cc-cat-grid{grid-template-columns:1fr}.cc-lb .bar{display:none}}

/* breadcrumb */
.cc-breadcrumb ol{display:flex;flex-wrap:wrap;gap:6px;list-style:none;padding:0;margin:0;font-size:13px;color:var(--faint)}
.cc-breadcrumb ol a{color:var(--muted)}
.cc-breadcrumb ol a:hover{color:var(--ink)}

/* template responsive */
@media(max-width:760px){
  .cc-article-grid{grid-template-columns:1fr!important}
  .cc-article-grid aside{position:static!important;border-left:0!important;padding-left:0!important}
  .cc-seg-hero{grid-template-columns:1fr!important;gap:var(--s-6)!important}
  .cc-seg-pillars{grid-template-columns:1fr 1fr!important}
  .cc-contact-grid{grid-template-columns:1fr!important}
  .cc-about-grid{grid-template-columns:1fr!important}
  .cc-about-grid img{max-width:200px}
  .cc-tool-grid{grid-template-columns:1fr!important}
  .cc-logowall-grid{grid-template-columns:repeat(2,1fr)!important}
  .cc-teardown-grid{grid-template-columns:1fr!important;gap:var(--s-6)!important}
}
@media(max-width:520px){.cc-seg-pillars{grid-template-columns:1fr!important}}
@media(max-width:600px){
  .cc-case-row{grid-template-columns:1fr!important;gap:12px!important}
  .cc-case-row span[style*="white-space:nowrap"]{justify-self:start}
}

/* ============================================================================
   CASE-STUDY cards (generated into /case-studies/ + homepage featured slot)
   ============================================================================ */
.case-study{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px 24px;margin:var(--gap) 0}
.case-study:first-of-type{margin-top:0}
.case-study .tag{margin-bottom:var(--s-3)}
.case-study h3{font-size:clamp(19px,2.2vw,23px);font-weight:var(--fw-bold);letter-spacing:-.02em;margin:0 0 var(--s-2)}
.case-study .cs-client{color:var(--muted);font-size:14px;font-weight:var(--fw-semi);margin:0 0 var(--s-3)}
.case-study ul.cs-metrics{list-style:none;padding:0;margin:0 0 var(--s-4);max-width:none}
.case-study ul.cs-metrics li{position:relative;padding-left:26px;margin:0 0 var(--s-2);line-height:1.5}
.case-study ul.cs-metrics li::before{content:"";position:absolute;left:2px;top:.5em;width:9px;height:9px;border-radius:99px;background:var(--brand)}
.case-study ul.cs-metrics li strong{font-variant-numeric:tabular-nums;color:var(--ink)}
.case-study blockquote.cs-quote{margin:0 0 var(--s-4);padding:var(--s-4);background:var(--soft);border:1px solid var(--line);border-left:4px solid var(--brand);border-radius:8px;font-size:16px;line-height:var(--lh-body);color:var(--ink)}
.case-study blockquote.cs-quote p{margin:0 0 var(--s-2);max-width:none}
.case-study blockquote.cs-quote cite{display:block;font-style:normal;font-size:14px;color:var(--muted)}
.case-study .cs-retention{font-size:13px;color:var(--brand);font-weight:var(--fw-semi);margin:0 0 var(--s-3)}
.case-study .cs-cta{margin:var(--s-2) 0 0}
.case-study .cs-cta .btn{margin:4px 8px 4px 0}

/* ============================================================================
   AI Visibility Index pages (idx-wrap / idx-table / pullstat)
   ============================================================================ */
.idx-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:8px 0 4px}
.idx-table{border-collapse:collapse;width:100%;font-size:15px;min-width:520px}
.idx-table th,.idx-table td{border:1px solid var(--line);padding:10px 12px;text-align:left;vertical-align:top}
.idx-table th{background:var(--well);font-weight:700;color:var(--ink)}
.idx-table tbody tr:nth-child(even) td{background:color-mix(in srgb,var(--surface) 50%,transparent)}

/* ============================================================================
   FIND-YOUR-FIT recommender (ff-*)
   ============================================================================ */
.ff-hidden{display:none}
.ff-progress{display:flex;align-items:center;gap:8px;margin:8px 0 20px;font-size:13px;color:var(--muted)}
.ff-bar{flex:1;height:8px;background:var(--line);border-radius:99px;overflow:hidden}
.ff-bar>i{display:block;height:100%;background:var(--brand);width:0;transition:width .25s ease}
@media(prefers-reduced-motion:reduce){.ff-bar>i{transition:none}}
.ff-step{border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px 22px 8px;background:var(--surface-1)}
.ff-q{font-size:21px;font-weight:700;letter-spacing:-.01em;margin:0 0 4px;color:var(--ink)}
.ff-help{color:var(--muted);margin:0 0 16px;font-size:15px}
.ff-options{display:grid;gap:10px}
.ff-opt{display:flex;gap:12px;align-items:flex-start;border:1.5px solid var(--line);border-radius:10px;padding:13px 15px;cursor:pointer;transition:border-color .15s,background .15s;font-size:16px}
.ff-opt:hover{border-color:var(--brand);background:var(--surface-2)}
.ff-opt input{margin-top:3px;accent-color:var(--brand);width:18px;height:18px;flex:0 0 auto}
.ff-opt.sel{border-color:var(--brand);background:var(--brand-tint-2);box-shadow:inset 0 0 0 1px var(--brand)}
.ff-opt:focus-within{outline:2px solid var(--brand);outline-offset:2px}
.ff-nav{display:flex;justify-content:space-between;gap:12px;margin-top:18px;flex-wrap:wrap}
.ff-nav .right{margin-left:auto}
.ff-rec{margin-top:8px}
.ff-card{border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px 20px;margin:14px 0;background:var(--surface-1)}
.ff-card.primary{border:2px solid var(--brand);background:color-mix(in srgb,var(--brand) 6%,var(--surface-1))}
.ff-tag{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--brand);background:var(--brand-tint);border-radius:99px;padding:3px 10px;margin-bottom:6px}
.ff-tag.later{color:var(--warn);background:var(--warn-tint)}
.ff-tag.none{color:var(--muted);background:var(--soft)}
.ff-rowtop{display:flex;justify-content:space-between;gap:14px;align-items:baseline;flex-wrap:wrap}
.ff-rowtop h3{margin:0}
.ff-why{color:var(--muted);margin:6px 0 0}
.ff-est{display:flex;gap:22px;flex-wrap:wrap;background:var(--soft);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;margin:14px 0}
.ff-est b{display:block;font-family:var(--mono);font-size:24px;font-weight:var(--fw-bold);letter-spacing:-.02em;color:var(--ink)}
.ff-est span{font-size:13px;color:var(--muted)}
.ff-addons{margin:6px 0}
.ff-addons li{margin:0 0 10px}
.ff-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}
.ff-trace{margin-top:14px}
.ff-trace li{margin:0 0 6px;color:var(--muted);font-size:14px}
.ff-mono{font:13px/1.5 var(--mono);background:var(--well);border:1px solid var(--line);border-radius:8px;padding:10px 12px;white-space:pre-wrap;overflow:auto;color:var(--ink)}
.ff-noscript{border:1px solid var(--warn);background:var(--warn-tint);border-radius:10px;padding:14px 16px}

/* ============================================================================
   FREE-TOOL page components (scorecard / roi / llms-txt / schema / checklist)
   ============================================================================ */
.q{border:1px solid var(--line);border-radius:10px;padding:14px 16px;margin:10px 0;background:var(--surface-1)}
.q p{margin:0 0 8px;font-weight:600}
.q label{margin-right:18px;font-weight:400;cursor:pointer}
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 18px}
.tabs button{background:var(--surface-1);border:1px solid var(--line);border-radius:var(--radius-sm);padding:10px 16px;font:inherit;font-weight:600;cursor:pointer;color:var(--ink)}
.tabs button[aria-selected=true]{background:var(--brand);color:var(--on-brand);border-color:var(--brand)}
.panel{display:none}
.panel.on{display:block}
.status{font-weight:600}
.faqrow{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;margin:0 0 8px;align-items:start}
.faqrow input{width:100%;padding:9px;border:1px solid var(--line);border-radius:8px;font:inherit;background:var(--surface);color:var(--ink)}
.f-q,.f-a{width:100%}
.pagerow{display:grid;grid-template-columns:1fr 1.4fr 2fr auto;gap:8px;margin:0 0 8px;align-items:start}
.pagerow input{width:100%;padding:9px;border:1px solid var(--line);border-radius:8px;font:inherit;background:var(--surface);color:var(--ink)}
.p-path,.p-title,.p-desc{width:100%}
@media(max-width:680px){.pagerow,.faqrow{grid-template-columns:1fr}}
.rm{background:var(--surface-1);border:1px solid var(--line);border-radius:8px;padding:0 12px;cursor:pointer;color:var(--brand);font-weight:700;line-height:2.4}
.cat{border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;margin:14px 0;background:var(--surface-1)}
.cat h3{margin-top:0;display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.cat h3 .ct{font-size:13px;font-weight:700;color:var(--muted)}
.ct{font-size:13px;font-weight:700;color:var(--muted)}
.item{display:flex;gap:10px;align-items:flex-start;padding:8px 0;border-top:1px solid var(--line)}
.item:first-of-type{border-top:0}
.item input{margin-top:4px;width:18px;height:18px;flex:0 0 auto;accent-color:var(--brand)}
.item label{cursor:pointer;font-weight:400}
.item .why,.why{display:block;font-size:13px;color:var(--muted);margin-top:2px}
.track{flex:1 1 200px;height:10px;background:var(--well);border:1px solid var(--line);border-radius:999px;overflow:hidden;min-width:160px}
.track>span{display:block;height:100%;width:0;background:var(--brand);transition:width .2s}
@media(prefers-reduced-motion:reduce){.track>span{transition:none}}

/* ============================================================================
   Type / layout utilities + small helpers
   ============================================================================ */
.lede{font-size:var(--fs-lead);line-height:1.55;color:var(--muted);max-width:var(--measure)}
/* inline source citation next to an external statistic */
.cite{font-size:.85em;color:var(--muted);white-space:nowrap}
.cite:hover{color:var(--ink)}

/* ---- narrow-screen guards (verified: no horizontal overflow at 360px) ---- */
@media(max-width:880px){
  .cc-hero-grid{grid-template-columns:1fr!important}
}
@media(max-width:560px){
  .cc-fig-grid{grid-template-columns:1fr!important;justify-items:start}
  .cc-chip{white-space:normal}                 /* let an over-long chip wrap, not overflow */
  .cc-incl-others{grid-template-columns:1fr!important}
  .grid.three,.cols{grid-template-columns:1fr!important}
  .cc-hero-grid>*,.cc-fig-grid>*{min-width:0}  /* let grid children shrink below content */
  .cc-bar{--cc-label:92px;--cc-val:60px}       /* tighter fixed cols so the bar track fits */
  .cc-bar .track{min-width:0}
  .btn,a.btn,button.btn{white-space:normal}    /* a long button label wraps, doesn't overflow */
}

/* ============================================================================
   PRINT / PDF — clean light output (state-of-report, guide, press kit, any page).
   Force the light palette (ink on white, ink-saving), static header, drop chrome
   noise, keep data-viz colours, A4 margins.
   ============================================================================ */
@media print{
  :root{
    --surface-0:#fff;--surface-1:#fff;--surface-2:#f4f7fb;--surface-3:#fff;--well:#eef2f7;
    --bg:#fff;--surface:#fff;--soft:#f5f8fc;--ink:#0f1720;--muted:#3a4654;--faint:#5b6b7a;
    --line:#cdd7e2;--line-2:#b8c4d2;--brand:#155fd1;--brand-strong:#0b3d91;--brandink:#0b3d91;
    --btn:#155fd1;--on-brand:#fff;--band:rgba(21,95,209,.16);--bar-other:#9fb0c2;
  }
  *{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  body{background:#fff;color:#0f1720}
  header.site{position:static;background:#fff;border-bottom:1px solid #cdd7e2;backdrop-filter:none;-webkit-backdrop-filter:none}
  .skip-link,.nav-toggle,.nav-dd,header.site nav a:not(.cta),footer.site .foot-news,
  .cc-glow::before,script,[data-cc-video]{display:none!important}
  a{color:#0f1720}
  .band,.card,.btn{box-shadow:none!important}
  section{border-top-color:#e4ebf2}
  .card,figure,.cc-figure,table,.cc-incl-pillar,details{break-inside:avoid}
  h1,h2,h3{break-after:avoid}
  @page{margin:18mm}
}

/* ---- reduced motion: kill non-essential animation ---- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .skeleton::after{display:none}
}
