/* =============================================================================
   WUC About Us — Production CSS v1
   Token namespace: --ab-*
   Loaded by: wuc-ab-page-enqueue.php (mu-plugin)
   Scope: .wuc-ab-page wrapper to prevent theme leakage
   ============================================================================= */

.wuc-ab-page {
  --ab-bg-base: #FFFFFF; --ab-bg-subtle: #F8FAFC; --ab-bg-section: #F1F5F9; --ab-bg-trust: #0A2540;
  --ab-ink-primary: #0F172A; --ab-ink-secondary: #475569; --ab-ink-muted: #64748B; --ab-ink-faint: #94A3B8;
  --ab-ink-inverse: #FFFFFF; --ab-ink-inverse-2: #CBD5E1;
  --ab-line-hairline: #E2E8F0; --ab-line-strong: #CBD5E1; --ab-line-trust: rgba(255,255,255,0.10);
  --ab-accent: #0050C8; --ab-success: #047857;
  --ab-prac-field: #6366F1; --ab-prac-lifecycle: #B45309; --ab-prac-compliance: #BE185D;
  --ab-prac-strategy: #047857; --ab-prac-sales: #0891B2; --ab-prac-federal: #1E40AF;
  --ab-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  --ab-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --ab-fs-mono-xs: 12px; --ab-fs-mono-sm: 13px; --ab-fs-body: 16px; --ab-fs-lead: 18px;
  --ab-fs-h4: 20px; --ab-fs-h3: 24px;
  --ab-fs-display: clamp(36px, 5.2vw, 56px); --ab-fs-hero: clamp(40px, 5.8vw, 60px);
  --ab-sp-1: 4px; --ab-sp-2: 8px; --ab-sp-3: 12px; --ab-sp-4: 16px;
  --ab-sp-5: 24px; --ab-sp-6: 32px; --ab-sp-7: 48px; --ab-sp-8: 64px; --ab-sp-9: 96px;
  --ab-r-1: 4px; --ab-r-2: 8px; --ab-r-3: 12px;
  --ab-container: 1240px;
  font-family: var(--ab-sans); font-size: var(--ab-fs-body); line-height: 1.55; color: var(--ab-ink-primary);
}
.wuc-ab-page *, .wuc-ab-page *::before, .wuc-ab-page *::after { box-sizing: border-box; }
.wuc-ab-page a { color: inherit; }

.wuc-ab-page .ab-skip { position: absolute; left: -9999px; top: 0; background: var(--ab-bg-trust); color: var(--ab-ink-inverse); padding: var(--ab-sp-3) var(--ab-sp-5); text-decoration: none; font-family: var(--ab-mono); font-size: var(--ab-fs-mono-sm); z-index: 9999; }
.wuc-ab-page .ab-skip:focus { left: var(--ab-sp-4); top: var(--ab-sp-4); }
.wuc-ab-page .ab-container { max-width: var(--ab-container); margin: 0 auto; padding-inline: var(--ab-sp-5); }
@media (min-width: 768px) { .wuc-ab-page .ab-container { padding-inline: var(--ab-sp-7); } }
.wuc-ab-page .ab-section { padding-block: clamp(56px, 7vw, 96px); border-block-end: 1px solid var(--ab-line-hairline); }
.wuc-ab-page .ab-section--subtle { background: var(--ab-bg-subtle); }
.wuc-ab-page .ab-kicker { font-family: var(--ab-mono); font-size: var(--ab-fs-mono-sm); font-weight: 500; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ab-accent); margin: 0 0 var(--ab-sp-4); display: inline-flex; align-items: center; gap: var(--ab-sp-2); }
.wuc-ab-page .ab-kicker::before { content: ""; width: 24px; height: 1px; background: currentColor; }
.wuc-ab-page .ab-section-h { font-size: var(--ab-fs-display); font-weight: 600; letter-spacing: -0.022em; line-height: 1.08; margin: 0 0 var(--ab-sp-5); max-width: 26ch; }
.wuc-ab-page .ab-section-lead { font-size: var(--ab-fs-lead); color: var(--ab-ink-secondary); line-height: 1.55; max-width: 60ch; margin: 0 0 var(--ab-sp-7); }

.wuc-ab-page .ab-pill { display: inline-flex; align-items: center; padding: 5px 10px 5px 14px; border: 1px solid var(--ab-line-hairline); border-left: 4px solid var(--ab-line-strong); border-radius: 0 999px 999px 0; font-family: var(--ab-mono); font-size: var(--ab-fs-mono-xs); font-weight: 500; letter-spacing: 0.04em; text-transform: uppercase; color: var(--ab-ink-secondary); background: var(--ab-bg-base); white-space: nowrap; }
.wuc-ab-page .ab-pill--prac-field      { border-left-color: var(--ab-prac-field); }
.wuc-ab-page .ab-pill--prac-lifecycle  { border-left-color: var(--ab-prac-lifecycle); }
.wuc-ab-page .ab-pill--prac-compliance { border-left-color: var(--ab-prac-compliance); }
.wuc-ab-page .ab-pill--prac-strategy   { border-left-color: var(--ab-prac-strategy); }
.wuc-ab-page .ab-pill--prac-sales      { border-left-color: var(--ab-prac-sales); }
.wuc-ab-page .ab-pill--prac-federal    { border-left-color: var(--ab-prac-federal); }

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

.wuc-ab-page .ab-hero { padding-block: clamp(72px, 8vw, 120px); background: radial-gradient(1200px 600px at 100% 0%, rgba(0,80,200,0.04), transparent 60%), var(--ab-bg-base); border-bottom: 1px solid var(--ab-line-hairline); }
.wuc-ab-page .ab-hero-grid { display: grid; grid-template-columns: 1fr; gap: var(--ab-sp-7); }
@media (min-width: 1024px) { .wuc-ab-page .ab-hero-grid { grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr); gap: var(--ab-sp-9); align-items: center; } }
.wuc-ab-page .ab-hero-h1 { font-size: var(--ab-fs-hero); font-weight: 600; letter-spacing: -0.024em; line-height: 1.04; margin: 0 0 var(--ab-sp-5); max-width: 18ch; }
.wuc-ab-page .ab-hero-h1 .ab-accent-text { color: var(--ab-accent); }
.wuc-ab-page .ab-hero-sub { font-size: var(--ab-fs-lead); color: var(--ab-ink-secondary); line-height: 1.55; max-width: 56ch; margin: 0 0 var(--ab-sp-7); }
.wuc-ab-page .ab-hero-cta { display: flex; flex-wrap: wrap; gap: var(--ab-sp-3); margin-bottom: var(--ab-sp-5); }
.wuc-ab-page .ab-hero-meta { font-family: var(--ab-mono); font-size: var(--ab-fs-mono-xs); color: var(--ab-ink-muted); letter-spacing: 0.04em; }
.wuc-ab-page .ab-hero-aside { background: var(--ab-bg-base); border: 1px solid var(--ab-line-hairline); border-radius: var(--ab-r-3); padding: var(--ab-sp-6); position: relative; overflow: hidden; }
.wuc-ab-page .ab-hero-aside::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 3px; background: linear-gradient(90deg, var(--ab-accent), transparent); }
.wuc-ab-page .ab-hero-aside-h { font-family: var(--ab-mono); font-size: var(--ab-fs-mono-sm); letter-spacing: 0.06em; text-transform: uppercase; color: var(--ab-ink-secondary); margin: 0 0 var(--ab-sp-5); padding-block-end: var(--ab-sp-4); border-block-end: 1px solid var(--ab-line-hairline); }
.wuc-ab-page .ab-hero-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--ab-sp-5); }
.wuc-ab-page .ab-hero-stat .ab-stat-num { display: block; font-family: var(--ab-mono); font-size: 28px; font-weight: 500; color: var(--ab-ink-primary); letter-spacing: -0.01em; margin-bottom: 2px; }
.wuc-ab-page .ab-hero-stat .ab-stat-label { font-family: var(--ab-sans); font-size: var(--ab-fs-mono-sm); color: var(--ab-ink-muted); }

.wuc-ab-page .ab-origin-grid { display: grid; grid-template-columns: 1fr; gap: var(--ab-sp-7); align-items: start; }
@media (min-width: 1024px) { .wuc-ab-page .ab-origin-grid { grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr); gap: var(--ab-sp-9); } }
.wuc-ab-page .ab-origin-prose p { font-size: var(--ab-fs-body); line-height: 1.65; color: var(--ab-ink-secondary); margin: 0 0 var(--ab-sp-5); max-width: 60ch; }
.wuc-ab-page .ab-origin-prose strong { color: var(--ab-ink-primary); font-weight: 600; }
.wuc-ab-page .ab-origin-prose p:last-child { margin: 0; }
.wuc-ab-page .ab-timeline { background: var(--ab-bg-base); border: 1px solid var(--ab-line-hairline); border-radius: var(--ab-r-3); padding: var(--ab-sp-6); position: relative; overflow: hidden; }
.wuc-ab-page .ab-timeline::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 3px; background: linear-gradient(90deg, var(--ab-accent), transparent); }
.wuc-ab-page .ab-timeline-h { font-family: var(--ab-mono); font-size: var(--ab-fs-mono-sm); letter-spacing: 0.06em; text-transform: uppercase; color: var(--ab-ink-secondary); margin: 0 0 var(--ab-sp-5); padding-block-end: var(--ab-sp-4); border-block-end: 1px solid var(--ab-line-hairline); }
.wuc-ab-page .ab-timeline-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--ab-sp-5); }
.wuc-ab-page .ab-timeline-item { display: grid; grid-template-columns: 64px 1fr; gap: var(--ab-sp-4); padding-block-end: var(--ab-sp-5); border-block-end: 1px solid var(--ab-line-hairline); }
.wuc-ab-page .ab-timeline-item:last-child { padding-block-end: 0; border-block-end: none; }
.wuc-ab-page .ab-timeline-year { font-family: var(--ab-mono); font-size: var(--ab-fs-h4); font-weight: 500; color: var(--ab-ink-primary); letter-spacing: -0.01em; padding-top: 2px; }
.wuc-ab-page .ab-timeline-text { font-size: 14.5px; color: var(--ab-ink-secondary); line-height: 1.55; }
.wuc-ab-page .ab-timeline-text strong { color: var(--ab-ink-primary); font-weight: 600; }

.wuc-ab-page .ab-leaders-grid { display: grid; grid-template-columns: 1fr; gap: var(--ab-sp-6); }
@media (min-width: 768px) { .wuc-ab-page .ab-leaders-grid { grid-template-columns: repeat(2, 1fr); } }
.wuc-ab-page .ab-founder { grid-column: 1 / -1; background: var(--ab-bg-base); border: 1px solid var(--ab-line-hairline); border-radius: var(--ab-r-3); padding: clamp(28px, 4vw, 48px); position: relative; overflow: hidden; }
.wuc-ab-page .ab-founder::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 4px; background: var(--ab-accent); }
.wuc-ab-page .ab-founder-grid { display: grid; grid-template-columns: 1fr; gap: var(--ab-sp-6); }
@media (min-width: 768px) { .wuc-ab-page .ab-founder-grid { grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr); gap: var(--ab-sp-8); align-items: center; } }
.wuc-ab-page .ab-founder-portrait { background: var(--ab-bg-trust); color: var(--ab-ink-inverse); border-radius: var(--ab-r-2); padding: var(--ab-sp-7); display: flex; flex-direction: column; align-items: center; justify-content: center; aspect-ratio: 1 / 1; max-width: 320px; position: relative; overflow: hidden; }
.wuc-ab-page .ab-founder-portrait::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 3px; background: linear-gradient(90deg, var(--ab-accent), transparent); z-index: 2; }
.wuc-ab-page .ab-founder-initials { font-family: var(--ab-mono); font-size: 56px; font-weight: 500; letter-spacing: -0.02em; color: var(--ab-ink-inverse); }
.wuc-ab-page .ab-founder-portrait-meta { font-family: var(--ab-mono); font-size: var(--ab-fs-mono-xs); letter-spacing: 0.06em; text-transform: uppercase; color: var(--ab-ink-inverse-2); margin-top: var(--ab-sp-4); padding-top: var(--ab-sp-4); border-top: 1px solid var(--ab-line-trust); width: 100%; text-align: center; }
.wuc-ab-page .ab-founder-portrait--photo { padding: 0; background: var(--ab-bg-trust); }
.wuc-ab-page .ab-founder-portrait--photo .ab-founder-photo { display: block; width: 100%; height: 100%; object-fit: cover; object-position: center top; aspect-ratio: 1 / 1; }
.wuc-ab-page .ab-founder-portrait--photo .ab-founder-portrait-meta { position: absolute; inset: auto 0 0 0; margin: 0; padding: var(--ab-sp-6) var(--ab-sp-4) var(--ab-sp-3); border-top: none; background: linear-gradient(180deg, transparent 0%, rgba(10, 37, 64, 0.85) 60%, rgba(10, 37, 64, 0.95) 100%); text-align: center; z-index: 1; }
.wuc-ab-page .ab-founder-tag { display: inline-flex; align-items: center; gap: var(--ab-sp-2); font-family: var(--ab-mono); font-size: var(--ab-fs-mono-xs); letter-spacing: 0.08em; text-transform: uppercase; color: var(--ab-success); margin-bottom: var(--ab-sp-3); }
.wuc-ab-page .ab-founder-tag::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--ab-success); box-shadow: 0 0 0 4px rgba(4, 120, 87, 0.16); }
.wuc-ab-page .ab-founder-name { font-size: clamp(28px, 3vw, 36px); font-weight: 600; letter-spacing: -0.018em; line-height: 1.1; margin: 0 0 var(--ab-sp-2); }
.wuc-ab-page .ab-founder-role { font-family: var(--ab-mono); font-size: var(--ab-fs-mono-sm); letter-spacing: 0.04em; text-transform: uppercase; color: var(--ab-ink-secondary); margin: 0 0 var(--ab-sp-5); }
.wuc-ab-page .ab-founder-bio { font-size: var(--ab-fs-body); color: var(--ab-ink-secondary); line-height: 1.65; margin: 0; max-width: 56ch; }
.wuc-ab-page .ab-founder-bio p { margin: 0 0 var(--ab-sp-3); }
.wuc-ab-page .ab-founder-bio p:last-child { margin: 0; }

.wuc-ab-page .ab-leader { background: var(--ab-bg-base); border: 1px solid var(--ab-line-hairline); border-radius: var(--ab-r-3); display: flex; flex-direction: column; overflow: hidden; }
.wuc-ab-page .ab-leader--field      { --ab-leader-accent: var(--ab-prac-field); }
.wuc-ab-page .ab-leader--lifecycle  { --ab-leader-accent: var(--ab-prac-lifecycle); }
.wuc-ab-page .ab-leader--compliance { --ab-leader-accent: var(--ab-prac-compliance); }
.wuc-ab-page .ab-leader--strategy   { --ab-leader-accent: var(--ab-prac-strategy); }
.wuc-ab-page .ab-leader-photo-wrap { position: relative; width: 100%; height: 240px; background: var(--ab-bg-section); display: flex; align-items: center; justify-content: center; border-block-end: 1px solid var(--ab-line-hairline); overflow: hidden; }
.wuc-ab-page .ab-leader-photo-wrap::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 4px; background: var(--ab-leader-accent, var(--ab-accent)); z-index: 2; }
.wuc-ab-page .ab-leader-photo { display: block; width: 100%; height: 100%; object-fit: cover; object-position: center 22%; }
.wuc-ab-page .ab-leader-photo-fallback { font-family: var(--ab-mono); font-size: 40px; font-weight: 500; color: var(--ab-ink-primary); display: none; }
.wuc-ab-page .ab-leader.no-photo .ab-leader-photo-fallback { display: block; }
.wuc-ab-page .ab-leader.no-photo .ab-leader-photo { display: none; }
.wuc-ab-page .ab-leader-body { padding: var(--ab-sp-6); display: flex; flex-direction: column; }
.wuc-ab-page .ab-leader-pill { margin: 0 0 var(--ab-sp-4); align-self: flex-start; }
.wuc-ab-page .ab-leader-name { font-size: var(--ab-fs-h4); font-weight: 600; letter-spacing: -0.012em; color: var(--ab-ink-primary); margin: 0 0 var(--ab-sp-1); }
.wuc-ab-page .ab-leader-role { font-family: var(--ab-mono); font-size: var(--ab-fs-mono-xs); letter-spacing: 0.04em; text-transform: uppercase; color: var(--ab-ink-muted); margin: 0 0 var(--ab-sp-4); }
.wuc-ab-page .ab-leader-bio { font-size: 14.5px; color: var(--ab-ink-secondary); line-height: 1.55; margin: 0; }

.wuc-ab-page .ab-prac-grid { display: grid; grid-template-columns: 1fr; gap: 1px; background: var(--ab-line-hairline); border: 1px solid var(--ab-line-hairline); border-radius: var(--ab-r-3); overflow: hidden; }
@media (min-width: 768px) { .wuc-ab-page .ab-prac-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .wuc-ab-page .ab-prac-grid { grid-template-columns: repeat(3, 1fr); } }
.wuc-ab-page .ab-prac-card { background: var(--ab-bg-base); padding: var(--ab-sp-6); display: flex; flex-direction: column; gap: var(--ab-sp-3); position: relative; overflow: hidden; }
.wuc-ab-page .ab-prac-card::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 3px; background: var(--ab-prac-accent, var(--ab-accent)); }
.wuc-ab-page .ab-prac-card--field      { --ab-prac-accent: var(--ab-prac-field); }
.wuc-ab-page .ab-prac-card--lifecycle  { --ab-prac-accent: var(--ab-prac-lifecycle); }
.wuc-ab-page .ab-prac-card--compliance { --ab-prac-accent: var(--ab-prac-compliance); }
.wuc-ab-page .ab-prac-card--strategy   { --ab-prac-accent: var(--ab-prac-strategy); }
.wuc-ab-page .ab-prac-card--sales      { --ab-prac-accent: var(--ab-prac-sales); }
.wuc-ab-page .ab-prac-card--federal    { --ab-prac-accent: var(--ab-prac-federal); }
.wuc-ab-page .ab-prac-num { font-family: var(--ab-mono); font-size: var(--ab-fs-mono-xs); letter-spacing: 0.08em; color: var(--ab-ink-faint); margin: 0; }
.wuc-ab-page .ab-prac-title { font-size: var(--ab-fs-h4); font-weight: 600; letter-spacing: -0.012em; color: var(--ab-ink-primary); margin: 0; }
.wuc-ab-page .ab-prac-desc { font-size: 14.5px; color: var(--ab-ink-secondary); line-height: 1.6; margin: 0; }

.wuc-ab-page .ab-final { padding-block: clamp(72px, 9vw, 120px); background: radial-gradient(800px 400px at 0% 100%, rgba(0,80,200,0.18), transparent 60%), var(--ab-bg-trust); color: var(--ab-ink-inverse); }
.wuc-ab-page .ab-final-grid { display: grid; grid-template-columns: 1fr; gap: var(--ab-sp-8); }
@media (min-width: 1024px) { .wuc-ab-page .ab-final-grid { grid-template-columns: repeat(2, 1fr); gap: var(--ab-sp-9); } }
.wuc-ab-page .ab-final-block { padding-block-start: var(--ab-sp-5); border-block-start: 1px solid var(--ab-line-trust); }
.wuc-ab-page .ab-final-h { font-size: clamp(28px, 3vw, 36px); font-weight: 600; letter-spacing: -0.018em; line-height: 1.12; margin: 0 0 var(--ab-sp-4); color: var(--ab-ink-inverse); max-width: 18ch; }
.wuc-ab-page .ab-final-sub { font-size: var(--ab-fs-body); color: var(--ab-ink-inverse-2); line-height: 1.55; margin: 0 0 var(--ab-sp-5); max-width: 50ch; }
.wuc-ab-page .ab-final-cta { display: flex; flex-wrap: wrap; gap: var(--ab-sp-3); }
.wuc-ab-page .ab-final .ab-kicker { color: var(--ab-ink-inverse-2); }

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

/* === Polishing v1 — clean founder portrait + full-shot lead photos === */
.wuc-ab-page .ab-founder-portrait-meta { display: none; }
.wuc-ab-page .ab-leader-photo-wrap { height: auto; aspect-ratio: 1 / 1; background: var(--ab-bg-base); }
.wuc-ab-page .ab-leader-photo { object-fit: contain; object-position: center center; }

/* === Polishing v2 — top-down hierarchy: prominent CEO + practice-leads divider === */
.wuc-ab-page .ab-founder { background: var(--ab-bg-trust); color: var(--ab-ink-inverse); }
.wuc-ab-page .ab-founder::before { height: 6px; }
.wuc-ab-page .ab-founder-portrait { max-width: 400px; }
.wuc-ab-page .ab-founder-name { color: var(--ab-ink-inverse); font-size: clamp(32px, 3.4vw, 44px); }
.wuc-ab-page .ab-founder-role { color: var(--ab-ink-inverse-2); }
.wuc-ab-page .ab-founder-bio { color: var(--ab-ink-inverse-2); }
.wuc-ab-page .ab-founder-bio strong { color: var(--ab-ink-inverse); }
.wuc-ab-page .ab-founder-tag { color: #34D399; }
.wuc-ab-page .ab-founder-tag::before { background: #34D399; box-shadow: 0 0 0 4px rgba(52, 211, 153, 0.18); }
.wuc-ab-page .ab-leaders-divider { grid-column: 1 / -1; display: flex; align-items: center; gap: var(--ab-sp-5); margin-block: var(--ab-sp-8) var(--ab-sp-3); }
.wuc-ab-page .ab-leaders-divider::before, .wuc-ab-page .ab-leaders-divider::after { content: ""; flex: 1; height: 1px; background: var(--ab-line-hairline); }
.wuc-ab-page .ab-leaders-divider-label { font-family: var(--ab-mono); font-size: var(--ab-fs-mono-sm); letter-spacing: 0.08em; text-transform: uppercase; color: var(--ab-ink-faint); }

/* ===== 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 ===== */
