/* =============================================================================
   WUC Case Studies — Production CSS v1
   Token namespace: --cs-*
   Loaded by: wuc-cs-page-enqueue.php (mu-plugin)
   Scope: only on pages using page-resources-case-studies.php template
   All selectors prefixed with .wuc-cs-page to prevent theme leakage.
   ============================================================================= */

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

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

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

  --cs-accent:         #0050C8;
  --cs-accent-deep:    #003C99;
  --cs-success:        #047857;

  --cs-ind-government:    #1E40AF;
  --cs-ind-financial:     #047857;
  --cs-ind-healthcare:    #0891B2;
  --cs-ind-retail:        #B45309;
  --cs-ind-manufacturing: #7C2D12;
  --cs-ind-education:     #6D28D9;

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

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

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

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

  font-family: var(--cs-sans); font-size: var(--cs-fs-body); line-height: 1.55;
  color: var(--cs-ink-primary); background: var(--cs-bg-base);
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
.wuc-cs-page *, .wuc-cs-page *::before, .wuc-cs-page *::after { box-sizing: border-box; }
.wuc-cs-page a { color: inherit; }

.wuc-cs-page .cs-skip { position: absolute; left: -9999px; top: 0; background: var(--cs-bg-trust); color: var(--cs-ink-inverse); padding: var(--cs-sp-3) var(--cs-sp-5); text-decoration: none; font-family: var(--cs-mono); font-size: var(--cs-fs-mono-sm); z-index: 9999; }
.wuc-cs-page .cs-skip:focus { left: var(--cs-sp-4); top: var(--cs-sp-4); }
.wuc-cs-page .cs-container { max-width: var(--cs-container); margin: 0 auto; padding-inline: var(--cs-sp-5); }
@media (min-width: 768px) { .wuc-cs-page .cs-container { padding-inline: var(--cs-sp-7); } }

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

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

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

/* INDUSTRY PILL */
.wuc-cs-page .cs-pill {
  display: inline-flex; align-items: center; padding: 5px 10px 5px 14px;
  border: 1px solid var(--cs-line-hairline);
  border-left: 4px solid var(--cs-line-strong);
  border-radius: 0 999px 999px 0;
  font-family: var(--cs-mono); font-size: var(--cs-fs-mono-xs);
  font-weight: 500; letter-spacing: 0.04em; text-transform: uppercase;
  color: var(--cs-ink-secondary); background: var(--cs-bg-base); white-space: nowrap;
}
.wuc-cs-page .cs-pill--ind-government     { border-left-color: var(--cs-ind-government); }
.wuc-cs-page .cs-pill--ind-financial      { border-left-color: var(--cs-ind-financial); }
.wuc-cs-page .cs-pill--ind-healthcare     { border-left-color: var(--cs-ind-healthcare); }
.wuc-cs-page .cs-pill--ind-retail         { border-left-color: var(--cs-ind-retail); }
.wuc-cs-page .cs-pill--ind-manufacturing  { border-left-color: var(--cs-ind-manufacturing); }
.wuc-cs-page .cs-pill--ind-education      { border-left-color: var(--cs-ind-education); }

/* Buttons */
.wuc-cs-page .cs-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--cs-sp-2); padding: 14px 24px;
  font-family: var(--cs-sans); font-size: var(--cs-fs-body); font-weight: 500;
  letter-spacing: -0.005em; border-radius: var(--cs-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-cs-page .cs-btn--primary { background: var(--cs-ink-primary); color: var(--cs-ink-inverse); }
.wuc-cs-page .cs-btn--primary:hover { background: var(--cs-bg-trust); transform: translateY(-1px); box-shadow: 0 6px 16px rgba(15, 23, 42, 0.18); }
.wuc-cs-page .cs-btn--secondary { background: var(--cs-bg-base); color: var(--cs-ink-primary); border-color: var(--cs-line-strong); }
.wuc-cs-page .cs-btn--secondary:hover { border-color: var(--cs-ink-primary); transform: translateY(-1px); }
.wuc-cs-page .cs-btn--inverse { background: var(--cs-ink-inverse); color: var(--cs-bg-trust); }
.wuc-cs-page .cs-btn--inverse:hover { background: var(--cs-ink-inverse-2); transform: translateY(-1px); }
.wuc-cs-page .cs-btn--ghost-inverse { background: transparent; color: var(--cs-ink-inverse); border-color: var(--cs-line-trust); }
.wuc-cs-page .cs-btn--ghost-inverse:hover { border-color: var(--cs-ink-inverse); transform: translateY(-1px); }
.wuc-cs-page .cs-btn .cs-arrow { width: 14px; height: 14px; transition: transform 120ms ease; }
.wuc-cs-page .cs-btn:hover .cs-arrow { transform: translateX(2px); }

.wuc-cs-page .cs-link {
  display: inline-flex; align-items: center; gap: var(--cs-sp-2);
  font-family: var(--cs-sans); font-size: 14px; font-weight: 500;
  color: var(--cs-accent); text-decoration: none;
  transition: color 120ms ease, gap 120ms ease;
}
.wuc-cs-page .cs-link:hover { color: var(--cs-accent-deep); gap: var(--cs-sp-3); }
.wuc-cs-page .cs-link .cs-arrow { width: 12px; height: 12px; }

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

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

/* FEATURED */
.wuc-cs-page .cs-featured { background: var(--cs-bg-base); border: 1px solid var(--cs-line-hairline); border-radius: var(--cs-r-3); padding: clamp(32px, 4vw, 56px); position: relative; overflow: hidden; }
.wuc-cs-page .cs-featured::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 4px; background: var(--cs-ind-government); }
.wuc-cs-page .cs-featured-tag {
  display: inline-flex; align-items: center; gap: var(--cs-sp-2);
  font-family: var(--cs-mono); font-size: var(--cs-fs-mono-xs);
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--cs-success);
  margin-bottom: var(--cs-sp-4);
}
.wuc-cs-page .cs-featured-tag::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--cs-success); box-shadow: 0 0 0 4px rgba(4, 120, 87, 0.16); }
.wuc-cs-page .cs-featured-headline { font-size: clamp(28px, 3.4vw, 40px); font-weight: 600; letter-spacing: -0.02em; line-height: 1.12; color: var(--cs-ink-primary); margin: 0 0 var(--cs-sp-3); max-width: 26ch; }
.wuc-cs-page .cs-featured-engagement { font-family: var(--cs-mono); font-size: var(--cs-fs-mono-sm); color: var(--cs-ink-secondary); letter-spacing: 0.04em; text-transform: uppercase; margin: 0 0 var(--cs-sp-7); }
.wuc-cs-page .cs-featured-engagement .cs-eng-strong { color: var(--cs-ink-primary); }

.wuc-cs-page .cs-featured-grid { display: grid; grid-template-columns: 1fr; gap: var(--cs-sp-6); margin-block-end: var(--cs-sp-7); }
@media (min-width: 1024px) { .wuc-cs-page .cs-featured-grid { grid-template-columns: minmax(0, 1fr) minmax(0, 1.6fr); gap: var(--cs-sp-8); align-items: start; } }

.wuc-cs-page .cs-stats-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--cs-line-hairline); border: 1px solid var(--cs-line-hairline); border-radius: var(--cs-r-2); overflow: hidden; }
.wuc-cs-page .cs-stat-cell { background: var(--cs-bg-base); padding: var(--cs-sp-5); }
.wuc-cs-page .cs-stat-cell .cs-stat-num { display: block; font-family: var(--cs-mono); font-size: 28px; font-weight: 500; color: var(--cs-ink-primary); letter-spacing: -0.01em; margin-bottom: 4px; }
.wuc-cs-page .cs-stat-cell .cs-stat-label { font-size: var(--cs-fs-mono-sm); color: var(--cs-ink-muted); line-height: 1.35; display: block; }

.wuc-cs-page .cs-cso { display: grid; grid-template-columns: 1fr; gap: var(--cs-sp-5); }
@media (min-width: 1024px) { .wuc-cs-page .cs-cso { grid-template-columns: repeat(3, 1fr); } }
.wuc-cs-page .cs-cso-block { padding: var(--cs-sp-4) 0 var(--cs-sp-4) var(--cs-sp-4); border-inline-start: 1px solid var(--cs-line-hairline); }
.wuc-cs-page .cs-cso-label { font-family: var(--cs-mono); font-size: var(--cs-fs-mono-xs); letter-spacing: 0.08em; text-transform: uppercase; color: var(--cs-ink-faint); margin: 0 0 var(--cs-sp-2); }
.wuc-cs-page .cs-cso-text { font-size: 14.5px; color: var(--cs-ink-secondary); line-height: 1.55; margin: 0; }
.wuc-cs-page .cs-cso-text strong { color: var(--cs-ink-primary); font-weight: 600; }

.wuc-cs-page .cs-featured-foot { display: flex; flex-wrap: wrap; align-items: center; gap: var(--cs-sp-4); padding-block-start: var(--cs-sp-6); border-block-start: 1px solid var(--cs-line-hairline); }
.wuc-cs-page .cs-featured-quote { flex: 1 1 320px; font-family: var(--cs-sans); font-size: 15px; color: var(--cs-ink-secondary); font-style: italic; line-height: 1.6; padding-inline-start: var(--cs-sp-4); border-inline-start: 3px solid var(--cs-line-strong); margin: 0; }
.wuc-cs-page .cs-featured-quote-attr { display: block; font-style: normal; font-family: var(--cs-mono); font-size: var(--cs-fs-mono-xs); letter-spacing: 0.06em; text-transform: uppercase; color: var(--cs-ink-muted); margin-top: var(--cs-sp-2); }

/* FILTER */
.wuc-cs-page .cs-filter { position: sticky; top: 0; z-index: 30; background: var(--cs-bg-base); border-block-end: 1px solid var(--cs-line-hairline); -webkit-backdrop-filter: saturate(180%) blur(8px); backdrop-filter: saturate(180%) blur(8px); }
.wuc-cs-page .cs-filter-inner { display: flex; align-items: center; justify-content: space-between; gap: var(--cs-sp-5); padding-block: var(--cs-sp-4); flex-wrap: wrap; }
.wuc-cs-page .cs-filter-list { display: flex; flex-wrap: wrap; gap: var(--cs-sp-2); list-style: none; margin: 0; padding: 0; overflow-x: auto; scrollbar-width: thin; }
.wuc-cs-page .cs-filter-link { display: inline-flex; align-items: center; gap: var(--cs-sp-2); padding: 8px 14px; font-family: var(--cs-mono); font-size: var(--cs-fs-mono-sm); letter-spacing: 0.04em; color: var(--cs-ink-secondary); text-decoration: none; background: transparent; border: 1px solid var(--cs-line-hairline); border-radius: 999px; white-space: nowrap; transition: color 120ms ease, border-color 120ms ease, background 120ms ease; }
.wuc-cs-page .cs-filter-link:hover { color: var(--cs-ink-primary); border-color: var(--cs-line-strong); }
.wuc-cs-page .cs-filter-link.is-active { background: var(--cs-bg-trust); border-color: var(--cs-bg-trust); color: var(--cs-ink-inverse); }
.wuc-cs-page .cs-filter-link .cs-filter-count { font-family: var(--cs-mono); font-size: var(--cs-fs-mono-xs); color: var(--cs-ink-faint); margin-inline-start: var(--cs-sp-2); }
.wuc-cs-page .cs-filter-link.is-active .cs-filter-count { color: var(--cs-ink-inverse-2); }
.wuc-cs-page .cs-filter-meta { font-family: var(--cs-mono); font-size: var(--cs-fs-mono-xs); color: var(--cs-ink-muted); letter-spacing: 0.04em; white-space: nowrap; }

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

.wuc-cs-page .cs-card { display: flex; flex-direction: column; background: var(--cs-bg-base); border: 1px solid var(--cs-line-hairline); border-radius: var(--cs-r-3); padding: var(--cs-sp-6); text-decoration: none; color: inherit; transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease; height: 100%; }
.wuc-cs-page .cs-card:hover { border-color: var(--cs-line-strong); box-shadow: 0 8px 24px rgba(15, 23, 42, 0.05); transform: translateY(-1px); }
.wuc-cs-page .cs-card-pill { margin: 0 0 var(--cs-sp-4); align-self: flex-start; }
.wuc-cs-page .cs-card-headline { font-size: var(--cs-fs-h3); font-weight: 600; letter-spacing: -0.014em; line-height: 1.22; color: var(--cs-ink-primary); margin: 0 0 var(--cs-sp-4); display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden; }
.wuc-cs-page .cs-card-engagement { font-family: var(--cs-mono); font-size: var(--cs-fs-mono-xs); color: var(--cs-ink-muted); letter-spacing: 0.06em; text-transform: uppercase; padding-block: var(--cs-sp-4); border-block: 1px solid var(--cs-line-hairline); margin-block-end: var(--cs-sp-4); }
.wuc-cs-page .cs-card-engagement .cs-eng-strong { color: var(--cs-ink-primary); }
.wuc-cs-page .cs-card-engagement .cs-eng-dot { color: var(--cs-ink-faint); margin-inline: 4px; }
.wuc-cs-page .cs-card-summary { font-size: 14.5px; color: var(--cs-ink-secondary); line-height: 1.6; margin: 0 0 var(--cs-sp-5); display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.wuc-cs-page .cs-card-cta { margin-top: auto; }

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

@media (prefers-reduced-motion: reduce) {
  .wuc-cs-page *, .wuc-cs-page *::before, .wuc-cs-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 ===== */
