/*
Theme Name: Sayari
Theme URI: https://sayari.com
Author: Sayari
Author URI: https://sayari.com
Description: The Judgment Infrastructure for Trustworthy AI in Economic Security & Commercial Risk - Sayari WordPress block theme. Dark brand system v2.1.
Version: 73.0
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 7.4
License: Proprietary
Text Domain: sayari
*/

/* ═══════════════════════════════════════
   WCAG 2.4.7 - Focus Visible (global)
   ═══════════════════════════════════════ */
*:focus-visible {
  outline: 2px solid var(--intel-blue, #1A73E8);
  outline-offset: 2px;
  border-radius: 4px;
  /* WCAG 2.4.11 - Focus Not Obscured: prevent sticky nav from covering
     focused elements. Nav height ≈ 64px; 90px gives safe clearance. */
  scroll-margin-top: 90px;
  scroll-margin-bottom: 20px;
}
/* Ensure dark-on-dark focus is visible on nav items */
.sayari-nav *:focus-visible,
.sayari-mobile-nav *:focus-visible {
  outline-color: #4291f5;
}

/* ═══════════════════════════════════════
   CSS CUSTOM PROPERTIES - Brand Guide v2.1 (March 2026)
   ═══════════════════════════════════════ */
:root {
  /* ─── PRIMARY PALETTE ─── */
  --obsidian:      #0D1117;
  --obsidian-deep: #080B0F;
  --intel-blue:    #1A73E8;
  --intel-blue-dim: rgba(26,115,232,.10);
  --intel-blue-bd:  rgba(26,115,232,.22);
  --intel-blue-glow: rgba(26,115,232,.35);
  --signal-white:  #F7F8FA;

  /* ─── AMBER ACCENT PALETTE ─── */
  --amber-gold:    #e8980f;   /* Primary accent - overlines, stats, active tabs */
  --amber-gold-dim: rgba(232,152,15,.10);
  --amber-gold-bd:  rgba(232,152,15,.22);
  --amber-cta:     #c87d0e;   /* CTA button background */
  --amber-hover:   #f5b942;   /* Hover state */
  --amber-pressed: #633806;   /* Pressed / active state */

  /* ─── SECONDARY PALETTE ─── */
  --clearance:     #e8980f;   /* Was teal #e8980f - now amber gold */
  --clearance-dim: rgba(232,152,15,.10);
  --clearance-bd:  rgba(232,152,15,.22);
  --alert:         #e8980f;   /* Was orange #e8980f - now amber gold */
  --alert-dim:     rgba(232,152,15,.08);
  --threat:        #E63946;   /* Threat Red - stays */
  --threat-dim:    rgba(230,57,70,.08);
  --violet:        #1A73E8;   /* Was purple #1A73E8 - now blue heritage */
  --violet-dim:    rgba(26,115,232,.08);
  --violet-bd:     rgba(26,115,232,.18);

  /* ─── NEUTRAL SCALE (dark → light) ─── */
  --n-900: #0D1117;
  --n-800: #1C2128;
  --n-700: #2D333B;
  --n-600: #444C56;
  --n-500: #8B95A1;
  --n-400: #ADBAC7;
  --n-100: #F7F8FA;

  /* ─── TEXT SEMANTIC TOKENS ─── */
  --text-primary:   #F7F8FA;   /* body copy on dark */
  --text-secondary: #ADBAC7;   /* secondary labels */
  --text-tertiary:  #8B95A1;   /* muted / captions */
  --text-dim:       #96A3B2;   /* dropdown labels - WCAG AA fix (was #8B95A1, now 6.30:1 on surface-1) */

  /* ─── BORDER TOKENS ─── */
  --border-light:  #1C2128;   /* subtle dividers */
  --border:        #2D333B;   /* standard borders */
  --border-mid:    #444C56;   /* emphasis borders */

  /* ─── SURFACE TOKENS ─── */
  --surface:       #0D1117;   /* page background */
  --surface-1:     #1C2128;   /* card bg level 1 */
  --surface-2:     #2D333B;   /* card bg level 2 / hover */
  --surface-raised: rgba(255,255,255,.025); /* glass card on obsidian */

  /* ─── LEGACY ALIASES (keep for backward compat with existing template refs) ─── */
  --blue-deep:     #1A73E8;
  --blue-mid:      #4291f5;
  --blue-lt:       #6aacf8;
  --blue-dim:      rgba(26,115,232,.10);
  --blue-bd:       rgba(26,115,232,.22);
  --green:         #e8980f;   /* Was #e8980f - now amber gold */
  --green-dark:    #c87d0e;   /* Was #c87d0e - now amber CTA */
  --green-dim:     rgba(232,152,15,.10);
  --s-white:       #0D1117;
  --s-cloud:       #1C2128;
  --s-mist:        #2D333B;
  --s-border:      #2D333B;
  --s-border-lt:   #1C2128;
  --tx-1: #F7F8FA;
  --tx-2: #ADBAC7;
  --tx-3: #8B95A1;
  --tx-4: #8B95A1;
  --tx-5: #2D333B;

  /* gradient - Intel Blue sweep, for ONE emphasis word only */
  --grad: linear-gradient(90deg, #1A73E8 0%, #4291f5 100%);
}

/* ═══════════════════════════════════════
   GLOBAL RESETS & BASE
   ═══════════════════════════════════════ */
*, *::before, *::after {
  box-sizing: border-box;
}

html {
  font-size: 16px;  /* base = 1rem */
  overflow-x: hidden; /* G11: prevent horizontal scroll at mobile viewports */
}

body {
  background: var(--surface);
  color: var(--text-primary);
  font-family: var(--wp--preset--font-family--inter), 'Inter', -apple-system, sans-serif;
  font-size: 16px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

/* ─── GLOBAL TYPOGRAPHY MINIMUMS ─── */
/* Enforce readable body text - no element below 14px for paragraph text */
p, li, td, label, .wp-block-paragraph {
  font-size: max(14px, inherit);
  line-height: 1.65;
  color: var(--text-secondary);
}

h3, h4, h5, h6 {
  color: var(--text-primary);
  font-family: var(--wp--preset--font-family--inter), 'Inter', -apple-system, sans-serif;
  line-height: 1.1;
  letter-spacing: -0.02em;
}
h1, h2 {
  color: var(--text-primary);
  font-family: 'Merriweather', Georgia, serif;
  letter-spacing: -0.02em;
}
h1 { line-height: 1.1; }
h2 { line-height: 1.2; }
/* Blue accent utility - wrap the target word/clause in <span class="s-accent"> */
.s-accent {
  color: var(--intel-blue, #1A73E8);
}

a {
  color: inherit;
  text-decoration: none;
}

/* Footer margin reset */
.wp-site-blocks > footer {
  margin-block-start: 0;
}

/* ═══════════════════════════════════════
   NAVIGATION - frosted obsidian, always dark
   ═══════════════════════════════════════ */
.sayari-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  background: rgba(13,17,23,0.92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border-light);
  transition: box-shadow 0.3s ease;
}

.sayari-nav.scrolled {
  box-shadow: 0 1px 24px rgba(0,0,0,.40);
}

.sayari-nav-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 14px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.sayari-nav-logo {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--text-primary);
  text-decoration: none;
  font-family: var(--wp--preset--font-family--inter);
  flex-shrink: 0;
  min-height: 44px;
  min-width: 44px;
  display: inline-flex;
  align-items: center;
}

/* Product lockup - "SAYARI | Graph" */
.sayari-nav-logo .logo-pipe {
  color: var(--border);
  margin: 0 6px;
  font-weight: 300;
}
.sayari-nav-logo .logo-product {
  color: var(--intel-blue);
}
.sayari-nav-logo .logo-product.clearance {
  color: var(--clearance);
}

.sayari-nav-links {
  display: flex;
  gap: 28px;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
}

.sayari-nav-links a {
  font-size: 16px;
  font-weight: 500;
  color: var(--text-secondary);
  text-decoration: none;
  transition: color 0.2s ease;
  letter-spacing: 0.01em;
  white-space: nowrap;
}

.sayari-nav-links a:hover {
  color: var(--text-primary);
}

.sayari-nav-cta {
  display: inline-flex;
  align-items: center;
  font-size: 12px;
  font-weight: 600;
  color: #fff;
  background: var(--intel-blue); /* #1A73E8 - was #155FCC (G5 fix) */
  padding: 7px 14px;
  border-radius: 6px;
  text-decoration: none;
  transition: all 0.2s ease;
  box-shadow: 0 2px 16px var(--intel-blue-glow);
  white-space: nowrap;
  flex-shrink: 0;
}

.sayari-nav-cta:hover {
  background: var(--blue-mid);
  box-shadow: 0 4px 24px var(--intel-blue-glow);
  transform: translateY(-1px);
  color: #fff;
}

/* Dropdown menus */
.sayari-nav-item {
  position: relative;
}

.sayari-nav-item > a.has-dropdown::after {
  content: '';
  display: inline-block;
  width: 0;
  height: 0;
  border-left: 3px solid transparent;
  border-right: 3px solid transparent;
  border-top: 4px solid var(--text-dim);
  margin-left: 5px;
  vertical-align: middle;
  transition: transform 0.2s ease;
}

.sayari-nav-item:hover > a.has-dropdown::after {
  transform: rotate(180deg);
}

.sayari-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--surface-1);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 8px;
  min-width: 220px;
  list-style: none;
  margin: 0;
  z-index: 200;
  box-shadow: 0 8px 40px rgba(0,0,0,.45);
  max-height: calc(100vh - 100px);
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: #2D333B transparent;
}

.sayari-nav-item:hover .sayari-dropdown,
.sayari-nav-item .sayari-dropdown.nav-open {
  display: block;
}

.sayari-dropdown li a {
  display: block;
  padding: 8px 12px;
  font-size: 14px;
  color: var(--text-secondary);
  border-radius: 6px;
  transition: all 0.15s ease;
}

.sayari-dropdown li a:hover {
  background: var(--surface-2);
  color: var(--text-primary);
}

/* Nav section labels within dropdowns */
.sayari-dropdown .nav-section-label {
  display: block;
  padding: 6px 12px 2px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-dim);
  pointer-events: none;
  margin-top: 4px;
}
.sayari-dropdown .nav-divider {
  border: none;
  border-top: 1px solid var(--border-light);
  margin: 6px 8px;
}

/* Beta badge in nav */
.nav-badge {
  display: inline-flex;
  align-items: center;
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #e8980f;
  background: rgba(232,152,15,.12);
  border: 1px solid rgba(232,152,15,.30);
  border-radius: 3px;
  padding: 1px 5px;
  margin-left: 6px;
  vertical-align: middle;
  line-height: 1.6;
}
.nav-badge.preview {
  color: #F5B94E;
  background: rgba(245,158,11,.10);
  border-color: rgba(245,158,11,.30);
}

/* ── MCP / Superconductor banner ── */
.mcp-banner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: 14px 36px;
  background: linear-gradient(90deg, rgba(26,115,232,.08) 0%, rgba(26,115,232,.08) 100%);
  border-top: 1px solid rgba(26,115,232,.20);
  border-bottom: 1px solid rgba(26,115,232,.20);
}
.mcp-banner-text {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary);
  letter-spacing: 0.03em;
}
.mcp-banner-text strong {
  color: var(--text-primary);
}
.mcp-banner-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #1A73E8;
  background: rgba(26,115,232,.10);
  border: 1px solid rgba(26,115,232,.28);
  border-radius: 20px;
  padding: 4px 12px;
  text-decoration: none;
  transition: all .2s;
}
.mcp-banner-pill:hover {
  background: rgba(26,115,232,.18);
  border-color: rgba(26,115,232,.50);
}
.mcp-banner-pill::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #1A73E8;
  display: inline-block;
  animation: mcp-pulse 2s ease-in-out infinite;
}
@keyframes mcp-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}

/* ═══════════════════════════════════════
   OVERLINE / LABEL STYLE
   10px is CORRECT for ALL-CAPS + letter-spacing labels (Stripe, Linear, Vercel convention)
   ═══════════════════════════════════════ */
.overline,
.sayari-overline {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-tertiary);
}

.overline-blue,
.sayari-overline-blue {
  color: var(--intel-blue);
}

.overline-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}

.overline-bar::before {
  content: '';
  display: block;
  width: 28px;
  height: 2px;
  background: currentColor;
  flex-shrink: 0;
  border-radius: 2px;
  opacity: 0.7;
}

/* ═══════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════ */
.wp-block-button__link {
  font-family: var(--wp--preset--font-family--inter);
  font-size: 14px !important;
  font-weight: 600;
  border-radius: 7px !important;
  transition: all 0.2s ease;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
}

.wp-block-button.is-style-primary .wp-block-button__link,
.btn-primary .wp-block-button__link {
  background: var(--intel-blue);
  color: #fff;
  box-shadow: 0 2px 16px var(--intel-blue-glow);
}

.wp-block-button.is-style-primary .wp-block-button__link:hover,
.btn-primary .wp-block-button__link:hover {
  background: var(--blue-mid);
  box-shadow: 0 6px 28px var(--intel-blue-glow);
  transform: translateY(-1px);
  color: #fff;
}

.wp-block-button.is-style-outline .wp-block-button__link,
.btn-outline .wp-block-button__link {
  background: transparent;
  color: var(--text-secondary);
  border: 1.5px solid var(--border) !important;
  box-shadow: none;
}

.wp-block-button.is-style-outline .wp-block-button__link:hover,
.btn-outline .wp-block-button__link:hover {
  border-color: var(--intel-blue) !important;
  color: var(--intel-blue);
}

/* ═══════════════════════════════════════
   CARDS
   ═══════════════════════════════════════ */
.sayari-card {
  background: var(--surface-raised);
  border: 1px solid var(--border-light);
  border-radius: 10px;
  box-shadow: 0 1px 4px rgba(0,0,0,.20);
  transition: all 0.25s ease;
  position: relative;
  overflow: hidden;
}

.sayari-card:hover {
  border-color: var(--intel-blue-bd);
  box-shadow: 0 4px 24px rgba(0,0,0,.35);
  transform: translateY(-2px);
}

.sayari-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--intel-blue);
  opacity: 0;
  transition: opacity 0.25s ease;
}

.sayari-card:hover::before {
  opacity: 1;
}

.sayari-card-blue {
  border-color: var(--intel-blue-bd);
  background: var(--intel-blue-dim);
}

/* ═══════════════════════════════════════
   EQUAL HEIGHT CARD COLUMNS
   ═══════════════════════════════════════ */
.equal-cards > .wp-block-column {
  display: flex;
  flex-direction: column;
  flex-grow: 0;
}

.equal-cards > .wp-block-column > .wp-block-group {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

.equal-cards .cta-bottom {
  margin-top: auto;
}

/* ═══════════════════════════════════════
   STAT DISPLAY (JetBrains Mono metrics)
   ═══════════════════════════════════════ */
.sayari-stat-num {
  font-family: var(--wp--preset--font-family--jetbrains-mono);
  font-size: clamp(22px, 2.8vw, 32px);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--text-primary);
}

.sayari-stat-num.accent {
  color: var(--intel-blue);
}

.sayari-stat-num.clearance {
  color: var(--clearance);
}

.sayari-stat-label {
  font-size: 14px;
  color: var(--text-secondary);
  margin-top: 6px;
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.5;
}

/* WCAG SC 1.4.3 - stat sub-labels on hero need higher contrast */
.hero-stat-label {
  color: #C5CDD6 !important;  /* ≈ 9.2:1 on #0D1117, up from #9BA8B5 */
}

/* ═══════════════════════════════════════
   STAT STRIP - Pattern C: Monospace stat strip
   ═══════════════════════════════════════ */
.sayari-stat-strip {
  display: flex;
  align-items: stretch;
  gap: 0;
}

.sayari-stat-strip .stat-item {
  flex: 1;
  padding: 24px 20px;
  text-align: center;
  border: 1px solid var(--border-light);
  border-radius: 10px;
  background: var(--surface-raised);
}

.sayari-stat-strip .stat-divider {
  width: 1px;
  background: var(--border-light);
  flex-shrink: 0;
}

/* ═══════════════════════════════════════
   SCROLLING LOGO TICKER
   ═══════════════════════════════════════ */
.sayari-ticker-wrap {
  overflow: hidden;
  position: relative;
  width: 100%;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}

.sayari-ticker {
  display: flex;
  gap: 56px;
  align-items: center;
  animation: sayari-scroll 50s linear infinite;
  width: max-content;
}

@keyframes sayari-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.sayari-ticker .ticker-logo {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  height: 18px;
  opacity: 0.7;
  transition: opacity 0.3s ease;
}

.sayari-ticker .ticker-logo svg {
  height: 18px;
  width: auto;
  display: block;
}

.sayari-ticker .ticker-logo:hover {
  opacity: 1;
}

/* ═══════════════════════════════════════
   TRUST BADGES / PILLS
   ═══════════════════════════════════════ */
.trust-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  border-radius: 6px;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.03em;
  background: var(--surface-1);
  border: 1px solid var(--border-light);
  color: var(--text-secondary);
}

.trust-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--clearance);
  display: inline-block;
  flex-shrink: 0;
}

.trust-dot.blue  { background: var(--intel-blue); }
.trust-dot.alert { background: var(--alert); }

/* ═══════════════════════════════════════
   TAB INTERFACE - Pattern A
   ═══════════════════════════════════════ */
.sayari-tabs {
  border-bottom: 1px solid var(--border-light);
  display: flex;
  gap: 0;
  margin-bottom: 32px;
}

.sayari-tab-btn {
  padding: 10px 22px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-dim);
  cursor: pointer;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  transition: all 0.2s ease;
  font-family: var(--wp--preset--font-family--inter);
  margin-bottom: -1px;
}

.sayari-tab-btn:hover {
  color: var(--text-secondary);
}

.sayari-tab-btn.active {
  color: var(--intel-blue);
  border-bottom-color: var(--intel-blue);
}

.sayari-tab-panel {
  display: none;
}

.sayari-tab-panel.active {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  align-items: start;
}

/* ═══════════════════════════════════════
   COMPARISON TABLE
   ═══════════════════════════════════════ */
.sayari-compare-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.sayari-compare-col {
  padding: 28px 24px;
  border-radius: 10px;
}

.sayari-compare-col.legacy {
  background: var(--surface-1);
  border: 1px dashed var(--border);
}

.sayari-compare-col.sayari-side {
  background: var(--intel-blue-dim);
  border: 1px solid var(--intel-blue-bd);
}

.compare-overline {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border-light);
}

.compare-overline.legacy     { color: var(--text-dim); }
.compare-overline.sayari-col { color: var(--intel-blue); }

.compare-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.compare-list li {
  font-size: 15px;
  color: var(--text-secondary);
  display: flex;
  align-items: flex-start;
  gap: 10px;
  line-height: 1.5;
}

.compare-list.legacy li::before {
  content: '-';
  color: var(--text-dim);
  flex-shrink: 0;
  font-size: 14px;
}

.compare-list.sayari-col li::before {
  content: '';
  display: inline-block;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--clearance-dim);
  border: 1px solid var(--clearance-bd);
  flex-shrink: 0;
  margin-top: 2px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 10'%3E%3Cpath d='M2 5l2 2 4-4' stroke='%2300C9A7' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
}

/* ═══════════════════════════════════════
   STEP NUMBERS
   ═══════════════════════════════════════ */
.sayari-step-num {
  font-family: var(--wp--preset--font-family--jetbrains-mono);
  font-size: clamp(36px, 4vw, 52px);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--intel-blue);
}

.workflow-connector {
  position: relative;
}

.workflow-connector::after {
  content: '';
  position: absolute;
  top: 24px;
  left: calc(50% + 80px);
  right: calc(-50% + 80px);
  height: 1px;
  background: linear-gradient(90deg, var(--border), transparent);
  pointer-events: none;
}

/* ═══════════════════════════════════════
   HERO SECTION
   ═══════════════════════════════════════ */
.sayari-hero {
  position: relative;
  overflow: hidden;
}

.sayari-hero-glow-1 {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  width: 700px;
  height: 700px;
  background: radial-gradient(circle, rgba(26,115,232,.06), transparent 70%);
  top: 38%;
  left: 62%;
  transform: translate(-50%, -50%);
}

.sayari-hero-glow-2 {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  width: 350px;
  height: 350px;
  background: radial-gradient(circle, rgba(26,115,232,.04), transparent 70%);
  top: 80%;
  left: 20%;
  transform: translate(-50%, -50%);
}

/* ═══════════════════════════════════════
   TEXT ACCENT HELPERS
   ═══════════════════════════════════════ */
/* Headline color-shift: dim word in text-tertiary, accent in intel-blue with glow */
.text-dim-word {
  color: var(--text-tertiary);
}

.text-accent-blue {
  color: var(--intel-blue);
  text-shadow: 0 0 28px rgba(26,115,232,.40);
}

.text-accent-clearance {
  color: var(--clearance);
  text-shadow: 0 0 28px rgba(232,152,15,.35);
}

.text-accent-violet {
  color: var(--violet);
  text-shadow: 0 0 28px rgba(26,115,232,.35);
}

/* Gradient text - single emphasis word only */
.text-grad {
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.text-dim-color {
  color: var(--text-tertiary);
}

/* ═══════════════════════════════════════
   MANIFESTO DECLARATION - Pattern B
   ═══════════════════════════════════════ */
.sayari-manifesto {
  background: var(--obsidian-deep);
  border-top: 1px solid var(--border-light);
  border-bottom: 1px solid var(--border-light);
  padding: 80px 0;
  text-align: center;
}

.sayari-manifesto-text {
  font-size: clamp(22px, 3vw, 36px);
  font-weight: 700;
  line-height: 1.35;
  color: var(--text-secondary);
  max-width: 780px;
  margin: 0 auto;
  letter-spacing: -0.02em;
}

.sayari-manifesto-text .accent {
  color: var(--text-primary);
}

/* ═══════════════════════════════════════
   PRESS COVERAGE TILES - Pattern D
   ═══════════════════════════════════════ */
.press-tile {
  background: var(--surface-1);
  border: 1px solid var(--border-light);
  border-radius: 10px;
  padding: 20px 24px;
  transition: border-color 0.2s ease;
}

.press-tile:hover {
  border-color: var(--border);
}

.press-tile-headline {
  font-size: 16px;
  font-weight: 500;
  color: var(--text-primary);
  line-height: 1.5;
  margin-bottom: 12px;
}

.press-tile-source {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-dim);
}

/* ═══════════════════════════════════════
   SOCIAL PROOF STAT CARDS - Pattern E
   ═══════════════════════════════════════ */
.proof-stat-card {
  background: var(--surface-1);
  border: 1px solid var(--border-light);
  border-radius: 10px;
  padding: 28px 24px;
  transition: border-color 0.25s ease;
}

.proof-stat-card:hover {
  border-color: var(--intel-blue-bd);
}

.proof-stat-metric {
  font-family: var(--wp--preset--font-family--jetbrains-mono);
  font-size: clamp(28px, 3.5vw, 44px);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--intel-blue);
  margin-bottom: 8px;
}

.proof-stat-metric.clearance {
  color: var(--clearance);
}

.proof-stat-label {
  font-size: 14px;
  color: var(--text-secondary);
  font-weight: 500;
  line-height: 1.55;
}

/* ── Logo bar - shared horizontal layout (homepage + about) ── */
.logo-bar {
  background: #0D1117;
  border-top: 1px solid #1C2128;
  border-bottom: 1px solid #1C2128;
  padding: 24px 0;
  overflow: hidden;
  position: relative;
}
.logo-bar .logo-label {
  text-align: center;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #9BA8B5;
  margin-bottom: 20px;
}
.logo-track {
  display: flex !important;
  flex-direction: row !important;
  align-items: center;
  justify-content: center;
  gap: 36px;
  flex-wrap: nowrap;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding: 0 24px;
  width: 100%;
}
.logo-slot {
  flex-shrink: 0;
  display: inline-flex !important;
  align-items: center;
}
.logo-slot img {
  height: 26px;
  width: auto;
  max-width: 140px;
  opacity: 0.45;
  filter: grayscale(1) brightness(2);
  object-fit: contain;
  vertical-align: middle;
}
.logo-name {
  color: #9BA8B5;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
}
.logo-name.gov { color: rgba(26,115,232,.45); }

/* PROOF TIER 1 - Logo bar */
.proof-logo-bar {
  display: flex;
  gap: 32px;
  align-items: center;
  flex-wrap: wrap;
}

.proof-logo-gov {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--intel-blue);
  opacity: 0.5;
  transition: opacity 0.2s ease;
}
.proof-logo-gov:hover { opacity: 0.85; }

.proof-logo-commercial {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-dim);
  transition: opacity 0.2s ease;
  opacity: 1;
}
.proof-logo-commercial:hover { color: var(--text-secondary); }

/* PROOF TIER 3 - Deep case study */
.proof-case-card {
  background: var(--surface-1);
  border: 1px solid var(--border-light);
  border-left: 3px solid var(--intel-blue);
  border-radius: 10px;
  padding: 28px 24px;
}

/* ═══════════════════════════════════════
   SECTION PADDING HELPERS
   ═══════════════════════════════════════ */
.section-hero     { padding: 136px 0 80px; }
.section-standard { padding: 80px 0; }
.section-compact  { padding: 56px 0; }
.section-ticker   { padding: 16px 0; }
.section-cta      { padding: 100px 0; }
.hub-hero-section { padding: 136px 0 72px; }

/* ═══════════════════════════════════════
   CHILD CARD GRID
   ═══════════════════════════════════════ */
.child-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.child-card {
  padding: 28px 24px;
  border-radius: 10px;
  background: var(--surface-raised);
  border: 1px solid var(--border-light);
  box-shadow: 0 1px 4px rgba(0,0,0,.20);
  transition: all 0.25s ease;
  position: relative;
  overflow: hidden;
}

.child-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--intel-blue);
  opacity: 0;
  transition: opacity 0.25s ease;
}

.child-card:hover {
  border-color: var(--intel-blue-bd);
  box-shadow: 0 4px 24px rgba(0,0,0,.35);
  transform: translateY(-2px);
}

.child-card:hover::before {
  opacity: 1;
}

/* ═══════════════════════════════════════
   PRESS / MEDIA LOGOS (legacy overline style)
   ═══════════════════════════════════════ */
.press-item {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-dim);
  opacity: 0.7;
  transition: opacity 0.3s ease;
}

.press-item:hover {
  opacity: 1;
}

/* ═══════════════════════════════════════
   AUDIENCE TABS
   ═══════════════════════════════════════ */
.audience-panel-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.audience-panel-list li {
  font-size: 14px;
  color: var(--text-secondary);
  display: flex;
  gap: 10px;
  align-items: flex-start;
  line-height: 1.6;
}

.audience-panel-list li::before {
  content: '';
  display: inline-block;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--intel-blue);
  flex-shrink: 0;
  margin-top: 6px;
}

/* ═══════════════════════════════════════
   PROOF METRIC CARDS
   ═══════════════════════════════════════ */
.proof-metric {
  font-family: var(--wp--preset--font-family--jetbrains-mono);
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 600;
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--intel-blue);
}

.proof-overline {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 12px;
  color: var(--text-dim);
}

/* ═══════════════════════════════════════
   RELATED CONTENT CARDS
   ═══════════════════════════════════════ */
.related-type {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 10px;
  color: var(--text-dim);
}

/* ═══════════════════════════════════════
   MONO DISPLAY
   ═══════════════════════════════════════ */
.mono {
  font-family: var(--wp--preset--font-family--jetbrains-mono);
}

.code-tag {
  font-family: var(--wp--preset--font-family--jetbrains-mono);
  font-size: 14px;
  color: var(--intel-blue);
  background: var(--intel-blue-dim);
  border: 1px solid var(--intel-blue-bd);
  padding: 2px 8px;
  border-radius: 4px;
}

/* ═══════════════════════════════════════
   CHALLENGE/PROBLEM CARDS
   ═══════════════════════════════════════ */
.challenge-card {
  padding: 24px 20px;
  border-radius: 10px;
  background: var(--surface-raised);
  border: 1px solid var(--border-light);
  box-shadow: 0 1px 4px rgba(0,0,0,.20);
  position: relative;
}

.challenge-card.accent {
  padding-left: 18px;
  border-left: 2px solid var(--alert);
  background: var(--alert-dim);
}

.challenge-num {
  font-family: var(--wp--preset--font-family--jetbrains-mono);
  font-size: 11px;
  font-weight: 600;
  color: var(--text-dim);
  letter-spacing: 0.08em;
  margin-bottom: 12px;
}

/* ═══════════════════════════════════════
   WORKFLOW STEPS
   ═══════════════════════════════════════ */
.workflow-step {
  padding: 28px 22px;
  border-radius: 10px;
  background: var(--surface-raised);
  border: 1px solid var(--border-light);
  box-shadow: 0 1px 4px rgba(0,0,0,.20);
  position: relative;
}

.workflow-step-badge {
  font-family: var(--wp--preset--font-family--jetbrains-mono);
  font-size: 11px;
  font-weight: 600;
  color: var(--intel-blue);
  background: var(--intel-blue-dim);
  border: 1px solid var(--intel-blue-bd);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
}

/* ═══════════════════════════════════════
   AWARDS / RECOGNITION
   ═══════════════════════════════════════ */
.award-card {
  padding: 18px 14px;
  border-radius: 10px;
  background: var(--surface-raised);
  border: 1px solid var(--border-light);
  box-shadow: 0 1px 4px rgba(0,0,0,.20);
  text-align: center;
  transition: all 0.3s ease;
}

.award-card:hover {
  border-color: var(--intel-blue-bd);
  box-shadow: 0 4px 24px rgba(0,0,0,.35);
}

/* ═══════════════════════════════════════
   ANIMATIONS - SCROLL REVEALS
   ═══════════════════════════════════════ */
.animate-on-scroll {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.animate-on-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.animate-on-scroll.delay-1 { transition-delay: 0.1s; }
.animate-on-scroll.delay-2 { transition-delay: 0.2s; }
.animate-on-scroll.delay-3 { transition-delay: 0.3s; }

.slide-in-left {
  opacity: 0;
  transform: translateX(-30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.slide-in-left.is-visible { opacity: 1; transform: translateX(0); }

.slide-in-right {
  opacity: 0;
  transform: translateX(30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.slide-in-right.is-visible { opacity: 1; transform: translateX(0); }

.stagger-children > * {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.stagger-children.is-visible > *:nth-child(1) { opacity: 1; transform: translateY(0); transition-delay: 0.08s; }
.stagger-children.is-visible > *:nth-child(2) { opacity: 1; transform: translateY(0); transition-delay: 0.16s; }
.stagger-children.is-visible > *:nth-child(3) { opacity: 1; transform: translateY(0); transition-delay: 0.24s; }
.stagger-children.is-visible > *:nth-child(4) { opacity: 1; transform: translateY(0); transition-delay: 0.32s; }

.hover-lift {
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.hover-lift:hover { transform: translateY(-3px); }

.pulse-blue {
  animation: pulse-blue 3s ease-in-out infinite;
}

@keyframes pulse-blue {
  0%, 100% { box-shadow: 0 0 0 0 rgba(26,115,232,0); }
  50%       { box-shadow: 0 0 24px 4px rgba(26,115,232,.18); }
}

/* ═══════════════════════════════════════
   BLOCKS
   ═══════════════════════════════════════ */
.wp-block-separator {
  border-color: var(--border-light);
  opacity: 1;
}

/* ═══════════════════════════════════════
   REDUCED MOTION
   ═══════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
  }
  .animate-on-scroll,
  .slide-in-left,
  .slide-in-right,
  .stagger-children > * {
    opacity: 1;
    transform: none;
  }
}

/* ═══════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════ */
/* ── Hamburger button - hidden on desktop ── */
.sayari-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  /* 44×44px minimum touch target (WCAG 2.5.5) */
  min-width: 44px;
  min-height: 44px;
  padding: 11px 11px;
  margin-left: 4px;
  z-index: 1001;
  -webkit-tap-highlight-color: transparent;
}
.sayari-hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--signal-white);
  border-radius: 2px;
  transition: transform 0.22s ease, opacity 0.22s ease;
  flex-shrink: 0;
}
.sayari-hamburger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.sayari-hamburger[aria-expanded="true"] span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.sayari-hamburger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── Mobile nav overlay ──
   Uses visibility+opacity instead of display:none so CSS transitions fire properly.
   display:none prevents transitions; visibility:hidden still allows them. */
.sayari-mobile-nav {
  display: flex;          /* always in flex context */
  position: fixed;
  inset: 0;
  z-index: 2000;
  background: rgba(8,11,15,0.60);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.22s ease, visibility 0.22s ease;
}
.sayari-mobile-nav.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.sayari-mobile-nav-inner {
  position: absolute;
  top: 0; right: 0;
  width: min(320px, 88vw);
  height: 100%;
  background: #0D1117;
  border-left: 1px solid var(--border-light);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  transform: translateX(100%);
  transition: transform 0.28s cubic-bezier(0.22,0.61,0.36,1);
}
.sayari-mobile-nav.is-open .sayari-mobile-nav-inner {
  transform: translateX(0);
}
.sayari-mobile-nav-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 20px 16px;
  border-bottom: 1px solid var(--border-light);
  flex-shrink: 0;
}
.sayari-mobile-close {
  background: none;
  border: 1px solid var(--border-light);
  color: var(--signal-white);
  font-size: 16px;
  line-height: 1;
  padding: 6px 10px;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.15s ease;
}
.sayari-mobile-close:hover { background: rgba(255,255,255,0.08); }

/* ── Mobile nav links ── */
.sayari-mobile-links {
  flex: 1;
  padding: 8px 0;
  overflow-y: auto;
}
.sayari-mobile-section {
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.sayari-mobile-parent {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background: none;
  border: none;
  color: var(--signal-white);
  font-family: var(--font-sans, 'Inter', sans-serif);
  font-size: 15px;
  font-weight: 500;
  padding: 14px 20px;
  min-height: 44px; /* WCAG touch target */
  cursor: pointer;
  text-align: left;
  transition: color 0.15s ease;
  -webkit-tap-highlight-color: transparent;
}
.sayari-mobile-parent:hover { color: var(--intel-blue); }
.sayari-mobile-chevron {
  font-size: 18px;
  line-height: 1;
  transition: transform 0.2s ease;
  color: var(--text-muted, #8b949e);
}
.sayari-mobile-parent.is-open .sayari-mobile-chevron { transform: rotate(90deg); }
.sayari-mobile-link {
  display: block;
  color: var(--signal-white);
  font-family: var(--font-sans, 'Inter', sans-serif);
  font-size: 15px;
  font-weight: 500;
  padding: 14px 20px;
  text-decoration: none;
  transition: color 0.15s ease;
}
.sayari-mobile-link:hover { color: var(--intel-blue); }
.sayari-mobile-children {
  list-style: none;
  margin: 0;
  padding: 0 0 8px 0;
  display: none;
  background: rgba(255,255,255,0.03);
}
.sayari-mobile-parent.is-open + .sayari-mobile-children { display: block; }
.sayari-mobile-children li a {
  display: flex;
  align-items: center;
  color: var(--text-muted, #8b949e);
  font-family: var(--font-sans, 'Inter', sans-serif);
  font-size: 14px;
  padding: 0 20px 0 28px;
  min-height: 44px; /* WCAG touch target */
  text-decoration: none;
  transition: color 0.15s ease;
  -webkit-tap-highlight-color: transparent;
}
.sayari-mobile-children li a:hover { color: var(--signal-white); }

/* ── Mobile CTA button ── */
.sayari-mobile-cta {
  display: block;
  margin: 16px 20px 24px;
  background: var(--intel-blue);
  color: #fff;
  font-family: var(--font-sans, 'Inter', sans-serif);
  font-size: 14px;
  font-weight: 600;
  padding: 12px 20px;
  border-radius: 8px;
  text-align: center;
  text-decoration: none;
  transition: opacity 0.15s ease;
  flex-shrink: 0;
}
.sayari-mobile-cta:hover { opacity: 0.88; }

@media (max-width: 1080px) {
  .sayari-nav-links { display: none; }
  .sayari-nav-cta   { display: none; }
  .sayari-hamburger { display: flex; }
  .sayari-nav-inner { padding: 14px 20px; }
}

@media (max-width: 768px) {
  .sayari-compare-row { grid-template-columns: 1fr; }
  .child-grid { grid-template-columns: 1fr; }
  .sayari-stat-strip { flex-direction: column; }
  .section-hero { padding: 120px 0 60px; }
  .proof-logo-bar { gap: 20px; }
  /* Footer grid stacks on mobile */
  footer [style*="grid-template-columns"] { grid-template-columns: 1fr 1fr !important; gap: 24px !important; }
  /* Footer bottom bar - allow full wrap */
  footer [style*="justify-content:space-between"] { flex-direction: column; gap: 12px; }
}
@media (max-width: 480px) {
  footer [style*="grid-template-columns"] { grid-template-columns: 1fr !important; }
  footer { padding-left: 20px !important; padding-right: 20px !important; }
  footer [style*="padding:0 36px"] { padding-left: 20px !important; padding-right: 20px !important; }
}

/* ═══════════════════════════════════════
   WCAG 2.5.5 - Touch-target minimum 44px
   ═══════════════════════════════════════ */
/* Desktop nav links */
.sayari-nav-links a {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  padding-top: 14px;
  padding-bottom: 14px;
}
/* CTA button - already ~34px, bump to 44px */
.sayari-nav-cta {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  padding: 10px 18px;
}
/* Footer links */
footer li a {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}

/* ═══════════════════════════════════════
   CTA CONTRAST FIX - darken primary blue for 5:1+
   ═══════════════════════════════════════ */
.wp-block-button.is-style-primary .wp-block-button__link,
.btn-primary .wp-block-button__link {
  background: #155FCC; /* darkened from #1A73E8 - 5.7:1 with #fff */
}

/* ═══════════════════════════════════════
   FOOTER LINK CONTRAST - bump to #B8C4D0 (7.5:1 on #0D1117)
   ═══════════════════════════════════════ */
footer li a,
footer [style*="display:flex"] a {
  color: #B8C4D0 !important;
}

/* ═══════════════════════════════════════
   RESPONSIVE IMAGES - fluid defaults
   ═══════════════════════════════════════ */
img {
  max-width: 100%;
  height: auto;
}

/* ═══════════════════════════════════════
   WCAG 1.4.4 - Reflow at 400% zoom
   ═══════════════════════════════════════ */
/* At 400% zoom (equiv ~320px effective viewport) stack everything */
@media (max-width: 400px) {
  .sayari-nav-inner { padding: 10px 12px; gap: 8px; max-width: 100% !important; }
  [style*="grid-template-columns"] { grid-template-columns: 1fr !important; }
  [style*="max-width"] { max-width: 100% !important; }
  .outcomes-grid, .use-cases-grid, .capabilities-grid,
  .child-grid, .platform-products { grid-template-columns: 1fr !important; }
  footer [style*="grid-template-columns"] { grid-template-columns: 1fr !important; }
  h1, h2 { font-size: clamp(1.4rem, 5vw, 2rem) !important; }
  * { overflow-wrap: break-word; word-break: break-word; }
}

/* ═══════════════════════════════════════
   MOBILE TEXT READABILITY (M4)
   ═══════════════════════════════════════ */
@media (max-width: 768px) {
  body { font-size: 17px; line-height: 1.7; }
  p, li, td, label, .wp-block-paragraph { font-size: max(16px, inherit); line-height: 1.7; }
  h1 { font-size: clamp(1.6rem, 6vw, 2.4rem); }
  h2 { font-size: clamp(1.3rem, 5vw, 2rem); }
  h3 { font-size: clamp(1.1rem, 4vw, 1.5rem); }
  /* Ensure adequate spacing on mobile */
  section, .pilot-section, [class*="-section"] { padding-left: 20px; padding-right: 20px; }
}

@media (max-width: 1024px) {
  .child-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ═══════════════════════════════════════
   FIXES: DROPDOWN, HOVER UNDERLINE,
   PAGE BREAKS, TIER N
   ═══════════════════════════════════════ */

/* .sayari-dropdown legacy rules removed - Resources/Company now use .sayari-mega-panel */

/* Underline on interactive product/child tiles hover */
.pp-card:hover .pp-name,
.child-card:hover .child-name,
.product-card:hover .product-name,
a.pp-card:hover .pp-name {
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: rgba(26,115,232,.5);
}

/* Fix white page breaks - dark background throughout */
html, body {
  background: #0D1117 !important;
}
.wp-site-blocks,
.is-root-container,
.wp-block-group,
.entry-content,
.site-content {
  background: #0D1117 !important;
}
.wp-block-html {
  margin-block: 0 !important;
  background: #0D1117;
}
/* Remove default block gap that creates visible seams */
.wp-site-blocks > * + * {
  margin-block-start: 0 !important;
}

/* Tier N - keep on one line */
.barrier-stat {
  white-space: nowrap;
}

/* Nav JS-controlled dropdown */
.sayari-dropdown.nav-open {
  display: block;
}

/* ═══════════════════════════════════════
   MOBILE - GLOBAL RESPONSIVE FIXES
   Breakpoints: 768px (phone), 900px (tablet)
   ═══════════════════════════════════════ */

/* Logo carousel - only pause on hover for devices that support hover.
   Prevents tap-to-freeze on touch screens. */
@media (hover: hover) {
  .logo-track:hover { animation-play-state: paused; }
}
/* Override the always-on hover rule for touch devices */
@media (hover: none) {
  .logo-track { animation-play-state: running !important; }
}

/* ── Homepage barrier grid: 4-col → 2-col → 1-col ── */
@media (max-width: 900px) {
  .barrier-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
}
@media (max-width: 480px) {
  .barrier-grid { grid-template-columns: 1fr; }
}

/* ── Global hero top-padding relief on mobile ── */
@media (max-width: 768px) {
  /* Shared hero classes used across content, coverage, sources, glossary pages */
  .cov-hero, .src-hero, .gloss-hero,
  .content-hero, .ind-hero, .sol-hero,
  .persona-hero { padding-top: 100px !important; }

  /* Wrap padding for inline-styled pages */
  .wrap, .wrap-w { padding: 0 20px !important; }

  /* ── Coverage page grids ── */
  .cov-stat-row        { grid-template-columns: repeat(2, 1fr); }
  .region-grid         { grid-template-columns: 1fr; }
  .method-grid         { grid-template-columns: 1fr; }
  .cadence-grid        { grid-template-columns: 1fr; }
  .opaque-list         { grid-template-columns: 1fr; }

  /* ── Sources page grids ── */
  .src-type-grid       { grid-template-columns: 1fr; }
  .src-detail-grid     { grid-template-columns: 1fr; }
  .er-diagram .er-row  { grid-template-columns: 1fr; }
  .er-arrow            { display: none; }
  .cmp-table           { font-size: 12px; }
  .cmp-table th, .cmp-table td { padding: 10px 8px; }

  /* ── Glossary page ── */
  .alpha-nav           { gap: 3px; }
  /* P3-fix: replaced hard width/height:28px with min-width/min-height:44px - WCAG 2.2 SC 2.5.8 */
  .alpha-nav a         { display: inline-flex; align-items: center; justify-content: center; min-width: 44px; min-height: 44px; width: auto; height: auto; line-height: normal; font-size: 12px; }
  .gloss-letter        { font-size: clamp(28px, 8vw, 40px); }
  .term-name           { font-size: 15px; flex-wrap: wrap; }

  /* ── Industry vertical (ind-) pages ── */
  .ind-hero-grid       { grid-template-columns: 1fr; }
  .ind-stat-card       { margin-top: 24px; }
  .challenge-grid      { grid-template-columns: 1fr; }
  .workflow-steps      { grid-template-columns: 1fr; }
  .workflow-steps::before { display: none; }
  .outcome-grid        { grid-template-columns: 1fr; }
  .product-grid        { grid-template-columns: 1fr; }
  .diff-grid           { grid-template-columns: 1fr; }
  .stat-flex           { flex-direction: column; gap: 24px; text-align: center; }
  .stat-divider        { width: 80px; height: 1px; }

  /* ── Nav touch targets - WCAG 2.5.8 Target Size (48px minimum) ── */
  .sayari-dropdown li a { padding: 12px 12px; min-height: 48px; display: flex; align-items: center; }
  .sayari-mobile-children li a { min-height: 48px; display: flex; align-items: center; }
  .sayari-mobile-parent { min-height: 48px; }
  .sayari-nav-cta { padding: 12px 20px; min-height: 48px; }

  /* ── Compare table on mobile ── */
  .cmp-table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }

  /* ── General 3-col → 1-col ── */
  .cov-section .region-grid,
  .src-section .src-type-grid { grid-template-columns: 1fr; }

  /* ── Button stacking ── */
  .cov-hero .fade > div[style*="display:flex"],
  .src-hero .fade > div[style*="display:flex"] { flex-wrap: wrap; }
}

/* ── Tablet: 2-col for some grids ── */
@media (max-width: 900px) and (min-width: 601px) {
  .region-grid         { grid-template-columns: repeat(2, 1fr); }
  .src-type-grid       { grid-template-columns: repeat(2, 1fr); }
  .cadence-grid        { grid-template-columns: repeat(2, 1fr) !important; }
  .src-detail-grid     { grid-template-columns: repeat(2, 1fr); }
  .opaque-list         { grid-template-columns: repeat(2, 1fr); }
}

/* ── Very small screens (≤380px) ── */
@media (max-width: 380px) {
  .cov-stat-row        { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .cov-stat-num        { font-size: 26px; }
  h1                   { font-size: 28px; }
  .btn                 { padding: 10px 18px; font-size: 12px; }
}

/* ══════════════════════════════════════
   GLOBAL MOBILE OVERRIDES (v27)
   Attribute selectors target inline styles directly so media queries
   can override them without needing !important on every element.
   ══════════════════════════════════════ */

/* ── TABLET breakpoint: 3-col → 2-col ── */
@media (max-width: 900px) {
  /* 3-col inline grids → 2-col on tablet */
  [style*="grid-template-columns:repeat(3,1fr)"],
  [style*="grid-template-columns: repeat(3, 1fr)"],
  [style*="grid-template-columns:repeat(3, 1fr)"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  /* 4-col inline grids → 2-col on tablet */
  [style*="grid-template-columns:repeat(4,1fr)"],
  [style*="grid-template-columns: repeat(4, 1fr)"],
  [style*="grid-template-columns:repeat(4, 1fr)"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  /* 5-col inline grids → 3-col on tablet */
  [style*="grid-template-columns:repeat(5,1fr)"],
  [style*="grid-template-columns: repeat(5, 1fr)"] {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

/* ── MOBILE breakpoint: stack everything ── */
@media (max-width: 768px) {
  /* Prevent horizontal scroll on all pages */
  body { overflow-x: hidden; }

  /* ── Inline multi-column grids → single column ── */
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns: 1fr 1fr"],
  [style*="grid-template-columns:repeat(2,1fr)"],
  [style*="grid-template-columns: repeat(2, 1fr)"],
  [style*="grid-template-columns:repeat(3,1fr)"],
  [style*="grid-template-columns: repeat(3, 1fr)"],
  [style*="grid-template-columns:repeat(4,1fr)"],
  [style*="grid-template-columns: repeat(4, 1fr)"],
  [style*="grid-template-columns:repeat(5,1fr)"],
  [style*="grid-template-columns:repeat(3, 1fr)"],
  [style*="grid-template-columns:repeat(4, 1fr)"] {
    grid-template-columns: 1fr !important;
  }

  /* ── Fixed-width sidebar grids → stack ── */
  [style*="280px 1fr"],
  [style*="280px, 1fr"],
  [style*="260px 1fr"],
  [style*="300px 1fr"],
  [style*="320px 1fr"] {
    grid-template-columns: 1fr !important;
  }

  /* ── 2-col hero split grids → stack ── */
  [style*="grid-template-columns:1fr 1fr;gap:64px"],
  [style*="grid-template-columns:1fr 1fr; gap:64px"] {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }

  /* ── Flex items with fixed min-width → full width ── */
  [style*="min-width:300px"],
  [style*="min-width: 300px"],
  [style*="min-width:280px"],
  [style*="min-width: 280px"],
  [style*="min-width:260px"],
  [style*="min-width:400px"],
  [style*="min-width: 400px"] {
    min-width: 0 !important;
    width: 100% !important;
    flex-basis: 100% !important;
  }

  /* ── Inline flex containers → wrap ── */
  [style*="display:flex"][style*="gap:64px"],
  [style*="display:flex"][style*="gap:56px"],
  [style*="display:flex"][style*="gap:48px"] {
    flex-wrap: wrap !important;
    gap: 24px !important;
  }

  /* ── Blog / report hero sidebar → stack ── */
  .blog-hero-inner,
  .rp-hero-inner { flex-direction: column !important; }
  .blog-sidebar,
  .rp-sidebar { width: 100% !important; position: static !important; }

  /* ── Demo page proof strip ── */
  .strip-stats { grid-template-columns: 1fr 1fr !important; gap: 28px; }
  .stat-cell::after { display: none !important; }

  /* ── Layout padding ── */
  .demo-inner,
  .news-wrap,
  .proof-strip-inner,
  .cta-rail-inner { padding-left: 20px !important; padding-right: 20px !important; }

  /* ── CTA rail: stack ── */
  .cta-rail-inner { flex-direction: column; text-align: center; }
  .cta-rail-btns  { flex-direction: column; width: 100%; }
  .cta-rail-btns .btn-primary,
  .cta-rail-btns .btn-outline { text-align: center; }

  /* ── Press/award grids on homepage ── */
  .press-grid { grid-template-columns: 1fr !important; }
  .award-grid { grid-template-columns: 1fr 1fr !important; gap: 14px !important; }

  /* ── Section padding reduction ── */
  section[style*="padding:88px"],
  section[style*="padding: 88px"] { padding-top: 48px !important; padding-bottom: 48px !important; }
  section[style*="padding:72px"],
  section[style*="padding: 72px"] { padding-top: 40px !important; padding-bottom: 40px !important; }
}

@media (max-width: 480px) {
  /* ── Proof strip: fully stacked ── */
  .strip-stats { grid-template-columns: 1fr !important; }
  .award-grid  { grid-template-columns: 1fr !important; }

  /* ── Demo form row: always 1 col ── */
  .form-row { grid-template-columns: 1fr !important; }

  /* ── Reduce all large gaps on small screens ── */
  [style*="gap:64px"] { gap: 20px !important; }
  [style*="gap:56px"] { gap: 20px !important; }
  [style*="gap:48px"] { gap: 16px !important; }
  [style*="gap:40px"] { gap: 16px !important; }
}

/* ═══════════════════════════════════════════════════════════════
   REBRAND v1 - Mega-Menu, Signal Panels, Marketecture
   ═══════════════════════════════════════════════════════════════ */

/* ── Mega-Menu Flyout Panel ── */
.sayari-mega-panel {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  background: #1C2128;
  border: 1px solid #2D333B;
  border-radius: 12px;
  padding: 20px 24px;
  min-width: 380px;
  z-index: 200;
  box-shadow: 0 12px 48px rgba(0,0,0,.55);
}

.sayari-mega-panel::before {
  content: '';
  position: absolute;
  top: -12px;
  left: 0;
  right: 0;
  height: 12px;
}

.sayari-nav-item:hover .sayari-mega-panel,
.sayari-mega-panel.nav-open {
  display: flex;
  gap: 24px;
}

.mega-col {
  flex: 1;
  min-width: 0;
}

.mega-col ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.mega-col ul li a {
  display: block;
  padding: 7px 10px;
  font-size: 13px;
  color: #ADBAC7;
  border-radius: 6px;
  text-decoration: none;
  transition: all 0.15s ease;
}

.mega-col ul li a:hover {
  background: rgba(26,115,232,0.08);
  color: #F7F8FA;
}

.mega-category-label {
  display: block;
  padding: 0 10px 8px;
  font-size: 12px; /* WCAG 2.1 AA minimum - was 9px */
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  pointer-events: none;
}

/* Products mega-menu - wider */
.mega-products {
  min-width: 560px;
}

/* "Soon" badge variant - WCAG SC 1.4.3 fix: #FDE68A on effective dark bg ≈ 10:1 */
.nav-badge-soon {
  display: inline-flex;
  align-items: center;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #FDE68A;
  background: rgba(245,158,11,.18);
  border: 1px solid rgba(245,158,11,.35);
  border-radius: 3px;
  padding: 1px 5px;
  margin-left: 6px;
  vertical-align: middle;
  line-height: 1.6;
}

/* Mobile category labels */
.mobile-cat-label {
  display: block;
  padding: 6px 28px 2px;
  font-size: 12px; /* WCAG 2.1 AA minimum - was 9px */
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  pointer-events: none;
}

/* ── Signal Panel (Farley-style monospace code blocks) ── */
.signal-panel {
  background: #080B0F;
  border: 1px solid #2D333B;
  border-radius: 10px;
  padding: 28px 32px;
  font-family: 'JetBrains Mono', 'Courier New', monospace;
  font-size: 14px;
  line-height: 2.2;
  color: #8B95A1;
  margin: 24px 0;
  overflow-x: auto;
}

.signal-panel .sp-comment {
  color: #8B95A1;
}

.signal-panel .sp-key {
  color: #ADBAC7;
}

.signal-panel .sp-number {
  color: #e8980f;
  font-weight: 600;
}

.signal-panel .sp-value {
  color: #1A73E8;
}

.signal-panel .sp-string {
  color: #e8980f;
}

.signal-panel .sp-label {
  color: #F7F8FA;
  font-weight: 600;
}

/* ── Marketecture Visual ── */
.marketecture {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 20px;
  margin: 40px 0;
}

.marketecture-col {
  border-radius: 10px;
  padding: 28px 24px;
  background: #0D1117;
  position: relative;
}

.marketecture-col.col-cwm {
  border: 2px solid #e8980f;
}

.marketecture-col.col-econsec {
  border: 2px solid #1A73E8;
}

.marketecture-col.col-ucr {
  border: 2px solid #e8980f;
}

.marketecture-col-title {
  font-size: 15px;
  font-weight: 700;
  color: #F7F8FA;
  margin-bottom: 4px;
}

.marketecture-col-sub {
  font-size: 12px;
  color: #8B95A1;
  margin-bottom: 20px;
  font-style: italic;
}

.marketecture-section-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #8B95A1;
  margin: 16px 0 8px;
}

.marketecture-product {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  background: #1C2128;
  border: 1px solid #2D333B;
  border-radius: 8px;
  margin-bottom: 8px;
  transition: border-color 0.2s ease;
}

.marketecture-product:hover {
  border-color: #444C56;
}

.marketecture-product-name {
  font-size: 14px;
  font-weight: 600;
  color: #F7F8FA;
}

.marketecture-product-desc {
  font-size: 12px;
  color: #ADBAC7;
  margin-top: 4px;
  line-height: 1.5;
}

.mp-badge {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 4px;
  white-space: nowrap;
  flex-shrink: 0;
}

.mp-badge-live {
  color: #e8980f;
  background: rgba(232,152,15,0.10);
  border: 1px solid rgba(232,152,15,0.30);
}

.mp-badge-soon {
  color: #1A73E8;
  background: rgba(26,115,232,0.10);
  border: 1px solid rgba(26,115,232,0.30);
}

.mp-badge-beta {
  color: #1A73E8;
  background: rgba(26,115,232,0.10);
  border: 1px solid rgba(26,115,232,0.30);
}

.mp-badge-partner {
  color: #e8980f;
  background: rgba(232,152,15,0.10);
  border: 1px solid rgba(232,152,15,0.30);
}

/* Sideconductor bar */
.sideconductor-bar {
  margin-top: 16px;
  padding: 16px 24px;
  border: 2px dashed #e8980f;
  border-radius: 10px;
  background: rgba(232,152,15,0.04);
  text-align: center;
}

.sideconductor-bar-title {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #e8980f;
  margin-bottom: 4px;
}

.sideconductor-bar-desc {
  font-size: 13px;
  color: #8B95A1;
}

/* Marketecture legend */
.marketecture-legend {
  display: flex;
  justify-content: center;
  gap: 24px;
  flex-wrap: wrap;
  margin-top: 20px;
  font-size: 12px;
  color: #8B95A1;
}

.legend-item {
  display: flex;
  align-items: center;
  gap: 6px;
}

.legend-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* ── Platform context nav strip (product pages) ── */
.platform-nav{background:#1C2128;border-top:1px solid #2D333B;border-bottom:1px solid #2D333B;padding:0;}
.platform-nav-inner{max-width:1080px;margin:0 auto;padding:16px 36px;display:flex;align-items:center;gap:24px;flex-wrap:wrap;}
.pn-label{font-size:10px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:#8B95A1;white-space:nowrap;}
.pn-pillars{display:flex;align-items:center;gap:8px;flex:1;flex-wrap:wrap;}
.pn-pillar{display:flex;align-items:center;gap:8px;}
.pn-pillar-name{font-size:10px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;white-space:nowrap;}
.pn-dot{width:3px;height:3px;border-radius:50%;background:#2D333B;flex-shrink:0;}
.pn-link{font-size:12px;color:#8B95A1;text-decoration:none;white-space:nowrap;transition:color .2s;}
.pn-link:hover{color:#F7F8FA;}
.pn-link.pn-active{color:#F7F8FA;font-weight:600;}
.pn-divider{width:1px;height:16px;background:#2D333B;margin:0 8px;flex-shrink:0;}
.pn-all{font-size:11px;font-weight:600;color:#1A73E8;text-decoration:none;white-space:nowrap;margin-left:auto;}
.pn-all:hover{text-decoration:underline;}

@media (max-width: 768px) {
  .marketecture {
    grid-template-columns: 1fr;
  }
  .sayari-mega-panel {
    min-width: 280px;
  }
  .mega-products {
    min-width: 280px;
    flex-direction: column;
  }
  .platform-nav-inner{flex-direction:column;align-items:flex-start;gap:12px;}
  .pn-pillars{flex-direction:column;align-items:flex-start;gap:8px;}
  .pn-divider{width:100%;height:1px;margin:4px 0;}
}

/* ═══════════════════════════════════════
   v58: CONTAINER QUERIES (EM5 - Emerging Standards)
   ═══════════════════════════════════════
   Progressively enhances card-based layouts so components
   adapt to their container width, not just the viewport. */
.rr-card,
.blog-card,
.cs-card,
.csd-rel-card,
.ib-card,
.sol-card {
  container-type: inline-size;
  container-name: card;
}

@container card (min-width: 400px) {
  .rr-card > *,
  .blog-card > *,
  .cs-card > *,
  .sol-card > * {
    /* Larger cards get slightly more generous spacing */
    padding-left: 28px;
    padding-right: 28px;
  }
}

@container card (max-width: 280px) {
  .rr-card h2,
  .rr-card h3,
  .blog-card h2,
  .blog-card h3 {
    font-size: clamp(15px, 4cqw, 20px);
  }
}

/* ═══════════════════════════════════════
   v58: TOUCH TARGET SIZING (WCAG 2.5.8 - M2/W6)
   ═══════════════════════════════════════
   Ensure all interactive elements meet 44×44px minimum. */

/* Footer social icon - was 32×32, now 44×44 with visual icon centered */
footer a[aria-label*="LinkedIn"],
footer a[aria-label*="Twitter"],
footer a[aria-label*="GitHub"] {
  min-width: 44px !important;
  min-height: 44px !important;
  width: 44px !important;
  height: 44px !important;
}

/* Generic small-link safeguard */
footer a,
.sayari-dropdown a,
.sayari-mega-panel a {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}

/* Mobile close button */
.sayari-mobile-close {
  min-width: 44px;
  min-height: 44px;
}

/* Accordion/FAQ triggers */
button.faq-trigger,
button.acc-trigger,
.sayari-mobile-parent {
  min-height: 44px;
}

/* button.faq-q reset properties now in canonical .faq-q block ~line 2586 */

/* ── Canonical breadcrumb (page-bc) - pill style ────────────────────────── */
.page-bc {
  display: flex;
  gap: 6px;
  align-items: center;
  margin-bottom: 20px;
  flex-wrap: wrap;
  padding: 0;
  list-style: none;
}
.page-bc-sep {
  display: none;
}
.page-bc a {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  font-family: 'JetBrains Mono', monospace;
  text-decoration: none;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  color: var(--tx2);
  transition: background .2s, color .2s, border-color .2s;
}
.page-bc a:hover {
  background: rgba(232,152,15,.15);
  border-color: rgba(232,152,15,.3);
  color: #e8980f;
}
.page-bc-curr {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  font-family: 'JetBrains Mono', monospace;
  background: rgba(232,152,15,.15);
  border: 1px solid rgba(232,152,15,.3);
  color: #e8980f;
}

/* ═══════════════════════════════════════
   v56: RESOURCE TILE TYPOGRAPHY (site-wide canonical)
   ═══════════════════════════════════════
   Standardises .rr-card, .resource-tile, .gmr-card, and inline
   resource tiles to 0.9rem title / 0.85rem meta. Per-page
   overrides in blog templates should match these values. */
.rr-card h4,
.rr-card .rr-title,
.resource-tile h4,
.resource-tile .tile-title {
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1.4;
}
.rr-card p,
.rr-card .rr-meta,
.resource-tile p,
.resource-tile .tile-meta {
  font-size: 0.85rem;
  line-height: 1.6;
}

/* ═══════════════════════════════════════
   HUBSPOT FORM - styled submit button
   Overrides browser-default gray button on embedded HubSpot forms.
   ═══════════════════════════════════════ */
.hbspt-form input[type="submit"],
.hs-button.primary,
.hs-submit input[type="submit"],
.hbspt-form .hs-button {
  background-color: #1A73E8 !important;
  background: #1A73E8 !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 7px !important;
  padding: 13px 28px !important;
  font-family: var(--wp--preset--font-family--inter, inherit) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: background 0.2s ease, box-shadow 0.2s ease !important;
  box-shadow: 0 2px 16px rgba(26,115,232,.35) !important;
  display: inline-block !important;
  min-width: 140px !important;
  text-align: center !important;
}
.hbspt-form input[type="submit"]:hover,
.hs-button.primary:hover,
.hs-submit input[type="submit"]:hover,
.hbspt-form .hs-button:hover {
  background-color: #1557b0 !important;
  background: #1557b0 !important;
  box-shadow: 0 6px 28px rgba(26,115,232,.45) !important;
  transform: translateY(-1px) !important;
}

/* ═══════════════════════════════════════════════════════════════
   F5 FIX v11: HubSpot Form Input Field Dark Theme (Global)
   
   /contact/ and /jp/demo/ were showing plain white browser-default
   form inputs. This CSS ensures the dark theme applies globally to
   all .hs-form instances before JS fires. The functions.php
   MutationObserver reinforces these styles at runtime.
   ═══════════════════════════════════════════════════════════════ */
.hs-form input:not([type="submit"]):not([type="hidden"]),
.hs-form-private input:not([type="submit"]):not([type="hidden"]),
.hs-form select,
.hs-form-private select,
.hs-form textarea,
.hs-form-private textarea {
  background-color: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid rgb(28, 33, 40) !important;
  border-radius: 7px !important;
  color: #ffffff !important;
  padding: 10px 14px !important;
  font-size: 14px !important;
  font-family: var(--wp--preset--font-family--inter, inherit) !important;
  transition: border-color 0.2s ease !important;
}
.hs-form input:not([type="submit"]):not([type="hidden"]):focus,
.hs-form-private input:not([type="submit"]):not([type="hidden"]):focus,
.hs-form select:focus,
.hs-form textarea:focus {
  border-color: #1A73E8 !important;
  outline: none !important;
  box-shadow: 0 0 0 2px rgba(26,115,232,0.65) !important;
}
.hs-form input::placeholder,
.hs-form-private input::placeholder,
.hs-form textarea::placeholder {
  color: rgba(255, 255, 255, 0.4) !important;
}
.hs-form label,
.hs-form-private label,
.hs-form .hs-field-desc {
  color: rgba(255, 255, 255, 0.75) !important;
}
.hs-error-msgs label,
.hs-form .hs-error-msg {
  color: #f87171 !important;
}

/* ── HubSpot form - full-width fields (global, all forms) ── */
.hs-form fieldset,
.hs-form-private fieldset {
  max-width: 100% !important;
  width: 100% !important;
}
.hs-form .hs-form-field,
.hs-form-private .hs-form-field {
  width: 100% !important;
  float: none !important;
  padding: 0 !important;
  margin-bottom: 10px;
}
.hs-form .input,
.hs-form-private .input {
  margin-right: 0 !important;
}
.hs-form input:not([type="submit"]):not([type="hidden"]),
.hs-form-private input:not([type="submit"]):not([type="hidden"]),
.hs-form select,
.hs-form-private select,
.hs-form textarea,
.hs-form-private textarea {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

/* ═══════════════════════════════════════
   PHASE 1 CENTRALIZATION - v59 (April 2026)
   Rules appearing in 65+ templates moved here.
   All template <style> block duplicates of these selectors
   have been stripped. Do NOT re-add these to individual templates.
   ═══════════════════════════════════════ */

/* ── Key Takeaways callout box ── */
.key-takeaways { background:#1C2128;border-left:4px solid #1A73E8;padding:24px 28px;margin:32px 0;border-radius:8px; }
.key-takeaways h3 { margin:0 0 14px;font-size:1rem;color:#F7F8FA;font-weight:700; }
.key-takeaways ul { margin:0;padding-left:18px; }
.key-takeaways li { margin-bottom:9px;font-size:.9rem;color:#ADBAC7; }

/* ── Blog / article body typography ── */
.blog-body { max-width:680px; }
.blog-body p { font-size:1rem;color:#ADBAC7;line-height:1.8;margin-bottom:20px; }
.blog-body ul { margin:16px 0 20px 24px;color:#ADBAC7; }
.blog-body li { margin-bottom:10px;line-height:1.7; }

/* ── Green CTA button (clearance/success variant) ── */
.btn-green { background:#e8980f;color:#0D1117;padding:14px 28px;border-radius:8px;font-weight:700;font-size:.95rem;text-decoration:none;display:inline-block;transition:opacity .2s; }
.btn-green:hover { opacity:.85; }

/* ── Resource / report section labels ── */
.rr-section-label { font-size:.75rem;font-weight:700;color:#9BA8B5;text-transform:uppercase;letter-spacing:.12em;margin-bottom:24px; }

/* ═══════════════════════════════════════
   PHASE 2 CENTRALIZATION - v61 (April 2026)
   10 selectors resolved from per-template <style> blocks.
   Canonical values approved by Benjamin Power, April 12 2026.
   Do NOT re-add these base rules to individual templates.
   Template-specific overrides (agent-composer, mcp, econ-sec-helm,
   agent-builder, case-studies) are documented in REQUIREMENTS.md §3.
   ═══════════════════════════════════════ */

/* ── Scroll-reveal: initial hidden state ── */
.s-stagger > * {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .5s ease, transform .5s ease;
}
/* Cascade delays for nth-child stagger (added fresh - 0.1s cadence) */
.s-stagger > *:nth-child(1) { transition-delay: 0s; }
.s-stagger > *:nth-child(2) { transition-delay: 0.1s; }
.s-stagger > *:nth-child(3) { transition-delay: 0.2s; }
.s-stagger > *:nth-child(4) { transition-delay: 0.3s; }

/* ── Scroll-reveal: visible state (JS adds .s-vis to element) ── */
/* Single-class rule - works when there is no competing .s-fade in inline styles */
.s-vis {
  opacity: 1;
  transform: translateY(0);
}
/* Higher-specificity override - beats .s-fade { opacity:0 } in per-template inline <style>
   blocks (which load after style.css and win the cascade at equal specificity 0,1,0).
   Compound selector 0,2,0 wins regardless of document order. */
.s-fade.s-vis,
.fade.vis {
  opacity: 1 !important;
  transform: translateY(0) !important;
}
/* Stagger children become visible when parent receives .s-vis */
.s-stagger.s-vis > * {
  opacity: 1;
  transform: translateY(0);
}

/* ── Hero CTA buttons - amber on Solutions pages ── */
.sol-hero-cta .btn,
.ind-hero .btn {
  background: #e8980f;
  color: #0D1117;
}
.sol-hero-cta .btn:hover,
.ind-hero .btn:hover {
  background: #f5b942;
  color: #0D1117;
}

/* ── Button hover states ── */
/* Base .btn gets a subtle lift + softer glow */
.btn:hover {
  box-shadow: 0 4px 20px rgba(26,115,232,.3);
  transform: translateY(-1px);
}
/* Primary CTA: stronger glow + lift */
.btn-primary:hover {
  box-shadow: 0 6px 24px rgba(26,115,232,.35);
  transform: translateY(-1px);
}
/* Outline variant: same shadow + lift as primary */
.btn-outline:hover {
  box-shadow: 0 6px 24px rgba(26,115,232,.35);
  transform: translateY(-1px);
}

/* ── Section heading ── */
.section-h2 {
  font-family: 'Merriweather', Georgia, serif;
  font-size: clamp(26px, 3.4vw, 38px);
  font-weight: 700;
  line-height: 1.2;
  color: #F7F8FA;
  margin: 0 0 24px 0;
}

/* ── Body text (approved 16px/1.7 - overrides prior 17px/1.6 standard) ── */
.body-text {
  font-family: Inter, sans-serif;
  font-size: 16px;
  line-height: 1.7;
  color: #ADBAC7;
  margin: 0;
}

/* ── Label / eyebrow text ── */
.lb {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
}

/* ── Content-detail card hover ── */
.cd:hover {
  transform: translateY(-3px);
  border-color: rgba(26,115,232,.15);
  background: rgba(255,255,255,.04);
}

/* ═══════════════════════════════════════════════════════════════
   FAQ - Canonical single design (v66+, April 2026)
   All solution/use-case templates rely on these rules only.
   No FAQ CSS should appear in individual template <style> blocks.
   LP templates (page-lp-*) use their own clp-faq section CSS.
   ═══════════════════════════════════════════════════════════════ */
.faq-band {
  padding: 64px 0;
  background: var(--obsidian-deep);
  border-top: 1px solid var(--border-light);
}
.faq-list {
  display: flex;
  flex-direction: column;
  margin-top: 28px;
  border: 1px solid var(--border-light);
  border-radius: 10px;
  overflow: hidden;
}
.faq-item {
  border-bottom: 1px solid var(--border-light);
}
.faq-item:last-child {
  border-bottom: none;
}
.faq-q {
  padding: 18px 22px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: rgba(255,255,255,.015);
  user-select: none;
  width: 100%;
  border: none;
  text-align: left;
  color: inherit;
  font-family: inherit;
}
.faq-q::after {
  content: '+';
  color: var(--text-dim);
  font-size: 16px;
  font-weight: 400;
  transition: transform .25s;
  flex-shrink: 0;
  margin-left: 16px;
  display: inline-block;
}
.faq-item.open .faq-q::after {
  transform: rotate(45deg);
}
.faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height .4s ease;
}
.faq-item.open .faq-a {
  max-height: 1500px;
}
.faq-a p {
  padding: 0 22px 18px;
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.75;
  margin: 0;
}


/* ═══════════════════════════════════════════════════════════════
   PHASE 3 CENTRALIZATION - v63 (April 2026)
   Blog/content layout, resource-row, reports, investigation
   briefs, case studies, and webinar CSS extracted from 97 templates.
   Canonical values approved by Benjamin Power, April 2026.
   Do NOT re-add stripped rules to individual templates.
   Intentional per-template overrides remain in their <style> blocks.
   ═══════════════════════════════════════════════════════════════ */

/* ── Scroll-reveal: base hidden state (centralized from all content types) ── */
.s-fade {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .65s cubic-bezier(.25,.46,.45,.94), transform .65s cubic-bezier(.25,.46,.45,.94);
}

/* ── Blog / Content layout ──────────────────────────────────────────────────── */
.bl-sources {
  max-width:680px;
  margin:60px auto 0;
  padding:0 40px;
}
.bl-sources-list {
  list-style:none;
  padding:0;
  margin:0;
}
.bl-sources-list a {
  color:#1A73E8;
  font-size:.95rem;
  line-height:1.6;
}
.bl-sources-list li { margin-bottom:12px; }
.bl-sources-title {
  font-size:1.25rem;
  font-weight:700;
  color:#F7F8FA;
  margin-bottom:20px;
}
.blog-author {
  font-size:13px;
  color:#9BA8B5;
}
.blog-badge {
  font-size:.75rem;
  font-weight:700;
  padding:6px 12px;
  background:#1C2128;
  border-radius:4px;
  color:#9BA8B5;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.blog-badge.category {
  color:#1A73E8;
  background:transparent;
  border:1px solid #1A73E8;
  padding:5px 11px;
}
.blog-body h2 {
  font-size:1.55rem;
  font-weight:700;
  color:#F7F8FA;
  margin:48px 0 18px;
  line-height:1.25;
  scroll-margin-top:80px;
}
.blog-body strong { color:#F7F8FA; }
.blog-container {
  max-width:960px;
  margin:0 auto;
  padding:60px 40px 80px;
  display:grid;
  grid-template-columns:200px 1fr;
  gap:40px;
}
.blog-date {
  font-size:.85rem;
  color:#9BA8B5;
}
.blog-hero h1 {
  font-size:clamp(1.8rem,4vw,2.8rem);
  font-weight:700;
  color:#F7F8FA;
  line-height:1.2;
  margin:0 0 28px;
}
.blog-hero-excerpt {
  font-size:1.1rem;
  color:#ADBAC7;
  line-height:1.75;
  margin-bottom:28px;
  max-width:680px;
}
.blog-hero-inner {
  max-width:820px;
  margin:0 auto;
  padding:0 40px;
}
.blog-meta {
  display:flex;
  gap:12px;
  align-items:center;
  margin-bottom:24px;
  flex-wrap:wrap;
}
.blog-toc {
  position:sticky;
  top:40px;
  height:fit-content;
}
.blog-toc h3 {
  font-size:.75rem;
  font-weight:700;
  color:#F7F8FA;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:16px;
}
.blog-toc-link {
  display:block;
  font-size:.82rem;
  color:#9BA8B5;
  text-decoration:none;
  margin-bottom:10px;
  padding-left:12px;
  border-left:2px solid transparent;
  transition:all .2s;
  line-height:1.5;
}
.blog-toc-link:hover,.blog-toc-link.active {
  color:#F7F8FA;
  border-left-color:#1A73E8;
  font-weight:600;
  color:#1A73E8;
}
.cta-block {
  background:#1C2128;
  padding:44px 40px;
  border-radius:12px;
  text-align:center;
  margin:60px 0;
}
.cta-block h3 {
  font-size:1.35rem;
  font-weight:700;
  color:#F7F8FA;
  margin-bottom:14px;
}
.cta-block p {
  font-size:.9rem;
  color:#9BA8B5;
  margin-bottom:24px;
}
.rr-badge-case {
  background:#251A35;
  color:#9C6BE8;
}
.rr-badge-guide {
  background:#162A20;
  color:#e8980f;
}
.rr-badge-report {
  background:#1A2A3A;
  color:#1A73E8;
}
.rr-badge-sm {
  font-size:.65rem;
  font-weight:700;
  padding:4px 8px;
  border-radius:3px;
  text-transform:uppercase;
  letter-spacing:.06em;
  display:inline-block;
  margin-bottom:12px;
}
.rr-card {
  background:#1C2128;
  border:1px solid #2D333B;
  border-radius:10px;
  padding:24px;
  display:flex;
  flex-direction:column;
  text-decoration:none;
  transition:border-color .2s,transform .2s;
}
.rr-card h4 {
  font-size:.9rem;
  font-weight:700;
  color:#F7F8FA;
  margin-bottom:10px;
  line-height:1.4;
  flex:1;
}
.rr-card p {
  font-size:.85rem;
  color:#9BA8B5;
  line-height:1.6;
  margin-bottom:16px;
}
.rr-card-cta {
  font-size:.82rem;
  color:#1A73E8;
  font-weight:600;
}
.rr-card:hover {
  border-color:#1A73E8;
  transform:translateY(-2px);
}
.rr-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.rr-section {
  background:#0D1117;
  padding:60px 0;
  border-top:1px solid #1C2128;
}
.rr-wrap {
  max-width:960px;
  margin:0 auto;
  padding:0 40px;
}

@media(max-width:1024px) {
  .blog-container {
    grid-template-columns:1fr;
    padding-top:40px;
  }
  .blog-toc {
    position:relative;
    top:auto;
    margin-bottom:32px;
  }
}

@media(max-width:640px) {
  .blog-container {
    padding-top:40px;
    padding-bottom:60px;
  }
  .blog-hero { padding:80px 0 40px; }
  .blog-hero-inner,.blog-container { padding:0 24px; }
}

@media(max-width:768px) {
  .rr-grid { grid-template-columns:1fr; }
  .rr-wrap { padding:0 24px; }
}
/* ── Reports ──────────────────────────────────────────────────── */
.5;}50% { opacity:1; }
.btn-dl-primary {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  background:var(--teal);
  color:#06090F;
  font-weight:700;
  font-size:.88rem;
  padding:13px 20px;
  border-radius:6px;
  width:100%;
  transition:background .2s;
  margin-bottom:10px;
}
.btn-dl-primary:hover { background:#00a888; }
.btn-dl-secondary {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  background:transparent;
  color:var(--tx2);
  font-size:.82rem;
  font-weight:600;
  padding:11px 20px;
  border-radius:6px;
  border:1px solid var(--mist);
  width:100%;
  transition:border-color .2s,color .2s;
}
.btn-dl-secondary:hover {
  border-color:var(--tx3);
  color:var(--tx1);
}
.rp-article { min-width:0; }
.rp-article h2 {
  font-size:1.35rem;
  font-weight:700;
  color:var(--tx1);
  margin:48px 0 16px;
  padding-top:48px;
  border-top:1px solid var(--cloud);
  page-break-after:avoid;
  break-after:avoid;
}
.rp-article h2 + p, .rp-article h3 + p {
  page-break-before:avoid;
  break-before:avoid;
}
.rp-article h2:first-child {
  margin-top:0;
  padding-top:0;
  border-top:none;
}
.rp-article h3 {
  font-size:1.05rem;
  font-weight:700;
  color:var(--tx1);
  margin:28px 0 12px;
  page-break-after:avoid;
  break-after:avoid;
}
.rp-article li {
  font-size:.9rem;
  color:var(--tx2);
  line-height:1.7;
  display:flex;
  gap:10px;
}
.rp-article li::before {
  content:'→';
  color:var(--teal);
  font-weight:700;
  font-size:.8rem;
  flex-shrink:0;
  margin-top:2px;
}
.rp-article p {
  font-size:.92rem;
  color:var(--tx2);
  line-height:1.85;
  margin-bottom:18px;
}
.rp-article strong {
  color:var(--tx1);
  font-weight:600;
}
.rp-article ul {
  margin:0 0 18px 0;
  padding-left:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.rp-article ul,.rp-article ol {
  margin:0 0 18px 0;
  padding-left:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.rp-badge {
  font-family:'JetBrains Mono',monospace;
  font-size:.6rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:4px 10px;
  border-radius:3px;
}
.rp-badge-gov {
  color:var(--violet);
  background:var(--violet-dim);
  border:1px solid var(--violet-bd);
}
.rp-badge-new {
  color:var(--blue);
  background:var(--blue-dim);
  border:1px solid var(--blue-bd);
}
.rp-badge-report {
  color:var(--teal);
  background:rgba(232,152,15,.1);
  border:1px solid rgba(232,152,15,.25);
}
.rp-bc-inner {
  max-width:1200px;
  margin:0 auto;
  padding:0 40px;
  display:flex;
  gap:8px;
  align-items:center;
  font-size:.72rem;
  color:var(--tx3);
}
.rp-bc-inner a {
  color:var(--tx3);
  transition:color .2s;
}
.rp-bc-inner a:hover { color:var(--tx2); }
.rp-bc-sep { opacity:.4; }
.rp-body {
  max-width:1200px;
  margin:0 auto;
  padding:60px 40px;
  display:grid;
  grid-template-columns:1fr 280px;
  gap:60px;
  align-items:start;
}
.rp-breadcrumb {
  background:var(--obs);
  border-bottom:1px solid var(--cloud);
  padding:14px 0;
}
.rp-callout {
  background:var(--cloud);
  border:1px solid var(--mist);
  border-left:3px solid var(--violet);
  border-radius:0 8px 8px 0;
  padding:20px 24px;
  margin:28px 0;
}
.rp-callout p {
  font-size:.86rem;
  color:var(--tx2);
  line-height:1.7;
  margin-bottom:0;
}
.rp-callout-label {
  font-family:'JetBrains Mono',monospace;
  font-size:.6rem;
  font-weight:700;
  color:var(--violet);
  text-transform:uppercase;
  letter-spacing:.1em;
  margin-bottom:8px;
}
.rp-data-cell {
  background:var(--cloud);
  border:1px solid var(--mist);
  border-radius:8px;
  padding:20px 22px;
}
.rp-data-cell-label {
  font-size:.76rem;
  color:var(--tx3);
  line-height:1.5;
}
.rp-data-cell-num {
  font-family:'JetBrains Mono',monospace;
  font-size:1.5rem;
  font-weight:700;
  color:var(--blue);
  line-height:1;
  margin-bottom:6px;
}
.rp-data-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
  margin:24px 0;
}
.rp-date {
  font-size:.75rem;
  color:var(--tx3);
}
.rp-dl-divider {
  border:none;
  border-top:1px solid var(--mist);
  margin:20px 0;
}
.rp-dl-note {
  font-size:.68rem;
  color:var(--tx4);
  margin-top:12px;
  text-align:center;
  line-height:1.5;
}
.rp-dl-panel {
  background:linear-gradient(165deg,#161B26 0%,#1C2231 100%);
  border:1px solid rgba(26,115,232,.25);
  border-radius:12px;
  padding:28px 22px 24px;
  min-width:260px;
  max-width:280px;
  box-shadow:0 4px 24px rgba(26,115,232,.12),0 1px 3px rgba(0,0,0,.3);
  position:relative;
}
.rp-dl-panel h3 {
  font-size:.88rem;
  font-weight:700;
  color:var(--tx1);
  line-height:1.4;
  margin-bottom:16px;
}
.rp-dl-panel-label {
  font-size:.65rem;
  font-weight:700;
  color:var(--tx3);
  text-transform:uppercase;
  letter-spacing:.12em;
  margin-bottom:12px;
}
.rp-dl-panel::before {
  content:'';
  position:absolute;
  top:-1px;
  left:-1px;
  right:-1px;
  height:3px;
  background:linear-gradient(90deg,var(--violet),var(--green),var(--blue));
  border-radius:12px 12px 0 0;
  z-index:1;
}
.rp-dl-trust {
  display:flex;
  align-items:center;
  gap:6px;
  margin-top:14px;
  font-size:.68rem;
  color:var(--tx3);
}
.rp-dl-trust svg {
  width:12px;
  height:12px;
  fill:none;
  stroke:var(--green);
  stroke-width:2;
}
.rp-finding {
  background:var(--cloud);
  padding:32px 36px;
}
.rp-finding-label {
  font-size:.78rem;
  color:var(--tx2);
  line-height:1.55;
  margin-top:8px;
}
.rp-finding-num {
  font-family:'JetBrains Mono',monospace;
  font-size:2.2rem;
  font-weight:700;
  line-height:1;
}
.rp-finding-num.c-alert { color:var(--alert); }
.rp-finding-num.c-blue { color:var(--blue); }
.rp-finding-num.c-green { color:var(--teal); }
.rp-finding-num.c-violet { color:var(--violet); }
.rp-findings {
  background:var(--cloud);
  border-top:1px solid var(--mist);
  border-bottom:1px solid var(--mist);
  padding:40px 0;
}
.rp-findings-inner {
  max-width:1200px;
  margin:0 auto;
  padding:0 40px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--mist);
}
.rp-hero {
  padding:64px 0 56px;
  background:var(--obs);
  border-bottom:1px solid var(--cloud);
}
.rp-hero h1 {
  font-size:clamp(1.6rem,2.8vw,2.5rem);
  font-weight:700;
  line-height:1.2;
  color:var(--tx1);
  margin-bottom:18px;
}
.rp-hero-content { max-width:720px; }
.rp-hero-deck {
  font-size:1rem;
  color:var(--tx2);
  line-height:1.75;
  margin-bottom:24px;
}
.rp-hero-inner {
  max-width:1200px;
  margin:0 auto;
  padding:0 40px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:40px;
  align-items:start;
}
.rp-hero-meta {
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:20px;
  flex-wrap:wrap;
}
.rp-hero-signals {
  display:flex;
  gap:32px;
  flex-wrap:wrap;
}
.rp-hero-tags {
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  margin-bottom:28px;
}
.rp-hero-teaser {
  margin-top:28px;
  padding-top:22px;
  border-top:1px solid var(--cloud);
}
.rp-hero-teaser-items {
  display:flex;
  flex-direction:column;
  gap:8px;
}
.rp-hero-teaser-items li {
  font-size:.78rem;
  color:var(--tx2);
  line-height:1.55;
  display:flex;
  gap:10px;
  align-items:flex-start;
  list-style:none;
}
.rp-hero-teaser-items li::before {
  content:'→';
  color:var(--green);
  font-weight:700;
  font-size:.72rem;
  flex-shrink:0;
  margin-top:1px;
}
.rp-hero-teaser-label {
  font-size:.6rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--tx3);
  margin-bottom:14px;
  display:flex;
  align-items:center;
  gap:8px;
}
.rp-hero-teaser-label::after {
  content:'';
  flex:1;
  height:1px;
  background:var(--cloud);
}
.rp-nation-card {
  background:var(--cloud);
  border:1px solid var(--mist);
  border-radius:8px;
  padding:20px 22px;
}
.rp-nation-card h4 {
  font-size:.88rem;
  font-weight:700;
  color:var(--tx1);
  margin-bottom:8px;
  line-height:1.3;
}
.rp-nation-card p {
  font-size:.78rem;
  color:var(--tx3);
  line-height:1.6;
}
.rp-nation-card-flag {
  font-size:.65rem;
  font-weight:700;
  color:var(--teal);
  text-transform:uppercase;
  letter-spacing:.12em;
  margin-bottom:8px;
}
.rp-nation-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
  margin:24px 0;
}
.rp-pullquote {
  border-left:3px solid var(--teal);
  padding:20px 28px;
  background:rgba(232,152,15,.04);
  border-radius:0 6px 6px 0;
  margin:32px 0;
}
.rp-pullquote cite {
  font-size:.72rem;
  color:var(--tx3);
  font-style:normal;
  display:block;
  margin-top:10px;
}
.rp-pullquote p {
  font-size:1rem;
  color:var(--tx1);
  font-style:italic;
  line-height:1.7;
  margin-bottom:0;
}
.rp-rel-card {
  background:var(--obs);
  border:1px solid var(--mist);
  border-top:3px solid var(--teal);
  border-radius:8px;
  padding:22px 20px;
}
.rp-rel-card h3 {
  font-size:.88rem;
  font-weight:700;
  color:var(--tx1);
  line-height:1.4;
  margin-bottom:8px;
}
.rp-rel-card p {
  font-size:.76rem;
  color:var(--tx3);
  line-height:1.6;
}
.rp-rel-card-type {
  font-family:'JetBrains Mono',monospace;
  font-size:.58rem;
  color:var(--teal);
  text-transform:uppercase;
  letter-spacing:.1em;
  margin-bottom:10px;
}
.rp-rel-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.rp-related {
  border-top:1px solid var(--cloud);
  padding:56px 0;
  background:var(--cloud);
}
.rp-related-cta {
  font-size:.8rem;
  font-weight:600;
  color:var(--teal);
}
.rp-related-head {
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:28px;
}
.rp-related-inner {
  max-width:1200px;
  margin:0 auto;
  padding:0 40px;
}
.rp-related-item {
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:10px 0;
  border-bottom:1px solid var(--mist);
}
.rp-related-item a {
  display:flex;
  flex-direction:column;
  gap:4px;
}
.rp-related-item h4 {
  font-size:.8rem;
  font-weight:600;
  color:var(--tx1);
  line-height:1.4;
  transition:color .2s;
}
.rp-related-item h4:hover { color:var(--teal); }
.rp-related-item span {
  font-size:.68rem;
  color:var(--tx3);
}
.rp-related-item:last-child {
  border-bottom:none;
  padding-bottom:0;
}
.rp-related-label {
  font-size:.68rem;
  font-weight:700;
  color:var(--tx3);
  text-transform:uppercase;
  letter-spacing:.14em;
}
.rp-scroll-hint {
  margin-top:18px;
  display:flex;
  align-items:center;
  gap:8px;
  font-size:.72rem;
  color:var(--tx3);
  animation:rp-pulse 2s ease-in-out infinite;
}
.rp-scroll-hint svg {
  width:14px;
  height:14px;
  fill:none;
  stroke:var(--violet);
  stroke-width:2;
  animation:rp-bounce 2s ease-in-out infinite;
}
.rp-section-id {
  display:block;
  height:0;
  pointer-events:none;
}
.rp-sidebar {
  position:sticky;
  top:80px;
}
.rp-sidebar-card {
  background:var(--cloud);
  border:1px solid var(--mist);
  border-radius:8px;
  padding:20px;
  margin-bottom:16px;
}
.rp-sidebar-card-label {
  font-size:.62rem;
  font-weight:700;
  color:var(--tx3);
  text-transform:uppercase;
  letter-spacing:.12em;
  margin-bottom:12px;
}
.rp-signal {
  display:flex;
  flex-direction:column;
  gap:4px;
}
.rp-signal-lbl {
  font-size:.7rem;
  color:var(--tx3);
  max-width:180px;
  line-height:1.45;
}
.rp-signal-num {
  font-family:'JetBrains Mono',monospace;
  font-size:1.6rem;
  font-weight:700;
  line-height:1;
}
.rp-stat-inline {
  background:var(--cloud);
  border:1px solid var(--mist);
  border-radius:8px;
  padding:24px 28px;
  margin:28px 0;
  display:flex;
  gap:20px;
  align-items:center;
}
.rp-stat-inline-num {
  font-family:'JetBrains Mono',monospace;
  font-size:2rem;
  font-weight:700;
  color:var(--teal);
  white-space:nowrap;
}
.rp-stat-inline-text {
  font-size:.85rem;
  color:var(--tx2);
  line-height:1.65;
}
.rp-tag {
  font-size:.62rem;
  color:var(--tx3);
  border:1px solid var(--mist);
  border-radius:3px;
  padding:4px 10px;
  background:var(--cloud);
}
.rp-toc-label {
  font-size:.65rem;
  font-weight:700;
  color:var(--tx3);
  text-transform:uppercase;
  letter-spacing:.12em;
  margin-bottom:10px;
}
.rp-toc-list {
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.rp-toc-list li a {
  font-size:.78rem;
  color:var(--tx3);
  display:flex;
  align-items:center;
  gap:8px;
  padding:5px 0;
  border-left:2px solid transparent;
  padding-left:10px;
  transition:color .2s,border-color .2s;
}
.rp-toc-list li a:hover,.rp-toc-list li a.active {
  color:var(--tx1);
  border-left-color:var(--teal);
}
.rp-toc-num {
  font-family:'JetBrains Mono',monospace;
  font-size:.6rem;
  color:var(--tx4);
}

@media(max-width:768px) {
  .rp-bc-inner,.rp-hero-inner,.rp-findings-inner,.rp-body,.rp-related-inner {
    padding-left:20px;
    padding-right:20px;
  }
  .rp-hero { padding:48px 0 40px; }
  .rp-rel-grid { grid-template-columns:1fr; }
}

@media(max-width:900px) {
  .rp-body { grid-template-columns:1fr; }
  .rp-data-grid { grid-template-columns:1fr; }
  .rp-dl-panel {
    position:static;
    max-width:100%;
    min-width:unset;
  }
  .rp-findings-inner {
    grid-template-columns:1fr;
    gap:0;
  }
  .rp-hero-inner { grid-template-columns:1fr; }
  .rp-nation-grid { grid-template-columns:1fr; }
  .rp-rel-grid { grid-template-columns:1fr 1fr; }
  .rp-sidebar { position:static; }
}
/* ── Investigation Briefs ──────────────────────────────────────────────────── */
.btn-dl-primary {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  background:var(--orange);
  color:#fff;
  font-weight:700;
  font-size:.88rem;
  padding:13px 20px;
  border-radius:6px;
  width:100%;
  transition:background .2s;
  margin-bottom:10px;
  cursor:pointer;
  border:none;
}
.btn-dl-primary:hover { background:#e55a2b; }
.btn-dl-secondary {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  background:transparent;
  color:var(--tx2);
  font-size:.82rem;
  font-weight:600;
  padding:11px 20px;
  border-radius:6px;
  border:1px solid var(--mist);
  width:100%;
  transition:border-color .2s,color .2s;
}
.btn-dl-secondary:hover {
  border-color:var(--tx3);
  color:var(--tx1);
}
.btn-ghost {
  display:inline-flex;
  align-items:center;
  padding:13px 28px;
  font-size:.85rem;
  font-weight:600;
  color:var(--tx2);
  border:1px solid var(--mist);
  border-radius:7px;
  margin-left:12px;
  transition:all .2s;
}
.btn-ghost:hover {
  border-color:var(--tx3);
  color:var(--tx1);
}
.btn-orange {
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:13px 28px;
  font-size:.85rem;
  font-weight:600;
  background:var(--orange);
  color:#fff;
  border-radius:7px;
  transition:all .2s;
}
.btn-orange:hover {
  box-shadow:0 6px 20px rgba(232,152,15,.3);
  transform:translateY(-1px);
}
.c-alert { color:var(--alert); }
.c-blue { color:var(--blue); }
.c-green { color:var(--green); }
.c-orange { color:var(--orange); }
/* faq-a p, faq-item, faq-q, faq-q::after - see canonical block ~line 2584 */
.rp-article { min-width:0; }
.rp-article h2 {
  font-size:1.3rem;
  font-weight:700;
  color:var(--tx1);
  margin:48px 0 16px;
  padding-top:48px;
  border-top:1px solid var(--cloud);
}
.rp-article h2:first-child {
  margin-top:0;
  padding-top:0;
  border-top:none;
}
.rp-article li {
  font-size:.9rem;
  color:var(--tx2);
  line-height:1.7;
  display:flex;
  gap:10px;
}
.rp-article li::before {
  content:'→';
  color:var(--orange);
  font-weight:700;
  font-size:.8rem;
  flex-shrink:0;
  margin-top:2px;
}
.rp-article p {
  font-size:.92rem;
  color:var(--tx2);
  line-height:1.85;
  margin-bottom:18px;
}
.rp-article strong {
  color:var(--tx1);
  font-weight:600;
}
.rp-article ul,.rp-article ol {
  margin:0 0 18px 0;
  padding-left:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.rp-badge {
  font-family:'JetBrains Mono',monospace;
  font-size:.6rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:4px 10px;
  border-radius:3px;
}
.rp-badge-ib {
  color:var(--orange);
  background:var(--orange-dim);
  border:1px solid var(--orange-bd);
}
.rp-badge-new {
  color:var(--blue);
  background:var(--blue-dim);
  border:1px solid var(--blue-bd);
}
.rp-bc-inner {
  max-width:1200px;
  margin:0 auto;
  padding:0 40px;
  display:flex;
  gap:8px;
  align-items:center;
  font-size:.72rem;
  color:var(--tx3);
}
.rp-bc-inner a {
  color:var(--tx3);
  transition:color .2s;
}
.rp-bc-inner a:hover { color:var(--tx2); }
.rp-bc-sep { opacity:.4; }
.rp-body {
  max-width:1200px;
  margin:0 auto;
  padding:60px 40px;
  display:grid;
  grid-template-columns:1fr 320px;
  gap:60px;
  align-items:start;
}
.rp-breadcrumb {
  background:var(--obs);
  border-bottom:1px solid var(--cloud);
  padding:14px 0;
}
.rp-callout {
  background:var(--cloud);
  border:1px solid var(--mist);
  border-left:3px solid var(--orange);
  border-radius:0 8px 8px 0;
  padding:20px 24px;
  margin:28px 0;
}
.rp-callout p {
  font-size:.86rem;
  color:var(--tx2);
  line-height:1.7;
  margin-bottom:0;
}
.rp-callout-label {
  font-family:'JetBrains Mono',monospace;
  font-size:.6rem;
  font-weight:700;
  color:var(--orange);
  text-transform:uppercase;
  letter-spacing:.1em;
  margin-bottom:8px;
}
.rp-cta {
  padding:64px 0;
  text-align:center;
  border-top:1px solid var(--mist);
}
.rp-cta h2 {
  font-size:clamp(1.4rem,2.4vw,2rem);
  font-weight:700;
  color:var(--tx1);
  margin-bottom:12px;
}
.rp-cta p {
  font-size:.9rem;
  color:var(--tx2);
  margin-bottom:28px;
}
.rp-date {
  font-size:.75rem;
  color:var(--tx3);
}
.rp-dl-cover {
  object-fit:cover;
  max-height:360px;
}
.rp-dl-divider {
  border:none;
  border-top:1px solid var(--mist);
  margin:20px 0;
}
.rp-dl-form-wrap { min-height:180px; }
.rp-dl-note {
  font-size:.68rem;
  color:var(--tx4);
  margin-top:12px;
  text-align:center;
  line-height:1.5;
}
.rp-dl-panel { overflow:hidden; }
.rp-dl-panel h3 {
  font-size:.88rem;
  font-weight:700;
  color:var(--tx1);
  line-height:1.4;
  margin-bottom:16px;
}
.rp-dl-panel-label {
  font-size:.65rem;
  font-weight:700;
  color:var(--tx3);
  text-transform:uppercase;
  letter-spacing:.12em;
  margin-bottom:12px;
}
.rp-finding {
  background:var(--cloud);
  padding:32px 36px;
}
.rp-finding-label {
  font-size:.78rem;
  color:var(--tx2);
  line-height:1.55;
  margin-top:8px;
}
.rp-finding-num {
  font-family:'JetBrains Mono',monospace;
  font-size:2rem;
  font-weight:700;
  line-height:1;
}
.rp-findings {
  background:var(--cloud);
  border-top:1px solid var(--mist);
  border-bottom:1px solid var(--mist);
  padding:40px 0;
}
.rp-findings-inner {
  max-width:1200px;
  margin:0 auto;
  padding:0 40px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--mist);
}
.rp-hero {
  padding:64px 0 56px;
  background:var(--obs);
  border-bottom:1px solid var(--cloud);
}
.rp-hero h1 {
  font-size:clamp(1.5rem,2.6vw,2.3rem);
  font-weight:700;
  line-height:1.2;
  color:var(--tx1);
  margin-bottom:18px;
}
.rp-hero-content { max-width:720px; }
.rp-hero-deck {
  font-size:.95rem;
  color:var(--tx2);
  line-height:1.75;
  margin-bottom:24px;
}
.rp-hero-inner {
  max-width:1200px;
  margin:0 auto;
  padding:0 40px;
  display:grid;
  grid-template-columns:1fr 320px;
  gap:40px;
  align-items:start;
}
.rp-hero-meta {
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:20px;
  flex-wrap:wrap;
}
.rp-hero-tags {
  display:flex;
  flex-wrap:wrap;
  gap:7px;
}
.rp-pullquote {
  border-left:3px solid var(--orange);
  padding:20px 28px;
  background:rgba(232,152,15,.04);
  border-radius:0 6px 6px 0;
  margin:32px 0;
}
.rp-pullquote p {
  font-size:1rem;
  color:var(--tx1);
  font-style:italic;
  line-height:1.7;
  margin-bottom:0;
}
.rp-rel-card {
  background:var(--obs);
  border:1px solid var(--mist);
  border-top:3px solid var(--orange);
  border-radius:8px;
  padding:22px 20px;
  transition:border-color .2s,transform .2s;
  cursor:pointer;
  display:block;
}
.rp-rel-card h3 {
  font-size:.85rem;
  font-weight:700;
  color:var(--tx1);
  line-height:1.4;
  margin-bottom:8px;
}
.rp-rel-card p {
  font-size:.76rem;
  color:var(--tx3);
  line-height:1.6;
}
.rp-rel-card-type {
  font-family:'JetBrains Mono',monospace;
  font-size:.58rem;
  color:var(--orange);
  text-transform:uppercase;
  letter-spacing:.1em;
  margin-bottom:10px;
}
.rp-rel-card:hover {
  border-color:var(--orange);
  transform:translateY(-2px);
}
.rp-rel-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.rp-related {
  border-top:1px solid var(--cloud);
  padding:56px 0;
  background:var(--cloud);
}
.rp-related-cta {
  font-size:.8rem;
  font-weight:600;
  color:var(--orange);
}
.rp-related-head {
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:28px;
}
.rp-related-inner {
  max-width:1200px;
  margin:0 auto;
  padding:0 40px;
}
.rp-related-label {
  font-size:.68rem;
  font-weight:700;
  color:var(--tx3);
  text-transform:uppercase;
  letter-spacing:.14em;
}
.rp-sidebar {
  position:sticky;
  top:80px;
}
.rp-sidebar-card {
  background:var(--cloud);
  border:1px solid var(--mist);
  border-radius:8px;
  padding:20px;
  margin-bottom:16px;
}
.rp-sidebar-card-label {
  font-size:.62rem;
  font-weight:700;
  color:var(--tx3);
  text-transform:uppercase;
  letter-spacing:.12em;
  margin-bottom:12px;
}
.rp-tag {
  font-size:.62rem;
  color:var(--tx3);
  border:1px solid var(--mist);
  border-radius:3px;
  padding:4px 10px;
  background:var(--cloud);
}
.rp-toc-label {
  font-size:.65rem;
  font-weight:700;
  color:var(--tx3);
  text-transform:uppercase;
  letter-spacing:.12em;
  margin-bottom:10px;
}
.rp-toc-list {
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.rp-toc-list li a {
  font-size:.78rem;
  color:var(--tx3);
  display:flex;
  align-items:center;
  gap:8px;
  padding:5px 0;
  border-left:2px solid transparent;
  padding-left:10px;
  transition:color .2s,border-color .2s;
}
.rp-toc-list li a:hover,.rp-toc-list li a.active {
  color:var(--tx1);
  border-left-color:var(--orange);
}
.rp-toc-num {
  font-family:'JetBrains Mono',monospace;
  font-size:.6rem;
  color:var(--tx4);
}
.wp-site-blocks { overflow-x:hidden; }
.wp-site-blocks>* {
  max-width:100%!important;
  margin-left:0!important;
  margin-right:0!important;
}


/* .rp-dl-panel base visual rule (centralized in second pass) */
.rp-dl-panel {
  background:var(--cloud);
  border:1px solid var(--mist);
  border-top:3px solid var(--orange);
  border-radius:10px;
  padding:28px 24px;
  min-width:280px;
  max-width:320px;
  position:sticky;
  top:80px;
}
@media(max-width:768px) {
  .rp-breadcrumb .rp-bc-inner,.rp-hero-inner,.rp-findings-inner,.rp-body,.rp-related-inner {
    padding-left:20px;
    padding-right:20px;
  }
  .rp-findings-inner { grid-template-columns:1fr; }
  .rp-hero { padding:48px 0 40px; }
  .rp-rel-grid { grid-template-columns:1fr; }
}

@media(max-width:900px) {
  .rp-body { grid-template-columns:1fr; }
  .rp-dl-panel {
    position:static;
    max-width:100%;
    min-width:unset;
  }
  .rp-findings-inner {
    grid-template-columns:1fr;
    gap:0;
  }
  .rp-hero-inner { grid-template-columns:1fr; }
  .rp-rel-grid { grid-template-columns:1fr 1fr; }
  .rp-sidebar { position:static; }
}
/* ── Case Studies ──────────────────────────────────────────────────── */
#hs-download-reveal { display:none; }
#hubspot-form-embed { margin:0; }
.5;}50% { opacity:1; }
.btn-cs-demo {
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--green);
  color:#0D1117;
  font-size:.85rem;
  font-weight:700;
  padding:12px 22px;
  border-radius:6px;
  border:none;
  transition:background .2s,transform .15s;
}
.btn-cs-demo:hover {
  background:#00e0bb;
  transform:translateY(-1px);
}
.btn-cs-dl {
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--violet);
  color:#F7F8FA;
  font-weight:700;
  font-size:.85rem;
  padding:12px 22px;
  border-radius:6px;
  transition:background .2s;
}
.btn-cs-dl:hover { background:#1456B3; }
.csd-badge {
  font-family:'JetBrains Mono',monospace;
  font-size:.6rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:4px 10px;
  border-radius:3px;
  color:var(--violet);
  background:var(--violet-dim);
  border:1px solid var(--violet-bd);
}
.csd-badge.blue {
  color:var(--blue);
  background:var(--blue-dim);
  border-color:var(--blue-bd);
}
.csd-badge.green {
  color:var(--green);
  background:var(--green-dim);
  border-color:var(--green-bd);
}
.csd-badge.orange {
  color:var(--orange);
  background:var(--orange-dim);
  border-color:var(--orange-bd);
}
.csd-bc {
  background:var(--obs);
  border-bottom:1px solid var(--cloud);
  padding:14px 0;
}
.csd-bc-inner {
  max-width:1100px;
  margin:0 auto;
  padding:0 40px;
  display:flex;
  gap:8px;
  align-items:center;
  font-size:.72rem;
  color:var(--tx3);
}
.csd-bc-inner a {
  color:var(--tx3);
  transition:color .2s;
}
.csd-bc-inner a:hover { color:var(--tx2); }
.csd-bc-sep { opacity:.4; }
.csd-body {
  max-width:1100px;
  margin:0 auto;
  padding:60px 40px;
}
.csd-cap-chip {
  font-size:.75rem;
  font-weight:600;
  color:var(--blue);
  background:var(--blue-dim);
  border:1px solid var(--blue-bd);
  padding:6px 12px;
  border-radius:20px;
}
.csd-cap-chips {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.csd-cap-label {
  font-size:.65rem;
  font-weight:700;
  color:var(--tx3);
  text-transform:uppercase;
  letter-spacing:.14em;
  margin-bottom:16px;
}
.csd-capabilities {
  background:var(--cloud);
  border:1px solid var(--mist);
  border-radius:10px;
  padding:28px 32px;
  margin:40px 0;
}
.csd-dl-row {
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:flex-start;
}
.csd-hero {
  padding:40px 0 0;
  background:var(--obs);
  border-bottom:1px solid var(--cloud);
}
.csd-hero h1 {
  font-size:clamp(1.6rem,2.8vw,2.4rem);
  font-weight:700;
  line-height:1.2;
  color:var(--tx1);
  margin-bottom:12px;
  max-width:800px;
}
.csd-hero-deck {
  font-size:.92rem;
  color:var(--tx2);
  line-height:1.7;
  max-width:680px;
  margin-bottom:24px;
}
.csd-hero-gate {
  display:grid;
  grid-template-columns:1fr 360px;
  gap:40px;
  align-items:start;
  margin-top:4px;
}
.csd-hero-left .csd-hero-metric {
  display:flex;
  align-items:baseline;
  gap:10px;
  margin-bottom:10px;
}
.csd-hero-left .csd-hero-metric-label {
  font-size:.78rem;
  color:var(--tx2);
  line-height:1.4;
}
.csd-hero-left .csd-hero-metric-num {
  font-family:'JetBrains Mono',monospace;
  font-size:1.4rem;
  font-weight:700;
  line-height:1;
}
.csd-hero-left .csd-hero-ns {
  margin-top:18px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.csd-hero-left .csd-hero-ns-card {
  border-left:2px solid var(--violet-bd);
  padding-left:14px;
}
.csd-hero-left .csd-hero-ns-card.res { border-color:var(--blue); }
.csd-hero-left .csd-hero-ns-card.sol { border-color:var(--green); }
.csd-hero-left .csd-hero-ns-h {
  font-size:.88rem;
  font-weight:600;
  color:var(--tx1);
  line-height:1.4;
}
.csd-hero-left .csd-hero-ns-tag {
  font-size:.6rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--tx3);
  margin-bottom:4px;
}
.csd-hero-meta {
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:14px;
  flex-wrap:wrap;
}
.csd-hero-right {
  background:linear-gradient(165deg,#161B26 0%,#1C2231 100%);
  border:1px solid rgba(26,115,232,.25);
  border-radius:12px;
  padding:24px 22px;
  box-shadow:0 4px 24px rgba(26,115,232,.12),0 1px 3px rgba(0,0,0,.3);
  position:relative;
  overflow:hidden;
}
.csd-hero-right .csd-form-heading {
  font-size:.88rem;
  font-weight:700;
  color:var(--tx1);
  letter-spacing:0;
  text-transform:none;
  margin-bottom:4px;
}
.csd-hero-right .csd-form-sub {
  font-size:.78rem;
  color:var(--tx3);
  margin-bottom:20px;
  line-height:1.5;
}
.csd-hero-right .csd-form-trust {
  display:flex;
  align-items:center;
  gap:6px;
  margin-top:14px;
  font-size:.68rem;
  color:var(--tx3);
}
.csd-hero-right .csd-form-trust svg {
  width:12px;
  height:12px;
  fill:none;
  stroke:var(--green);
  stroke-width:2;
}
.csd-hero-right::before {
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:3px;
  background:linear-gradient(90deg,var(--violet),var(--green),var(--blue));
  border-radius:12px 12px 0 0;
}
.csd-hero-toc {
  margin-top:28px;
  padding-top:20px;
  border-top:1px solid var(--cloud);
}
.csd-hero-toc-items {
  display:flex;
  flex-direction:column;
  gap:6px;
}
.csd-hero-toc-items a {
  font-size:.8rem;
  color:var(--tx2);
  text-decoration:none;
  display:flex;
  align-items:center;
  gap:8px;
  padding:6px 0;
  transition:color .2s,padding-left .2s;
}
.csd-hero-toc-items a .toc-arrow {
  color:var(--violet);
  opacity:.4;
  font-size:.7rem;
  transition:opacity .2s;
}
.csd-hero-toc-items a:hover {
  color:var(--violet);
  padding-left:4px;
}
.csd-hero-toc-items a:hover .toc-arrow { opacity:1; }
.csd-hero-toc-label {
  font-size:.6rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--tx3);
  margin-bottom:12px;
  display:flex;
  align-items:center;
  gap:8px;
}
.csd-hero-toc-label::after {
  content:'';
  flex:1;
  height:1px;
  background:var(--cloud);
}
.csd-hero-top { padding-bottom:32px; }
.csd-metric {
  background:var(--cloud);
  padding:36px 40px;
}
.csd-metric-label {
  font-size:.8rem;
  color:var(--tx2);
  margin-top:8px;
  line-height:1.5;
}
.csd-metric-num {
  font-family:'JetBrains Mono',monospace;
  font-size:2.4rem;
  font-weight:700;
  color:var(--violet);
  line-height:1;
}
.csd-metric-num.blue { color:var(--blue); }
.csd-metric-num.green { color:var(--green); }
.csd-metric-num.orange { color:var(--orange); }
.csd-metric-sub {
  font-size:.7rem;
  color:var(--tx3);
  margin-top:4px;
}
.csd-metrics {
  background:var(--cloud);
  border-top:1px solid var(--mist);
  padding:0;
}
.csd-metrics-inner {
  max-width:1100px;
  margin:0 auto;
  padding:0 40px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--mist);
}
.csd-narrative {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-bottom:56px;
}
.csd-narrative-card {
  background:var(--cloud);
  border:1px solid var(--mist);
  border-radius:10px;
  padding:28px 24px;
}
.csd-narrative-card h3 {
  font-size:.92rem;
  font-weight:700;
  color:var(--tx1);
  margin-bottom:10px;
  line-height:1.4;
}
.csd-narrative-card p {
  font-size:.8rem;
  color:var(--tx3);
  line-height:1.65;
}
.csd-narrative-card-label {
  font-family:'JetBrains Mono',monospace;
  font-size:.6rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.1em;
  margin-bottom:12px;
}
.csd-narrative-card-label.challenge { color:var(--violet); }
.csd-narrative-card-label.result { color:var(--green); }
.csd-narrative-card-label.solution { color:var(--blue); }
.csd-not-found {
  max-width:800px;
  margin:80px auto;
  padding:40px;
  text-align:center;
}
.csd-not-found a {
  color:var(--violet);
  font-weight:600;
  transition:color .2s;
}
.csd-not-found a:hover { color:#4291F5; }
.csd-not-found h1 {
  font-size:2rem;
  margin-bottom:16px;
  color:var(--tx1);
}
.csd-not-found p {
  color:var(--tx2);
  margin-bottom:24px;
  line-height:1.7;
}
.csd-quote {
  background:var(--cloud);
  border-left:3px solid var(--violet);
  padding:28px 32px;
  border-radius:0 8px 8px 0;
  margin:40px 0;
}
.csd-quote p {
  font-size:1.05rem;
  color:var(--tx1);
  font-style:italic;
  line-height:1.7;
  margin-bottom:12px;
}
.csd-quote-attr {
  font-size:.75rem;
  color:var(--tx3);
  display:flex;
  flex-direction:column;
  gap:2px;
}
.csd-quote-name {
  font-weight:600;
  color:var(--tx2);
}
.csd-rel-card {
  color:inherit;
  text-decoration:none;
  display:block;
}
.csd-rel-card h3 {
  font-size:.88rem;
  font-weight:700;
  color:var(--tx1);
  line-height:1.4;
  margin-bottom:8px;
}
.csd-rel-card p {
  font-size:.76rem;
  color:var(--tx3);
  line-height:1.6;
}
.csd-rel-card-link::after {
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  border-radius:10px;
}
.csd-rel-card:hover {
  border-color:var(--violet);
  transform:translateY(-2px);
}
.csd-rel-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
}
.csd-rel-type {
  font-family:'JetBrains Mono',monospace;
  font-size:.58rem;
  color:var(--violet);
  text-transform:uppercase;
  letter-spacing:.1em;
  margin-bottom:10px;
}
.csd-related {
  background:var(--cloud);
  border-top:1px solid var(--mist);
  padding:56px 0;
}
.csd-related-cta-link {
  font-size:.8rem;
  font-weight:600;
  color:var(--violet);
}
.csd-related-head {
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:28px;
}
.csd-related-inner {
  max-width:1100px;
  margin:0 auto;
  padding:0 40px;
}
.csd-related-label {
  font-size:.68rem;
  font-weight:700;
  color:var(--tx3);
  text-transform:uppercase;
  letter-spacing:.14em;
}
.csd-result-item {
  background:var(--cloud);
  border:1px solid var(--mist);
  border-radius:8px;
  padding:20px 22px;
}
.csd-result-label {
  font-size:.78rem;
  color:var(--tx2);
  line-height:1.5;
}
.csd-result-num {
  font-family:'JetBrains Mono',monospace;
  font-size:1.5rem;
  font-weight:700;
  color:var(--green);
  line-height:1;
  margin-bottom:6px;
}
.csd-results-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
  margin-top:24px;
}
.csd-scroll-hint {
  margin-top:20px;
  display:flex;
  align-items:center;
  gap:8px;
  font-size:.72rem;
  color:var(--tx3);
  animation:csd-pulse 2s ease-in-out infinite;
}
.csd-scroll-hint svg {
  width:14px;
  height:14px;
  fill:none;
  stroke:var(--violet);
  stroke-width:2;
  animation:csd-bounce 2s ease-in-out infinite;
}
.csd-section {
  margin-bottom:56px;
  padding-bottom:56px;
  border-bottom:1px solid var(--cloud);
}
.csd-section h2 {
  font-size:1.3rem;
  font-weight:700;
  color:var(--tx1);
  margin-bottom:20px;
}
.csd-section li {
  font-size:.9rem;
  color:var(--tx2);
  line-height:1.7;
  display:flex;
  gap:10px;
  align-items:flex-start;
}
.csd-section li::before {
  content:'\2192';
  color:var(--violet);
  font-weight:700;
  font-size:.8rem;
  flex-shrink:0;
  margin-top:2px;
}
.csd-section p {
  font-size:.92rem;
  color:var(--tx2);
  line-height:1.85;
  margin-bottom:16px;
}
.csd-section strong { color:var(--tx1); }
.csd-section ul {
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-bottom:16px;
}
.csd-section-eyebrow {
  font-size:.65rem;
  font-weight:700;
  color:var(--tx3);
  text-transform:uppercase;
  letter-spacing:.14em;
  margin-bottom:10px;
}
.csd-section:last-child {
  border-bottom:none;
  margin-bottom:0;
  padding-bottom:0;
}
.csd-segment {
  font-size:.75rem;
  color:var(--tx3);
}
.csd-wrap {
  max-width:1100px;
  margin:0 auto;
  padding:0 40px;
}
.hs-gate-wrapper { margin-bottom:0; }
.rp-dl-note {
  margin-bottom:16px;
  font-size:.82rem;
  color:#9BA8B5;
}

@media(max-width:768px) {
  .csd-bc-inner,.csd-wrap,.csd-body,.csd-related-inner {
    padding-left:20px;
    padding-right:20px;
  }
  .csd-hero { padding-top:48px; }
  .csd-hero-gate {
    grid-template-columns:1fr;
    gap:32px;
  }
  .csd-hero-right { order:-1; }
  .csd-metrics-inner { grid-template-columns:1fr; }
  .csd-rel-grid { grid-template-columns:1fr; }
}

@media(max-width:900px) {
  .csd-metrics-inner {
    grid-template-columns:1fr 1fr;
    background:none;
    gap:1px;
  }
  .csd-narrative { grid-template-columns:1fr; }
  .csd-rel-grid { grid-template-columns:1fr; }
  .csd-results-grid { grid-template-columns:1fr; }
}
/* ── Webinars ──────────────────────────────────────────────────── */
.btn-cta-lg {
  background:var(--wbr-accent);
  color:#F7F8FA;
  padding:14px 32px;
  border-radius:6px;
  font-weight:600;
  font-size:.88rem;
  transition:background .2s;
  display:inline-block;
}
.btn-cta-lg:hover { background:#c87d0e; }
.btn-cta-sm {
  background:var(--wbr-accent);
  color:#F7F8FA;
  padding:11px 20px;
  border-radius:6px;
  font-weight:600;
  font-size:.82rem;
  white-space:nowrap;
  transition:background .2s;
}
.btn-cta-sm:hover { background:#c87d0e; }
.wbr-bc {
  background:var(--obs);
  border-bottom:1px solid var(--cloud);
  padding:14px 0;
}
.wbr-bc-inner {
  max-width:1100px;
  margin:0 auto;
  padding:0 40px;
  display:flex;
  gap:8px;
  align-items:center;
  font-size:.72rem;
  color:var(--tx3);
}
.wbr-bc-inner a {
  color:var(--tx3);
  transition:color .2s;
}
.wbr-bc-inner a:hover { color:var(--tx2); }
.wbr-bc-sep { opacity:.4; }
.wbr-bio-toggle {
  display:inline-block;
  font-size:.72rem;
  color:var(--wbr-accent);
  font-weight:600;
  cursor:pointer;
  margin-top:6px;
  transition:color .2s;
}
.wbr-bio-toggle:hover { color:#f5b942; }
.wbr-body {
  max-width:1100px;
  margin:0 auto;
  padding:56px 40px;
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:60px;
  align-items:start;
}
.wbr-category {
  font-family:'JetBrains Mono',monospace;
  font-size:.62rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--wbr-accent);
  margin-bottom:16px;
  display:block;
}
.wbr-content {
  max-width:720px;
  min-width:0;
}
.wbr-content h2 {
  font-size:1.2rem;
  font-weight:700;
  color:var(--tx1);
  margin:40px 0 14px;
}
.wbr-content h3 {
  font-size:1rem;
  font-weight:700;
  color:var(--tx1);
  margin:24px 0 10px;
}
.wbr-content li {
  font-size:.9rem;
  color:var(--tx2);
  line-height:1.7;
  position:relative;
  padding-left:24px;
}
.wbr-content li::before {
  content:'→';
  color:var(--wbr-accent);
  font-weight:700;
  font-size:.78rem;
  position:absolute;
  left:0;
  top:3px;
}
.wbr-content p {
  font-size:.92rem;
  color:var(--tx2);
  line-height:1.85;
  margin-bottom:18px;
}
.wbr-content strong {
  color:var(--tx1);
  display:block;
  margin-bottom:2px;
}
.wbr-content ul,.wbr-content ol {
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:12px;
  margin-bottom:18px;
}
.wbr-cta-band {
  background:linear-gradient(135deg,rgba(232,152,15,.08) 0%,rgba(26,115,232,.06) 100%);
  border-top:1px solid var(--mist);
  border-bottom:1px solid var(--mist);
  padding:56px 40px;
  text-align:center;
}
.wbr-cta-band h2 {
  font-size:1.3rem;
  font-weight:700;
  color:var(--tx1);
  margin-bottom:12px;
}
.wbr-cta-band p {
  font-size:.95rem;
  color:var(--tx2);
  margin-bottom:24px;
  line-height:1.7;
}
.wbr-cta-band-inner {
  max-width:600px;
  margin:0 auto;
}
.wbr-date {
  font-size:.78rem;
  color:var(--tx3);
}
.wbr-deck {
  font-size:1.05rem;
  color:var(--tx2);
  line-height:1.8;
  margin-bottom:28px;
  font-weight:400;
}
.wbr-duration-badge {
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--wbr-accent-dim);
  border:1px solid var(--wbr-accent-bd);
  color:var(--wbr-accent);
  padding:6px 12px;
  border-radius:20px;
  font-size:.72rem;
  font-weight:600;
}
.wbr-hero {
  padding:60px 0 52px;
  background:var(--obs);
  border-bottom:1px solid var(--cloud);
}
.wbr-hero h1 {
  font-size:clamp(1.7rem,3vw,2.6rem);
  font-weight:700;
  line-height:1.2;
  color:var(--tx1);
  margin-bottom:20px;
}
.wbr-hero-inner {
  max-width:800px;
  margin:0 auto;
  padding:0 40px;
}
.wbr-inline-cta {
  background:linear-gradient(135deg,rgba(232,152,15,.08) 0%,rgba(26,115,232,.06) 100%);
  border:1px solid var(--mist);
  border-radius:10px;
  padding:28px 30px;
  margin:40px 0;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  flex-wrap:wrap;
}
.wbr-inline-cta-text h4 {
  font-size:.95rem;
  font-weight:700;
  color:var(--tx1);
  margin-bottom:6px;
}
.wbr-inline-cta-text p {
  font-size:.82rem;
  color:var(--tx3);
  margin-bottom:0;
  line-height:1.5;
}
.wbr-lead {
  font-size:1.05rem;
  color:var(--tx1);
  line-height:1.85;
  margin-bottom:32px;
  font-weight:400;
}
.wbr-meta-row {
  display:flex;
  align-items:center;
  gap:20px;
  flex-wrap:wrap;
  padding-top:24px;
  border-top:1px solid var(--cloud);
}
.wbr-play-icon {
  display:inline-block;
  width:12px;
  height:12px;
}
.wbr-rel-card {
  background:var(--obs);
  border:1px solid var(--mist);
  border-top:3px solid var(--wbr-accent-dim);
  border-radius:8px;
  padding:22px 20px;
  transition:border-color .2s,transform .2s;
  cursor:pointer;
}
.wbr-rel-card h3 {
  font-size:.88rem;
  font-weight:700;
  color:var(--tx1);
  line-height:1.4;
  margin-bottom:8px;
}
.wbr-rel-card p {
  font-size:.76rem;
  color:var(--tx3);
  line-height:1.6;
  margin-bottom:12px;
}
.wbr-rel-card-meta {
  font-size:.67rem;
  color:var(--tx4);
}
.wbr-rel-card-type {
  font-family:'JetBrains Mono',monospace;
  font-size:.57rem;
  color:var(--tx3);
  text-transform:uppercase;
  letter-spacing:.1em;
  margin-bottom:9px;
}
.wbr-rel-card:hover {
  border-top-color:var(--wbr-accent);
  border-color:var(--wbr-accent);
  transform:translateY(-2px);
}
.wbr-rel-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.wbr-rel-head {
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:28px;
}
.wbr-rel-label {
  font-size:.68rem;
  font-weight:700;
  color:var(--tx3);
  text-transform:uppercase;
  letter-spacing:.14em;
}
.wbr-related {
  border-top:1px solid var(--cloud);
  padding:56px 0;
  background:var(--cloud);
}
.wbr-related-inner {
  max-width:1100px;
  margin:0 auto;
  padding:0 40px;
}
.wbr-sc-label {
  font-size:.62rem;
  font-weight:700;
  color:var(--tx3);
  text-transform:uppercase;
  letter-spacing:.12em;
  margin-bottom:12px;
}
.wbr-sidebar {
  position:sticky;
  top:80px;
}
.wbr-sidebar-card {
  background:var(--cloud);
  border:1px solid var(--mist);
  border-radius:8px;
  padding:18px;
  margin-bottom:14px;
}
.wbr-social-btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  background:var(--cloud);
  border:1px solid var(--mist);
  border-radius:6px;
  color:var(--tx2);
  transition:background .2s,color .2s;
  cursor:pointer;
}
.wbr-social-btn:hover {
  background:var(--wbr-accent);
  color:#FFF;
  border-color:var(--wbr-accent);
}
.wbr-socials {
  display:flex;
  gap:12px;
  align-items:center;
  margin:48px 0;
  padding-top:32px;
  border-top:1px solid var(--cloud);
}
.wbr-socials-label {
  font-size:.72rem;
  color:var(--tx3);
  text-transform:uppercase;
  font-weight:600;
  margin-right:8px;
  letter-spacing:.08em;
}
.wbr-speaker-avatar {
  width:44px;
  height:44px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:.95rem;
  font-weight:700;
  color:#FFF;
  flex-shrink:0;
}
.wbr-speaker-bio {
  font-size:.78rem;
  color:var(--tx3);
  line-height:1.65;
  max-height:3.3em;
  overflow:hidden;
  transition:max-height .3s ease;
}
.wbr-speaker-bio.wbr-bio-expanded { max-height:none; }
.wbr-speaker-card {
  background:var(--obs);
  border:1px solid var(--mist);
  border-radius:8px;
  padding:16px;
  margin-bottom:14px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.wbr-speaker-header {
  display:flex;
  gap:12px;
  align-items:flex-start;
}
.wbr-speaker-info h4 {
  font-size:.9rem;
  font-weight:700;
  color:var(--tx1);
  margin-bottom:2px;
}
.wbr-speaker-title {
  font-size:.72rem;
  color:var(--tx3);
  line-height:1.4;
}
.wbr-video {
  max-width:960px;
  margin:56px auto;
  padding:0 40px;
}
.wbr-video-container {
  position:relative;
  width:100%;
  padding-bottom:56.25%;
  background:linear-gradient(135deg,rgba(232,152,15,.08) 0%,rgba(26,115,232,.06) 100%);
  border-radius:10px;
  overflow:hidden;
  border:1px solid var(--mist);
}
.wbr-video-placeholder {
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:20px;
}
.wbr-video-play {
  width:64px;
  height:64px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(232,152,15,.2);
  border-radius:50%;
  border:2px solid var(--wbr-accent);
}
.wbr-video-play svg {
  width:28px;
  height:28px;
  fill:var(--wbr-accent);
}
.wbr-video-text {
  font-size:.9rem;
  color:var(--tx3);
  text-align:center;
  padding:0 20px;
}

@media(max-width:768px) {
  .wbr-bc-inner,.wbr-hero-inner,.wbr-body,.wbr-related-inner,.wbr-cta-band {
    padding-left:20px;
    padding-right:20px;
  }
  .wbr-cta-band { padding:40px 20px; }
  .wbr-hero { padding:48px 0 40px; }
  .wbr-inline-cta {
    flex-direction:column;
    align-items:flex-start;
  }
  .wbr-rel-grid { grid-template-columns:1fr; }
  .wbr-video { padding:0 20px; }
}

@media(max-width:900px) {
  .wbr-body { grid-template-columns:1fr; }
  .wbr-rel-grid { grid-template-columns:1fr 1fr; }
  .wbr-sidebar { position:static; }
}
/* ═══════════════════════════════════════════════════════════════
   PHASE 4 CENTRALIZATION - v69 (April 2026)
   Variance scan run across all 276 templates. Assessment below.
   All canonical values already exist in this file (Phase 2).
   No rules were moved - all template copies are intentional overrides
   documented in REQUIREMENTS.md §3.
   ═══════════════════════════════════════════════════════════════

   .btn:hover         → ALREADY CENTRALIZED. 0 template copies. ✓
   .body-text         → ALREADY CENTRALIZED. 0 template copies. ✓

   .btn-primary:hover → 2 templates (page-agent-composer.html, page-mcp.html)
                        Value: {background:#1557B0}
                        INTENTIONAL OVERRIDE - flat hover for editorial aesthetic.
                        Documented in REQUIREMENTS.md §3. Do not strip.

   .btn-outline:hover → 1 template (page-case-studies.html)
                        Value: {border-color:var(--violet);color:var(--violet);}
                        INTENTIONAL OVERRIDE - violet accent for case-studies listing.
                        Documented in REQUIREMENTS.md §3. Do not strip.

   .section-h2        → 3 templates (page-agent-composer.html, page-econ-sec-helm.html,
                        page-mcp.html)
                        Value: {font-size:clamp(28px,4vw,44px);font-weight:300;
                                line-height:1.15;color:var(--text-primary)}
                        INTENTIONAL OVERRIDE - thin-weight editorial heading aesthetic.
                        Documented in REQUIREMENTS.md §3. Do not strip.

   .faq-a             → ⚠️ SKIPPED - two coexisting architectures across templates:
                        (1) max-height approach (style.css canonical)
                        (2) display:none approach (per-template variant)
                        Centralizing would break one group. Requires Benjamin Power
                        decision before any action. Do not touch without explicit approval.

/* ═══════════════════════════════════════════════════════════════════════════
 * G13 FIX - Touch Target Minimum (WCAG 2.5.5 AAA / 2.5.8 AA)
 *
 * Target: 44 × 44 CSS px minimum tap area on every interactive element.
 *
 * Strategy:
 *   • Standalone links (pillar, sidebar, product-rec): min-height + flex
 *   • Pill buttons / breadcrumbs (.page-bc a): invisible ::after hit-area
 *     expander so the visual pill stays compact but the tap zone is 44px
 *   • Fine-print links (.form-note a): 24px min-height (WCAG 2.5.8 AA
 *     minimum; 44px would look wrong at 0.68rem font size)
 *   • Marketecture product names: min-width + min-height on the link
 *
 * Added: April 2026 / theme v35
 * ═══════════════════════════════════════════════════════════════════════════ */

/* ── Breadcrumb pills ("Commercial", "Enterprise", etc.) ─────────────────── */
/* Keep visual pill height; expand invisible tap zone with ::after            */
.page-bc a {
  position: relative;
}
.page-bc a::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  min-width: 44px;
  min-height: 44px;
}

/* ── Pillar / section arrow links ("Explore the World Model →") ──────────── */
/* Template sets display:inline-block - add vertical padding to reach 44px   */
.pillar-link {
  padding-top: 11px;
  padding-bottom: 11px;
}

/* ── Marketecture product name links ("MCP", "Signal", "Graph") ──────────── */
.marketecture-product-name {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  min-width: 44px;
  padding-left: 6px;
  padding-right: 6px;
}

/* ── Sidebar anchor nav links ("The problem", "Sayari's approach") ──────── */
/* Template inline style sets padding:6px 0 - override with min-height       */
.sidebar-link {
  min-height: 44px;
  display: flex !important;
  align-items: center;
}

/* ── Product recommendation card links ("Explore Sayari Graph →") ────────── */
/* Template sets display:block with no min-height                             */
.product-rec-card-link {
  min-height: 44px;
  display: flex !important;
  align-items: center;
}

/* ── Form fine-print links (Privacy Policy, Terms in /demo/ form note) ────── */
/* 0.68rem text - 44px would look huge; 24px meets WCAG 2.5.8 AA minimum     */
.form-note a {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding-top: 4px;
  padding-bottom: 4px;
}

/* ═══════════════════════════════════════════════════════════════════════════ */
   ═══════════════════════════════════════════════════════════════ */
