/* RecapWP — foundation.css
   Auto-split from the per-page-scoped stylesheet. Edit this file directly;
   it is hand-maintained (no build step). See CLAUDE.md asset pipeline. */

/* =============================================================================
   RecapWP — FOUNDATION (shared, loaded on every front-end page)
   Brand atoms (from base.css) + :root tokens + reset + topbar/footer/mobile
   chrome + standalone (dark) 404/coming-soon/maintenance theme + feature-flag
   body classes + @keyframes + the shared .docsearch palette (docs + changelog).
   Per-page rules live in their own page-<slug>.css, enqueued conditionally.
   Split from the old single main.css for PageSpeed (2026-06); no build step —
   edit directly. WP-only blocks have NO pre-prod source; preserved verbatim.
   ============================================================================= */

/* =============================================================================
   FOUNDATION · 01. RESET
   ============================================================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
/* Offset in-page anchor jumps so targets clear the sticky topbar */
[id]{scroll-margin-top:70px}

/* =============================================================================
   FOUNDATION · 02. TOKENS (superset :root — base.css values + serif + changelog)
   ============================================================================= */
:root{
  --ink-950:#0B1020;
  --ink-900:#1A1F36;
  --ink-800:#252B47;
  --ink-700:#373E5C;
  --ink-500:#5B6483;
  --ink-300:#A3ACC9;
  --ink-150:#E8EDFF;

  --blue-700:#1E47C2;
  --blue-600:#3B6EF8;
  --blue-400:#7DA0FB;
  --blue-200:#C7D7FD;
  --blue-100:#EEF2FF;

  --white:#FFFFFF;
  --off:#F7F8FC;
  --slate:#F1F5F9;
  --border:#E2E5F0;
  --muted:#6B7280;
  --hint:#9CA3AF;

  --success:#16A34A; --success-bg:#DCFCE7;
  --warning:#D97706; --warning-bg:#FEF3C7;
  --danger:#DC2626;  --danger-bg:#FEE2E2;

  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --serif:'Fraunces',Georgia,serif;

  --shadow-sm:0 2px 8px rgba(11,16,32,0.06);
  --shadow-md:0 8px 24px rgba(11,16,32,0.10);
  --shadow-lg:0 24px 60px -18px rgba(11,16,32,0.28);

  /* Change-type accents (changelog) */
  --type-new:#1E47C2; --type-new-bg:#EEF2FF; --type-new-bd:#C7D7FD;
  --type-imp:#7C3AED; --type-imp-bg:#F3EEFE; --type-imp-bd:#DCCCFB;
  --type-fix:#15803D; --type-fix-bg:#DCFCE7; --type-fix-bd:#BBF7D0;
  --type-sec:#B45309; --type-sec-bg:#FEF3C7; --type-sec-bd:#FDE68A;
}

/* =============================================================================
   FOUNDATION · 03. SHARED ATOMS (from base.css — base/logo/eyebrow/buttons/
   badges/health-ring/stat-tile/report-card/topbar/layout)
   ============================================================================= */
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  font-size:14px;color:var(--ink-900);background:var(--off);line-height:1.6;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:'cv11','ss01';
}
::selection{background:var(--blue-100);color:var(--ink-900)}
a{color:inherit}

/* ───────────── Logo ───────────── */
.logo{display:inline-flex;align-items:center;gap:11px;text-decoration:none}
.logo-mark{
  width:34px;height:34px;border-radius:9px;background:var(--ink-900);
  position:relative;flex-shrink:0;border:1px solid rgba(255,255,255,0.06);
}
.logo-mark::before{
  content:'';position:absolute;top:9px;left:9px;right:9px;height:1.5px;
  background:rgba(255,255,255,0.40);border-radius:1px;
}
.logo-mark::after{
  content:'';position:absolute;bottom:7px;right:7px;width:9px;height:9px;
  background:var(--blue-600);border-radius:50%;
}
.logo-mark.sm{width:26px;height:26px;border-radius:7px}
.logo-mark.sm::before{top:7px;left:7px;right:7px;height:1.25px}
.logo-mark.sm::after{bottom:5.5px;right:5.5px;width:7px;height:7px}
.wordmark{
  font-weight:700;font-size:18px;letter-spacing:-0.035em;line-height:1;
  color:var(--ink-900);font-feature-settings:'cv11','ss01','kern';
}
.wordmark em{color:var(--blue-600);font-style:normal}
.wordmark.light{color:#fff}

/* ───────────── Eyebrow ───────────── */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:11px;font-weight:500;
  color:var(--blue-600);text-transform:uppercase;letter-spacing:0.14em;
}
.eyebrow::before{content:'';width:6px;height:6px;background:var(--blue-600);border-radius:50%}
.eyebrow.muted{color:var(--muted)}
.eyebrow.muted::before{background:var(--ink-700)}
.eyebrow.light{color:var(--ink-300)}
.eyebrow.light::before{background:var(--blue-400)}

/* Section terminator */
.section-end{
  display:flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:10px;color:var(--hint);
  text-transform:uppercase;letter-spacing:0.16em;
}
.section-end::before{content:'';flex:1;height:1px;background:var(--border)}
.section-end::after{content:'';width:7px;height:7px;background:var(--blue-600);border-radius:50%;flex-shrink:0}
.section-end.dark{color:var(--ink-300)}
.section-end.dark::before{background:rgba(255,255,255,0.10)}

/* ───────────── Buttons ───────────── */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-weight:600;font-size:13.5px;
  padding:11px 18px;border-radius:7px;
  text-decoration:none;cursor:pointer;border:1px solid transparent;
  transition:background 0.12s,border-color 0.12s,color 0.12s,transform 0.06s;
  line-height:1;white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--ink-900);color:#fff}
.btn.primary:hover{background:var(--ink-800)}
.btn.accent{background:var(--blue-600);color:#fff}
.btn.accent:hover{background:var(--blue-700)}
.btn.ghost{background:transparent;color:var(--ink-900);border-color:var(--border)}
.btn.ghost:hover{background:var(--white);border-color:var(--ink-700)}
.btn.ghost.on-dark{color:#fff;border-color:rgba(255,255,255,0.18)}
.btn.ghost.on-dark:hover{background:rgba(255,255,255,0.06);border-color:rgba(255,255,255,0.40)}
.btn.lg{padding:14px 22px;font-size:14px}
.btn .arrow{font-weight:500}

.btn-text{
  display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:13.5px;
  color:var(--ink-900);text-decoration:none;
  border-bottom:1px solid var(--ink-900);padding-bottom:2px;line-height:1;
}
.btn-text:hover{color:var(--blue-700);border-bottom-color:var(--blue-700)}
.btn-text.on-dark{color:#fff;border-bottom-color:rgba(255,255,255,0.45)}
.btn-text.on-dark:hover{color:var(--blue-400);border-bottom-color:var(--blue-400)}

/* ───────────── Badges & pills ───────────── */
.pro-badge{
  display:inline-flex;align-items:center;gap:5px;
  font-family:var(--mono);font-size:9.5px;font-weight:600;
  color:var(--blue-700);background:var(--blue-100);border:1px solid var(--blue-200);
  text-transform:uppercase;letter-spacing:0.12em;padding:2px 7px;border-radius:3px;line-height:1.4;
}
.pro-badge.on-dark{background:rgba(125,160,251,0.14);color:#A8C3FF;border-color:rgba(125,160,251,0.32)}
.free-badge{
  display:inline-flex;align-items:center;
  font-family:var(--mono);font-size:9.5px;font-weight:600;
  color:var(--ink-700);background:var(--off);border:1px solid var(--border);
  text-transform:uppercase;letter-spacing:0.12em;padding:2px 7px;border-radius:3px;line-height:1.4;
}

/* Status pill (plugin chrome) */
.status-pill{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:11px;color:var(--muted);
  background:var(--white);border:1px solid var(--border);
  padding:7px 12px;border-radius:6px;text-transform:uppercase;letter-spacing:0.08em;
  white-space:nowrap;
}
.status-pill b{color:var(--ink-900);font-weight:600}
.status-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--ink-700);flex-shrink:0}
.status-pill .dot.blue{background:var(--blue-600)}
.status-pill .dot.green{background:var(--success)}
.status-pill.on-dark{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.10);color:var(--ink-300)}
.status-pill.on-dark b{color:#fff}

/* ───────────── Health ring ───────────── */
.health-ring{
  width:52px;height:52px;border-radius:50%;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:13px;font-weight:600;color:var(--ink-900);
  font-variant-numeric:tabular-nums;
  background:
    radial-gradient(closest-side, #fff 78%, transparent 79% 100%),
    conic-gradient(var(--blue-600) var(--pct,92%), var(--blue-200) 0);
}
.health-ring.on-dark{
  color:#fff;
  background:
    radial-gradient(closest-side, var(--ink-900) 78%, transparent 79% 100%),
    conic-gradient(var(--blue-400) var(--pct,92%), rgba(255,255,255,0.12) 0);
}

/* ───────────── Stat tile (plugin dashboard card) ───────────── */
.stat-tile{
  border:1px solid var(--border);border-radius:10px;background:#fff;
  padding:18px 18px 16px;position:relative;
}
.stat-tile::before{
  content:'';position:absolute;top:0;left:18px;width:20px;height:5px;
  background:var(--ink-900);border-radius:0 0 3px 3px;
}
.stat-tile.accent::before{background:var(--blue-600)}
.stat-tile.warn::before{background:var(--danger)}
.stat-tile .k{
  font-family:var(--mono);font-size:9.5px;color:var(--muted);
  text-transform:uppercase;letter-spacing:0.12em;margin-bottom:10px;display:block;
}
.stat-tile .v{
  font-size:30px;font-weight:700;color:var(--ink-900);
  font-variant-numeric:tabular-nums;letter-spacing:-0.03em;line-height:1;
}
.stat-tile .v.blue{color:var(--blue-600)}
.stat-tile .v.red{color:var(--danger)}
.stat-tile .v sup{font-size:13px;font-weight:600;color:var(--muted);margin-left:2px;vertical-align:baseline}
.stat-tile .d{
  font-family:var(--mono);font-size:10px;color:var(--success);margin-top:9px;
  display:inline-flex;align-items:center;gap:5px;font-variant-numeric:tabular-nums;
}
.stat-tile .d.down{color:var(--danger)}

/* ───────────── Report mockup card (hero product shot) ───────────── */
.report-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:14px;box-shadow:var(--shadow-lg);overflow:hidden;
}
.report-head{
  background:var(--ink-900);color:#fff;padding:22px 26px 20px;position:relative;overflow:hidden;
}
.report-head::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,0.06) 1px,transparent 0);
  background-size:14px 14px;pointer-events:none;
}
.report-head::after{
  content:'';position:absolute;top:-80px;right:-60px;width:340px;height:240px;pointer-events:none;
  background:radial-gradient(ellipse 60% 70% at 70% 30%,rgba(59,110,248,0.28) 0%,transparent 65%);
}
.report-head-row{display:flex;align-items:center;justify-content:space-between;gap:18px;position:relative;z-index:1}
.report-head-meta{display:flex;align-items:center;gap:10px}
.report-head-meta .wordmark{font-size:15px;color:#fff}
.report-head-meta .sep{width:1px;height:14px;background:rgba(255,255,255,0.12)}
.report-head-meta .tag{
  font-family:var(--mono);font-size:9.5px;color:var(--ink-300);
  text-transform:uppercase;letter-spacing:0.14em;
}
.report-cover{padding:34px 26px 26px;color:#fff;position:relative;z-index:1}
.report-cover .month{
  font-family:var(--mono);font-size:10px;color:var(--blue-400);
  text-transform:uppercase;letter-spacing:0.18em;margin-bottom:14px;
  display:flex;align-items:center;gap:8px;
}
.report-cover .month::before{content:'';width:5px;height:5px;background:var(--blue-600);border-radius:50%}
.report-cover .score{display:flex;align-items:flex-end;gap:4px;margin-bottom:8px}
.report-cover .score .big{font-size:60px;font-weight:800;letter-spacing:-0.05em;line-height:0.85;color:#fff;font-variant-numeric:tabular-nums}
.report-cover .score .out{font-size:20px;color:var(--ink-300);font-weight:500;margin-bottom:6px}
.report-cover .grade{
  font-family:var(--mono);font-size:11px;color:#86EFAC;text-transform:uppercase;letter-spacing:0.12em;
  display:inline-flex;align-items:center;gap:8px;
}
.report-cover .grade::before{content:'';width:6px;height:6px;border-radius:50%;background:#86EFAC}
.report-body{padding:22px 26px 20px;background:#fff}
.report-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--border);padding-top:18px}
.report-stats .rs{padding:0 16px;border-left:1px solid var(--border)}
.report-stats .rs:first-child{border-left:none;padding-left:0}
.report-stats .rs .l{
  font-family:var(--mono);font-size:9px;color:var(--muted);
  text-transform:uppercase;letter-spacing:0.12em;margin-bottom:8px;
}
.report-stats .rs .v{font-size:22px;font-weight:700;color:var(--ink-900);font-variant-numeric:tabular-nums;letter-spacing:-0.02em;line-height:1}
.report-stats .rs .v.blue{color:var(--blue-600)}
.report-stats .rs .v sup{font-size:11px;color:var(--muted);font-weight:500}
.report-stats .rs .d{font-family:var(--mono);font-size:9px;color:var(--success);margin-top:6px;display:block}
.report-footer{
  padding:12px 26px;background:var(--ink-900);color:var(--ink-300);
  font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:0.14em;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.report-footer span{display:inline-flex;align-items:center;gap:8px}
.report-footer span::before{content:'';width:5px;height:5px;background:var(--blue-600);border-radius:50%}

/* ───────────── Topbar ───────────── */
.topbar{
  background:rgba(247,248,252,0.86);backdrop-filter:saturate(160%) blur(8px);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:100;
}
.topbar.on-dark{background:rgba(11,16,32,0.6);border-bottom-color:rgba(255,255,255,0.08)}
.topbar-inner{
  max-width:1200px;margin:0 auto;padding:16px clamp(20px,4vw,40px);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.topbar nav{display:flex;align-items:center;gap:4px}
.topbar nav a{
  font-size:13px;color:var(--ink-700);text-decoration:none;
  padding:7px 11px;border-radius:5px;transition:background 0.12s,color 0.12s;white-space:nowrap;
}
.topbar nav a:hover{background:var(--white);color:var(--ink-900)}
.topbar.on-dark nav a{color:var(--ink-300)}
.topbar.on-dark nav a:hover{background:rgba(255,255,255,0.06);color:#fff}
.topbar-right{display:flex;align-items:center;gap:10px}
.topbar-version{
  font-family:var(--mono);font-size:10px;color:var(--muted);
  background:var(--white);border:1px solid var(--border);
  padding:2px 6px;border-radius:3px;letter-spacing:0.06em;
}
.topbar.on-dark .topbar-version{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.10);color:var(--ink-300)}

/* ───────────── Layout helpers ───────────── */
.wrap{max-width:1200px;margin:0 auto;padding:0 clamp(20px,4vw,40px)}
.hr-rule{height:1px;background:var(--border);width:100%}

/* =============================================================================
   08. STANDALONE PAGES (404 / coming-soon / maintenance)
   These pages use body.standalone for scoping — they keep inline chrome and need
   their dark base layer + simpler topbar/footer applied via body-class scope so
   they don't clash with the marketing layout.
   ============================================================================= */
body.standalone{
  color:#fff;background:var(--ink-950);
  min-height:100vh;display:flex;flex-direction:column;
  position:relative;overflow-x:hidden;
}
body.standalone ::selection{background:var(--blue-600);color:#fff}

/* Background — dot grid + radial glow */
body.standalone .bg{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-color:var(--ink-950);
  background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,0.06) 1px,transparent 0);
  background-size:20px 20px;
}
body.standalone .bg::before{
  content:'';position:absolute;top:-10%;left:50%;width:min(900px,120vw);height:620px;
  transform:translateX(-50%);
  background:radial-gradient(ellipse 60% 70% at 50% 0%,rgba(59,110,248,0.22) 0%,transparent 70%);
}
body.standalone .bg::after{
  content:'';position:absolute;bottom:-20%;right:-10%;width:min(680px,90vw);height:520px;
  background:radial-gradient(ellipse 60% 60% at 70% 100%,rgba(125,160,251,0.12) 0%,transparent 70%);
}

/* Giant decorative period mark */
body.standalone .period-deco{
  position:fixed;z-index:0;pointer-events:none;user-select:none;
  right:clamp(-60px,-3vw,-20px);bottom:clamp(-120px,-10vw,-40px);
  font-weight:800;font-size:clamp(280px,40vw,620px);line-height:0.7;
  color:var(--blue-600);opacity:0.07;letter-spacing:-0.05em;
}
body.standalone .period-deco.maint{transform:rotate(-12deg);transform-origin:70% 70%}

/* 404 ghost number, top-right */
body.standalone .ghost-404{
  position:fixed;z-index:0;pointer-events:none;user-select:none;
  top:clamp(-40px,-4vw,0px);right:clamp(-20px,2vw,40px);
  font-weight:800;font-size:clamp(180px,28vw,420px);line-height:0.8;
  color:#fff;opacity:0.04;letter-spacing:-0.04em;font-variant-numeric:tabular-nums;
}

/* Logo (override — transparent mark on dark bg, no border) */
body.standalone .logo-mark{
  width:30px;height:30px;border-radius:8px;background:transparent;
  position:relative;flex-shrink:0;border:none;
}
body.standalone .logo-mark::before{content:'';position:absolute;top:8px;left:8px;right:8px;height:1.5px;background:rgba(255,255,255,0.55);border-radius:1px}
body.standalone .logo-mark::after{content:'';position:absolute;bottom:6px;right:6px;width:8px;height:8px;background:var(--blue-600);border-radius:50%}
body.standalone .wordmark{font-weight:700;font-size:18px;letter-spacing:-0.035em;line-height:1;color:#fff;font-feature-settings:'cv11','ss01','kern'}
body.standalone .wordmark em{color:var(--blue-400);font-style:normal;margin-left:-0.06em}

/* Topbar override — simple, non-sticky, transparent */
body.standalone .topbar{
  position:relative;z-index:2;padding:28px clamp(20px,5vw,48px);
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  background:transparent;border:none;
  backdrop-filter:none;-webkit-backdrop-filter:none;
}
body.standalone .topbar::before{display:none}
body.standalone .topbar .status{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:10.5px;color:var(--ink-300);
  text-transform:uppercase;letter-spacing:0.14em;
  border:1px solid rgba(255,255,255,0.10);border-radius:99px;padding:7px 14px;
}
body.standalone .topbar .status::before{
  content:'';width:6px;height:6px;border-radius:50%;background:var(--blue-400);
  box-shadow:0 0 7px rgba(125,160,251,0.9);
  animation:standalone-blink 1.6s ease-in-out infinite;
}
@keyframes standalone-blink{0%,100%{opacity:1}50%{opacity:0.35}}

/* Buttons override — accent/ghost on dark */
body.standalone .btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-weight:600;font-size:14px;
  padding:13px 22px;border-radius:8px;
  text-decoration:none;cursor:pointer;border:1px solid transparent;
  transition:background 0.12s,border-color 0.12s,color 0.12s,transform 0.06s;
  line-height:1;white-space:nowrap;
}
body.standalone .btn:active{transform:translateY(1px)}
body.standalone .btn.accent{background:var(--blue-600);color:#fff}
body.standalone .btn.accent:hover{background:var(--blue-700)}
body.standalone .btn.ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,0.18)}
body.standalone .btn.ghost:hover{border-color:rgba(255,255,255,0.45);background:rgba(255,255,255,0.04)}
body.standalone .btn .arrow{font-weight:500}

/* Main column */
body.standalone main{
  position:relative;z-index:2;flex:1;
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(32px,6vw,72px) clamp(20px,5vw,48px) clamp(48px,8vw,96px);
  max-width:1080px;width:100%;margin:0 auto;
}
body.standalone main .eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--mono);font-size:11.5px;font-weight:500;color:var(--blue-400);
  text-transform:uppercase;letter-spacing:0.16em;margin-bottom:26px;
}
body.standalone main .eyebrow::before{content:'';width:7px;height:7px;background:var(--blue-400);border-radius:50%}
body.standalone main h1{
  font-size:clamp(52px,10vw,128px);font-weight:800;letter-spacing:-0.05em;line-height:0.9;
  color:#fff;text-wrap:balance;
}
body.standalone main h1 em{color:var(--blue-400);font-style:normal}
body.standalone main .lede{
  margin-top:30px;font-size:clamp(17px,2vw,22px);color:var(--ink-300);line-height:1.55;
  max-width:580px;text-wrap:pretty;
}
body.standalone main .lede strong{color:#fff;font-weight:600}
body.standalone main .cta-row{margin-top:40px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}

/* Build progress strip (the months row at the bottom of standalone pages) */
body.standalone main .progress{
  margin-top:clamp(44px,6vw,72px);padding-top:28px;
  border-top:1px solid rgba(255,255,255,0.08);
  display:flex;align-items:center;gap:clamp(16px,3vw,40px);flex-wrap:wrap;
}
body.standalone main .progress .pg-item{display:flex;flex-direction:column;gap:8px}
body.standalone main .progress .pg-k{font-family:var(--mono);font-size:10px;color:var(--ink-500);text-transform:uppercase;letter-spacing:0.14em}
body.standalone main .progress .pg-v{font-size:15px;font-weight:600;color:#fff;display:inline-flex;align-items:center;gap:9px}
body.standalone main .progress .pg-v .dot{width:7px;height:7px;border-radius:50%;background:var(--blue-400)}

/* Period strip on standalone uses different muted colors */
body.standalone main .period-strip{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--mono);font-size:10px;color:var(--ink-500);
  text-transform:uppercase;letter-spacing:0.14em;
}
body.standalone main .period-strip .dots{display:inline-flex;gap:6px;align-items:center}
body.standalone main .period-strip .dots span{
  width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.14);display:inline-block;
}
body.standalone main .period-strip .dots span.on{background:var(--blue-400)}

/* Footer override (standalone — flat dark, no dot-grid, no CTA strip) */
body.standalone > footer,
body.standalone footer{
  position:relative;z-index:2;
  padding:24px clamp(20px,5vw,48px);
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  flex-wrap:wrap;
  font-family:var(--mono);font-size:10.5px;color:var(--ink-500);
  text-transform:uppercase;letter-spacing:0.12em;
  border-top:1px solid rgba(255,255,255,0.06);
  background:transparent;background-image:none;
  overflow:visible;
}
body.standalone footer::before{display:none}
body.standalone footer a{color:var(--ink-300);text-decoration:none;transition:color 0.12s}
body.standalone footer a:hover{color:#fff}


/* =============================================================================
   20. FEATURE-FLAG MODIFIERS (body-class toggles preserved from each page)
   ============================================================================= */
/* Standalone bg + period-deco off-switches (works on 404/coming-soon/maintenance) */
body.no-glow .bg::before,
body.no-glow .bg::after{display:none}
body.no-deco .period-deco{display:none}

/* Privacy + Terms: hide all summary boxes */
body.no-summary .summary{display:none}

/* About: switch pullquote to inline blockquote style */
body.quote-inline .pullquote{
  background:transparent;border:none;box-shadow:none;
  padding:18px 0 18px 28px;border-left:3px solid var(--blue-600);border-radius:0;
}
body.quote-inline .pullquote::before{display:none}

/* Support: 2-column form layout */
body.form-2col form.contact-form{display:grid;grid-template-columns:1fr 1fr;gap:18px}
body.form-2col form.contact-form .full,
body.form-2col form.contact-form .field.subject,
body.form-2col form.contact-form .field.message,
body.form-2col form.contact-form .form-foot,
body.form-2col form.contact-form .checkbox{grid-column:1 / -1}

/* Support: hide the "before you email" rt-card */
body.no-rt .rt-card{display:none}

/* Changelog: hide chip count badges */
body.no-counts .cl-chip .count{display:none}

/* Changelog: strong-tint colored heads on change-groups */
body.tint-strong .change-group[data-type="new"] .cg-head{background:var(--type-new-bg);border-bottom-color:var(--type-new-bd)}
body.tint-strong .change-group[data-type="imp"] .cg-head{background:var(--type-imp-bg);border-bottom-color:var(--type-imp-bd)}
body.tint-strong .change-group[data-type="fix"] .cg-head{background:var(--type-fix-bg);border-bottom-color:var(--type-fix-bd)}
body.tint-strong .change-group[data-type="sec"] .cg-head{background:var(--type-sec-bg);border-bottom-color:var(--type-sec-bd)}
body.tint-strong .change-group[data-type="new"]{border-color:var(--type-new-bd)}
body.tint-strong .change-group[data-type="imp"]{border-color:var(--type-imp-bd)}
body.tint-strong .change-group[data-type="fix"]{border-color:var(--type-fix-bd)}
body.tint-strong .change-group[data-type="sec"]{border-color:var(--type-sec-bd)}

/* Changelog: filter-hide groups whose data-type doesn't match the active filter */
body[data-filter="new"] .change-group:not([data-type="new"]),
body[data-filter="imp"] .change-group:not([data-type="imp"]),
body[data-filter="fix"] .change-group:not([data-type="fix"]),
body[data-filter="sec"] .change-group:not([data-type="sec"]){display:none}
body[data-filter] .release.hide-by-filter{display:none}

/* Changelog: empty-results message */
body.empty-results .no-results{display:block}

/* Docs: sidebar plain (no boxes around version + progress) */
body.sb-plain .docs-sidebar .sb-version,
body.sb-plain .docs-sidebar .sb-progress{
  background:transparent;border:none;padding-left:0;padding-right:0;
}
body.sb-plain .docs-sidebar h4{padding:0 0 0 0}
body.sb-plain .docs-sidebar ul li a{padding-left:0}

/* Density-compact tweak (about / changelog / docs / privacy / terms) */
body.density-compact .editorial p{font-size:15.5px;line-height:1.65;margin-bottom:14px}
body.density-compact .editorial h2{font-size:24px;margin:32px 0 12px}
body.density-compact .editorial .lead::first-letter{font-size:4.2em}
body.density-compact .belief{padding:18px 0}
body.density-compact .belief h3{font-size:18px}
body.density-compact .belief p{font-size:14.5px}
body.density-compact .pullquote q{font-size:20px}
body.density-compact .release-body{padding-bottom:32px}
body.density-compact .release-summary{font-size:15px}
body.density-compact .release-blurb{font-size:13px;margin-bottom:14px}
body.density-compact .change-group{margin-bottom:8px}
body.density-compact .cg-head{padding:8px 14px}
body.density-compact .cg-list li{padding:8px 14px;font-size:13.5px}
body.density-compact .article p{font-size:14px;line-height:1.6;margin-bottom:10px}
body.density-compact .article h2{margin:32px 0 10px;font-size:21px}
body.density-compact .article h3{margin:20px 0 8px;font-size:15px}
body.density-compact .docs-section{margin-bottom:44px}
body.density-compact .cat-card{padding:16px 16px 14px}
body.density-compact .cat-card h3{font-size:15px}
body.density-compact .cat-card p{font-size:13px}
body.density-compact .docs-sidebar ul li a{padding:5px 10px;font-size:12.5px}
body.density-compact .code-block pre{padding:12px 14px;font-size:11.5px}
body.density-compact .legal-section{margin-bottom:32px}
body.density-compact .legal-section h2{font-size:20px;margin-bottom:12px}
body.density-compact .legal-section h3{margin:16px 0 8px;font-size:15px}
body.density-compact .legal-section p,
body.density-compact .legal-section li{font-size:14px;line-height:1.6;margin-bottom:10px}
body.density-compact .summary p{font-size:13px}
body.density-compact .legal-intro{font-size:14px;padding:16px 18px;margin-bottom:24px}

/* =============================================================================
   21. WP ADMIN BAR — offset sticky chrome when the bar is showing
   The bar is 32px on desktop / 46px on phones; WP shifts `html` down to
   compensate, but `position:sticky` sticks to the viewport, not the html
   margin, so sticky elements still get covered. Push each one down by the
   bar's height when body.admin-bar is present.
   ============================================================================= */
.admin-bar .topbar{top:32px}
.admin-bar .cl-controls{top:calc(60px + 32px)}
.admin-bar .docs-sidebar{top:calc(84px + 32px)}
/* .release-stamp deliberately omitted — its --stamp-top is computed in JS from
   the live .cl-controls computed top, which already includes the admin-bar
   shift. Adding it again here double-offsets on desktop and (because the rule
   has no media-query wrapper) wins over `top:auto` at ≤860px, dragging the
   stamp down on top of the next release-body. */
@media screen and (max-width:782px){
	.admin-bar .topbar{top:46px}
	.admin-bar .cl-controls{top:calc(60px + 46px)}
	.admin-bar .docs-sidebar{top:calc(84px + 46px)}
}
@keyframes aiblink{50%{opacity:0}}
@keyframes recap-spin{to{transform:rotate(360deg)}}
@keyframes spulse{0%{transform:scale(.6);opacity:.5}100%{transform:scale(1.5);opacity:0}}
.docsearch{position:fixed;inset:0;z-index:300;display:none;align-items:flex-start;justify-content:center;padding:14vh 20px 20px;background:rgba(11,16,32,0.45);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}
.docsearch.open{display:flex}
.docsearch-box{width:100%;max-width:560px;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);overflow:hidden;display:flex;flex-direction:column;max-height:70vh}
.docsearch-in{display:flex;align-items:center;gap:11px;padding:14px 16px;border-bottom:1px solid var(--border)}
.docsearch-in svg{width:18px;height:18px;fill:none;stroke:var(--hint);stroke-width:2;stroke-linecap:round;flex-shrink:0}
.docsearch-in input{flex:1;border:none;outline:none;font-family:var(--sans);font-size:15px;color:var(--ink-900);background:transparent}
.docsearch-in .esc{font-family:var(--mono);font-size:9.5px;color:var(--muted);border:1px solid var(--border);border-radius:5px;padding:3px 6px;letter-spacing:0.06em;flex-shrink:0}
.docsearch-list{overflow-y:auto;padding:6px;scrollbar-width:thin}
.docsearch-item{display:flex;align-items:baseline;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;text-decoration:none}
.docsearch-item .t{font-size:13.5px;color:var(--ink-900);font-weight:500;line-height:1.3;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.docsearch-item .c{font-family:var(--mono);font-size:9.5px;color:var(--hint);margin-left:auto;text-transform:uppercase;letter-spacing:0.08em;flex-shrink:0;white-space:nowrap}
.docsearch-item.sel,.docsearch-item:hover{background:var(--off)}
.docsearch-item.sel .t{color:var(--blue-700)}
.docsearch-empty{padding:26px 16px;text-align:center;color:var(--muted);font-size:13px}
