/* =============================================================================
   WUC Research & Whitepapers Hub — Production CSS v1
   Token namespace: --wpr-*
   Loaded by: wuc-wpr-page-enqueue.php (mu-plugin)
   Scope: only on pages using page-resources-whitepapers.php template
   All selectors prefixed with .wuc-wpr-page to prevent theme leakage.
   ============================================================================= */

.wuc-wpr-page {
  --wpr-bg-base:        #FFFFFF;
  --wpr-bg-subtle:      #F8FAFC;
  --wpr-bg-section:     #F1F5F9;
  --wpr-bg-trust:       #0A2540;
  --wpr-bg-trust-2:     #082037;

  --wpr-ink-primary:    #0F172A;
  --wpr-ink-secondary:  #475569;
  --wpr-ink-muted:      #64748B;
  --wpr-ink-faint:      #94A3B8;
  --wpr-ink-inverse:    #FFFFFF;
  --wpr-ink-inverse-2:  #CBD5E1;

  --wpr-line-hairline:  #E2E8F0;
  --wpr-line-strong:    #CBD5E1;
  --wpr-line-trust:     rgba(255,255,255,0.10);
  --wpr-line-trust-2:   rgba(255,255,255,0.16);

  --wpr-accent:         #0050C8;
  --wpr-accent-deep:    #003C99;

  --wpr-cat-maintenance:#DC2626;
  --wpr-cat-infra:      #6366F1;
  --wpr-cat-managed:    #0D9488;
  --wpr-cat-lifecycle:  #B45309;
  --wpr-cat-cost:       #047857;
  --wpr-cat-trends:     #7C3AED;
  --wpr-cat-compliance: #BE185D;

  --wpr-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  --wpr-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  --wpr-fs-mono-xs: 12px;
  --wpr-fs-mono-sm: 13px;
  --wpr-fs-body:    16px;
  --wpr-fs-lead:    18px;
  --wpr-fs-h4:      20px;
  --wpr-fs-h3:      24px;
  --wpr-fs-display: clamp(36px, 5.2vw, 56px);
  --wpr-fs-hero:    clamp(40px, 5.8vw, 60px);

  --wpr-sp-1: 4px;  --wpr-sp-2: 8px;  --wpr-sp-3: 12px; --wpr-sp-4: 16px;
  --wpr-sp-5: 24px; --wpr-sp-6: 32px; --wpr-sp-7: 48px; --wpr-sp-8: 64px; --wpr-sp-9: 96px;

  --wpr-r-1: 4px; --wpr-r-2: 8px; --wpr-r-3: 12px;
  --wpr-container: 1240px;

  font-family: var(--wpr-sans);
  font-size: var(--wpr-fs-body);
  line-height: 1.55;
  color: var(--wpr-ink-primary);
  background: var(--wpr-bg-base);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

.wuc-wpr-page *, .wuc-wpr-page *::before, .wuc-wpr-page *::after { box-sizing: border-box; }
.wuc-wpr-page a { color: inherit; }

.wuc-wpr-page .wpr-skip {
  position: absolute; left: -9999px; top: 0;
  background: var(--wpr-bg-trust); color: var(--wpr-ink-inverse);
  padding: var(--wpr-sp-3) var(--wpr-sp-5);
  text-decoration: none;
  font-family: var(--wpr-mono); font-size: var(--wpr-fs-mono-sm);
  z-index: 9999;
}
.wuc-wpr-page .wpr-skip:focus { left: var(--wpr-sp-4); top: var(--wpr-sp-4); }

.wuc-wpr-page .wpr-container {
  max-width: var(--wpr-container);
  margin: 0 auto;
  padding-inline: var(--wpr-sp-5);
}
@media (min-width: 768px) { .wuc-wpr-page .wpr-container { padding-inline: var(--wpr-sp-7); } }

.wuc-wpr-page .wpr-section {
  padding-block: clamp(56px, 7vw, 96px);
  border-block-end: 1px solid var(--wpr-line-hairline);
}
.wuc-wpr-page .wpr-section--subtle  { background: var(--wpr-bg-subtle); }

.wuc-wpr-page .wpr-kicker {
  font-family: var(--wpr-mono); font-size: var(--wpr-fs-mono-sm);
  font-weight: 500; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--wpr-accent);
  margin: 0 0 var(--wpr-sp-4);
  display: inline-flex; align-items: center; gap: var(--wpr-sp-2);
}
.wuc-wpr-page .wpr-kicker::before { content: ""; width: 24px; height: 1px; background: currentColor; }

.wuc-wpr-page .wpr-section-h {
  font-size: var(--wpr-fs-display); font-weight: 600;
  letter-spacing: -0.022em; line-height: 1.08;
  margin: 0 0 var(--wpr-sp-5); max-width: 26ch;
}
.wuc-wpr-page .wpr-section-lead {
  font-size: var(--wpr-fs-lead); color: var(--wpr-ink-secondary);
  line-height: 1.55; max-width: 60ch; margin: 0 0 var(--wpr-sp-7);
}

/* Buttons */
.wuc-wpr-page .wpr-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--wpr-sp-2); padding: 14px 24px;
  font-family: var(--wpr-sans); font-size: var(--wpr-fs-body); font-weight: 500;
  letter-spacing: -0.005em; border-radius: var(--wpr-r-2);
  text-decoration: none;
  transition: transform 120ms ease, background 120ms ease, border-color 120ms ease, color 120ms ease, box-shadow 120ms ease;
  border: 1px solid transparent; cursor: pointer; line-height: 1;
}
.wuc-wpr-page .wpr-btn--primary { background: var(--wpr-ink-primary); color: var(--wpr-ink-inverse); }
.wuc-wpr-page .wpr-btn--primary:hover { background: var(--wpr-bg-trust); transform: translateY(-1px); box-shadow: 0 6px 16px rgba(15, 23, 42, 0.18); }
.wuc-wpr-page .wpr-btn--secondary { background: var(--wpr-bg-base); color: var(--wpr-ink-primary); border-color: var(--wpr-line-strong); }
.wuc-wpr-page .wpr-btn--secondary:hover { border-color: var(--wpr-ink-primary); transform: translateY(-1px); }
.wuc-wpr-page .wpr-btn--inverse { background: var(--wpr-ink-inverse); color: var(--wpr-bg-trust); }
.wuc-wpr-page .wpr-btn--inverse:hover { background: var(--wpr-ink-inverse-2); transform: translateY(-1px); }
.wuc-wpr-page .wpr-btn--ghost-inverse { background: transparent; color: var(--wpr-ink-inverse); border-color: var(--wpr-line-trust); }
.wuc-wpr-page .wpr-btn--ghost-inverse:hover { border-color: var(--wpr-ink-inverse); transform: translateY(-1px); }
.wuc-wpr-page .wpr-btn .wpr-arrow { width: 14px; height: 14px; transition: transform 120ms ease; }
.wuc-wpr-page .wpr-btn:hover .wpr-arrow { transform: translateX(2px); }
.wuc-wpr-page .wpr-btn--card { padding: 12px 18px; font-size: 14px; align-self: flex-start; }

/* HERO */
.wuc-wpr-page .wpr-hero {
  padding-block: clamp(72px, 8vw, 120px);
  background: radial-gradient(1200px 600px at 100% 0%, rgba(0,80,200,0.04), transparent 60%), var(--wpr-bg-base);
  border-bottom: 1px solid var(--wpr-line-hairline);
}
.wuc-wpr-page .wpr-hero-grid { display: grid; grid-template-columns: 1fr; gap: var(--wpr-sp-7); }
@media (min-width: 1024px) { .wuc-wpr-page .wpr-hero-grid { grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr); gap: var(--wpr-sp-9); align-items: center; } }
.wuc-wpr-page .wpr-hero-h1 { font-size: var(--wpr-fs-hero); font-weight: 600; letter-spacing: -0.024em; line-height: 1.04; margin: 0 0 var(--wpr-sp-5); max-width: 16ch; }
.wuc-wpr-page .wpr-hero-h1 .wpr-accent-text { color: var(--wpr-accent); }
.wuc-wpr-page .wpr-hero-sub { font-size: var(--wpr-fs-lead); color: var(--wpr-ink-secondary); line-height: 1.55; max-width: 56ch; margin: 0 0 var(--wpr-sp-7); }
.wuc-wpr-page .wpr-hero-cta { display: flex; flex-wrap: wrap; gap: var(--wpr-sp-3); margin-bottom: var(--wpr-sp-5); }
.wuc-wpr-page .wpr-hero-meta { font-family: var(--wpr-mono); font-size: var(--wpr-fs-mono-xs); color: var(--wpr-ink-muted); letter-spacing: 0.04em; }

.wuc-wpr-page .wpr-hero-aside {
  background: var(--wpr-bg-base); border: 1px solid var(--wpr-line-hairline);
  border-radius: var(--wpr-r-3); padding: var(--wpr-sp-6);
  position: relative; overflow: hidden;
}
.wuc-wpr-page .wpr-hero-aside::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 3px; background: linear-gradient(90deg, var(--wpr-accent), transparent); }
.wuc-wpr-page .wpr-hero-aside-h {
  font-family: var(--wpr-mono); font-size: var(--wpr-fs-mono-sm);
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--wpr-ink-secondary);
  margin: 0 0 var(--wpr-sp-5);
  padding-block-end: var(--wpr-sp-4);
  border-block-end: 1px solid var(--wpr-line-hairline);
}
.wuc-wpr-page .wpr-hero-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--wpr-sp-5); }
.wuc-wpr-page .wpr-hero-stat .wpr-stat-num { display: block; font-family: var(--wpr-mono); font-size: 28px; font-weight: 500; color: var(--wpr-ink-primary); letter-spacing: -0.01em; margin-bottom: 2px; }
.wuc-wpr-page .wpr-hero-stat .wpr-stat-label { font-family: var(--wpr-sans); font-size: var(--wpr-fs-mono-sm); color: var(--wpr-ink-muted); }

/* DOCUMENT COVER */
.wuc-wpr-page .wpr-cover {
  display: flex; flex-direction: column;
  position: relative;
  background: var(--wpr-bg-trust); color: var(--wpr-ink-inverse);
  border-radius: var(--wpr-r-3);
  overflow: hidden;
  aspect-ratio: 3 / 4;
  padding: var(--wpr-sp-6);
}
.wuc-wpr-page .wpr-cover::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 4px; background: var(--wpr-cover-accent, var(--wpr-accent)); }
.wuc-wpr-page .wpr-cover-meta { display: flex; align-items: center; justify-content: space-between; gap: var(--wpr-sp-3); margin-bottom: auto; }
.wuc-wpr-page .wpr-cover-id { font-family: var(--wpr-mono); font-size: var(--wpr-fs-mono-xs); letter-spacing: 0.06em; color: var(--wpr-ink-inverse-2); text-transform: uppercase; }
.wuc-wpr-page .wpr-cover-topic {
  font-family: var(--wpr-mono); font-size: var(--wpr-fs-mono-xs);
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 4px 8px;
  border: 1px solid var(--wpr-line-trust-2);
  border-radius: var(--wpr-r-1);
  color: var(--wpr-ink-inverse);
  background: rgba(255,255,255,0.04);
  white-space: nowrap;
}
.wuc-wpr-page .wpr-cover-rule { width: 32px; height: 1px; background: var(--wpr-cover-accent, var(--wpr-accent)); margin-block-end: var(--wpr-sp-3); }
.wuc-wpr-page .wpr-cover-title {
  font-size: clamp(20px, 2vw, 24px); font-weight: 600;
  letter-spacing: -0.014em; line-height: 1.18;
  margin: 0 0 var(--wpr-sp-4); max-width: 16ch;
  display: -webkit-box; -webkit-line-clamp: 5; -webkit-box-orient: vertical; overflow: hidden;
}
.wuc-wpr-page .wpr-cover-faux-lines { display: flex; flex-direction: column; gap: 6px; margin-block-start: var(--wpr-sp-3); opacity: 0.32; }
.wuc-wpr-page .wpr-cover-faux-line { height: 1px; background: var(--wpr-ink-inverse); border-radius: 1px; }
.wuc-wpr-page .wpr-cover-faux-line:nth-child(1) { width: 80%; }
.wuc-wpr-page .wpr-cover-faux-line:nth-child(2) { width: 92%; }
.wuc-wpr-page .wpr-cover-faux-line:nth-child(3) { width: 76%; }
.wuc-wpr-page .wpr-cover-foot {
  display: flex; align-items: center; justify-content: space-between; gap: var(--wpr-sp-3);
  margin-top: auto;
  padding-block-start: var(--wpr-sp-4);
  border-block-start: 1px solid var(--wpr-line-trust-2);
  font-family: var(--wpr-mono); font-size: var(--wpr-fs-mono-xs);
  letter-spacing: 0.06em; color: var(--wpr-ink-inverse-2);
}
.wuc-wpr-page .wpr-cover-foot .wpr-cover-pages { color: var(--wpr-ink-inverse); }

.wuc-wpr-page .wpr-cover--cat-maintenance { --wpr-cover-accent: var(--wpr-cat-maintenance); }
.wuc-wpr-page .wpr-cover--cat-infra       { --wpr-cover-accent: var(--wpr-cat-infra); }
.wuc-wpr-page .wpr-cover--cat-managed     { --wpr-cover-accent: var(--wpr-cat-managed); }
.wuc-wpr-page .wpr-cover--cat-lifecycle   { --wpr-cover-accent: var(--wpr-cat-lifecycle); }
.wuc-wpr-page .wpr-cover--cat-cost        { --wpr-cover-accent: var(--wpr-cat-cost); }
.wuc-wpr-page .wpr-cover--cat-trends      { --wpr-cover-accent: var(--wpr-cat-trends); }
.wuc-wpr-page .wpr-cover--cat-compliance  { --wpr-cover-accent: var(--wpr-cat-compliance); }

/* FEATURED */
.wuc-wpr-page .wpr-featured {
  display: grid; grid-template-columns: 1fr;
  gap: var(--wpr-sp-7); align-items: stretch;
  background: var(--wpr-bg-base); border: 1px solid var(--wpr-line-hairline);
  border-radius: var(--wpr-r-3); padding: var(--wpr-sp-7);
}
@media (min-width: 1024px) {
  .wuc-wpr-page .wpr-featured { grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr); gap: var(--wpr-sp-8); padding: var(--wpr-sp-8); }
}
.wuc-wpr-page .wpr-featured .wpr-cover { max-width: 320px; }
@media (min-width: 1024px) { .wuc-wpr-page .wpr-featured .wpr-cover { max-width: none; } }
.wuc-wpr-page .wpr-featured-content { display: flex; flex-direction: column; }
.wuc-wpr-page .wpr-featured-tag {
  display: inline-flex; align-items: center; gap: var(--wpr-sp-2);
  font-family: var(--wpr-mono); font-size: var(--wpr-fs-mono-xs);
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--wpr-accent);
  margin-bottom: var(--wpr-sp-4);
}
.wuc-wpr-page .wpr-featured-tag::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--wpr-accent); box-shadow: 0 0 0 4px rgba(0, 80, 200, 0.18);
}
.wuc-wpr-page .wpr-featured-title { font-size: clamp(28px, 3vw, 36px); font-weight: 600; letter-spacing: -0.018em; line-height: 1.18; color: var(--wpr-ink-primary); margin: 0 0 var(--wpr-sp-4); }
.wuc-wpr-page .wpr-featured-abstract { font-size: var(--wpr-fs-body); color: var(--wpr-ink-secondary); line-height: 1.65; margin: 0 0 var(--wpr-sp-6); max-width: 60ch; }
.wuc-wpr-page .wpr-featured-meta {
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--wpr-sp-3);
  padding-block: var(--wpr-sp-5);
  border-block: 1px solid var(--wpr-line-hairline);
  margin-block-end: var(--wpr-sp-6);
  font-family: var(--wpr-mono); font-size: var(--wpr-fs-mono-xs);
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--wpr-ink-muted);
}
.wuc-wpr-page .wpr-featured-meta .wpr-meta-strong { color: var(--wpr-ink-primary); }
.wuc-wpr-page .wpr-featured-meta .wpr-meta-dot { color: var(--wpr-ink-faint); }

/* CATALOG */
.wuc-wpr-page .wpr-grid { display: grid; grid-template-columns: 1fr; gap: var(--wpr-sp-6); }
@media (min-width: 768px) { .wuc-wpr-page .wpr-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .wuc-wpr-page .wpr-grid { grid-template-columns: repeat(3, 1fr); } }

.wuc-wpr-page .wpr-card {
  display: flex; flex-direction: column;
  background: var(--wpr-bg-base); border: 1px solid var(--wpr-line-hairline);
  border-radius: var(--wpr-r-3); overflow: hidden;
  transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
  height: 100%;
}
.wuc-wpr-page .wpr-card:hover { border-color: var(--wpr-line-strong); box-shadow: 0 8px 24px rgba(15, 23, 42, 0.05); transform: translateY(-1px); }
.wuc-wpr-page .wpr-card .wpr-cover { border-radius: 0; }
.wuc-wpr-page .wpr-card-body { padding: var(--wpr-sp-6); display: flex; flex-direction: column; flex-grow: 1; }
.wuc-wpr-page .wpr-card-title {
  font-size: var(--wpr-fs-h4); font-weight: 600; letter-spacing: -0.012em; line-height: 1.28;
  color: var(--wpr-ink-primary); margin: 0 0 var(--wpr-sp-3);
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}
.wuc-wpr-page .wpr-card-abstract {
  font-size: 14.5px; color: var(--wpr-ink-secondary); line-height: 1.6;
  margin: 0 0 var(--wpr-sp-5);
  display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden;
}
.wuc-wpr-page .wpr-card-meta {
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--wpr-sp-3);
  padding-block: var(--wpr-sp-4);
  border-block-start: 1px solid var(--wpr-line-hairline);
  margin-block-end: var(--wpr-sp-4);
  font-family: var(--wpr-mono); font-size: var(--wpr-fs-mono-xs);
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--wpr-ink-muted);
}
.wuc-wpr-page .wpr-card-meta .wpr-meta-strong { color: var(--wpr-ink-primary); }
.wuc-wpr-page .wpr-card-meta .wpr-meta-dot { color: var(--wpr-ink-faint); }
.wuc-wpr-page .wpr-card-cta { margin-top: auto; }

/* SUBSCRIBE */
.wuc-wpr-page .wpr-subscribe {
  background: var(--wpr-bg-base); border: 1px solid var(--wpr-line-hairline);
  border-radius: var(--wpr-r-3);
  padding: clamp(32px, 4vw, 56px);
  display: grid; grid-template-columns: 1fr; gap: var(--wpr-sp-6);
  align-items: center; position: relative; overflow: hidden;
}
.wuc-wpr-page .wpr-subscribe::before { content: ""; position: absolute; inset: 0 auto 0 0; width: 4px; background: var(--wpr-accent); }
@media (min-width: 1024px) { .wuc-wpr-page .wpr-subscribe { grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr); gap: var(--wpr-sp-8); } }
.wuc-wpr-page .wpr-sub-title { font-size: clamp(24px, 2.4vw, 32px); font-weight: 600; letter-spacing: -0.016em; line-height: 1.18; margin: 0 0 var(--wpr-sp-3); max-width: 22ch; }
.wuc-wpr-page .wpr-sub-desc { font-size: var(--wpr-fs-body); color: var(--wpr-ink-secondary); line-height: 1.6; margin: 0; max-width: 50ch; }
.wuc-wpr-page .wpr-sub-form { display: flex; flex-direction: column; gap: var(--wpr-sp-3); }
.wuc-wpr-page .wpr-sub-input-row { display: flex; gap: var(--wpr-sp-3); flex-wrap: wrap; }
.wuc-wpr-page .wpr-sub-input {
  flex: 1 1 220px; min-width: 0;
  padding: 14px 16px;
  font-family: var(--wpr-sans); font-size: var(--wpr-fs-body);
  color: var(--wpr-ink-primary); background: var(--wpr-bg-base);
  border: 1px solid var(--wpr-line-strong);
  border-radius: var(--wpr-r-2);
  transition: border-color 120ms ease, box-shadow 120ms ease;
}
.wuc-wpr-page .wpr-sub-input:focus { outline: none; border-color: var(--wpr-accent); box-shadow: 0 0 0 3px rgba(0, 80, 200, 0.12); }
.wuc-wpr-page .wpr-sub-foot { font-family: var(--wpr-mono); font-size: var(--wpr-fs-mono-xs); color: var(--wpr-ink-muted); letter-spacing: 0.04em; margin: 0; }
.wuc-wpr-page .wpr-sub-honeypot { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; }

/* FINAL */
.wuc-wpr-page .wpr-final {
  padding-block: clamp(72px, 9vw, 120px);
  background: radial-gradient(800px 400px at 0% 100%, rgba(0,80,200,0.18), transparent 60%), var(--wpr-bg-trust);
  color: var(--wpr-ink-inverse);
}
.wuc-wpr-page .wpr-final-h { font-size: var(--wpr-fs-display); font-weight: 600; letter-spacing: -0.022em; line-height: 1.06; margin: 0 0 var(--wpr-sp-5); max-width: 22ch; color: var(--wpr-ink-inverse); }
.wuc-wpr-page .wpr-final-sub { font-size: var(--wpr-fs-lead); color: var(--wpr-ink-inverse-2); line-height: 1.55; max-width: 60ch; margin: 0 0 var(--wpr-sp-7); }
.wuc-wpr-page .wpr-final-cta { display: flex; flex-wrap: wrap; gap: var(--wpr-sp-3); }
.wuc-wpr-page .wpr-final .wpr-kicker { color: var(--wpr-ink-inverse-2); }

@media (prefers-reduced-motion: reduce) {
  .wuc-wpr-page *, .wuc-wpr-page *::before, .wuc-wpr-page *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* ===== MOBILE OVERFLOW RESCUE — added 2026-05-09 (sweep) =====
   Generic [class*=...] selectors so it works for any page-prefix variant. */
@media (max-width: 768px) {
    [class*="-trust-row"],
    [class*="-trust-strip"],
    [class*="-badge-row"] {
        flex-wrap: wrap !important;
        gap: 12px !important;
    }
    [class*="-trust-cell"],
    [class*="-badge-cell"] {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
    }
    button[class*="-faq-q"],
    button[class*="-faq-q"] > span,
    [class*="-faq-question"],
    [class*="-faq-question"] > span {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        white-space: normal !important;
        overflow-wrap: break-word !important;
        word-wrap: break-word !important;
        hyphens: auto;
    }
    [class*="-matrix-wrap"],
    [class*="-table-wrap"],
    [class*="-compare-wrap"] {
        max-width: 100% !important;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    [class*="-matrix"]:not([class*="-wrap"]),
    [class*="-compare-table"] {
        min-width: 600px;
        max-width: none;
    }
    [class*="-hero"],
    [class*="-hero"] * {
        max-width: 100vw;
    }
    [class*="-stats-row"],
    [class*="-metric-row"],
    [class*="-kpi-row"] {
        flex-wrap: wrap !important;
        gap: 16px !important;
    }
    [class*="-stat-cell"],
    [class*="-metric-cell"],
    [class*="-kpi-cell"] {
        flex: 1 1 calc(50% - 16px) !important;
        min-width: 0 !important;
    }
    [class*="-pillar-grid"],
    [class*="-feature-grid"],
    [class*="-card-grid"] {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }
    img, picture, svg, video, iframe {
        max-width: 100%;
        height: auto;
    }
    html, body {
        max-width: 100vw;
        overflow-x: clip;
    }
}
@media (max-width: 480px) {
    [class*="-trust-cell"] { font-size: 14px; }
    button[class*="-faq-q"] { padding: 14px 16px; }
    [class*="-stat-cell"],
    [class*="-metric-cell"],
    [class*="-kpi-cell"] {
        flex: 1 1 100% !important;
    }
}
/* ===== end MOBILE OVERFLOW RESCUE ===== */

/* ===== MOBILE OVERFLOW RESCUE v2 — added 2026-05-09 =====
   Supplements v1. Targets residuals discovered via DOM probe:
   - tables with hardcoded min-width that exceed viewport (e.g., .cio-matrix 880px)
   - exit-intent banners and notification overlays with fixed pixel widths
   - reCAPTCHA badge oversize on narrow phones */
@media (max-width: 768px) {
    /* Tables: any matrix/compare table becomes a self-scrolling block */
    table[class*="-matrix"],
    table[class*="-compare"],
    [class*="-matrix"]:not([class*="-wrap"]),
    [class*="-compare-table"] {
        display: block !important;
        overflow-x: auto !important;
        max-width: 100% !important;
        min-width: 0 !important;
        width: 100% !important;
        -webkit-overflow-scrolling: touch !important;
    }
    /* Inner table layout preserved while parent is overflow-scrollable */
    table[class*="-matrix"] thead,
    table[class*="-matrix"] tbody,
    table[class*="-matrix"] tr {
        display: table-row-group;
    }
    table[class*="-matrix"] thead { display: table-header-group; }
    table[class*="-matrix"] tr { display: table-row; }

    /* Exit banners / popup asides: fit narrow viewport */
    aside[id*="exit"],
    aside[class*="exit"],
    [id*="-exit-banner"],
    [class*="-exit-banner"],
    [id*="-popup"],
    [class*="-popup-card"] {
        max-width: calc(100vw - 32px) !important;
        width: auto !important;
        left: 16px !important;
        right: 16px !important;
    }

    /* Generic table protection — last-resort catch-all */
    table {
        max-width: 100%;
    }
}

@media (max-width: 480px) {
    /* reCAPTCHA badge — shrink so it doesn't dominate the corner */
    .grecaptcha-badge {
        transform: scale(0.75);
        transform-origin: bottom right;
    }

    /* Tighter exit-banner padding on small phones */
    aside[id*="exit"],
    [class*="-exit-banner"] {
        padding: 16px !important;
    }
}
/* ===== end MOBILE OVERFLOW RESCUE v2 ===== */
