/* AgentticAI Website stylesheet — light mode only
 *
 * Composition model: this file is an extension of the AgentticAI design
 * system originally shipped as the standalone homepage prototype. Tokens
 * (:root) and DS-core components are preserved 1:1 with the prototype.
 * Components added by this site for product/landing pages are documented
 * below the DS-core block so we can keep the gap visible.
 *
 * DS-core components (mirrored from the prototype):
 *   .btn / .eyebrow / .chip / .kpi / .bubble / .float / .logo-marquee
 *   .nav / .nav-link / .megamenu / .mm-item / .mm-feature
 *   .hero / .hero-grid / .hero-bg
 *   .dash / .dash-sidebar / .dash-main / .dash-right / .assistant
 *   .pcard (problem cards) / .fcard (feature cards) / .ecard (eco cards)
 *   .rcard (resource cards) / .plan / .agency / .gov / .trust
 *
 * Website-added components (not in the original DS gallery):
 *   .answer / .answer-card                        — "what is AgentticAI" band
 *   .economics / .econ-stat / .econ-list          — agency economics block
 *   .launch-grid / .launch-step                   — launch path
 *   .faq-list / .faq-item                         — FAQ accordions
 *   .product-grid / .product-tile                 — product index
 *   .product-stage / .product-overview-band       — product page hero + overview
 *   .product-river / .product-lanes               — product page sections
 *   .product-flow-track / .product-evidence       — product page sections
 *   .product-gallery / .product-dashboard         — Lote C content-typed mocks
 *   .product-flow-diagram / .product-workspace    — Lote C content-typed mocks
 *   .product-editor / .product-pipeline           — Lote C content-typed mocks
 *   .product-security / .product-builder          — Lote C content-typed mocks
 *   .product-operations                           — Lote C content-typed mocks
 *   .related-products / .related-card             — cross-link tiles
 *   .nav-toggle / .mobile-nav / .mobile-nav-list  — mobile drawer
 *
 * Documented deviations from the prototype:
 *   --btn-accent uses a gradient (vs. solid --accent in the DS gallery)
 *     to give the primary CTA more visual weight on the marketing site.
 *   --section--surface adds a soft blue radial fade at the top of each
 *     surface section (vs. plain --surface in the DS gallery) for depth.
 *   --text-3 raised to #6b7280 from the prototype's #8a94a6 to clear the
 *     WCAG AA 4.5:1 contrast bar for normal text on white.
 */

:root {
  --bg: #ffffff;
  --surface: #f7f8fa;
  --surface-2: #fbfcfd;
  --elev: #ffffff;
  --border: #e5e7eb;
  --border-soft: #eef0f3;
  --border-strong: #d8dde4;
  --text: #0b1020;
  --text-2: #5b6472;
  --text-3: #6b7280;
  --muted: #94a3b8;

  --accent: #2563eb;
  --accent-2: #3730a3;
  --accent-soft: #eef2ff;
  --cyan: #06b6d4;
  --green: #10b981;
  --amber: #f59e0b;
  --red: #ef4444;
  --blue-soft: #eff6ff;
  --cyan-soft: #ecfeff;

  --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.04), 0 1px 1px rgba(15, 23, 42, 0.03);
  --shadow-md: 0 8px 24px -8px rgba(15, 23, 42, 0.08), 0 2px 6px rgba(15, 23, 42, 0.04);
  --shadow-lg: 0 24px 60px -20px rgba(15, 23, 42, 0.18), 0 8px 24px -12px rgba(15, 23, 42, 0.08);

  --radius-sm: 8px;
  --radius: 12px;
  --radius-lg: 16px;
  --radius-xl: 24px;

  --container: 1280px;
  --font-sans: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --font-mono: "JetBrains Mono", "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;
}

* { box-sizing: border-box; }
html, body { padding: 0; margin: 0; }
body {
  font-family: var(--font-sans);
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: "ss01", "cv11";
  line-height: 1.5;
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: transparent; color: inherit; }
img { max-width: 100%; display: block; }

/* ---------- global focus ring ---------- */
:focus { outline: none; }
:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: inherit;
}
a:focus-visible,
button:focus-visible,
[role="button"]:focus-visible,
summary:focus-visible {
  outline-offset: 3px;
}
.btn:focus-visible,
.nav-link:focus-visible,
.nav-toggle:focus-visible,
.mm-item:focus-visible,
.product-tile:focus-visible,
.rcard:focus-visible,
.related-card:focus-visible {
  outline-offset: 2px;
}
.btn--on-dark:focus-visible,
.btn--on-dark-ghost:focus-visible,
.agency .btn:focus-visible {
  outline-color: #fff;
}

/* ---------- layout primitives ---------- */
.container {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 32px;
}
@media (max-width: 720px) {
  .container { padding: 0 20px; }
}

.section {
  padding: 120px 0;
  position: relative;
}
.section--tight { padding: 88px 0; }
.section--surface {
  background:
    linear-gradient(180deg, rgba(37,99,235,0.025), transparent 180px),
    var(--surface);
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-2);
  background: var(--surface);
  border: 1px solid var(--border);
  padding: 6px 10px;
  border-radius: 999px;
}
.eyebrow .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
}

h1, h2, h3, h4 { font-family: var(--font-sans); color: var(--text); margin: 0; letter-spacing: -0.02em; }
h1 { font-size: clamp(38px, 4.8vw, 60px); line-height: 1.04; font-weight: 600; letter-spacing: -0.035em; }
h2 { font-size: clamp(30px, 3.4vw, 44px); line-height: 1.08; font-weight: 600; letter-spacing: -0.028em; }
h3 { font-size: 22px; line-height: 1.25; font-weight: 600; letter-spacing: -0.015em; }
h4 { font-size: 16px; line-height: 1.3; font-weight: 600; }

p { margin: 0; color: var(--text-2); }
.lead { font-size: 18px; line-height: 1.55; color: var(--text-2); }

.section-head {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 56px;
  max-width: 720px;
}
.section-head--center {
  align-items: center;
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

/* ---------- buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 44px;
  padding: 0 18px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -0.005em;
  transition: transform 120ms ease, background 160ms ease, border-color 160ms ease, color 160ms ease, box-shadow 160ms ease;
  white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn--primary {
  background: var(--text);
  color: #fff;
  box-shadow: 0 1px 0 0 rgba(255,255,255,0.06) inset, var(--shadow-sm);
}
.btn--primary:hover { background: #1a2238; }
.btn--accent {
  background: linear-gradient(135deg, var(--accent), var(--accent-2) 58%, var(--cyan));
  color: #fff;
  box-shadow: 0 1px 0 0 rgba(255,255,255,0.12) inset, 0 6px 16px -8px rgba(37, 99, 235, 0.6);
}
.btn--accent:hover { box-shadow: 0 1px 0 0 rgba(255,255,255,0.12) inset, 0 10px 22px -12px rgba(37, 99, 235, 0.8); }
.btn--ghost {
  background: #fff;
  color: var(--text);
  border: 1px solid var(--border);
}
.btn--ghost:hover { border-color: var(--border-strong); background: #fcfcfd; }
.btn--link {
  height: auto; padding: 0;
  color: var(--text);
  font-weight: 500;
}
.btn--link:hover { color: var(--accent); }
.btn--lg { height: 48px; padding: 0 22px; font-size: 15px; border-radius: 12px; }

.btn .arrow {
  transition: transform 160ms ease;
}
.btn:hover .arrow { transform: translateX(2px); }

/* ---------- top nav (frosted glass) ---------- */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,0.55);
  backdrop-filter: saturate(180%) blur(22px);
  -webkit-backdrop-filter: saturate(180%) blur(22px);
  border-bottom: 1px solid transparent;
  box-shadow: inset 0 -1px 0 0 rgba(255,255,255,0.4);
  transition: border-color 160ms ease, background 160ms ease, box-shadow 160ms ease;
}
.nav.is-scrolled {
  border-bottom-color: rgba(229,231,235,0.7);
  background: rgba(255,255,255,0.68);
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,0.6),
    0 8px 24px -16px rgba(15,23,42,0.18);
}
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .nav { background: rgba(255,255,255,0.92); }
  .nav.is-scrolled { background: rgba(255,255,255,0.96); }
}
.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
}
.nav-left { display: flex; align-items: center; gap: 36px; }
.brand {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  font-size: 16px;
  letter-spacing: -0.015em;
  color: var(--text);
}
.brand-logo {
  height: 26px;
  width: auto;
  max-width: none;
  display: block;
  flex-shrink: 0;
}
.brand-logo--lg { height: 30px; }
.brand-mark {
  width: 26px; height: 26px;
  border-radius: 7px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  position: relative;
  box-shadow: 0 4px 12px -4px rgba(37,99,235,0.5), inset 0 1px 0 rgba(255,255,255,0.3);
}
.brand-mark::before, .brand-mark::after {
  content: "";
  position: absolute;
  background: #fff;
  border-radius: 1.5px;
}
.brand-mark::before { left: 6px; top: 7px; width: 14px; height: 2.5px; opacity: 0.85; }
.brand-mark::after { left: 6px; top: 12px; width: 9px; height: 2.5px; opacity: 0.85; box-shadow: 0 5px 0 0 rgba(255,255,255,0.85); }

.nav-links { display: flex; gap: 2px; }
.nav-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 44px;
  padding: 0 12px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text-2);
  transition: color 120ms ease, background 120ms ease;
}
.nav-link:hover { color: var(--text); background: var(--surface); }
.nav-link.is-active { color: var(--text); }
.nav-link .caret { width: 10px; height: 10px; opacity: 0.6; transition: transform 160ms; }
.megamenu-anchor.is-open .nav-link .caret,
.nav-link[data-open="true"] .caret { transform: rotate(180deg); }

.nav-right { display: flex; align-items: center; gap: 8px; }

/* ---------- mega-menu ---------- */
.megamenu-anchor { position: relative; }
.megamenu-anchor::after {
  content: "";
  position: absolute;
  left: -12px;
  right: -12px;
  top: 100%;
  height: 18px;
}
.megamenu {
  position: fixed;
  top: 72px;
  left: max(16px, calc((100vw - var(--container)) / 2 + 32px));
  /* Span the full content width so columns never cramp — regardless of how
     much copy a locale needs (Spanish runs longer than English). */
  width: min(calc(var(--container) - 64px), calc(100vw - 32px));
  transform: translateY(-4px);
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: var(--shadow-lg);
  padding: 12px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease, transform 180ms ease;
  z-index: 60;
  max-width: calc(100vw - 32px);
}
.megamenu.is-open,
.megamenu-anchor.is-open > .megamenu,
.megamenu-anchor:hover > .megamenu {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

/* Mega menus share the same fixed left edge as the page content instead of
   drifting with each individual nav trigger. */

.mm-layout {
  display: grid;
  gap: 12px;
}
.mm-layout--with-feature {
  /* minmax(0,…) so long (e.g. Spanish) column text can't blow out the track
     and collapse the feature column. */
  grid-template-columns: minmax(0, 2.2fr) minmax(0, 1fr);
}
.megamenu--gov .mm-layout--with-feature {
  grid-template-columns: minmax(0, 2fr) minmax(240px, 0.85fr);
}
.mm-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
}
.mm-col {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.mm-section-label {
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-3);
  padding: 8px 12px 6px;
}
.mm-item {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 8px 12px;
  border-radius: 12px;
  transition: background 120ms ease;
  position: relative;
}
.mm-item:hover { background: var(--surface); }
.mm-item:hover .mm-arrow { opacity: 1; transform: translateX(0); }
.mm-item .mm-icon {
  width: 32px; height: 32px;
  border-radius: 9px;
  background: var(--surface);
  border: 1px solid var(--border-soft);
  display: grid; place-items: center;
  flex-shrink: 0;
  color: var(--accent);
}
.mm-item .mm-icon--accent {
  background: var(--accent-soft);
  border-color: transparent;
}
.mm-item .mm-text { min-width: 0; flex: 1; }
.mm-item .mm-label {
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text);
  letter-spacing: -0.005em;
  display: flex; align-items: baseline; gap: 6px; flex-wrap: wrap;
}
.mm-item .mm-desc {
  font-size: 12px;
  color: var(--text-3);
  margin-top: 1px;
  line-height: 1.2;
  text-wrap: pretty;
}
.mm-item .mm-arrow {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translate(-3px, -50%);
  opacity: 0;
  color: var(--text-3);
  transition: opacity 150ms ease, transform 150ms ease;
}
.mm-tag {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--accent);
  background: var(--accent-soft);
  border-radius: 4px;
  padding: 1px 5px;
}

/* mega-menu feature panel */
.mm-feature {
  background: var(--surface-2);
  border: 1px solid var(--border-soft);
  border-radius: 14px;
  padding: 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
  overflow: hidden;
}
.mm-feature::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(60% 50% at 100% 0%, var(--accent-soft), transparent 60%);
  pointer-events: none;
}
.mm-feature .mm-eyebrow {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
  position: relative;
}
.mm-feature h4 {
  font-size: 15px;
  letter-spacing: -0.015em;
  position: relative;
}
.mm-feature p {
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--text-2);
  position: relative;
}
.mm-feature .mm-feature-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--accent);
  margin-top: 4px;
  position: relative;
}
.mm-feature .mm-feature-art {
  position: relative;
  margin-top: 4px;
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: 10px;
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.mm-feature .mm-feature-art .row {
  display: flex; align-items: center; gap: 8px;
  font-size: 11.5px; color: var(--text-2);
}
.mm-feature .mm-feature-art .row .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }
.mm-feature .mm-feature-art .row .bar {
  flex: 1; height: 4px; border-radius: 2px;
  background: var(--surface); overflow: hidden; position: relative;
}
.mm-feature .mm-feature-art .row .bar::after {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0;
  width: var(--w, 60%);
  background: linear-gradient(90deg, var(--accent), var(--cyan));
  border-radius: 2px;
}

.mm-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px 4px;
  margin-top: 6px;
  border-top: 1px solid var(--border-soft);
  font-size: 12.5px;
  color: var(--text-3);
}
.mm-footer a { color: var(--accent); font-weight: 500; }
.mm-footer a:hover { text-decoration: underline; }

@media (max-width: 760px) {
  .megamenu { display: none; }
  .megamenu-anchor .nav-link .caret { display: none; }
}

/* ---------- hero ---------- */
.hero {
  position: relative;
  padding: 80px 0 40px;
  overflow: hidden;
}
.hero-bg {
  position: absolute; inset: 0;
  pointer-events: none;
  background:
    linear-gradient(120deg, rgba(37,99,235,0.07), transparent 32%),
    linear-gradient(240deg, rgba(6,182,212,0.08), transparent 34%),
    linear-gradient(180deg, rgba(124,58,237,0.05), transparent 44%);
}
.hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, rgba(15,23,42,0.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(15,23,42,0.04) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(70% 60% at 50% 0%, #000 0%, transparent 80%);
  -webkit-mask-image: radial-gradient(70% 60% at 50% 0%, #000 0%, transparent 80%);
  opacity: 0.6;
  pointer-events: none;
}
.hero-inner {
  position: relative;
  text-align: center;
  display: grid;
  justify-items: center;
  gap: 22px;
}
.hero h1 { max-width: 920px; text-wrap: balance; }
.hero h1 .accent {
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 60%, var(--cyan) 110%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero-lead {
  max-width: 720px;
  font-size: 19px;
  color: var(--text-2);
  line-height: 1.55;
  text-wrap: pretty;
}
.hero-ctas {
  display: flex;
  gap: 10px;
  margin-top: 6px;
  flex-wrap: wrap;
  justify-content: center;
}
.hero-micro {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--text-3); font-size: 13px;
  margin-top: 4px;
}
.hero-micro .pulse {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 0 4px rgba(16,185,129,0.18);
}

.hero-visual {
  position: relative;
  margin-top: 56px;
  width: 100%;
  max-width: 1180px;
  aspect-ratio: 16 / 9.2;
  overflow: visible;
}

/* ---------- dashboard mock ---------- */
.dash {
  position: absolute; inset: 0;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 20px;
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  display: grid;
  grid-template-columns: 240px 1fr 320px;
}
.dash-shine {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(37,99,235,0.04), transparent 30%);
  pointer-events: none;
}

.dash-sidebar {
  background: var(--surface-2);
  border-right: 1px solid var(--border-soft);
  padding: 16px 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 13px;
}
.dash-sidebar .org {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px;
  border: 1px solid var(--border-soft);
  background: #fff;
  border-radius: 10px;
  margin-bottom: 12px;
}
.dash-sidebar .org-mark {
  width: 24px; height: 24px; border-radius: 6px;
  background: linear-gradient(135deg, #0b1020, #3a4663);
  display: grid; place-items: center;
  color: #fff; font-size: 10px; font-weight: 600;
}
.dash-sidebar .org-name { font-weight: 600; font-size: 12.5px; }
.dash-sidebar .org-meta { font-size: 10.5px; color: var(--text-3); font-family: var(--font-mono); }

.dash-nav-section {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-3);
  padding: 12px 10px 6px;
}
.dash-nav {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 10px;
  border-radius: 8px;
  color: var(--text-2);
  font-size: 12.5px;
}
.dash-nav:hover { background: rgba(15,23,42,0.04); }
.dash-nav.is-active {
  background: #fff;
  border: 1px solid var(--border-soft);
  color: var(--text);
  box-shadow: var(--shadow-sm);
  font-weight: 500;
}
.dash-nav .ico { width: 14px; height: 14px; color: var(--text-3); }
.dash-nav.is-active .ico { color: var(--accent); }
.dash-nav .count {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--text-3);
  background: rgba(15,23,42,0.04);
  padding: 1px 6px;
  border-radius: 6px;
}

.dash-main {
  padding: 18px 22px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  background: #fff;
  min-width: 0;
}
.dash-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.dash-crumb {
  display: flex; align-items: center; gap: 8px;
  font-size: 12.5px;
  color: var(--text-3);
}
.dash-crumb b { color: var(--text); font-weight: 600; }
.dash-search {
  display: flex; align-items: center; gap: 6px;
  background: var(--surface);
  border: 1px solid var(--border-soft);
  border-radius: 8px;
  padding: 6px 10px;
  font-size: 12px; color: var(--text-3);
  flex: 1; max-width: 220px;
}
.dash-search .kbd {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 10px;
  padding: 1px 5px;
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--text-3);
}
.dash-tabs {
  display: flex; gap: 2px;
  border-bottom: 1px solid var(--border-soft);
}
.dash-tab {
  padding: 8px 12px;
  font-size: 12.5px;
  color: var(--text-3);
  border-bottom: 1.5px solid transparent;
  margin-bottom: -1px;
}
.dash-tab.is-active {
  color: var(--text);
  border-bottom-color: var(--text);
  font-weight: 500;
}

.dash-kpis {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.kpi {
  border: 1px solid var(--border-soft);
  background: #fff;
  border-radius: 12px;
  padding: 12px;
  display: flex; flex-direction: column; gap: 8px;
}
.kpi .label { font-size: 11px; color: var(--text-3); font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.06em; }
.kpi .value { font-size: 20px; font-weight: 600; letter-spacing: -0.02em; }
.kpi .delta { font-size: 11px; color: var(--green); font-family: var(--font-mono); }
.kpi .delta.warn { color: var(--amber); }
.kpi .bar {
  height: 6px; border-radius: 4px; background: var(--surface);
  position: relative; overflow: hidden;
}
.kpi .bar::after {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0;
  background: linear-gradient(90deg, var(--accent), var(--cyan));
  border-radius: 4px;
  width: var(--w, 60%);
  animation: bargrow 1.6s cubic-bezier(.2,.7,.2,1) both;
}
@keyframes bargrow {
  from { width: 0; }
}

.dash-table {
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  overflow: hidden;
  flex: 1;
  display: flex; flex-direction: column;
  background: #fff;
}
.dash-table-head {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 0.8fr;
  padding: 10px 14px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-3);
  background: var(--surface-2);
  border-bottom: 1px solid var(--border-soft);
}
.dash-row {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 0.8fr;
  padding: 10px 14px;
  font-size: 12.5px;
  align-items: center;
  border-bottom: 1px solid var(--border-soft);
}
.dash-row:last-child { border-bottom: 0; }
.dash-row .client {
  display: flex; align-items: center; gap: 9px;
  font-weight: 500;
}
.dash-row .avatar {
  width: 22px; height: 22px; border-radius: 6px;
  display: grid; place-items: center;
  color: #fff; font-size: 10px; font-weight: 600;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
}
.dash-row .avatar.v2 { background: linear-gradient(135deg, #10b981, #059669); }
.dash-row .avatar.v3 { background: linear-gradient(135deg, #f59e0b, #d97706); }
.dash-row .avatar.v4 { background: linear-gradient(135deg, #ec4899, #be185d); }
.dash-row .avatar.v5 { background: linear-gradient(135deg, #06b6d4, #0e7490); }

.usage-bar {
  height: 5px; border-radius: 3px; background: var(--surface);
  overflow: hidden; position: relative;
}
.usage-bar::after {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0;
  width: var(--u, 50%); border-radius: 3px;
  background: var(--accent);
}
.usage-bar.warn::after { background: var(--amber); }
.usage-bar.crit::after { background: var(--red); }

.chip {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 2px 8px; border-radius: 999px;
  font-size: 11px; font-weight: 500;
  font-family: var(--font-sans);
  border: 1px solid var(--border-soft);
  background: var(--surface);
  color: var(--text-2);
}
.chip .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--text-3); }
.chip--ok { color: #047857; background: #ecfdf5; border-color: #d1fae5; }
.chip--ok .dot { background: var(--green); }
.chip--warn { color: #92400e; background: #fffbeb; border-color: #fde68a; }
.chip--warn .dot { background: var(--amber); }
.chip--info { color: #1e40af; background: #eff6ff; border-color: #dbeafe; }
.chip--info .dot { background: var(--accent); }
.chip--violet { color: #5b21b6; background: #f5f3ff; border-color: #ddd6fe; }
.chip--violet .dot { background: #7c3aed; }

/* dash right (assistant + cards) */
.dash-right {
  border-left: 1px solid var(--border-soft);
  background: var(--surface-2);
  padding: 16px;
  display: flex; flex-direction: column; gap: 12px;
  min-width: 0;
}
.dash-right .head {
  display: flex; align-items: center; justify-content: space-between;
  font-size: 12px;
  color: var(--text-3);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.assistant {
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.assistant-head {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--border-soft);
}
.assistant-head .avatar {
  width: 28px; height: 28px; border-radius: 8px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  display: grid; place-items: center; color: #fff;
}
.assistant-head .name { font-size: 13px; font-weight: 600; }
.assistant-head .status { font-size: 11px; color: var(--green); display: inline-flex; align-items: center; gap: 5px; }
.assistant-head .status .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 3px rgba(16,185,129,0.18); }
.assistant-body { padding: 12px; display: flex; flex-direction: column; gap: 10px; font-size: 12.5px; }
.bubble {
  padding: 9px 11px;
  border-radius: 12px;
  max-width: 92%;
  line-height: 1.45;
}
.bubble.user {
  align-self: flex-end;
  background: var(--surface);
  border: 1px solid var(--border-soft);
  color: var(--text);
  border-bottom-right-radius: 4px;
}
.bubble.bot {
  align-self: flex-start;
  background: var(--accent-soft);
  border: 1px solid #dbe4ff;
  color: #1e3a8a;
  border-bottom-left-radius: 4px;
}
.bubble .cite {
  display: inline-flex; align-items: center; gap: 4px;
  margin-top: 6px;
  font-family: var(--font-mono); font-size: 10.5px;
  padding: 1px 6px; border-radius: 5px;
  background: #fff; border: 1px solid #dbe4ff;
  color: var(--accent);
}
.caret-blink {
  display: inline-block;
  width: 6px; height: 13px;
  background: var(--accent);
  vertical-align: -2px;
  margin-left: 1px;
  animation: blink 1s steps(2) infinite;
  border-radius: 1px;
}
@keyframes blink { 50% { opacity: 0; } }

.assistant-input {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 10px;
  border-top: 1px solid var(--border-soft);
  font-size: 12px;
  color: var(--text-3);
  background: var(--surface-2);
}
.assistant-input .send {
  margin-left: auto; width: 22px; height: 22px;
  border-radius: 6px; background: var(--accent);
  display: grid; place-items: center; color: #fff;
}

/* floating cards near hero */
.floats {
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 3;
}
.float {
  position: absolute;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: var(--shadow-lg);
  padding: 12px 14px;
  display: flex; align-items: center; gap: 10px;
  font-size: 12.5px;
  color: var(--text);
  min-width: 180px;
  animation: floaty 6s ease-in-out infinite alternate;
}
.float .ico {
  width: 28px; height: 28px; border-radius: 8px;
  display: grid; place-items: center;
  background: var(--surface);
  color: var(--accent);
  flex-shrink: 0;
}
.float .ico--ok { color: #059669; background: #ecfdf5; }
.float .ico--amber { color: #b45309; background: #fffbeb; }
.float .ico--violet { color: #7c3aed; background: #f5f3ff; }
.float strong { font-weight: 600; font-size: 12.5px; }
.float .sub { font-size: 11px; color: var(--text-3); margin-top: 1px; font-family: var(--font-mono); }
.float .text { display: flex; flex-direction: column; }
.float--a { top: -18px; left: -28px; animation-delay: -1s; }
.float--b { top: 18%; right: -38px; animation-delay: -3s; }
.float--c { bottom: 10%; left: -32px; animation-delay: -2s; }
.float--d { bottom: -16px; right: 12%; animation-delay: -4s; }
@keyframes floaty {
  from { transform: translateY(0); }
  to { transform: translateY(-8px); }
}
@media (max-width: 1100px) {
  .float--a, .float--b, .float--c, .float--d { display: none; }
}

/* ---------- logos strip (marquee) ---------- */
.logos {
  padding: 56px 0 0;
}
.logos-label {
  text-align: center;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 22px;
}
.logo-marquee {
  position: relative;
  overflow: hidden;
  border-top: 1px solid var(--border-soft);
  border-bottom: 1px solid var(--border-soft);
  mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 8%, #000 92%, transparent 100%);
}
.logo-marquee-track {
  display: flex;
  width: max-content;
  animation: logoMarquee 60s linear infinite;
}
.logo-marquee:hover .logo-marquee-track {
  animation-play-state: paused;
}
@keyframes logoMarquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.logo-cell {
  flex: 0 0 auto;
  width: 200px;
  height: 80px;
  display: grid;
  place-items: center;
  position: relative;
  color: var(--text-3);
  font-weight: 600;
  letter-spacing: -0.01em;
  border-right: 1px solid var(--border-soft);
}
.logo-cell .logo-text {
  letter-spacing: 0.18em;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-3);
}
.logo-cell .placeholder-tag {
  position: absolute; top: 6px; right: 6px;
  font-family: var(--font-mono); font-size: 9px;
  color: var(--muted); letter-spacing: 0.05em;
}
@media (max-width: 900px) {
  .logo-cell { width: 160px; }
}

/* ---------- answer engine section ---------- */
.answer-section {
  padding-top: 96px;
}
.answer {
  border: 1px solid var(--border);
  border-radius: 24px;
  background:
    linear-gradient(90deg, rgba(37,99,235,0.045), transparent 48%),
    linear-gradient(180deg, #fff, var(--surface-2));
  padding: 34px;
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.35fr);
  gap: 30px;
  box-shadow: var(--shadow-md);
  position: relative;
  overflow: hidden;
}
.answer-copy {
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
}
.answer-copy h2 {
  font-size: clamp(28px, 3.4vw, 42px);
}
.answer-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  position: relative;
}
.answer-card {
  background: linear-gradient(180deg, #fff, var(--surface-2));
  border: 1px solid var(--border-soft);
  border-radius: 16px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 230px;
}
.answer-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  background: var(--blue-soft);
  color: var(--accent);
}
.answer-card:nth-child(2) .answer-icon { background: var(--blue-soft); color: var(--accent); }
.answer-card:nth-child(3) .answer-icon { background: var(--cyan-soft); color: var(--accent); }
.answer-card h3 { font-size: 16px; }
.answer-card p { font-size: 13.5px; line-height: 1.55; }
@media (max-width: 1050px) {
  .answer { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .answer { padding: 24px; }
  .answer-cards { grid-template-columns: 1fr; }
  .answer-card { min-height: 0; }
}

/* ---------- problem cards ---------- */
.problem-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  align-items: start;
}
@media (max-width: 900px) { .problem-grid { grid-template-columns: 1fr; } }

.pcard {
  position: relative;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 28px;
  background: #fff;
  display: flex; flex-direction: column; gap: 14px;
  overflow: hidden;
}
.pcard .pnum {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--text-3);
  letter-spacing: 0.06em;
}
.pcard h3 { font-size: 19px; }
.pcard p { font-size: 14.5px; }
.pcard .pmock {
  margin-top: auto;
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  background: var(--surface-2);
  padding: 14px;
  font-size: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* fmock-row: shared between .fcard .fmock and .pcard .pmock; the
   previous version only styled it when inside .fcard, which left the
   problem-card chips unaligned. */
.fmock-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: 8px;
  font-size: 12px;
}

/* ---------- how it works ---------- */
.how {
  position: relative;
}
.how-diagram {
  position: relative;
  margin-top: 40px;
  border: 1px solid var(--border);
  border-radius: 24px;
  background: #fff;
  padding: 28px;
  overflow: hidden;
}
.how-diagram .bg-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, rgba(15,23,42,0.025) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(15,23,42,0.025) 1px, transparent 1px);
  background-size: 32px 32px;
  mask-image: radial-gradient(80% 80% at 50% 50%, #000, transparent);
  -webkit-mask-image: radial-gradient(80% 80% at 50% 50%, #000, transparent);
}
.how-grid {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 32px;
}
@media (max-width: 900px) { .how-grid { grid-template-columns: 1fr; } }

.layer {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 20px;
  display: flex; flex-direction: column; gap: 14px;
  position: relative;
  box-shadow: var(--shadow-sm);
}
.layer .lhead {
  display: flex; align-items: center; gap: 10px;
}
.layer .lnum {
  width: 26px; height: 26px;
  border-radius: 8px;
  background: var(--text);
  color: #fff;
  display: grid; place-items: center;
  font-family: var(--font-mono); font-size: 12px;
  font-weight: 600;
}
.layer h4 { font-size: 15px; }
.layer .lsub { font-size: 12.5px; color: var(--text-3); }
.layer .lmock {
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  background: var(--surface-2);
  padding: 14px;
  font-size: 12.5px;
  flex: 1;
  display: flex; flex-direction: column; gap: 8px;
}
.layer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 7px; }
.layer ul li {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--text-2);
}
.layer ul li::before {
  content: ""; width: 14px; height: 14px;
  border-radius: 4px;
  background: var(--accent-soft);
  border: 1px solid #dbe4ff;
  flex-shrink: 0;
  background-image: linear-gradient(135deg, transparent 40%, var(--accent) 40%, var(--accent) 60%, transparent 60%);
  background-size: 60% 60%;
  background-repeat: no-repeat;
  background-position: center;
}

/* connector lines between layers (desktop) */
@media (min-width: 900px) {
  .how-grid::before, .how-grid::after {
    content: "";
    position: absolute;
    top: 50px;
    width: 32px;
    height: 1.5px;
    background: linear-gradient(90deg, var(--accent), var(--cyan));
    opacity: 0.5;
  }
  .how-grid::before { left: calc(33.333% - 16px); }
  .how-grid::after { left: calc(66.666% - 16px); }
}

/* ---------- feature blocks ---------- */
.features {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
@media (max-width: 1050px) { .features { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 700px) { .features { grid-template-columns: 1fr; } }

.fcard {
  position: relative;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: #fff;
  padding: 26px;
  display: flex; flex-direction: column; gap: 18px;
  transition: border-color 200ms ease, transform 200ms ease;
  min-height: 380px;
  overflow: hidden;
}
.fcard:hover { border-color: var(--border-strong); }
.fcard .ftop { display: flex; align-items: center; gap: 10px; }
.fcard .ficon {
  width: 32px; height: 32px;
  border-radius: 9px;
  background: var(--accent-soft);
  color: var(--accent);
  display: grid; place-items: center;
}
.fcard h3 { font-size: 17px; }
.fcard p { font-size: 14px; line-height: 1.55; }
.fcard .fmock {
  margin-top: auto;
  background: var(--surface-2);
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  padding: 14px;
  font-size: 12px;
  display: flex; flex-direction: column; gap: 8px;
  min-height: 140px;
}
.fcard .fmock-row {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 10px;
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: 8px;
  font-size: 12px;
}

/* ---------- agency block ---------- */
/* Full-bleed dark band: the background spans the viewport, the content
   stays inside the page container. */
.agency-section {
  position: relative;
  overflow: hidden;
  background: var(--text);
  color: #fff;
}
.agency {
  background: transparent;
  color: #fff;
  border-radius: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
  position: relative;
  z-index: 1;
}
@media (max-width: 900px) {
  .agency { grid-template-columns: 1fr; padding: 0; gap: 36px; }
}
/* Ambient corner glow lives on the full-bleed section (not the centered
   container) so it spreads edge to edge with the dark band and never clips
   into a visible box at the container's right edge. */
.agency-section::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(40% 70% at 100% 0%, rgba(37,99,235,0.22), transparent 62%),
    radial-gradient(36% 50% at 0% 100%, rgba(6,182,212,0.16), transparent 62%);
  pointer-events: none;
}
.agency-bg-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.045) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.045) 1px, transparent 1px);
  background-size: 56px 56px;
  /* Cover the whole full-bleed band as a texture, fading softly at all four
     edges so the grid never reads as a contained box over the dark surface. */
  -webkit-mask-image:
    linear-gradient(to bottom, transparent 0%, #000 13%, #000 87%, transparent 100%),
    linear-gradient(to right, transparent 0%, #000 6%, #000 94%, transparent 100%);
  -webkit-mask-composite: source-in;
  mask-image:
    linear-gradient(to bottom, transparent 0%, #000 13%, #000 87%, transparent 100%),
    linear-gradient(to right, transparent 0%, #000 6%, #000 94%, transparent 100%);
  mask-composite: intersect;
  pointer-events: none;
}
.agency-text { position: relative; z-index: 1; display: flex; flex-direction: column; gap: 18px; }
.agency-text h2 { color: #fff; }
.agency-text p { color: rgba(255,255,255,0.66); font-size: 16px; }
.agency-text .eyebrow { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.12); color: rgba(255,255,255,0.7); }
.agency-text .eyebrow .dot { background: var(--cyan); }
.agency-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 18px;
  margin-top: 8px;
  list-style: none; padding: 0;
}
.agency-list li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 14px; color: rgba(255,255,255,0.88);
  line-height: 1.45;
}
.agency-list .check {
  width: 18px; height: 18px; border-radius: 6px;
  background: rgba(37,99,235,0.18);
  border: 1px solid rgba(37,99,235,0.5);
  color: #93c5fd;
  display: grid; place-items: center; flex-shrink: 0;
  margin-top: 1px;
}
.agency-ctas { display: flex; gap: 10px; margin-top: 14px; }
.btn--on-dark { background: #fff; color: var(--text); }
.btn--on-dark:hover { background: #f1f5f9; }
.btn--on-dark-ghost { background: transparent; color: #fff; border: 1px solid rgba(255,255,255,0.18); }
.btn--on-dark-ghost:hover { background: rgba(255,255,255,0.06); }

.agency-mock {
  position: relative; z-index: 1;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 18px;
  padding: 18px;
  backdrop-filter: blur(8px);
}
.agency-mock-head {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 12px; margin-bottom: 12px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  font-size: 12px; color: rgba(255,255,255,0.6);
  font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.06em;
}
.agency-mock-rows { display: flex; flex-direction: column; gap: 8px; }
.amrow {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 14px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 10px;
  font-size: 13px;
}
.amrow .name { display: flex; align-items: center; gap: 10px; font-weight: 500; }
.amrow .av {
  width: 22px; height: 22px; border-radius: 6px;
  display: grid; place-items: center; color: #fff; font-size: 10px; font-weight: 600;
}
.amrow .badge {
  font-family: var(--font-mono); font-size: 10.5px;
  padding: 2px 7px; border-radius: 5px;
  background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.7);
  border: 1px solid rgba(255,255,255,0.08);
}
.amrow .badge--scale { background: rgba(37,99,235,0.2); color: #93c5fd; border-color: rgba(37,99,235,0.4); }
.amrow .usage-mini {
  width: 90px; height: 4px; border-radius: 2px;
  background: rgba(255,255,255,0.08); overflow: hidden;
  position: relative;
}
.amrow .usage-mini::after {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0;
  width: var(--u, 50%); border-radius: 2px;
  background: linear-gradient(90deg, var(--cyan), var(--accent));
}

/* ---------- agency economics ---------- */
.economics {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.2fr);
  gap: 18px;
}
.econ-stats {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.econ-stat {
  border: 1px solid var(--border);
  border-radius: 18px;
  background:
    linear-gradient(90deg, rgba(37,99,235,0.035), transparent 44%),
    #fff;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  position: relative;
  overflow: hidden;
}
.econ-stat strong {
  font-family: var(--font-mono);
  font-size: 34px;
  letter-spacing: -0.04em;
}
.econ-stat span {
  color: var(--text);
  font-size: 15px;
  font-weight: 600;
}
.econ-stat small {
  color: var(--text-3);
  font-size: 12px;
}
.econ-list {
  border: 1px solid var(--border);
  border-radius: 20px;
  background: #fff;
  overflow: hidden;
}
.econ-item {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 14px;
  padding: 22px;
  border-bottom: 1px solid var(--border-soft);
}
.econ-item:last-child { border-bottom: 0; }
.econ-num {
  width: 30px;
  height: 30px;
  border-radius: 9px;
  display: grid;
  place-items: center;
  background: var(--blue-soft);
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 11px;
}
.econ-item:nth-child(2) .econ-num,
.econ-item:nth-child(3) .econ-num,
.econ-item:nth-child(4) .econ-num { background: var(--accent-soft); color: var(--accent); }
.econ-item h3 {
  font-size: 16px;
  margin-bottom: 5px;
}
.econ-item p {
  font-size: 13.5px;
  line-height: 1.55;
}
@media (max-width: 900px) {
  .economics { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .econ-item { grid-template-columns: 1fr; }
}

/* ---------- government block ---------- */
.gov {
  display: grid;
  grid-template-columns: 1fr 1.05fr;
  gap: 56px;
  align-items: center;
}
@media (max-width: 900px) { .gov { grid-template-columns: 1fr; gap: 36px; } }

.gov-text h2 { max-width: 520px; }
.gov-list {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 18px 24px; margin-top: 28px;
  list-style: none; padding: 0;
}
.gov-list li { display: flex; flex-direction: column; gap: 4px; padding: 0; }
.gov-list li .l {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13.5px; font-weight: 600;
}
.gov-list li .sub { font-size: 12.5px; color: var(--text-3); line-height: 1.5; }
.gov-list .ico {
  width: 24px; height: 24px; border-radius: 7px;
  background: var(--accent-soft); color: var(--accent);
  display: grid; place-items: center; flex-shrink: 0;
}

.gov-mock {
  border: 1px solid var(--border);
  border-radius: 20px;
  background: #fff;
  padding: 24px;
  box-shadow: var(--shadow-md);
  display: flex; flex-direction: column; gap: 16px;
  position: relative;
  overflow: hidden;
}
.gov-mock-head {
  display: flex; align-items: center; gap: 10px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border-soft);
}
.gov-mock-head .seal {
  width: 36px; height: 36px;
  border-radius: 10px;
  background: linear-gradient(135deg, #0b1020, #3a4663);
  display: grid; place-items: center;
  color: #fff;
  position: relative;
}
.gov-mock-head .seal::after {
  content: ""; position: absolute; inset: 3px;
  border: 1.5px dashed rgba(255,255,255,0.3);
  border-radius: 7px;
}
.gov-mock-head .htitle { font-size: 14px; font-weight: 600; }
.gov-mock-head .hsub { font-size: 11.5px; color: var(--text-3); font-family: var(--font-mono); }
.gov-mock-head .right {
  margin-left: auto;
  display: flex; gap: 6px;
}

.gov-deps {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
}
.gov-dep {
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  padding: 12px;
  display: flex; flex-direction: column; gap: 8px;
  background: var(--surface-2);
}
.gov-dep .dh { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; }
.gov-dep .ds { font-size: 11.5px; color: var(--text-3); font-family: var(--font-mono); }
.gov-dep .dm {
  display: flex; align-items: center; gap: 8px; font-size: 11.5px;
  color: var(--text-2);
}
.gov-dep .ico {
  width: 22px; height: 22px; border-radius: 6px;
  background: #fff; border: 1px solid var(--border-soft);
  display: grid; place-items: center;
  color: var(--accent);
}

.gov-audit {
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  background: var(--surface-2);
  padding: 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  display: flex; flex-direction: column; gap: 5px;
  color: var(--text-2);
}
.gov-audit .line { display: flex; gap: 10px; align-items: center; }
.gov-audit .ts { color: var(--text-3); }
.gov-audit .tag { color: var(--accent); }

/* ---------- ecosystem ---------- */
.eco {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
@media (max-width: 1050px) { .eco { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 700px) { .eco { grid-template-columns: 1fr; } }

.ecard {
  position: relative;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: #fff;
  padding: 22px;
  display: flex; flex-direction: column; gap: 14px;
  transition: border-color 160ms ease;
  min-height: 220px;
  overflow: hidden;
}
.ecard:hover { border-color: var(--border-strong); }
.ecard .ehead { display: flex; align-items: center; gap: 10px; }
.ecard .eicon {
  width: 30px; height: 30px;
  border-radius: 8px;
  background: var(--surface);
  border: 1px solid var(--border-soft);
  color: var(--accent);
  display: grid; place-items: center;
}
.ecard h4 { font-size: 14.5px; }
.ecard p { font-size: 13px; color: var(--text-3); line-height: 1.5; flex: 1; }
.ecard .efoot {
  display: flex; align-items: center; justify-content: space-between;
  border-top: 1px solid var(--border-soft);
  padding-top: 12px;
}
.ecard .link {
  font-size: 12.5px; color: var(--accent); font-weight: 500;
  display: inline-flex; align-items: center; gap: 4px;
}
.ecard .efrag {
  display: flex; gap: 4px;
}
.efrag .pixel {
  width: 5px; height: 5px; border-radius: 1px;
  background: var(--border);
}

/* ---------- product INDEX page (composed, not flat grid) ---------- */
.product-index-opener {
  position: relative;
  padding: 96px 0 56px;
  overflow: hidden;
  border-bottom: 1px solid var(--border-soft);
}
.product-index-opener-inner {
  position: relative;
  max-width: 820px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.product-index-opener h1 {
  font-size: clamp(36px, 5.2vw, 56px);
  line-height: 1.06;
  letter-spacing: -0.03em;
  font-weight: 600;
  text-wrap: balance;
}
.product-index-opener .hero-lead {
  max-width: 680px;
  font-size: 17px;
}

.product-categories .container {
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.product-cat {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 36px;
  padding: 36px 0;
  border-top: 1px solid var(--border-soft);
  align-items: start;
  position: relative;
}
.product-cat:first-child { border-top: none; padding-top: 24px; }
.product-cat-label {
  position: sticky;
  top: 88px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-self: start;
}
.product-cat-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  background: #fff;
  border: 1px solid var(--border);
  position: relative;
}
.product-cat-name {
  font-family: var(--font-mono);
  font-size: 12.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--text-2);
}
.product-cat-headline {
  font-size: clamp(26px, 3.2vw, 36px);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.1;
  margin-bottom: 10px;
  text-wrap: balance;
}
.product-cat-copy {
  font-size: 16px;
  line-height: 1.6;
  color: var(--text-2);
  margin-bottom: 22px;
  max-width: 64ch;
  text-wrap: pretty;
}
.product-cat-modules {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.product-cat-module {
  display: grid;
  grid-template-columns: 40px 1fr auto;
  gap: 14px;
  align-items: center;
  padding: 14px 18px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: #fff;
  transition: border-color 160ms ease, transform 160ms ease, box-shadow 160ms ease;
}
.product-cat-module:hover {
  border-color: var(--border-strong);
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}
.product-cat-module-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  background: var(--accent-soft);
  color: var(--accent);
}
.product-cat-module-text { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.product-cat-module-title {
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.012em;
  color: var(--text);
}
.product-cat-module-sub {
  font-size: 13px;
  color: var(--text-3);
  line-height: 1.45;
}
.product-cat-module-arrow {
  color: var(--text-3);
  opacity: 0;
  transform: translateX(-4px);
  transition: opacity 160ms ease, transform 160ms ease;
}
.product-cat-module:hover .product-cat-module-arrow {
  opacity: 1;
  transform: translateX(0);
  color: var(--accent);
}

/* Identidad visual distinta por categoría */
.product-cat--operate .product-cat-num {
  background: var(--text);
  color: #fff;
  border-color: var(--text);
}
.product-cat--operate .product-cat-name { color: var(--text); }
.product-cat--operate .product-cat-module-icon {
  background: rgba(11, 16, 32, 0.05);
  color: var(--text);
}

.product-cat--build .product-cat-num {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff;
  border-color: transparent;
}
.product-cat--build .product-cat-name { color: var(--accent); }
.product-cat--build .product-cat-module-icon {
  background: var(--accent-soft);
  color: var(--accent);
}

.product-cat--work .product-cat-num {
  background: linear-gradient(135deg, var(--cyan), #0891b2);
  color: #fff;
  border-color: transparent;
}
.product-cat--work .product-cat-name { color: #0891b2; }
.product-cat--work .product-cat-module-icon {
  background: var(--cyan-soft);
  color: #0891b2;
}

@media (max-width: 760px) {
  .product-cat { grid-template-columns: 1fr; gap: 20px; padding: 28px 0; }
  .product-cat-label { position: static; flex-direction: row; align-items: center; }
  .product-cat-num { width: 36px; height: 36px; font-size: 12.5px; }
  .product-cat-headline { font-size: 24px; }
  .product-cat-copy { font-size: 14.5px; margin-bottom: 16px; }
  .product-cat-module { grid-template-columns: 32px 1fr auto; padding: 12px 14px; gap: 12px; }
  .product-cat-module-icon { width: 32px; height: 32px; }
}

/* ---- starter combinations (3 lanes) ---- */
.starter-lanes {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.starter-lane {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 26px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: #fff;
  position: relative;
}
.starter-lane::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 18px;
  border: 1px dashed transparent;
  pointer-events: none;
  transition: border-color 200ms ease;
}
.starter-lane:hover::before { border-color: var(--accent); }
.starter-audience {
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -0.018em;
  color: var(--text);
  line-height: 1.3;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border-soft);
  text-wrap: balance;
}
.starter-modules {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
  counter-reset: starter;
}
.starter-modules li {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 10px;
  align-items: center;
}
.starter-module-num {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  color: var(--text-3);
  text-align: center;
  padding: 4px 0;
  border-right: 1px dashed var(--border);
  letter-spacing: 0.06em;
}
.starter-module-link {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 8px;
  align-items: center;
  padding: 8px 10px;
  border-radius: 8px;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text);
  transition: background 120ms ease, color 120ms ease;
}
.starter-module-link:hover { background: var(--surface); color: var(--accent); }
.starter-module-icon {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  background: var(--surface);
  color: var(--accent);
  display: grid;
  place-items: center;
}
.starter-module-arrow { color: var(--text-3); }
.starter-module-link:hover .starter-module-arrow { color: var(--accent); }
.starter-why {
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--text-2);
  border-top: 1px solid var(--border-soft);
  padding-top: 14px;
  margin-top: auto;
  text-wrap: pretty;
}
@media (max-width: 980px) {
  .starter-lanes { grid-template-columns: 1fr; }
}

/* ---------- product pages ---------- */
.product-index-hero,
.product-hero {
  position: relative;
  padding: 60px 0 76px;
  overflow: hidden;
  border-bottom: 1px solid var(--border-soft);
}
.product-index-inner {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 18px;
}
.product-index-inner h1 { max-width: 820px; }
.product-index-inner .hero-lead { max-width: 760px; }
.product-index-section { padding-top: 80px; }
.product-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.product-tile {
  position: relative;
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 18px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 300px;
  transition: border-color 160ms ease, transform 160ms ease, box-shadow 160ms ease;
  overflow: hidden;
}
.product-tile:hover {
  border-color: var(--border-strong);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.product-tile-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.product-tile-icon,
.product-console-icon,
.related-icon {
  width: 34px; height: 34px;
  border-radius: 10px;
  display: grid; place-items: center;
  background: var(--accent-soft);
  color: var(--accent);
}
.product-category {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.product-tile h3 { font-size: 19px; }
.product-tile p {
  font-size: 13.5px;
  line-height: 1.55;
  flex: 1;
}
.product-tile-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: var(--accent);
  font-size: 13px;
  font-weight: 500;
  margin-top: auto;
}
.product-hero-inner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(420px, 1fr);
  gap: 56px;
  align-items: center;
}
.product-hero-copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 18px;
}
.product-hero-copy h1 {
  font-size: clamp(38px, 4.5vw, 56px);
  max-width: 720px;
}
.product-hero-copy .hero-lead { max-width: 650px; }
.product-breadcrumb {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-3);
}
.product-breadcrumb svg { transform: rotate(180deg); }
/* Breadcrumb (back to category) and the current-page pill share one line. */
.hero-topline {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 14px;
}
.hero-topline .eyebrow { margin: 0; }
.product-ctas { justify-content: flex-start; margin-top: 8px; }
.product-hero-art {
  position: relative;
  min-width: 0;
}
.product-console {
  position: relative;
  border: 1px solid var(--border);
  border-radius: 24px;
  background: #fff;
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}
.product-console::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to right, rgba(15,23,42,0.03) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(15,23,42,0.03) 1px, transparent 1px);
  background-size: 36px 36px;
  mask-image: radial-gradient(70% 70% at 50% 40%, #000, transparent);
  -webkit-mask-image: radial-gradient(70% 70% at 50% 40%, #000, transparent);
  pointer-events: none;
}
.product-console-top {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 18px;
  border-bottom: 1px solid var(--border-soft);
  font-family: var(--font-mono);
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-3);
}
.product-console-body {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 180px;
  gap: 14px;
  padding: 18px;
}
.product-console-main,
.product-console-side {
  border: 1px solid var(--border-soft);
  background: var(--surface-2);
  border-radius: 16px;
  padding: 14px;
}
.product-console-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 14px;
}
.product-console-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.product-console-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 9px;
  align-items: center;
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: 10px;
  padding: 9px 10px;
  font-size: 12px;
  color: var(--text-2);
}
.row-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 0 3px rgba(16,185,129,0.14);
}
.row-state {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--accent);
  background: var(--accent-soft);
  border-radius: 999px;
  padding: 2px 6px;
}
.product-console-side {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.product-stat-mini {
  display: flex;
  flex-direction: column;
  gap: 6px;
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  padding: 12px;
}
.product-stat-mini strong {
  font-size: 22px;
  letter-spacing: -0.03em;
}
.mini-label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.mini-bar {
  height: 5px;
  border-radius: 999px;
  background: var(--surface);
  position: relative;
  overflow: hidden;
}
.mini-bar::after {
  content: "";
  position: absolute;
  inset: 0;
  width: var(--w, 70%);
  background: linear-gradient(90deg, var(--accent), var(--cyan));
  border-radius: inherit;
  animation: bargrow 1.4s cubic-bezier(.2,.7,.2,1) both;
}
.product-proof {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 48px;
  align-items: center;
}
.product-proof h2 { margin-top: 14px; }
.product-proof .lead { margin-top: 14px; max-width: 660px; }
.product-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.product-stat {
  border: 1px solid var(--border);
  border-radius: 16px;
  background: #fff;
  padding: 22px;
  min-height: 140px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 6px;
}
.product-stat strong {
  font-family: var(--font-mono);
  font-size: 32px;
  letter-spacing: -0.04em;
  color: var(--text);
}
.product-stat span {
  font-size: 13px;
  color: var(--text-2);
}
.product-stat small {
  font-size: 11px;
  color: var(--text-3);
}
.product-answer {
  display: grid;
  grid-template-columns: minmax(0, 0.82fr) minmax(360px, 1fr);
  gap: 48px;
  align-items: center;
}
.product-answer h2 { margin-top: 14px; }
.product-answer .lead { margin-top: 14px; }
.product-answer-card {
  border: 1px solid var(--border);
  border-radius: 18px;
  background:
    radial-gradient(circle at 100% 0%, rgba(6,182,212,0.08), transparent 36%),
    #fff;
  box-shadow: var(--shadow-md);
  padding: 22px;
  display: grid;
  gap: 10px;
}
.answer-line {
  display: grid;
  grid-template-columns: 26px 1fr;
  gap: 12px;
  align-items: start;
  border: 1px solid var(--border-soft);
  border-radius: 13px;
  background: rgba(255,255,255,0.76);
  padding: 13px 14px;
  color: var(--text-2);
  font-size: 13.5px;
  line-height: 1.5;
}
.answer-line svg {
  width: 26px; height: 26px;
  padding: 6px;
  border-radius: 8px;
  background: var(--accent-soft);
  color: var(--accent);
}
.product-pain-grid,
.product-detail-grid,
.product-signal-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.product-pain-card,
.product-detail-card,
.signal-card {
  position: relative;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: #fff;
  box-shadow: var(--shadow-sm);
  padding: 24px;
  min-height: 240px;
  overflow: hidden;
  transition: border-color 160ms ease, transform 160ms ease, box-shadow 160ms ease;
}
.product-pain-card:hover,
.product-detail-card:hover,
.signal-card:hover {
  border-color: var(--border-strong);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.product-pain-card::after,
.product-detail-card::after,
.signal-card::after {
  content: "";
  position: absolute;
  right: -44px;
  bottom: -44px;
  width: 140px;
  height: 140px;
  border-radius: 50%;
  background: rgba(37,99,235,0.045);
  pointer-events: none;
}
.product-pain-card > *,
.product-detail-card > *,
.signal-card > * {
  position: relative;
  z-index: 1;
}
.product-pain-card > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: var(--surface);
  border: 1px solid var(--border-soft);
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 11px;
  margin-bottom: 28px;
}
.product-pain-card h3,
.product-detail-card h3 { font-size: 19px; }
.product-pain-card p,
.product-detail-card p,
.signal-card p {
  margin-top: 12px;
  font-size: 13.5px;
  line-height: 1.6;
  color: var(--text-2);
}
.product-detail-card {
  min-height: 330px;
  display: flex;
  flex-direction: column;
}
.product-detail-card ul {
  list-style: none;
  padding: 0;
  margin: 20px 0 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.product-detail-card li {
  position: relative;
  padding-left: 20px;
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.55;
}
.product-detail-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--cyan);
  box-shadow: 0 0 0 4px rgba(6,182,212,0.1);
}
.signal-card {
  min-height: 200px;
  display: flex;
  flex-direction: column;
}
.signal-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}
.signal-top span {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-3);
}
.signal-top strong {
  color: var(--accent);
  font-size: 20px;
  line-height: 1;
}
.signal-meter {
  height: 6px;
  border-radius: 999px;
  background: var(--surface);
  position: relative;
  overflow: hidden;
  margin-top: auto;
}
.signal-meter span {
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--w, 70%);
  border-radius: inherit;
  background: linear-gradient(90deg, var(--accent), var(--cyan));
  animation: bargrow 1.35s cubic-bezier(.2,.7,.2,1) both;
}
.product-faq-section {
  border-top: 1px solid var(--border-soft);
  border-bottom: 1px solid var(--border-soft);
}
.product-split {
  display: grid;
  grid-template-columns: 0.7fr 1.3fr;
  gap: 40px;
}
.product-feature-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
.product-feature {
  display: flex;
  gap: 12px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: #fff;
  padding: 18px;
}
.product-feature .check {
  width: 24px; height: 24px;
  border-radius: 7px;
  background: var(--accent-soft);
  color: var(--accent);
  display: grid; place-items: center;
  flex-shrink: 0;
}
.product-feature p,
.workflow-step p,
.product-info-card p,
.related-card p {
  font-size: 13.5px;
  line-height: 1.55;
}
.product-workflow {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.workflow-step {
  border: 1px solid var(--border);
  border-radius: 16px;
  background: #fff;
  padding: 20px;
  min-height: 170px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.workflow-step span {
  width: 30px; height: 30px;
  border-radius: 9px;
  background: var(--text);
  color: #fff;
  display: grid; place-items: center;
  font-family: var(--font-mono);
  font-size: 11px;
}
.product-two-col {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 56px;
}
.product-card-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.product-info-card {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 14px;
  padding: 16px;
}
.product-info-card span {
  width: 26px; height: 26px;
  border-radius: 8px;
  display: grid; place-items: center;
  background: var(--surface);
  border: 1px solid var(--border-soft);
  color: var(--accent);
  flex-shrink: 0;
}
.related-products {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.related-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 12px;
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 16px;
  padding: 22px;
  min-height: 240px;
  transition: border-color 160ms ease, transform 160ms ease;
  overflow: hidden;
}
.related-card:hover {
  border-color: var(--border-strong);
  transform: translateY(-2px);
}
.related-card h3 { font-size: 17px; }
.related-card > span:last-child {
  color: var(--accent);
  margin-top: auto;
}
@media (max-width: 1050px) {
  .product-grid { grid-template-columns: repeat(2, 1fr); }
  .product-hero-inner,
  .product-proof,
  .product-answer,
  .product-split,
  .product-two-col { grid-template-columns: 1fr; }
  .product-hero-inner { gap: 38px; }
  .product-pain-grid,
  .product-detail-grid,
  .product-signal-grid { grid-template-columns: 1fr; }
  .product-workflow { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 760px) {
  .product-index-hero,
  .product-hero { padding: 40px 0 56px; }
  .product-grid,
  .product-feature-list,
  .product-stats,
  .product-workflow,
  .related-products { grid-template-columns: 1fr; }
  .product-answer-card,
  .product-pain-card,
  .product-detail-card,
  .signal-card { min-height: 0; }
  .product-console-body { grid-template-columns: 1fr; }
  /* Desktop two-column gap becomes a tall empty stack gap on mobile. */
  .product-two-col { gap: 30px; }
  .product-split { gap: 28px; }
  .product-console-side { display: none; }
  .product-ctas { flex-direction: column; align-items: stretch; width: 100%; }
  .product-ctas .btn { width: 100%; }
}

/* ---------- product story pages ---------- */
.product-story-hero {
  --product-accent: var(--accent);
  --product-accent-2: var(--cyan);
  --product-soft: var(--blue-soft);
  position: relative;
  overflow: hidden;
  padding: 60px 0 80px;
  border-bottom: 1px solid var(--border-soft);
  background:
    linear-gradient(135deg, rgba(37,99,235,.055), transparent 38%),
    linear-gradient(180deg, #fff 0%, #f8fbff 100%);
}
.product-theme--build {
  --product-accent: #06b6d4;
  --product-accent-2: #2563eb;
  --product-soft: #ecfeff;
}
.product-theme--work {
  --product-accent: #10b981;
  --product-accent-2: #2563eb;
  --product-soft: #ecfdf5;
}
.product-theme--govern {
  --product-accent: #3730a3;
  --product-accent-2: #2563eb;
  --product-soft: #eef2ff;
}
.product-story-hero-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(420px, .82fr);
  gap: 72px;
  align-items: center;
}
.product-story-copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 18px;
}
.product-story-copy h1 {
  max-width: 760px;
  font-size: clamp(40px, 5vw, 60px);
  line-height: 1.04;
}
.product-story-copy .hero-lead {
  max-width: 690px;
}
/* Hero key points — the context the lead alone cannot carry.
   Each point pairs a short claim with a sentence of substance so the
   visitor does not have to imagine the benefit. */
.product-hero-points {
  list-style: none;
  padding: 0;
  margin: 4px 0 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
  max-width: 620px;
  width: 100%;
}
.product-hero-points li {
  display: grid;
  grid-template-columns: 26px 1fr;
  gap: 12px;
  align-items: start;
}
.php-mark {
  width: 24px;
  height: 24px;
  border-radius: 7px;
  background: var(--accent-soft);
  color: var(--accent);
  display: grid;
  place-items: center;
  margin-top: 1px;
}
.php-text {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}
.php-text strong {
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.01em;
  line-height: 1.35;
}
.php-label {
  font-weight: 500;
  color: var(--text-2);
}
.php-note {
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--text-2);
  text-wrap: pretty;
}
.product-story-art {
  position: relative;
}
.product-stage {
  position: relative;
  border: 1px solid rgba(216,221,228,.92);
  border-radius: 24px;
  background: rgba(255,255,255,.88);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  animation: product-stage-float 7s ease-in-out infinite;
}
.product-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--product-accent) 8%, transparent), transparent 42%),
    linear-gradient(to right, rgba(15,23,42,.035) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(15,23,42,.03) 1px, transparent 1px);
  background-size: auto, 42px 42px, 42px 42px;
  pointer-events: none;
}
.product-stage-head,
.product-stage-body,
.product-stage-foot {
  position: relative;
  z-index: 1;
}
.product-stage-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 20px 22px;
  border-bottom: 1px solid var(--border-soft);
}
.product-stage-head > div {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}
.product-stage-head strong {
  font-size: 16px;
}
.product-stage-head > span,
.stage-label {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.product-stage-icon {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: var(--product-soft);
  color: var(--product-accent);
  border: 1px solid color-mix(in srgb, var(--product-accent) 18%, var(--border));
}
.product-stage-body {
  display: grid;
  grid-template-columns: 1fr 160px;
  gap: 16px;
  padding: 18px;
}
.product-stage-main {
  border: 1px solid var(--border-soft);
  border-radius: 18px;
  background: rgba(255,255,255,.82);
  padding: 16px;
}
.stage-lines {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 14px;
}
.stage-line {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 12px;
  align-items: center;
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  background: #fff;
  padding: 11px 12px;
  transform: translateY(8px);
  opacity: 0;
  animation: product-line-in .7s cubic-bezier(.2,.7,.2,1) forwards;
  animation-delay: var(--d, 0ms);
}
.stage-line span {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: 9px;
  background: var(--text);
  color: #fff;
  font-family: var(--font-mono);
  font-size: 10.5px;
}
.stage-line p {
  font-size: 13px;
  color: var(--text-2);
}
.product-stage-metrics {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.product-stage-metrics div {
  border: 1px solid var(--border-soft);
  border-radius: 14px;
  background: rgba(255,255,255,.84);
  padding: 13px;
}
.product-stage-metrics span {
  display: block;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.product-stage-metrics strong {
  display: block;
  margin-top: 5px;
  font-size: 22px;
  color: var(--text);
}
.product-stage-foot {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 10px;
  align-items: start;
  padding: 16px 22px 20px;
  border-top: 1px solid var(--border-soft);
  background: rgba(247,248,250,.72);
}
.product-stage-foot span {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: 9px;
  background: var(--product-soft);
  color: var(--product-accent);
}
.product-stage-foot p {
  font-size: 13px;
  line-height: 1.55;
}
.product-overview-band--solo {
  display: block;
  padding-bottom: 8px;
}
.product-overview-band--solo .product-overview-copy .lead {
  max-width: 820px;
  font-size: 17px;
}
.product-overview-band {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(380px, .8fr);
  gap: 56px;
  align-items: end;
  padding-bottom: 8px;
}
.product-overview-copy h2 {
  margin-top: 16px;
}
.product-overview-copy .lead {
  margin-top: 16px;
  max-width: 760px;
}
.product-overview-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: var(--border);
}
.product-overview-stats div {
  min-height: 136px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  background: #fff;
  padding: 20px;
}
.product-overview-stats strong {
  font-family: var(--font-mono);
  font-size: 30px;
}
.product-overview-stats span,
.product-overview-stats small {
  font-size: 12.5px;
  color: var(--text-3);
}
.product-answer-panel {
  display: grid;
  grid-template-columns: minmax(0, .8fr) minmax(360px, 1fr);
  gap: 56px;
  align-items: center;
}
.product-answer-copy h2,
.product-lanes-intro h2,
.product-river-aside h2,
.product-evidence-main h2 {
  margin-top: 16px;
}
.product-answer-copy .lead {
  margin-top: 16px;
}
.product-answer-points {
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--border);
}
.product-answer-points div {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 14px;
  padding: 20px 0;
  border-bottom: 1px solid var(--border);
}
.product-answer-points span {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: 9px;
  background: var(--accent-soft);
  color: var(--accent);
}
.product-answer-points p {
  color: var(--text);
  font-size: 15px;
  line-height: 1.55;
}
.product-lanes {
  display: grid;
  grid-template-columns: minmax(300px, .64fr) minmax(0, 1fr);
  gap: 70px;
}
.product-lanes-intro {
  position: sticky;
  top: 112px;
  align-self: start;
}
.product-lane-list {
  position: relative;
  display: flex;
  flex-direction: column;
}
.product-lane-list::before {
  content: "";
  position: absolute;
  left: 17px;
  top: 20px;
  bottom: 20px;
  width: 1px;
  background: linear-gradient(var(--border), var(--accent), var(--border));
}
.product-lane {
  position: relative;
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 22px;
  padding: 8px 0 36px;
}
.product-lane > span {
  position: relative;
  z-index: 1;
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--border);
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 11px;
}
.product-lane h3 {
  font-size: 24px;
}
.product-lane p {
  max-width: 760px;
  margin-top: 10px;
  font-size: 15px;
  line-height: 1.65;
}
.product-river {
  display: grid;
  grid-template-columns: minmax(300px, .72fr) minmax(0, 1.15fr);
  gap: 72px;
}
.product-river-aside {
  position: sticky;
  top: 112px;
  align-self: start;
}
.product-river-aside p {
  margin-top: 18px;
  font-size: 15px;
}
.product-river-list {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.product-river-item {
  display: grid;
  grid-template-columns: 58px 1fr;
  gap: 22px;
  border: 1px solid var(--border);
  border-radius: 20px;
  background: #fff;
  padding: 26px;
  box-shadow: var(--shadow-sm);
}
.product-river-item > span {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: var(--text);
  color: #fff;
  font-family: var(--font-mono);
  font-size: 12px;
}
.product-river-item h3 {
  font-size: 24px;
}
.product-river-item p {
  margin-top: 8px;
  font-size: 15px;
  line-height: 1.65;
}
.product-river-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}
.product-river-chips em {
  max-width: 100%;
  border: 1px solid var(--border-soft);
  border-radius: 999px;
  background: var(--surface-2);
  padding: 7px 10px;
  font-style: normal;
  font-size: 12px;
  color: var(--text-2);
}
/* Detail points as prose, not chips — full sentences that elaborate
   the idea instead of compressing it into 3-word tags. */
.product-river-points {
  list-style: none;
  padding: 0;
  margin: 18px 0 0;
  display: flex;
  flex-direction: column;
  gap: 11px;
}
.product-river-points li {
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: 11px;
  align-items: start;
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--text-2);
}
.product-river-points .prp-mark {
  color: var(--accent);
  margin-top: 4px;
}
.product-flow-head {
  max-width: 640px;
}
.product-flow-track {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--border);
  border-radius: 22px;
  overflow: hidden;
  background: #fff;
}
.product-flow-track::before {
  content: "";
  position: absolute;
  left: 8%;
  right: 8%;
  top: 34px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
}
.product-flow-step {
  position: relative;
  min-height: 210px;
  padding: 58px 24px 24px;
  border-right: 1px solid var(--border-soft);
}
.product-flow-step:last-child {
  border-right: 0;
}
.product-flow-step span {
  position: absolute;
  top: 18px;
  left: 24px;
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: var(--product-soft, var(--accent-soft));
  border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--border));
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 11px;
}
.product-flow-step p {
  font-size: 14px;
  line-height: 1.6;
}
.product-evidence {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .82fr);
  gap: 52px;
}
.product-signal-lines {
  display: flex;
  flex-direction: column;
  margin-top: 30px;
  border-top: 1px solid var(--border);
}
.product-signal-line {
  display: grid;
  grid-template-columns: 116px 1fr;
  gap: 24px;
  padding: 22px 0;
  border-bottom: 1px solid var(--border);
}
.product-signal-line strong {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  line-height: 1.35;
  color: var(--accent);
  overflow-wrap: anywhere;
  margin-top: 3px;
}
.product-signal-line span {
  display: block;
  margin-bottom: 6px;
  color: var(--text);
  font-weight: 600;
}
.product-signal-line p {
  font-size: 14px;
  line-height: 1.6;
}
.product-evidence-side {
  display: grid;
  gap: 14px;
}
.product-evidence-side > div {
  border: 1px solid var(--border);
  border-radius: 20px;
  background: #fff;
  padding: 24px;
}
.product-evidence-side h3 {
  font-size: 21px;
  margin-bottom: 14px;
}
.product-evidence-side p {
  padding: 12px 0;
  border-top: 1px solid var(--border-soft);
  font-size: 14px;
  line-height: 1.55;
}
@keyframes product-stage-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}
@keyframes product-line-in {
  to { transform: translateY(0); opacity: 1; }
}
@media (max-width: 1100px) {
  .product-story-hero-inner,
  .product-overview-band,
  .product-answer-panel,
  .product-lanes,
  .product-river,
  .product-evidence {
    grid-template-columns: 1fr;
  }
  .product-story-art {
    max-width: 760px;
  }
  .product-lanes-intro,
  .product-river-aside {
    position: static;
  }
  .product-flow-track {
    grid-template-columns: repeat(2, 1fr);
  }
  .product-flow-step:nth-child(2) {
    border-right: 0;
  }
  .product-flow-track::before {
    display: none;
  }
}
@media (max-width: 760px) {
  .product-story-hero {
    padding: 98px 0 68px;
  }
  .product-story-hero-inner {
    gap: 40px;
  }
  .product-stage-body,
  .product-stage-head,
  .product-stage-foot,
  .product-river-item,
  .product-signal-line {
    grid-template-columns: 1fr;
  }
  .product-stage-head {
    align-items: flex-start;
    flex-direction: column;
  }
  .product-stage-metrics,
  .product-overview-stats,
  .product-flow-track {
    grid-template-columns: 1fr;
  }
  .product-flow-step,
  .product-flow-step:nth-child(2) {
    border-right: 0;
    border-bottom: 1px solid var(--border-soft);
    min-height: 0;
  }
  .product-flow-step:last-child {
    border-bottom: 0;
  }
  .product-river-item {
    padding: 22px;
  }
}

/* ---------- solution story pages ---------- */
.solution-hero {
  --solution-accent: var(--accent);
  --solution-accent-2: var(--cyan);
  --solution-soft: rgba(37, 99, 235, 0.08);
  --solution-soft-2: rgba(6, 182, 212, 0.08);
  position: relative;
  padding: 60px 0 76px;
  overflow: hidden;
  border-bottom: 1px solid var(--border-soft);
  background:
    radial-gradient(circle at 18% 18%, var(--solution-soft), transparent 34%),
    radial-gradient(circle at 88% 28%, var(--solution-soft-2), transparent 32%),
    linear-gradient(180deg, #fff 0%, #fbfcff 100%);
}
.solution-hero--marketing,
.solution-hero--support,
.solution-hero--knowledge {
  --solution-accent: var(--cyan);
  --solution-accent-2: var(--green);
  --solution-soft: rgba(6, 182, 212, 0.08);
  --solution-soft-2: rgba(16, 185, 129, 0.07);
}
.solution-hero--integrator,
.solution-hero--enterprise,
.solution-hero--content {
  --solution-accent: var(--accent-2);
  --solution-accent-2: var(--accent);
  --solution-soft: rgba(55, 48, 163, 0.075);
  --solution-soft-2: rgba(37, 99, 235, 0.06);
}
.solution-hero--sales {
  --solution-accent: var(--accent);
  --solution-accent-2: var(--amber);
  --solution-soft: rgba(37, 99, 235, 0.07);
  --solution-soft-2: rgba(245, 158, 11, 0.09);
}
.solution-hero-inner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(480px, .92fr);
  gap: 56px;
  align-items: center;
}
.solution-hero--marketing .solution-hero-inner,
.solution-hero--sales .solution-hero-inner,
.solution-hero--content .solution-hero-inner {
  grid-template-columns: minmax(480px, .92fr) minmax(0, 1.08fr);
}
.solution-hero--marketing .solution-hero-copy,
.solution-hero--sales .solution-hero-copy,
.solution-hero--content .solution-hero-copy {
  order: 2;
}
.solution-hero--marketing .solution-hero-art,
.solution-hero--sales .solution-hero-art,
.solution-hero--content .solution-hero-art {
  order: 1;
}
.solution-hero-copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 18px;
}
.solution-hero-copy h1 {
  font-size: clamp(36px, 4.3vw, 54px);
  line-height: 1.05;
  max-width: 760px;
}
.solution-hero-copy .hero-lead {
  max-width: 700px;
}
.solution-hero-art {
  position: relative;
  min-width: 0;
}
.solution-canvas {
  position: relative;
  min-height: 620px;
}
.solution-canvas-shell {
  position: relative;
  z-index: 1;
  border: 1px solid var(--border);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  animation: solution-canvas-rise .7s ease both;
}
.solution-canvas-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to right, rgba(15, 23, 42, 0.035) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(15, 23, 42, 0.035) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: radial-gradient(78% 70% at 50% 40%, #000, transparent);
  -webkit-mask-image: radial-gradient(78% 70% at 50% 40%, #000, transparent);
  pointer-events: none;
}
.solution-canvas-top {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 18px 20px;
  border-bottom: 1px solid var(--border-soft);
}
.solution-canvas-top span {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.solution-canvas-top strong {
  font-size: 14px;
}
.solution-canvas-body {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 180px;
  gap: 16px;
  padding: 20px;
}
.solution-canvas-main,
.solution-canvas-rail {
  position: relative;
}
.solution-canvas-main {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.solution-node {
  display: grid;
  grid-template-columns: 38px 1fr;
  gap: 13px;
  align-items: flex-start;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: #fff;
  padding: 16px;
}
.solution-node > span {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  color: var(--solution-accent);
  background: var(--solution-soft);
  border: 1px solid color-mix(in srgb, var(--solution-accent) 16%, var(--border));
}
.solution-node strong {
  display: block;
  font-size: 15px;
  margin-bottom: 5px;
}
.solution-node p {
  font-size: 12.5px;
  line-height: 1.55;
  color: var(--text-2);
}
.solution-node--soft {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, .92), rgba(255, 255, 255, .72)),
    var(--solution-soft);
}
.solution-canvas-lines {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-left: 20px;
}
.solution-canvas-lines::before {
  content: "";
  position: absolute;
  left: 8px;
  top: 4px;
  bottom: 4px;
  width: 1px;
  background: linear-gradient(180deg, transparent, var(--solution-accent), transparent);
}
.solution-canvas-line {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 10px;
  align-items: center;
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  background: rgba(255, 255, 255, .82);
  padding: 10px 12px;
  transform: translateX(12px);
  opacity: 0;
  animation: solution-line-in .55s ease forwards;
  animation-delay: var(--d, 0ms);
}
.solution-canvas-line span {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--solution-accent);
}
.solution-canvas-line p {
  font-size: 12.5px;
  line-height: 1.4;
}
.solution-canvas-rail {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.solution-rail-stat {
  border: 1px solid var(--border-soft);
  border-radius: 16px;
  background: #fff;
  padding: 16px;
  min-height: 112px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  animation: solution-card-float 7s ease-in-out infinite;
  animation-delay: var(--d, 0ms);
}
.solution-rail-stat strong {
  font-family: var(--font-mono);
  font-size: 24px;
  color: var(--solution-accent);
}
.solution-rail-stat span {
  font-size: 12px;
  color: var(--text-2);
}
.solution-float-card {
  position: absolute;
  z-index: 2;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: rgba(255, 255, 255, .94);
  box-shadow: var(--shadow-md);
  padding: 14px 16px;
  min-width: 150px;
  animation: solution-card-float 7.5s ease-in-out infinite;
}
.solution-float-card span {
  display: block;
  font-family: var(--font-mono);
  color: var(--solution-accent);
  font-size: 18px;
  margin-bottom: 2px;
}
.solution-float-card p {
  font-size: 12px;
  color: var(--text-2);
}
.solution-float-card--one {
  top: 42px;
  right: -22px;
}
.solution-float-card--two {
  left: -18px;
  bottom: 72px;
  animation-delay: 260ms;
}
.solution-positioning {
  background: #fff;
}
.solution-positioning-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(420px, .8fr);
  gap: 56px;
  align-items: center;
}
.solution-positioning-copy h2 {
  margin-top: 16px;
}
.solution-positioning-copy .lead {
  margin-top: 16px;
  max-width: 760px;
}
.solution-positioning-metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border: 1px solid var(--border);
  border-radius: 22px;
  background: var(--surface-2);
  overflow: hidden;
}
.solution-positioning-metrics div {
  padding: 24px 18px;
  border-right: 1px solid var(--border-soft);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
}
.solution-positioning-metrics div:last-child {
  border-right: 0;
}
.solution-positioning-metrics strong {
  font-family: var(--font-mono);
  font-size: 23px;
  color: var(--accent);
}
.solution-positioning-metrics span,
.solution-positioning-metrics small {
  font-size: 12.5px;
  color: var(--text-2);
}
.solution-answer {
  display: grid;
  grid-template-columns: minmax(0, .8fr) minmax(420px, 1fr);
  gap: 60px;
  align-items: start;
}
.solution-answer-question {
  position: sticky;
  top: 118px;
}
.solution-answer-question h2 {
  margin-top: 16px;
}
.solution-answer-body {
  border-left: 1px solid var(--border);
  padding-left: 40px;
}
.solution-answer-body .lead {
  max-width: 720px;
}
.solution-answer-points {
  display: grid;
  gap: 12px;
  margin-top: 28px;
}
.solution-answer-points div {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 12px;
  align-items: start;
}
.solution-answer-points span {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: 9px;
  background: var(--accent-soft);
  color: var(--accent);
}
.solution-answer-points p {
  font-size: 14.5px;
  line-height: 1.6;
}
.solution-map-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 28px;
  margin-bottom: 54px;
}
.solution-map-head h2 {
  max-width: 760px;
}
.solution-map {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.solution-map-row {
  display: grid;
  grid-template-columns: minmax(0, .95fr) 72px minmax(0, 1.1fr);
  align-items: stretch;
}
.solution-map-problem,
.solution-map-model {
  border: 1px solid var(--border);
  background: #fff;
  padding: 26px;
  min-height: 230px;
}
.solution-map-problem {
  border-radius: 22px 8px 8px 22px;
}
.solution-map-model {
  border-radius: 8px 22px 22px 8px;
}
.solution-map-problem > span {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid var(--border-soft);
  background: var(--surface);
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
  margin-bottom: 28px;
}
.solution-map-problem h3,
.solution-map-model h3 {
  font-size: 21px;
}
.solution-map-problem p,
.solution-map-model p {
  margin-top: 12px;
  font-size: 14px;
  line-height: 1.62;
}
.solution-map-model div {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 20px;
}
.solution-map-model em {
  font-style: normal;
  font-size: 12px;
  line-height: 1.35;
  color: var(--text-2);
  border: 1px solid var(--border-soft);
  border-radius: 999px;
  background: var(--surface-2);
  padding: 7px 10px;
}
.solution-map-connector {
  position: relative;
  display: grid;
  place-items: center;
}
.solution-map-connector::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, var(--border), var(--accent), var(--border));
}
.solution-map-connector span {
  position: relative;
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 8px rgba(37, 99, 235, .08);
}
.solution-model {
  display: grid;
  grid-template-columns: minmax(260px, .42fr) 1fr;
  gap: 58px;
}
.solution-model-aside {
  position: sticky;
  top: 118px;
  align-self: start;
}
.solution-model-aside h2 {
  margin-top: 16px;
}
.solution-model-flow {
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--border);
}
.solution-model-step {
  display: grid;
  grid-template-columns: 74px 1fr;
  gap: 26px;
  padding: 30px 0;
  border-bottom: 1px solid var(--border);
}
.solution-model-step > span {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: var(--text);
  color: #fff;
  font-family: var(--font-mono);
  font-size: 11px;
}
.solution-model-step h3 {
  font-size: 24px;
}
.solution-model-step p {
  margin-top: 10px;
  font-size: 14.5px;
  line-height: 1.62;
  max-width: 780px;
}
.solution-model-step ul {
  list-style: none;
  padding: 0;
  margin: 22px 0 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.solution-model-step li {
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  background: var(--surface-2);
  padding: 12px;
  font-size: 12.5px;
  line-height: 1.45;
  color: var(--text-2);
}
.solution-playbook-section {
  background:
    linear-gradient(90deg, rgba(37,99,235,0.035), transparent 42%),
    #fff;
}
.solution-playbook {
  display: grid;
  grid-template-columns: .48fr 1fr;
  gap: 56px;
  align-items: center;
}
.solution-playbook-intro h2 {
  margin-top: 16px;
}
.solution-playbook-track {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid var(--border);
  border-radius: 24px;
  background: #fff;
  overflow: hidden;
}
.solution-playbook-track::before {
  content: "";
  position: absolute;
  top: 44px;
  left: 28px;
  right: 28px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
}
.solution-playbook-step {
  position: relative;
  min-height: 260px;
  padding: 72px 22px 22px;
  border-right: 1px solid var(--border-soft);
}
.solution-playbook-step:last-child {
  border-right: 0;
}
.solution-playbook-step span {
  position: absolute;
  top: 28px;
  left: 22px;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--border));
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 11px;
}
.solution-playbook-step p {
  font-size: 13.5px;
  line-height: 1.6;
}
.solution-outcomes {
  display: grid;
  grid-template-columns: minmax(260px, .36fr) 1fr;
  gap: 56px;
  align-items: start;
}
.solution-outcome-copy h2 {
  margin-top: 16px;
}
.solution-outcome-board {
  border: 1px solid var(--border);
  border-radius: 24px;
  background: #fff;
  overflow: hidden;
}
.solution-outcome-card {
  position: relative;
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 24px;
  padding: 26px;
  border-bottom: 1px solid var(--border-soft);
}
.solution-outcome-card:last-child {
  border-bottom: 0;
}
.solution-outcome-card div {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.solution-outcome-card span {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.solution-outcome-card strong {
  color: var(--accent);
  font-size: 26px;
}
.solution-outcome-card p {
  font-size: 14px;
  line-height: 1.6;
  padding-bottom: 16px;
}
.solution-outcome-card em {
  position: absolute;
  left: 26px;
  right: 26px;
  bottom: 18px;
  height: 5px;
  border-radius: 999px;
  background: var(--surface);
  overflow: hidden;
}
.solution-outcome-card em::after {
  content: "";
  display: block;
  width: var(--w, 70%);
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--accent), var(--cyan));
  animation: bargrow 1.25s cubic-bezier(.2,.7,.2,1) both;
}
@keyframes solution-canvas-rise {
  from { transform: translateY(14px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
@keyframes solution-line-in {
  to { transform: translateX(0); opacity: 1; }
}
@keyframes solution-card-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-7px); }
}
@media (max-width: 1120px) {
  .solution-hero-inner,
  .solution-hero--marketing .solution-hero-inner,
  .solution-hero--sales .solution-hero-inner,
  .solution-hero--content .solution-hero-inner,
  .solution-positioning-inner,
  .solution-answer,
  .solution-model,
  .solution-playbook,
  .solution-outcomes {
    grid-template-columns: 1fr;
  }
  .solution-hero--marketing .solution-hero-copy,
  .solution-hero--sales .solution-hero-copy,
  .solution-hero--content .solution-hero-copy,
  .solution-hero--marketing .solution-hero-art,
  .solution-hero--sales .solution-hero-art,
  .solution-hero--content .solution-hero-art {
    order: initial;
  }
  .solution-hero-art {
    max-width: 780px;
  }
  .solution-answer-question,
  .solution-model-aside {
    position: static;
  }
  .solution-map-row {
    grid-template-columns: 1fr;
  }
  .solution-map-problem,
  .solution-map-model {
    border-radius: 22px;
  }
  .solution-map-connector {
    min-height: 48px;
  }
  .solution-map-connector::before {
    left: 50%;
    right: auto;
    top: 0;
    bottom: 0;
    width: 1px;
    height: auto;
    background: linear-gradient(180deg, var(--border), var(--accent), var(--border));
  }
  .solution-model-step ul {
    grid-template-columns: 1fr;
  }
  .solution-playbook-track {
    grid-template-columns: repeat(2, 1fr);
  }
  .solution-playbook-track::before {
    display: none;
  }
  .solution-playbook-step:nth-child(2) {
    border-right: 0;
  }
}
@media (max-width: 760px) {
  .solution-hero {
    padding: 40px 0 38px;
  }
  .solution-hero-inner {
    gap: 28px;
  }
  .solution-hero-copy {
    gap: 14px;
  }
  .solution-hero-copy h1 {
    font-size: clamp(34px, 11vw, 40px);
    line-height: 1.06;
  }
  .solution-hero-copy .hero-lead {
    font-size: 16px;
    line-height: 1.48;
  }
  .solution-hero .product-ctas {
    flex-direction: row;
    align-items: center;
    width: auto;
  }
  .solution-hero .product-ctas .btn {
    width: auto;
  }
  .solution-canvas {
    min-height: 0;
  }
  .solution-canvas-body {
    gap: 12px;
    padding: 14px;
  }
  .solution-canvas-top {
    align-items: flex-start;
    flex-direction: column;
    gap: 5px;
    padding: 14px;
  }
  .solution-canvas-main {
    gap: 10px;
  }
  .solution-node {
    grid-template-columns: 32px 1fr;
    padding: 12px;
  }
  .solution-node > span {
    width: 32px;
    height: 32px;
    border-radius: 10px;
  }
  .solution-node p {
    font-size: 12px;
  }
  .solution-node--soft,
  .solution-canvas-lines,
  .solution-canvas-rail {
    display: none;
  }
  .solution-canvas-lines {
    padding-left: 0;
  }
  .solution-canvas-lines::before {
    display: none;
  }
  .solution-canvas-line {
    grid-template-columns: 30px 1fr;
    padding: 9px 10px;
  }
  .solution-canvas-body,
  .solution-positioning-metrics,
  .solution-model-step,
  .solution-outcome-card {
    grid-template-columns: 1fr;
  }
  .solution-float-card {
    display: none;
  }
  .solution-positioning-metrics div {
    border-right: 0;
    border-bottom: 1px solid var(--border-soft);
  }
  .solution-positioning-metrics div:last-child {
    border-bottom: 0;
  }
  .solution-answer-body {
    border-left: 0;
    padding-left: 0;
  }
  .solution-map-head {
    align-items: flex-start;
    flex-direction: column;
  }
  .solution-map-problem,
  .solution-map-model {
    padding: 22px;
  }
  .solution-playbook-track {
    grid-template-columns: 1fr;
  }
  .solution-playbook-step,
  .solution-playbook-step:nth-child(2) {
    border-right: 0;
    border-bottom: 1px solid var(--border-soft);
    min-height: 0;
  }
  .solution-playbook-step:last-child {
    border-bottom: 0;
  }
}

/* ---------- government pages ---------- */
.government-page {
  --gov-accent: var(--accent);
  --gov-accent-2: var(--cyan);
  --gov-accent-soft: rgba(37, 99, 235, .08);
  --gov-accent-soft-2: rgba(6, 182, 212, .06);
}
.government-page--service {
  --gov-accent: #0f766e;
  --gov-accent-2: #2563eb;
  --gov-accent-soft: rgba(15, 118, 110, .08);
  --gov-accent-soft-2: rgba(37, 99, 235, .06);
}
.government-page--central {
  --gov-accent: #4338ca;
  --gov-accent-2: #0891b2;
  --gov-accent-soft: rgba(67, 56, 202, .08);
  --gov-accent-soft-2: rgba(8, 145, 178, .06);
}
.government-page--departments {
  --gov-accent: #0f766e;
  --gov-accent-2: #7c3aed;
  --gov-accent-soft: rgba(15, 118, 110, .08);
  --gov-accent-soft-2: rgba(124, 58, 237, .055);
}
.government-page--citizen {
  --gov-accent: #2563eb;
  --gov-accent-2: #0f766e;
  --gov-accent-soft: rgba(37, 99, 235, .085);
  --gov-accent-soft-2: rgba(15, 118, 110, .06);
}
.government-page--security {
  --gov-accent: #4f46e5;
  --gov-accent-2: #0f172a;
  --gov-accent-soft: rgba(79, 70, 229, .08);
  --gov-accent-soft-2: rgba(15, 23, 42, .045);
}
.government-hero {
  position: relative;
  padding: 56px 0 68px;
  overflow: hidden;
  border-bottom: 1px solid var(--border-soft);
  background:
    radial-gradient(circle at 14% 20%, var(--gov-accent-soft), transparent 34%),
    radial-gradient(circle at 88% 24%, var(--gov-accent-soft-2), transparent 28%),
    linear-gradient(180deg, #fff 0%, #f8fbff 100%);
}
.government-hero-inner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(500px, .94fr);
  gap: 64px;
  align-items: center;
}
.government-hero-copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 18px;
}
.government-hero-copy h1 {
  font-size: clamp(38px, 4.5vw, 56px);
  line-height: 1.05;
  max-width: 780px;
}
.government-hero-copy .hero-lead {
  max-width: 720px;
}
.government-hero-art {
  min-width: 0;
}
.government-visual {
  position: relative;
}
.government-map {
  border: 1px solid var(--border);
  border-radius: 28px;
  background: rgba(255, 255, 255, .9);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.government-map::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to right, rgba(15,23,42,.035) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(15,23,42,.035) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: radial-gradient(75% 70% at 50% 38%, #000, transparent);
  -webkit-mask-image: radial-gradient(75% 70% at 50% 38%, #000, transparent);
  pointer-events: none;
}
.government-map-head,
.government-map-body,
.government-map-foot {
  position: relative;
}
.government-map-head {
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 12px;
  align-items: center;
  padding: 18px 20px;
  border-bottom: 1px solid var(--border-soft);
}
.government-map-head > span {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  color: var(--gov-accent, var(--accent));
  background: color-mix(in srgb, var(--gov-accent, var(--accent)) 9%, #fff);
  border: 1px solid var(--border-soft);
}
.government-map-head strong {
  display: block;
  font-size: 15px;
}
.government-map-head p {
  font-size: 12px;
  color: var(--text-3);
}
.government-map-body {
  padding: 18px;
  display: grid;
  gap: 14px;
}
.government-authority {
  position: relative;
  border: 1px solid var(--border);
  border-radius: 18px;
  background:
    linear-gradient(135deg, var(--gov-accent-soft), var(--gov-accent-soft-2)),
    #fff;
  padding: 20px;
  text-align: center;
}
.government-authority::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -22px;
  width: 1px;
  height: 22px;
  background: var(--border-strong);
}
.government-authority span,
.government-unit span,
.government-map-foot span {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.government-authority strong {
  display: block;
  margin-top: 6px;
  font-size: 28px;
  color: var(--gov-accent, var(--accent));
}
.government-authority p {
  font-size: 13px;
}
.government-unit-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  padding-top: 10px;
}
.government-unit {
  border: 1px solid var(--border-soft);
  border-radius: 16px;
  background: #fff;
  padding: 14px;
  min-height: 122px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.government-unit strong {
  font-size: 14px;
}
.government-unit p {
  font-size: 12.5px;
  line-height: 1.45;
}
.government-map-foot {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--border-soft);
}
.government-map-foot div {
  padding: 16px;
  border-right: 1px solid var(--border-soft);
}
.government-map-foot div:last-child {
  border-right: 0;
}
.government-map-foot strong {
  display: block;
  font-family: var(--font-mono);
  font-size: 20px;
  color: var(--gov-accent, var(--accent));
  margin-bottom: 2px;
}
.government-brief-section {
  position: relative;
  margin-top: -1px;
  background:
    linear-gradient(90deg, rgba(248,250,252,.2), rgba(255,255,255,.92) 22%, rgba(255,255,255,.92) 78%, rgba(248,250,252,.2)),
    #fff;
  border-bottom: 1px solid var(--border-soft);
}
.government-brief {
  display: grid;
  grid-template-columns: minmax(280px, .72fr) minmax(0, 1fr);
  gap: 58px;
  align-items: start;
}
.government-brief-main {
  padding-top: 4px;
}
.government-brief-main h2 {
  margin-top: 14px;
  max-width: 560px;
}
.government-brief-main p {
  margin-top: 18px;
  max-width: 640px;
  font-size: 14px;
  line-height: 1.7;
  color: var(--text-2);
}
.government-brief-lines {
  border-top: 1px solid var(--border);
}
.government-brief-line {
  display: grid;
  grid-template-columns: 150px 1fr;
  gap: 26px;
  padding: 22px 0;
  border-bottom: 1px solid var(--border-soft);
}
.government-brief-line span {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.government-brief-line p {
  font-size: 14px;
  line-height: 1.62;
  color: var(--text-2);
}
.government-buyer {
  display: grid;
  grid-template-columns: minmax(280px, .48fr) 1fr;
  gap: 42px;
  align-items: stretch;
}
.government-buyer-kicker {
  border-right: 1px solid var(--border);
  padding-right: 36px;
}
.government-buyer-kicker h2 {
  margin-top: 14px;
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.08;
}
.government-buyer-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 1px solid var(--border);
  border-radius: 24px;
  overflow: hidden;
  background: #fff;
}
.government-buyer-card {
  padding: 24px;
  border-right: 1px solid var(--border-soft);
  min-height: 244px;
}
.government-buyer-card:last-child {
  border-right: 0;
}
.government-buyer-card > span {
  width: 38px;
  height: 38px;
  border-radius: 13px;
  display: grid;
  place-items: center;
  color: var(--gov-accent, var(--accent));
  background: color-mix(in srgb, var(--gov-accent, var(--accent)) 9%, #fff);
  border: 1px solid var(--border-soft);
  margin-bottom: 34px;
}
.government-buyer-card h3 {
  font-size: 20px;
}
.government-buyer-card p {
  margin-top: 12px;
  font-size: 13.5px;
  line-height: 1.6;
}
.government-pillars {
  display: grid;
  grid-template-columns: minmax(260px, .4fr) 1fr;
  gap: 56px;
  align-items: start;
}
.government-pillars-copy h2,
.government-section-head h2,
.government-detail-aside h2,
.government-playbook-copy h2,
.government-outcomes-copy h2 {
  margin-top: 16px;
}
.government-pillar-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 10px;
}
.government-pillar {
  border: 1px solid var(--border);
  border-radius: 18px;
  background: #fff;
  padding: 18px;
  min-height: 232px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.government-pillar > span {
  width: 34px;
  height: 34px;
  border-radius: 11px;
  display: grid;
  place-items: center;
  background: var(--surface);
  color: var(--gov-accent, var(--accent));
  font-family: var(--font-mono);
  font-size: 11px;
}
.government-pillar h3 {
  font-size: 18px;
}
.government-pillar p {
  font-size: 13px;
  line-height: 1.55;
}
.government-answer {
  display: grid;
  grid-template-columns: minmax(0, .72fr) minmax(420px, 1fr);
  gap: 58px;
  align-items: start;
}
.government-answer h2 {
  margin-top: 16px;
}
.government-answer-panel {
  border-left: 1px solid var(--border);
  padding-left: 42px;
}
.government-answer-list {
  display: grid;
  gap: 12px;
  margin-top: 28px;
}
.government-answer-list div {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 12px;
  align-items: start;
}
.government-answer-list span {
  width: 28px;
  height: 28px;
  border-radius: 9px;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--gov-accent, var(--accent)) 9%, #fff);
  color: var(--gov-accent, var(--accent));
}
.government-answer-list p {
  font-size: 14px;
  line-height: 1.6;
}
.government-section-head {
  max-width: 780px;
  margin-bottom: 54px;
}
.government-section-head--center {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}
.government-comparison {
  border: 1px solid var(--border);
  border-radius: 24px;
  background: #fff;
  overflow: hidden;
}
.government-comparison-row {
  display: grid;
  grid-template-columns: .62fr 1fr 1fr;
  border-bottom: 1px solid var(--border-soft);
}
.government-comparison-row:last-child {
  border-bottom: 0;
}
.government-comparison-row > div {
  padding: 24px;
  border-right: 1px solid var(--border-soft);
}
.government-comparison-row > div:last-child {
  border-right: 0;
}
.government-comparison-row h3 {
  font-size: 20px;
}
.government-comparison-row span {
  display: block;
  margin-bottom: 10px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.government-comparison-row p {
  font-size: 13.5px;
  line-height: 1.6;
}
.government-comparison-row > div:last-child {
  background: linear-gradient(135deg, var(--gov-accent-soft, rgba(37,99,235,.045)), var(--gov-accent-soft-2, rgba(6,182,212,.035)));
}
.government-scorecard {
  position: relative;
  display: grid;
  grid-template-columns: minmax(280px, .44fr) 1fr;
  gap: 52px;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: 28px;
  background:
    radial-gradient(circle at 0% 0%, var(--gov-accent-soft), transparent 36%),
    linear-gradient(135deg, #fff, #f8fbff);
  box-shadow: var(--shadow-sm);
  padding: 36px;
  overflow: hidden;
}
.government-scorecard::after {
  content: "";
  position: absolute;
  inset: auto -12% -42% 46%;
  height: 220px;
  background: radial-gradient(circle, var(--gov-accent-soft-2), transparent 68%);
  pointer-events: none;
}
.government-scorecard-copy,
.government-scorecard-grid {
  position: relative;
}
.government-scorecard-copy h2 {
  margin-top: 14px;
}
.government-scorecard-copy p {
  margin-top: 16px;
  font-size: 14px;
  line-height: 1.7;
}
.government-scorecard-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.government-scorecard-item {
  border: 1px solid var(--border-soft);
  border-radius: 18px;
  background: rgba(255,255,255,.82);
  padding: 18px;
  min-height: 186px;
}
.government-scorecard-item > span {
  display: inline-flex;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--gov-accent, var(--accent));
  margin-bottom: 28px;
}
.government-scorecard-item h3 {
  font-size: 18px;
}
.government-scorecard-item p {
  margin-top: 10px;
  font-size: 12.8px;
  line-height: 1.55;
}
.government-scenario-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border: 1px solid var(--border);
  border-radius: 26px;
  background: #fff;
  overflow: hidden;
}
.government-scenario {
  min-height: 218px;
  padding: 24px;
  border-right: 1px solid var(--border-soft);
  border-bottom: 1px solid var(--border-soft);
}
.government-scenario:nth-child(3n) {
  border-right: 0;
}
.government-scenario:nth-last-child(-n+3) {
  border-bottom: 0;
}
.government-scenario h3 {
  font-size: 20px;
}
.government-scenario p {
  margin-top: 14px;
  font-size: 13.5px;
  line-height: 1.62;
}
.government-detail {
  display: grid;
  grid-template-columns: minmax(280px, .42fr) 1fr;
  gap: 58px;
}
.government-detail-aside {
  position: sticky;
  top: 118px;
  align-self: start;
}
.government-detail-aside p {
  margin-top: 18px;
  font-size: 14px;
  line-height: 1.65;
}
.government-detail-list {
  display: grid;
  gap: 14px;
}
.government-detail-card {
  display: grid;
  grid-template-columns: 56px minmax(0, .8fr) minmax(320px, 1fr);
  gap: 22px;
  align-items: start;
  border: 1px solid var(--border);
  border-radius: 20px;
  background: #fff;
  padding: 24px;
}
.government-detail-card > span {
  width: 40px;
  height: 40px;
  border-radius: 13px;
  display: grid;
  place-items: center;
  color: #fff;
  background: linear-gradient(135deg, var(--text), color-mix(in srgb, var(--gov-accent, var(--accent)) 45%, var(--text)));
  font-family: var(--font-mono);
  font-size: 11px;
}
.government-detail-card h3 {
  font-size: 22px;
}
.government-detail-card p {
  margin-top: 10px;
  font-size: 14px;
  line-height: 1.6;
}
.government-detail-card ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 9px;
}
.government-detail-card li {
  position: relative;
  padding-left: 18px;
  font-size: 12.8px;
  line-height: 1.5;
  color: var(--text-2);
}
.government-detail-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gov-accent-2, var(--cyan));
}
.government-flow {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 1px solid var(--border);
  border-radius: 26px;
  background: #fff;
  overflow: hidden;
}
.government-flow-card {
  border-right: 1px solid var(--border-soft);
  padding: 24px;
  min-height: 342px;
  display: flex;
  flex-direction: column;
}
.government-flow-card:last-child {
  border-right: 0;
}
.government-flow-card > span {
  font-family: var(--font-mono);
  color: var(--gov-accent, var(--accent));
  margin-bottom: 34px;
}
.government-flow-card h3 {
  font-size: 21px;
}
.government-flow-card p {
  margin-top: 12px;
  font-size: 13.5px;
  line-height: 1.58;
}
.government-flow-card div {
  display: grid;
  gap: 8px;
  margin-top: auto;
  padding-top: 24px;
}
.government-flow-card em {
  font-style: normal;
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  background: var(--surface-2);
  padding: 10px;
  font-size: 12px;
  line-height: 1.4;
  color: var(--text-2);
}
.government-procurement {
  display: grid;
  grid-template-columns: minmax(280px, .44fr) 1fr;
  gap: 52px;
  align-items: start;
}
.government-procurement-copy h2 {
  margin-top: 14px;
}
.government-procurement-copy p {
  margin-top: 16px;
  font-size: 14px;
  line-height: 1.7;
}
.government-procurement-list {
  display: grid;
  gap: 0;
  border-top: 1px solid var(--border);
}
.government-procurement-list article {
  display: grid;
  grid-template-columns: minmax(160px, .35fr) 1fr;
  gap: 28px;
  padding: 22px 0;
  border-bottom: 1px solid var(--border-soft);
}
.government-procurement-list h3 {
  font-size: 18px;
}
.government-procurement-list p {
  font-size: 13.5px;
  line-height: 1.62;
}
.government-playbook {
  display: grid;
  grid-template-columns: minmax(260px, .36fr) 1fr;
  gap: 58px;
  align-items: start;
}
.government-playbook-list {
  border-left: 1px solid var(--border);
  padding-left: 34px;
  display: grid;
  gap: 12px;
}
.government-playbook-step {
  position: relative;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: #fff;
  padding: 20px 22px 20px 62px;
}
.government-playbook-step span {
  position: absolute;
  left: 18px;
  top: 18px;
  width: 30px;
  height: 30px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--gov-accent, var(--accent)) 9%, #fff);
  color: var(--gov-accent, var(--accent));
  font-family: var(--font-mono);
  font-size: 11px;
}
.government-playbook-step p {
  font-size: 14px;
  line-height: 1.6;
}
.government-outcomes {
  display: grid;
  grid-template-columns: minmax(260px, .34fr) 1fr;
  gap: 58px;
}
.government-outcome-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.government-outcome {
  border: 1px solid var(--border);
  border-radius: 20px;
  background: #fff;
  padding: 24px;
  min-height: 240px;
}
.government-outcome strong {
  display: inline-flex;
  font-family: var(--font-mono);
  font-size: 24px;
  color: var(--gov-accent, var(--accent));
  margin-bottom: 34px;
}
.government-outcome h3 {
  font-size: 20px;
}
.government-outcome p {
  margin-top: 12px;
  font-size: 13.5px;
  line-height: 1.6;
}
@media (max-width: 1120px) {
  .government-hero-inner,
  .government-brief,
  .government-buyer,
  .government-scorecard,
  .government-procurement,
  .government-pillars,
  .government-answer,
  .government-detail,
  .government-playbook,
  .government-outcomes {
    grid-template-columns: 1fr;
  }
  .government-hero-art {
    max-width: 780px;
  }
  .government-pillar-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .government-detail-aside {
    position: static;
  }
  .government-detail-card,
  .government-comparison-row,
  .government-flow,
  .government-outcome-grid,
  .government-scorecard-grid,
  .government-scenario-list {
    grid-template-columns: 1fr;
  }
  .government-buyer-kicker {
    border-right: 0;
    padding-right: 0;
  }
  .government-buyer-grid {
    grid-template-columns: 1fr;
  }
  .government-buyer-card {
    min-height: 0;
    border-right: 0;
    border-bottom: 1px solid var(--border-soft);
  }
  .government-buyer-card:last-child {
    border-bottom: 0;
  }
  .government-scenario,
  .government-scenario:nth-child(3n),
  .government-scenario:nth-last-child(-n+3) {
    border-right: 0;
    border-bottom: 1px solid var(--border-soft);
  }
  .government-scenario:last-child {
    border-bottom: 0;
  }
  .government-flow-card {
    border-right: 0;
    border-bottom: 1px solid var(--border-soft);
  }
  .government-flow-card:last-child {
    border-bottom: 0;
  }
  .government-comparison-row > div,
  .government-map-foot div {
    border-right: 0;
    border-bottom: 1px solid var(--border-soft);
  }
  .government-comparison-row > div:last-child,
  .government-map-foot div:last-child {
    border-bottom: 0;
  }
}
@media (max-width: 760px) {
  .government-hero {
    padding: 34px 0 16px;
  }
  .government-hero-inner {
    gap: 16px;
  }
  .government-hero-copy {
    gap: 12px;
  }
  .government-hero .product-breadcrumb {
    display: none;
  }
  .government-hero-copy h1 {
    font-size: clamp(30px, 9vw, 36px);
    line-height: 1.06;
  }
  .government-hero-copy .hero-lead {
    font-size: 15px;
    line-height: 1.46;
  }
  .government-hero .product-ctas {
    flex-direction: row;
    align-items: center;
    width: auto;
  }
  .government-hero .product-ctas .btn {
    width: auto;
  }
  .government-unit-grid,
  .government-map-foot,
  .government-pillar-grid {
    grid-template-columns: 1fr;
  }
  .government-unit-grid,
  .government-unit:nth-child(n+2),
  .government-map-foot {
    display: none;
  }
  .government-map-body {
    padding: 14px;
    gap: 10px;
  }
  .government-map-head {
    grid-template-columns: 34px 1fr;
    padding: 14px;
  }
  .government-map-head > span {
    width: 34px;
    height: 34px;
    border-radius: 11px;
  }
  .government-authority {
    padding: 14px;
  }
  .government-authority::after {
    display: none;
  }
  .government-authority strong {
    font-size: 22px;
  }
  .government-unit {
    min-height: 112px;
    padding: 13px;
  }
  .government-map-foot div {
    padding: 14px;
  }
  .government-brief {
    gap: 26px;
  }
  .government-brief-line {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 18px 0;
  }
  .government-scorecard {
    padding: 22px;
    border-radius: 22px;
    gap: 24px;
  }
  .government-scorecard-item {
    min-height: 0;
  }
  .government-procurement-list article {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .government-answer-panel {
    border-left: 0;
    padding-left: 0;
  }
  .government-detail-card {
    padding: 20px;
  }
  .government-playbook-list {
    border-left: 0;
    padding-left: 0;
  }
}

/* ---------- trust strip ---------- */
.trust {
  border: 1px solid var(--border);
  border-radius: 24px;
  background: var(--surface-2);
  padding: 32px;
  display: grid;
  grid-template-columns: 1.1fr 2fr;
  gap: 32px;
  align-items: center;
}
@media (max-width: 900px) { .trust { grid-template-columns: 1fr; } }
.trust h3 { font-size: 22px; max-width: 320px; }
.trust p { font-size: 14px; margin-top: 8px; }
.trust-items {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4px 18px;
}
@media (max-width: 600px) { .trust-items { grid-template-columns: 1fr; } }
.trust-item {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 0;
  border-bottom: 1px solid var(--border-soft);
  font-size: 13.5px;
  color: var(--text);
}
.trust-item:nth-last-child(-n+2) { border-bottom: 0; }
.trust-item .ico {
  width: 24px; height: 24px;
  border-radius: 7px;
  background: #fff;
  border: 1px solid var(--border-soft);
  color: var(--accent);
  display: grid; place-items: center;
  flex-shrink: 0;
}

/* ---------- plans ---------- */
.plans {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
@media (max-width: 1000px) { .plans { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .plans { grid-template-columns: 1fr; } }
.plan {
  border: 1px solid var(--border);
  border-radius: 18px;
  background: #fff;
  padding: 24px;
  display: flex; flex-direction: column; gap: 14px;
  position: relative;
}
.plan.featured {
  border-color: var(--text);
  box-shadow: 0 0 0 1px var(--text), var(--shadow-lg);
}
.plan-tag {
  position: absolute; top: -10px; left: 24px;
  background: var(--text); color: #fff;
  padding: 3px 10px; border-radius: 999px;
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.02em;
  z-index: 1;
}
.plan-name { font-size: 16px; font-weight: 600; }
.plan-tagline { font-size: 13px; color: var(--text-3); }
.plan-price {
  display: flex; align-items: baseline; gap: 6px;
  padding: 10px 0;
  border-top: 1px solid var(--border-soft);
  border-bottom: 1px solid var(--border-soft);
}
.plan-price .amount { font-family: var(--font-mono); font-size: 22px; font-weight: 600; letter-spacing: -0.01em; color: var(--text); }
.plan-price .note { font-size: 11.5px; color: var(--text-3); }
.plan-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 8px;
}
.plan-list li { font-size: 13px; color: var(--text-2); display: flex; gap: 8px; align-items: flex-start; }
.plan-list li::before {
  content: ""; flex-shrink: 0;
  width: 14px; height: 14px; margin-top: 3px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14' fill='none'%3E%3Cpath d='M2.5 7.5l3 3 6-7' stroke='%232563EB' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size: contain; background-repeat: no-repeat;
}

/* ---------- pricing page ---------- */
.pricing-hero {
  position: relative;
  overflow: hidden;
  padding: 60px 0 80px;
  border-bottom: 1px solid var(--border-soft);
  background:
    radial-gradient(circle at 78% 24%, rgba(6, 182, 212, 0.13), transparent 34%),
    linear-gradient(180deg, #fff 0%, #f9fbff 100%);
}

.pricing-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(420px, 0.8fr);
  gap: 72px;
  align-items: center;
  position: relative;
  z-index: 1;
}

.pricing-hero-copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 20px;
}

.pricing-hero-copy h1 {
  max-width: 760px;
  font-size: clamp(40px, 5vw, 62px);
}

.pricing-hero-copy .hero-lead { max-width: 680px; }

.pricing-facts {
  width: 100%;
  max-width: 660px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--border);
  box-shadow: var(--shadow-sm);
}

.pricing-facts div {
  background: rgba(255,255,255,.86);
  padding: 16px 18px;
}

.pricing-facts strong {
  display: block;
  font-family: var(--font-mono);
  font-size: 20px;
  color: var(--text);
}

.pricing-facts span {
  display: block;
  margin-top: 3px;
  font-size: 12px;
  color: var(--text-3);
}

.pricing-hero-art { position: relative; }

.pricing-snapshot {
  position: relative;
  border: 1px solid rgba(216,221,228,.9);
  border-radius: 22px;
  background: rgba(255,255,255,.86);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(18px);
  overflow: hidden;
}

.pricing-snapshot::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(37,99,235,.055), transparent 34%),
    linear-gradient(180deg, rgba(6,182,212,.08), transparent 28%);
  pointer-events: none;
}

.pricing-snapshot-head,
.pricing-snapshot-row,
.pricing-snapshot-foot {
  position: relative;
  z-index: 1;
}

.pricing-snapshot-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  padding: 22px;
  border-bottom: 1px solid var(--border-soft);
}

.pricing-snapshot-head span,
.pricing-snapshot-row span,
.pricing-snapshot-foot {
  font-size: 12px;
  color: var(--text-3);
}

.pricing-snapshot-head strong {
  display: block;
  margin-top: 2px;
  font-size: 16px;
}

.pricing-toggle {
  display: flex;
  align-items: center;
  align-self: flex-start;
  padding: 3px;
  gap: 2px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: #fff;
}

.pricing-toggle button {
  padding: 6px 9px;
  border-radius: 999px;
  font-size: 11px;
  color: var(--text-3);
  transition: background .16s ease, color .16s ease, box-shadow .16s ease;
}

.pricing-toggle button:focus-visible {
  outline: 0;
  box-shadow: 0 0 0 3px rgba(37,99,235,.16);
}

.pricing-toggle .active {
  background: var(--text);
  color: #fff;
}

.pricing-toggle--section {
  margin-top: 2px;
  background: var(--surface-2);
}

.pricing-snapshot-list {
  display: flex;
  flex-direction: column;
}

.pricing-snapshot-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 18px;
  align-items: center;
  padding: 18px 22px;
  border-bottom: 1px solid var(--border-soft);
  transition: background .2s ease, transform .2s ease;
}

.pricing-snapshot-row:hover {
  background: rgba(37,99,235,.035);
  transform: translateX(2px);
}

.pricing-snapshot-row.is-featured {
  background: linear-gradient(90deg, rgba(37,99,235,.09), rgba(6,182,212,.05));
}

.pricing-snapshot-row strong {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  color: var(--text);
}

.trial-chip {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  border: 1px solid rgba(37,99,235,.18);
  border-radius: 999px;
  background: rgba(37,99,235,.08);
  color: var(--accent);
  padding: 3px 8px;
  font-size: 10.5px;
  font-weight: 600;
}

.pricing-snapshot-row > div:last-child { text-align: right; }

.pricing-snapshot-row > div:last-child strong {
  justify-content: flex-end;
  font-family: var(--font-mono);
  font-size: 18px;
}

.pricing-snapshot-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 18px 22px;
  background: rgba(247,248,250,.82);
}

.pricing-snapshot-foot > div {
  display: flex;
  align-items: center;
  gap: 8px;
}

.pricing-snapshot-foot a {
  flex-shrink: 0;
  border: 1px solid rgba(37,99,235,.18);
  border-radius: 999px;
  background: #fff;
  padding: 7px 10px;
  color: var(--accent);
  font-size: 11.5px;
  font-weight: 600;
}

.pulse-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--green);
  box-shadow: 0 0 0 6px rgba(16,185,129,.12);
}

.pricing-positioning-panel {
  align-self: stretch;
  border-left: 2px solid var(--accent);
  padding: 8px 0 8px 24px;
}

.pricing-positioning-panel span {
  display: block;
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-3);
}

.pricing-positioning-panel strong {
  display: block;
  margin-top: 8px;
  font-size: 36px;
  letter-spacing: -0.03em;
}

.pricing-positioning-panel p {
  max-width: 340px;
  margin-top: 8px;
  font-size: 14px;
}

.pricing-section-head {
  max-width: 800px;
  margin-bottom: 40px;
}

.pricing-tier-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.pricing-tier {
  display: grid;
  grid-template-columns: 220px minmax(280px, 1.05fr) minmax(260px, .85fr) auto;
  gap: 28px;
  align-items: center;
  min-height: 172px;
  padding: 24px;
  border: 1px solid var(--border);
  border-radius: 20px;
  background: #fff;
  box-shadow: var(--shadow-sm);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.pricing-tier:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--border-strong);
}

.pricing-tier--featured {
  border-color: rgba(37,99,235,.45);
  background:
    linear-gradient(90deg, rgba(37,99,235,.055), rgba(6,182,212,.035) 46%, #fff 76%),
    #fff;
  box-shadow: 0 14px 36px -24px rgba(37,99,235,.55), var(--shadow-sm);
}

.pricing-tier-price {
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.pricing-tier-price h3 { font-size: 26px; }

.pricing-tier-price p,
.pricing-tier-price small {
  font-size: 12.5px;
  color: var(--text-3);
}

.pricing-tier-badge {
  width: fit-content;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 5px 9px;
  background: rgba(255,255,255,.76);
  color: var(--accent);
  font-size: 11px;
  font-weight: 600;
}

.pricing-amount {
  display: flex;
  align-items: baseline;
  gap: 9px;
  margin-top: 4px;
}

.pricing-amount strong {
  font-family: var(--font-mono);
  font-size: 26px;
  letter-spacing: -0.02em;
}

.pricing-amount span {
  font-size: 12px;
  color: var(--text-3);
}

.pricing-tier-fit {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.pricing-tier-fit p {
  max-width: 560px;
  font-size: 14px;
}

.pricing-trial-link {
  width: fit-content;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--accent);
  font-size: 13px;
  font-weight: 600;
}

.pricing-trial-link .arrow {
  transition: transform .2s ease;
}

.pricing-trial-link:hover .arrow {
  transform: translateX(3px);
}

.pricing-limit-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.pricing-limit-grid span {
  min-height: 36px;
  display: flex;
  align-items: center;
  border: 1px solid var(--border-soft);
  border-radius: 10px;
  background: var(--surface-2);
  padding: 8px 10px;
  font-size: 12px;
  color: var(--text-2);
}

.pricing-tier-features {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.pricing-tier-features span {
  border: 1px solid rgba(37,99,235,.14);
  border-radius: 999px;
  background: var(--accent-soft);
  color: #274690;
  padding: 6px 9px;
  font-size: 11.5px;
}

.pricing-compare-intro {
  max-width: 760px;
  margin-bottom: 34px;
}

.pricing-compare-intro h2 { margin-top: 16px; }
.pricing-compare-intro p { margin-top: 14px; }

.pricing-compare {
  overflow-x: auto;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: #fff;
  box-shadow: var(--shadow-sm);
}

.pricing-compare table {
  width: 100%;
  min-width: 880px;
  border-collapse: collapse;
}

.pricing-compare th,
.pricing-compare td {
  padding: 17px 18px;
  border-bottom: 1px solid var(--border-soft);
  text-align: left;
  vertical-align: top;
  font-size: 13px;
}

.pricing-compare thead th {
  position: sticky;
  top: 0;
  background: #fff;
  color: var(--text);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.pricing-compare tbody th {
  color: var(--text);
  font-weight: 600;
  background: rgba(247,248,250,.76);
}

.pricing-compare td { color: var(--text-2); }
.pricing-compare tr:last-child th,
.pricing-compare tr:last-child td { border-bottom: 0; }

.pricing-notes {
  display: grid;
  grid-template-columns: minmax(320px, .78fr) minmax(0, 1fr);
  gap: 72px;
  align-items: start;
}

.pricing-notes-copy {
  position: sticky;
  top: 120px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.pricing-note-lines {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid var(--border);
}

.pricing-note-line {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 22px;
  padding: 28px 0;
  border-bottom: 1px solid var(--border);
}

.pricing-note-line > span {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--text-3);
}

.pricing-note-line h3 {
  font-size: 22px;
  margin-bottom: 8px;
}

.pricing-note-line p {
  max-width: 640px;
  font-size: 15px;
}

@media (max-width: 1120px) {
  .pricing-hero-inner {
    grid-template-columns: 1fr;
    gap: 46px;
  }
  .pricing-hero-art { max-width: 680px; }
  .pricing-tier {
    grid-template-columns: minmax(180px, .8fr) minmax(0, 1.2fr);
  }
  .pricing-tier-features,
  .pricing-tier .btn { grid-column: 2; }
}

@media (max-width: 760px) {
  .pricing-hero { padding: 40px 0 60px; }
  .pricing-facts { grid-template-columns: 1fr; }
  .pricing-snapshot-head { flex-direction: column; }
  .pricing-snapshot-foot {
    align-items: flex-start;
    flex-direction: column;
  }
  .pricing-snapshot-row strong {
    align-items: flex-start;
    flex-direction: column;
  }
  .pricing-snapshot-row > div:last-child strong {
    align-items: flex-end;
  }
  .pricing-tier {
    grid-template-columns: 1fr;
    gap: 20px;
    padding: 22px;
  }
  .pricing-tier-features,
  .pricing-tier .btn { grid-column: auto; }
  .pricing-limit-grid { grid-template-columns: 1fr; }
  .pricing-notes {
    grid-template-columns: 1fr;
    gap: 34px;
  }
  .pricing-notes-copy { position: static; }
  .pricing-note-line {
    grid-template-columns: 1fr;
    gap: 8px;
  }
}

/* ---------- pricing: range rail (hero teaser) ---------- */
.pricing-rail {
  position: relative;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, #fff, var(--surface-2));
  box-shadow: var(--shadow-md);
  padding: 22px;
}
.pricing-rail-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 14px;
}
.pricing-rail-head span {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-3);
}
.pricing-rail-head strong { font-size: 13px; letter-spacing: -0.01em; }
.pricing-rail-track {
  position: relative;
  margin-top: 16px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.pricing-rail-track::before {
  content: '';
  position: absolute;
  left: 14px;
  top: 16px;
  bottom: 16px;
  width: 2px;
  background: linear-gradient(180deg, var(--border-strong), transparent);
}
.pricing-rail-stop {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 12px;
  border-radius: var(--radius);
}
.pricing-rail-dot {
  flex: none;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--border-strong);
  box-shadow: 0 0 0 4px #fff;
}
.pricing-rail-stop.is-featured { background: var(--accent-soft); }
.pricing-rail-stop.is-featured .pricing-rail-dot {
  background: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-soft);
}
.pricing-rail-meta { display: flex; flex-direction: column; }
.pricing-rail-meta strong { font-size: 15px; letter-spacing: -0.01em; }
.pricing-rail-meta span { font-family: var(--font-mono); font-size: 12px; color: var(--text-2); }
.pricing-rail-flag {
  margin-left: auto;
  font-style: normal;
  font-size: 11px;
  font-weight: 600;
  color: var(--accent);
  background: #fff;
  border: 1px solid var(--accent);
  border-radius: 999px;
  padding: 3px 9px;
}
.pricing-rail-foot {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12.5px;
  color: var(--text-2);
}

/* ---------- pricing: consolidated matrix ---------- */
.pricing-matrix-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 28px;
  margin-bottom: 28px;
}
.pricing-matrix-head h2 { margin-top: 14px; }
.pricing-matrix-head .lead { margin-top: 12px; max-width: 640px; }
.pricing-matrix {
  display: grid;
  grid-template-columns: minmax(190px, 1.15fr) repeat(var(--plan-count), minmax(0, 1fr));
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: #fff;
  box-shadow: var(--shadow-md);
  overflow: hidden;
}
.pm-head, .pm-group, .pm-row { display: contents; }
.pm-corner {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 4px;
  padding: 22px 20px;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
}
.pm-corner span { font-weight: 600; font-size: 15px; }
.pm-corner small { font-size: 11.5px; color: var(--text-3); }
.pm-plan {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  padding: 36px 18px 22px;
  border-bottom: 1px solid var(--border);
  border-left: 1px solid var(--border-soft);
}
.pm-plan.is-featured { background: rgba(37, 99, 235, .045); }
.pm-flag {
  position: absolute;
  top: 0;
  left: 18px;
  transform: translateY(-50%);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: #fff;
  background: var(--accent);
  border-radius: 999px;
  padding: 3px 10px;
}
/* Inside the matrix the container clips overflow (for rounded corners),
   so the flag sits within the reserved top padding instead of above it. */
.pm-plan .pm-flag { top: 12px; transform: none; }
.pm-badge {
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-3);
}
.pm-plan h3 { font-size: 22px; letter-spacing: -0.02em; }
.pm-plan > p { font-size: 12.5px; color: var(--text-2); min-height: 32px; }
.pm-price { display: flex; align-items: baseline; gap: 8px; margin-top: 6px; }
.pm-price strong { font-size: 26px; letter-spacing: -0.03em; }
.pm-price span { font-size: 12px; color: var(--text-3); }
.pm-trial { font-size: 11.5px; color: var(--text-3); }
.pm-cta { margin-top: 14px; width: 100%; justify-content: center; }
.pm-group-label {
  grid-column: 1 / -1;
  padding: 12px 20px;
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-3);
  background: var(--surface);
  border-bottom: 1px solid var(--border);
}
.pm-row-label {
  display: flex;
  align-items: center;
  padding: 14px 20px;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text);
  border-bottom: 1px solid var(--border-soft);
}
.pm-cell {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px 16px;
  text-align: center;
  border-bottom: 1px solid var(--border-soft);
  border-left: 1px solid var(--border-soft);
}
.pm-cell.is-featured { background: rgba(37, 99, 235, .045); }
.pm-group:last-child .pm-row:last-child .pm-row-label,
.pm-group:last-child .pm-row:last-child .pm-cell { border-bottom: 0; }
.pm-val { font-family: var(--font-mono); font-size: 13px; color: var(--text); }
.pm-no { color: var(--text-3); font-size: 15px; }
.pm-yes {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--accent-soft);
  color: var(--accent);
}
.pm-yes svg { width: 13px; height: 13px; }

/* ---------- pricing: baseline strip + chooser band ---------- */
.pricing-baseline {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.6fr);
  gap: 28px;
  align-items: center;
  padding: 24px 26px;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface-2);
}
.pricing-baseline-copy p { margin-top: 10px; font-size: 13.5px; color: var(--text-2); }
.pricing-baseline-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 22px;
}
.pricing-baseline-list li {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 13.5px;
  color: var(--text);
}
.pricing-baseline-list li span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--cyan-soft);
  color: var(--cyan);
  flex: none;
}
.pricing-baseline-list li span svg { width: 11px; height: 11px; }
.pricing-stage-band {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.pricing-stage {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 22px 20px;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: #fff;
}
.pricing-stage.is-trial { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(37,99,235,.08); }
.pricing-stage-top { display: flex; align-items: center; justify-content: space-between; }
.pricing-stage-step {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 600;
  color: var(--accent);
}
.pricing-stage-tag {
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--accent);
  background: var(--accent-soft);
  border-radius: 999px;
  padding: 3px 9px;
}
.pricing-stage strong { font-size: 16px; letter-spacing: -0.01em; }
.pricing-stage p { font-size: 13px; color: var(--text-2); line-height: 1.5; }

/* Mobile gets a dedicated stacked-card layout, not a squeezed or
   horizontally-scrolled table (mobile scrollbars aren't discoverable). */
.pricing-cards { display: none; }
.pricing-card {
  position: relative;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: #fff;
  box-shadow: var(--shadow-sm);
  padding: 24px 20px;
}
.pricing-card.is-featured {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, .08);
}
.pricing-card .pm-flag { left: 20px; }
.pc-top .pm-badge { display: block; }
.pc-top h3 { font-size: 24px; letter-spacing: -0.02em; margin-top: 6px; }
.pc-top > p { font-size: 13px; color: var(--text-2); margin-top: 4px; }
.pc-top .pm-price { margin-top: 14px; }
.pc-top .pm-price strong { font-size: 28px; letter-spacing: -0.03em; }
.pc-top .pm-price span { font-size: 12px; color: var(--text-3); }
.pc-top .pm-trial { display: block; margin-top: 4px; font-size: 11.5px; color: var(--text-3); }
.pc-group { margin-top: 16px; }
.pc-group-label {
  display: block;
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-3);
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}
.pc-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 11px 0;
  border-bottom: 1px solid var(--border-soft);
}
.pc-group .pc-row:last-child { border-bottom: 0; }
.pc-row-label { font-size: 13px; color: var(--text-2); }
.pc-row-val { display: inline-flex; align-items: center; justify-content: flex-end; font-size: 13px; text-align: right; }
.pc-cta { margin-top: 20px; width: 100%; justify-content: center; }

@media (max-width: 1000px) {
  .pricing-stage-band { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .pricing-matrix-head { flex-direction: column; align-items: flex-start; gap: 18px; }
}
@media (max-width: 820px) {
  .pricing-matrix { display: none; }
  .pricing-cards { display: flex; flex-direction: column; gap: 16px; }
  .pricing-baseline { grid-template-columns: 1fr; gap: 18px; }
}
@media (max-width: 620px) {
  .pricing-baseline-list { grid-template-columns: 1fr; }
  .pricing-stage-band { grid-template-columns: 1fr; }
}

/* ---------- resources ---------- */
.res {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
@media (max-width: 1000px) { .res { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .res { grid-template-columns: 1fr; } }
.rcard {
  border: 1px solid var(--border);
  border-radius: 14px;
  background: #fff;
  padding: 18px;
  display: flex; flex-direction: column; gap: 10px;
  min-height: 140px;
  transition: border-color 160ms ease;
}
.rcard:hover { border-color: var(--border-strong); }
.rcard .rkind {
  font-family: var(--font-mono); font-size: 10.5px;
  text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--accent);
}
.rcard h4 { font-size: 15px; line-height: 1.3; }
.rcard p { font-size: 12.5px; color: var(--text-3); flex: 1; }
.rcard .rlink {
  font-size: 12.5px; color: var(--text);
  display: inline-flex; align-items: center; gap: 4px;
  margin-top: auto;
}

/* ---------- launch path ---------- */
.launch-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.launch-step {
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 18px;
  padding: 22px;
  min-height: 250px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
  overflow: hidden;
}
.launch-step > span {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  background: var(--blue-soft);
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 11px;
}
.launch-step:nth-child(2) > span { background: var(--cyan-soft); color: var(--cyan); }
.launch-step:nth-child(3) > span,
.launch-step:nth-child(4) > span { background: var(--accent-soft); color: var(--accent); }
.launch-step h3 { font-size: 17px; }
.launch-step p {
  font-size: 13.5px;
  line-height: 1.55;
}
@media (max-width: 1050px) {
  .launch-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
  .launch-grid { grid-template-columns: 1fr; }
  .launch-step { min-height: 0; }
}

/* ---------- faq ---------- */
.faq-section {
  background:
    linear-gradient(180deg, #fff 0%, var(--surface-2) 100%);
}
.faq-list {
  max-width: 920px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.faq-item {
  border: 1px solid var(--border);
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.faq-item summary {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
  font-weight: 600;
  cursor: pointer;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary span {
  color: var(--accent);
  transition: transform 160ms ease;
  display: grid;
  place-items: center;
}
.faq-item[open] summary span { transform: rotate(180deg); }
.faq-item p {
  border-top: 1px solid var(--border-soft);
  padding: 0 20px 18px;
  font-size: 14px;
  line-height: 1.6;
}

/* ---------- final CTA ---------- */
.final {
  text-align: center;
  border: 1px solid var(--border);
  border-radius: 28px;
  background:
    radial-gradient(60% 60% at 50% 0%, rgba(37,99,235,0.08), transparent 70%),
    #fff;
  padding: 72px 32px;
  display: flex; flex-direction: column; align-items: center; gap: 18px;
  position: relative;
  overflow: hidden;
}
.final h2 { max-width: 760px; text-wrap: balance; }
.final p { max-width: 580px; font-size: 16px; }
.final-ctas { display: flex; gap: 10px; margin-top: 8px; flex-wrap: wrap; justify-content: center; }
.final-bg-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, rgba(15,23,42,0.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(15,23,42,0.04) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(60% 60% at 50% 50%, #000, transparent);
  -webkit-mask-image: radial-gradient(60% 60% at 50% 50%, #000, transparent);
  opacity: 0.5;
}

/* ---------- footer ---------- */
.footer {
  border-top: 1px solid var(--border-soft);
  padding: 64px 0 40px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr repeat(4, 1fr);
  gap: 40px;
}
@media (max-width: 900px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .footer-grid { grid-template-columns: 1fr; } }
.footer-brand p { font-size: 13px; margin-top: 14px; max-width: 280px; line-height: 1.5; }
.footer-col h5 {
  font-size: 12px; color: var(--text-3); margin: 0 0 12px;
  font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.08em;
  font-weight: 500;
}
.footer-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.footer-col li a { font-size: 13.5px; color: var(--text-2); }
.footer-col li a:hover { color: var(--text); }
.footer-bottom {
  border-top: 1px solid var(--border-soft);
  margin-top: 48px; padding-top: 24px;
  display: flex; justify-content: space-between; align-items: center;
  font-size: 12px; color: var(--text-3);
}
.footer-bottom .legal { display: flex; gap: 20px; }
.footer-disclaimer {
  margin-top: 36px;
  padding: 14px 18px;
  border: 1px dashed var(--border);
  border-radius: 10px;
  background: var(--surface-2);
  font-size: 12px;
  color: var(--text-3);
  line-height: 1.55;
  font-style: italic;
  max-width: 100%;
}

/* ---------- placeholder marker ---------- */
.is-placeholder {
  position: relative;
}
.is-placeholder::after {
  content: "PLACEHOLDER";
  position: absolute; top: 8px; right: 8px;
  font-family: var(--font-mono);
  font-size: 9px; letter-spacing: 0.08em;
  color: var(--muted);
  background: rgba(255,255,255,0.7);
  padding: 2px 5px; border-radius: 4px;
  border: 1px dashed var(--border-strong);
  pointer-events: none;
}
.logo-cell.is-placeholder::after { display: none; }

/* fade in on view */
[data-reveal] {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 600ms ease, transform 600ms cubic-bezier(.2,.7,.2,1);
}
[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* responsive dashboard collapse */
@media (max-width: 1100px) {
  .dash { grid-template-columns: 200px 1fr; }
  .dash-right { display: none; }
  .hero-visual { aspect-ratio: 16/11; }
}
@media (max-width: 760px) {
  .dash { grid-template-columns: 1fr; }
  .dash-sidebar { display: none; }
  .hero-visual { aspect-ratio: 4/5; }
  /* Tighten vertical rhythm on mobile — the desktop section spacing
     left pages feeling long and sparse on small screens. */
  .section { padding: 54px 0; }
  .section--tight { padding: 40px 0; }
  .section-head { margin-bottom: 30px; }
}
@media (max-width: 460px) {
  .section { padding: 46px 0; }
  .section--tight { padding: 34px 0; }
  .section-head { margin-bottom: 26px; gap: 12px; }
}
/* Ultra-narrow header (Galaxy Fold ~280px): the top Request Demo CTA
   collided with the logo and clipped it. Drop the header CTA — it stays
   available inside the mobile menu drawer. */
@media (max-width: 370px) {
  .nav-right .btn--primary { display: none; }
  .nav-inner { gap: 10px; }
  .nav-left { gap: 0; }
}


/* Static site responsive production patches */
@media (max-width: 980px) {
  .nav-left { gap: 18px; min-width: 0; }
  .nav-links { display: none; }
  .nav-inner { gap: 14px; }
  .nav-right { flex-shrink: 0; }
  .nav-right .btn--link { display: none !important; }
}
@media (max-width: 1180px) {
  .nav-right .btn--link { display: none !important; }
}
@media (max-width: 760px) {
  .hero { padding: 56px 0 28px; }
  .hero-lead { font-size: 16px; }
  .hero-visual { margin-top: 34px; aspect-ratio: 4 / 5; }
  .dash { grid-template-columns: 1fr; border-radius: 16px; }
  .dash-sidebar, .dash-bar, .dash-tabs, .dash-table { display: none; }
  .dash-main { padding: 14px; gap: 12px; }
  .dash-kpis { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .container { padding: 0 18px; }
  h1 { font-size: clamp(34px, 10vw, 42px); line-height: 1.08; letter-spacing: -0.025em; }
  h2 { font-size: clamp(28px, 9vw, 36px); letter-spacing: -0.02em; }
  .agency, .agency-text, .agency-mock, .gov, .gov-text, .gov-mock { min-width: 0; max-width: 100%; }
  .agency { border-radius: 22px; padding: 28px 18px; gap: 28px; }
  .agency-list, .gov-list, .gov-deps { grid-template-columns: 1fr; }
  .agency-ctas, .gov-actions { flex-direction: column; align-items: stretch; }
  .agency-mock { padding: 14px; }
  .agency-mock-head, .gov-mock-head { align-items: flex-start; flex-direction: column; gap: 8px; }
  .gov-mock { padding: 18px; }
  .gov-mock-head .right { margin-left: 0; flex-wrap: wrap; }
  .amrow { grid-template-columns: 1fr; gap: 8px; }
  .amrow .usage-mini { width: 100%; }
}
.language-switcher { display: inline-flex; align-items: center; gap: 8px; height: 44px; padding: 0 10px; border: 1px solid var(--border); border-radius: 10px; background: #fff; color: var(--text-2); font-size: 13px; }
.language-switcher select { border: 0; background: transparent; color: inherit; font: inherit; outline: none; cursor: pointer; }
.mobile-menu-toggle { display: none; }

/* ---------- mobile nav drawer ---------- */
.nav-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: #fff;
  color: var(--text);
  transition: background 160ms ease, border-color 160ms ease;
}
.nav-toggle:hover { background: var(--surface); border-color: var(--border-strong); }
.nav-toggle[aria-expanded="true"] { background: var(--surface); border-color: var(--border-strong); }
.nav-toggle .icon-close { display: none; }
.nav-toggle[aria-expanded="true"] .icon-menu { display: none; }
.nav-toggle[aria-expanded="true"] .icon-close { display: block; }

.mobile-nav {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: #fff;
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow-md);
  max-height: calc(100dvh - 64px);
  overflow-y: auto;
  z-index: 55;
}
.mobile-nav[hidden] { display: none; }
.mobile-nav-inner {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 14px 0 22px;
}
.mobile-nav-section {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-3);
  padding: 10px 4px 4px;
}
.mobile-nav-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.mobile-nav-list a {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 48px;
  padding: 10px 8px;
  border-radius: 10px;
  font-size: 15px;
  font-weight: 500;
  color: var(--text);
  transition: background 120ms ease;
}
.mobile-nav-list a:hover,
.mobile-nav-list a:focus-visible { background: var(--surface); }
.mobile-nav-list a .mn-icon {
  width: 32px;
  height: 32px;
  border-radius: 9px;
  background: var(--surface);
  border: 1px solid var(--border-soft);
  color: var(--accent);
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.mobile-nav-list a .mn-text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.mobile-nav-list a .mn-desc {
  font-size: 12.5px;
  font-weight: 400;
  color: var(--text-3);
  line-height: 1.4;
}
.mobile-nav-list a .mn-arrow {
  margin-left: auto;
  color: var(--text-3);
  flex-shrink: 0;
}
.mobile-nav-ctas {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-top: 16px;
  margin-top: 8px;
  border-top: 1px solid var(--border-soft);
}
.mobile-nav-ctas .btn { width: 100%; justify-content: center; }
.mobile-nav-langs {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 4px 4px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-3);
}
.mobile-nav-langs .language-switcher { display: inline-flex; flex: 1; }

body.has-mobile-nav-open { overflow: hidden; }

@media (max-width: 880px) {
  .nav-toggle { display: inline-flex; }
  .nav-left .nav-links { display: none; }
  .nav-right .nav-contact { display: none; }
  .nav-right .language-switcher { display: none; }
  .mobile-nav { display: block; }
  .mobile-nav[hidden] { display: none; }
}
@media (min-width: 881px) {
  .mobile-nav { display: none !important; }
}

/* ---------- product mocks (Lote C content-typed layouts) ---------- */
.pmock {
  position: relative;
  border: 1px solid var(--border);
  border-radius: 22px;
  background: #fff;
  box-shadow: var(--shadow-lg);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-height: 380px;
}
.pmock-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border-soft);
  background: linear-gradient(180deg, var(--surface-2), #fff);
  gap: 12px;
}
.pmock-head-id { display: flex; align-items: center; gap: 10px; min-width: 0; }
.pmock-head-id strong { font-size: 14px; font-weight: 600; letter-spacing: -0.01em; }
.pmock-icon {
  width: 30px; height: 30px;
  border-radius: 9px;
  background: var(--accent-soft);
  color: var(--accent);
  display: grid; place-items: center;
  flex-shrink: 0;
}
.pmock-head-status {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-3);
  white-space: nowrap;
}

/* --- gallery (Media Library) --- */
.pmock-gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  padding: 14px;
  flex: 1;
}
.pmock-gallery-card {
  position: relative;
  aspect-ratio: 1 / 1;
  border-radius: 10px;
  border: 1px solid var(--border-soft);
  overflow: hidden;
}
.pmock-gtone-a { background: linear-gradient(135deg, #c7d2fe, #818cf8); }
.pmock-gtone-b { background: linear-gradient(135deg, #bae6fd, #38bdf8); }
.pmock-gtone-c { background: linear-gradient(135deg, #f1f5f9, #cbd5e1); }
.pmock-gtone-d { background: linear-gradient(135deg, #fde68a, #f59e0b); }
.pmock-gtone-e { background: linear-gradient(135deg, #ddd6fe, #a78bfa); }
.pmock-gtone-f { background: linear-gradient(135deg, #99f6e4, #2dd4bf); }
.pmock-gallery-tag {
  position: absolute; top: 6px; left: 6px;
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: 0.06em; text-transform: uppercase;
  background: rgba(255,255,255,0.92);
  color: var(--text);
  padding: 2px 6px; border-radius: 4px;
}
.pmock-gallery-state {
  position: absolute; top: 6px; right: 6px;
  font-family: var(--font-mono); font-size: 9.5px;
  padding: 2px 5px; border-radius: 4px;
  background: rgba(255,255,255,0.92);
  color: var(--text-2);
  min-width: 22px; text-align: center;
}
.pmock-gallery-state--temp { color: #92400e; background: #fffbeb; }
.pmock-gallery-label {
  position: absolute; bottom: 6px; left: 6px; right: 6px;
  font-size: 10px; font-weight: 500;
  color: var(--text);
  background: rgba(255,255,255,0.92);
  padding: 3px 6px; border-radius: 5px;
  text-overflow: ellipsis; white-space: nowrap; overflow: hidden;
}
.pmock-gallery-meta {
  border-top: 1px solid var(--border-soft);
  padding: 12px 18px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px 16px;
  font-size: 12px;
  color: var(--text-2);
  background: var(--surface-2);
}
.pmock-gallery-meta > div { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.pmock-gallery-meta-wide { grid-column: 1 / -1; }
.pmock-meta-label {
  font-family: var(--font-mono); font-size: 9.5px;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--text-3);
}
.pmock-gallery-meta strong { font-size: 12px; font-weight: 600; color: var(--text); }

/* --- dashboard (Analytics) --- */
.pmock-dashboard-kpis {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  padding: 14px 14px 0;
}
.pd-kpi {
  border: 1px solid var(--border-soft);
  border-radius: 11px;
  padding: 10px 12px;
  background: #fff;
  display: flex; flex-direction: column; gap: 2px;
}
.pd-kpi-label {
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-3);
}
.pd-kpi strong { font-size: 18px; font-weight: 600; letter-spacing: -0.02em; color: var(--text); }
.pd-kpi-delta {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--green);
}
.pd-kpi-delta--warn { color: var(--amber); }
.pmock-dashboard-spark {
  padding: 14px;
  flex: 1;
}
.pd-spark-head {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 8px;
}
.pd-spark-svg {
  width: 100%; height: 70px;
  display: block;
}
.pmock-dashboard-alerts {
  display: flex; flex-direction: column; gap: 4px;
  padding: 0 14px 14px;
  font-size: 12px;
}
.pd-alert {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px;
  border: 1px solid var(--border-soft);
  border-radius: 9px;
  background: var(--surface-2);
  color: var(--text-2);
}
.pd-alert .chip { flex-shrink: 0; }

/* --- flow (Actions & Integrations) --- */
.pmock-flow-stage {
  position: relative;
  padding: 16px 16px 8px;
  display: flex; flex-direction: column; gap: 10px;
  flex: 1;
  min-height: 220px;
}
.pmock-flow-edges {
  position: absolute; inset: 0;
  pointer-events: none;
  width: 100%; height: 100%;
}
.pf-node {
  position: relative;
  z-index: 1;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #fff;
  padding: 10px 12px;
  display: flex; flex-direction: column; gap: 2px;
  box-shadow: var(--shadow-sm);
  width: 62%;
  max-width: 240px;
}
.pf-node--trigger { align-self: flex-start; }
.pf-node--action { align-self: center; border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent); }
.pf-node--webhook { align-self: flex-end; }
.pf-node-kind {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
}
.pf-node strong { font-size: 13px; font-weight: 600; }
.pf-node-meta {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-3);
}
.pmock-flow-log {
  border-top: 1px solid var(--border-soft);
  background: var(--surface-2);
  padding: 10px 14px;
  display: flex; flex-direction: column; gap: 4px;
  font-family: var(--font-mono); font-size: 10.5px;
  color: var(--text-2);
}
.pf-log-row { display: flex; align-items: center; gap: 10px; }
.pf-log-ts { color: var(--text-3); flex-shrink: 0; }
.pf-log-tag {
  color: var(--accent);
  background: var(--accent-soft);
  padding: 1px 6px; border-radius: 4px;
  font-size: 9.5px; letter-spacing: 0.05em;
  flex-shrink: 0;
}
.pf-log-tag--ok { color: #047857; background: #ecfdf5; }
.pf-log-tag--warn { color: #92400e; background: #fffbeb; }

/* --- workspace (Controlled Workspaces) --- */
.pmock-workspace-summary {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border-soft);
  background: var(--surface-2);
  gap: 12px;
}
.pw-avatars { display: flex; align-items: center; padding-right: 4px; }
.pw-avatar {
  width: 30px; height: 30px;
  margin-right: -8px;
  border: 2px solid #fff;
  border-radius: 8px;
  font-size: 10.5px;
  font-weight: 600;
  color: #fff;
  display: grid; place-items: center;
}
.pw-avatar-more {
  margin-left: 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
}
.pw-stats { display: flex; gap: 16px; font-size: 12px; color: var(--text-3); }
.pw-stats strong { color: var(--text); margin-right: 4px; font-weight: 600; }
.pmock-workspace-sessions {
  padding: 12px 14px;
  flex: 1;
  display: flex; flex-direction: column; gap: 4px;
}
.pw-session {
  display: grid;
  grid-template-columns: 70px 1fr auto;
  gap: 10px; align-items: center;
  padding: 9px 12px;
  border: 1px solid var(--border-soft);
  border-radius: 10px;
  background: #fff;
  font-size: 12px;
}
.pw-session-ts {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--text-3);
}
.pw-session-name { font-weight: 500; color: var(--text); }
.pmock-workspace-roles {
  padding: 12px 18px;
  border-top: 1px solid var(--border-soft);
  background: var(--surface-2);
  display: grid;
  grid-template-columns: 1fr 60px 60px 60px;
  row-gap: 6px;
  column-gap: 14px;
  font-size: 12px;
  align-items: center;
}
.pw-role-head, .pw-role-row { display: contents; }
.pw-role-head span {
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-3);
  text-align: center;
}
.pw-role-row strong { font-weight: 600; color: var(--text); }
.pw-role-row > span {
  justify-self: center;
  width: 18px; height: 18px;
  border-radius: 5px;
  border: 1px solid var(--border);
  background: #fff;
}
.pw-r-on {
  background: var(--accent-soft) !important;
  border-color: var(--accent) !important;
  position: relative;
}
.pw-r-on::after {
  content: "";
  position: absolute; inset: 4px;
  background: var(--accent);
  border-radius: 2px;
}

/* --- editor (Content Studio) --- */
.pmock-editor-toolbar {
  display: flex; align-items: center; gap: 6px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border-soft);
  background: var(--surface-2);
}
.pe-tb {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  padding: 4px 8px;
  border-radius: 6px;
  background: #fff;
  border: 1px solid var(--border-soft);
  color: var(--text-2);
  height: 26px;
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 26px;
}
.pe-tb--ai {
  color: var(--accent);
  background: var(--accent-soft);
  border-color: transparent;
  gap: 4px;
  padding: 4px 10px;
}
.pe-tb-divider {
  width: 1px; height: 14px;
  background: var(--border);
  margin: 0 4px;
}
.pmock-editor-canvas {
  padding: 16px 20px;
  flex: 1;
  display: flex; flex-direction: column; gap: 8px;
  background: #fff;
  font-size: 12.5px;
  line-height: 1.55;
  color: var(--text-2);
}
.pe-h1 {
  font-size: 18px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.015em;
}
.pe-p { display: block; }
.pe-selected {
  background: linear-gradient(transparent 60%, rgba(37,99,235,0.18) 60%);
  padding-right: 4px;
}
.pe-aibadge {
  display: inline-flex; align-items: center; gap: 4px;
  margin-left: 6px;
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--accent);
  background: var(--accent-soft);
  padding: 2px 6px;
  border-radius: 5px;
  white-space: nowrap;
}
.pmock-editor-versions {
  padding: 10px 14px;
  border-top: 1px solid var(--border-soft);
  background: var(--surface-2);
  display: flex; gap: 8px; flex-wrap: wrap;
  font-size: 11px;
  color: var(--text-3);
}
.pe-version {
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid var(--border-soft);
  background: #fff;
}
.pe-version strong { color: var(--text); font-weight: 600; margin-right: 4px; }
.pe-version--current { border-color: var(--accent); background: var(--accent-soft); }
.pe-version--current strong { color: var(--accent); }

/* --- pipeline (Knowledge & Sources) --- */
.pmock-pipeline-sources {
  padding: 14px;
  display: flex; flex-direction: column; gap: 6px;
  flex: 1;
}
.pp-source {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  gap: 10px;
  align-items: center;
  padding: 10px 12px;
  border: 1px solid var(--border-soft);
  border-radius: 10px;
  background: #fff;
  font-size: 12.5px;
}
.pp-source-icon { color: var(--accent); display: inline-flex; }
.pp-source-name { font-weight: 500; color: var(--text); }
.pp-source-bar {
  width: 80px; height: 4px;
  border-radius: 2px;
  background: var(--surface);
  position: relative; overflow: hidden;
}
.pp-source-bar > span {
  position: absolute; left: 0; top: 0; bottom: 0;
  width: var(--w, 50%);
  background: linear-gradient(90deg, var(--accent), var(--cyan));
}
.pp-source-meta {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--text-3);
}
.pmock-pipeline-answer {
  padding: 0 14px 14px;
}
.pp-answer-bubble {
  border: 1px solid #dbe4ff;
  border-radius: 12px;
  background: var(--accent-soft);
  padding: 12px 14px;
  display: flex; flex-direction: column; gap: 6px;
  font-size: 12.5px;
}
.pp-answer-q {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--accent);
}
.pp-answer-a {
  color: #1e3a8a;
  line-height: 1.5;
}
.pp-answer-cite {
  display: inline-flex; align-items: center; gap: 4px;
  margin-left: 6px;
  font-family: var(--font-mono);
  font-size: 9.5px;
  padding: 2px 6px;
  border-radius: 5px;
  background: #fff;
  border: 1px solid #dbe4ff;
  color: var(--accent);
  white-space: nowrap;
}

/* --- security (Security & Data Controls) --- */
.ps-encrypt {
  display: inline-flex; align-items: center; gap: 5px;
  color: #047857 !important;
}
.pmock-security-tenants {
  padding: 14px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  position: relative;
}
.pmock-security-tenants::before,
.pmock-security-tenants::after {
  content: "";
  position: absolute; top: 22px; bottom: 22px;
  width: 0;
  border-left: 1.5px dashed var(--border);
}
.pmock-security-tenants::before { left: 33.33%; }
.pmock-security-tenants::after { left: 66.66%; }
.ps-tenant {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 10px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #fff;
  min-width: 0;
}
.ps-tenant-mark {
  width: 28px; height: 28px;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff;
  display: grid; place-items: center;
  font-size: 11px; font-weight: 600;
  flex-shrink: 0;
}
.ps-tenant-mark--b { background: linear-gradient(135deg, #10b981, #059669); }
.ps-tenant-mark--c { background: linear-gradient(135deg, #f59e0b, #d97706); }
.ps-tenant div { min-width: 0; }
.ps-tenant strong { display: block; font-size: 12px; font-weight: 600; }
.ps-tenant span {
  font-size: 10px;
  color: var(--text-3);
  font-family: var(--font-mono);
}
.pmock-security-rbac {
  padding: 12px 18px;
  background: var(--surface-2);
  border-top: 1px solid var(--border-soft);
  display: grid;
  grid-template-columns: 1fr 32px 32px 32px;
  row-gap: 5px;
  column-gap: 14px;
  font-size: 12px;
  align-items: center;
}
.ps-rbac-head, .ps-rbac-row { display: contents; }
.ps-rbac-head span {
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-3);
  text-align: center;
}
.ps-rbac-row strong { font-weight: 600; color: var(--text); }
.ps-rbac-row > span {
  justify-self: center;
  width: 26px; height: 22px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 5px;
  background: #fff;
  border: 1px solid var(--border);
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-3);
}
.ps-rbac-row > span.ps-r-on {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: var(--accent);
  font-weight: 600;
}
.pmock-security-audit {
  padding: 10px 14px;
  border-top: 1px solid var(--border-soft);
  background: var(--surface-2);
  display: flex; flex-direction: column; gap: 4px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--text-2);
}
.ps-audit-row { display: flex; align-items: center; gap: 10px; }
.ps-audit-ts { color: var(--text-3); flex-shrink: 0; }
.ps-audit-tag {
  color: var(--accent);
  background: var(--accent-soft);
  padding: 1px 6px;
  border-radius: 4px;
  font-size: 9.5px;
  letter-spacing: 0.05em;
  flex-shrink: 0;
}
.ps-audit-tag--deny { color: var(--red); background: #fef2f2; }

/* --- builder (AI Assistant Builder) --- */
.pmock-builder-steps {
  padding: 14px;
  display: flex; flex-direction: column; gap: 4px;
  border-bottom: 1px solid var(--border-soft);
}
.pb-step {
  display: flex; align-items: center; gap: 12px;
  padding: 9px 12px;
  border: 1px solid var(--border-soft);
  border-radius: 10px;
  background: #fff;
}
.pb-step-num {
  width: 26px; height: 26px;
  border-radius: 8px;
  background: var(--surface);
  border: 1px solid var(--border-soft);
  color: var(--text-3);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  display: grid; place-items: center;
  flex-shrink: 0;
}
.pb-step strong { font-size: 13px; font-weight: 600; display: block; color: var(--text); }
.pb-step span {
  font-size: 11px;
  color: var(--text-3);
  font-family: var(--font-mono);
}
.pb-step--done .pb-step-num {
  background: var(--accent-soft);
  color: var(--accent);
  border-color: transparent;
}
.pb-step--active {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent);
}
.pb-step--active .pb-step-num {
  background: var(--accent);
  color: #fff;
  border-color: transparent;
}
.pmock-builder-playground {
  padding: 14px;
  flex: 1;
  display: flex; flex-direction: column; gap: 8px;
  background: var(--surface-2);
}
.pb-playground-head {
  display: flex; align-items: center; gap: 8px;
  font-size: 12.5px;
}
.pb-playground-head .avatar {
  width: 26px; height: 26px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  border-radius: 7px;
  display: grid; place-items: center;
  color: #fff;
}
.pb-playground-head strong { font-weight: 600; color: var(--text); }
.pb-status {
  margin-left: auto;
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 10.5px;
  color: #047857;
}
.pb-status .dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 0 3px rgba(16,185,129,0.18);
}
.pb-playground-body {
  display: flex; flex-direction: column; gap: 6px;
  padding: 4px 0;
}
.pb-playground-body .bubble {
  font-size: 12px;
  padding: 8px 10px;
}

/* --- operations (Agency & Client Management) --- */
.pmock-operations-kpis {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  padding: 14px 14px 0;
}
.po-kpi {
  border: 1px solid var(--border-soft);
  border-radius: 11px;
  padding: 10px 12px;
  background: #fff;
}
.po-kpi-label {
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-3);
  display: block; margin-bottom: 2px;
}
.po-kpi strong { font-size: 20px; font-weight: 600; letter-spacing: -0.02em; color: var(--text); }
.pmock-operations-clients {
  padding: 12px 14px;
  flex: 1;
  display: flex; flex-direction: column; gap: 4px;
}
.po-client {
  display: grid;
  grid-template-columns: 22px 1fr auto 70px auto;
  gap: 10px; align-items: center;
  padding: 8px 10px;
  border: 1px solid var(--border-soft);
  border-radius: 9px;
  background: #fff;
  font-size: 12px;
}
.po-client .avatar {
  width: 22px; height: 22px;
  border-radius: 6px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff;
  font-size: 9.5px;
  font-weight: 600;
  display: grid; place-items: center;
}
.po-client-name { font-weight: 500; color: var(--text); }
.po-client-pkg {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-3);
}
.po-client-bar {
  height: 4px;
  border-radius: 2px;
  background: var(--surface);
  position: relative; overflow: hidden;
}
.po-client-bar > span {
  position: absolute; left: 0; top: 0; bottom: 0;
  width: var(--w, 50%);
  background: var(--accent);
}
.pmock-operations-activity {
  padding: 10px 14px;
  border-top: 1px solid var(--border-soft);
  background: var(--surface-2);
  display: flex; flex-direction: column; gap: 4px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--text-2);
}
.po-act { display: flex; align-items: center; gap: 10px; }
.po-act-ts { color: var(--text-3); flex-shrink: 0; }
.po-act-tag {
  color: var(--accent);
  background: var(--accent-soft);
  padding: 1px 6px;
  border-radius: 4px;
  font-size: 9.5px;
  letter-spacing: 0.05em;
  flex-shrink: 0;
}

@media (max-width: 760px) {
  .pmock { min-height: 0; }
  .pmock-gallery-grid { grid-template-columns: repeat(3, 1fr); }
  .pmock-dashboard-kpis,
  .pmock-operations-kpis { grid-template-columns: repeat(3, 1fr); }
  .pf-node { width: 80%; max-width: none; }
  .pmock-flow-stage { min-height: 180px; }
}

/* ---------- home: hero extras (tagline + proof line) ---------- */
.hero-tagline {
  font-size: 16px;
  font-style: italic;
  color: var(--text-3);
  max-width: 640px;
  text-wrap: balance;
  letter-spacing: -0.005em;
  margin-top: -8px;
}
.hero-proof {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.04em;
  color: var(--text-3);
  margin-top: 4px;
}

/* ---------- home: 3 false alternatives (editorial, not card grid) ---------- */
.alternatives {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  align-items: start;
  margin-top: 16px;
}
.alt {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 4px 0;
  position: relative;
}
.alt-num {
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.08em;
  color: var(--text-3);
  font-weight: 500;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
}
.alt-title {
  font-size: 26px;
  font-weight: 600;
  letter-spacing: -0.022em;
  line-height: 1.15;
  color: var(--text);
}
.alt-body {
  font-size: 15px;
  line-height: 1.6;
  color: var(--text-2);
  text-wrap: pretty;
  max-width: 38ch;
}
.alt-resolution {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 56px;
  padding: 24px 28px;
  border-left: 3px solid var(--accent);
  background: linear-gradient(90deg, var(--accent-soft), transparent 60%);
  border-radius: 0 12px 12px 0;
}
.alt-resolution-marker {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: var(--accent);
  color: #fff;
  display: grid;
  place-items: center;
}
.alt-resolution p {
  font-size: 19px;
  font-weight: 500;
  color: var(--text);
  letter-spacing: -0.015em;
  line-height: 1.4;
  text-wrap: balance;
}
@media (max-width: 900px) {
  .alternatives { grid-template-columns: 1fr; gap: 36px; }
  .alt-resolution { margin-top: 32px; flex-direction: column; align-items: flex-start; gap: 12px; padding: 20px; }
  .alt-title { font-size: 22px; }
}

/* ---------- home: what it is (tenant diagram + pillars + modules) ---------- */
.tenant-diagram {
  border: 1px solid var(--border);
  border-radius: 20px;
  background: linear-gradient(180deg, #fff, var(--surface-2));
  padding: 24px 24px 20px;
  margin-bottom: 36px;
  position: relative;
  overflow: hidden;
}
.td-heading {
  margin-bottom: 18px;
  text-align: center;
}
.td-stack {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  max-width: 560px;
  margin: 0 auto;
}
.td-layer {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #fff;
  padding: 10px 16px;
  box-shadow: var(--shadow-sm);
  text-align: center;
  position: relative;
}
/* Staggered reveal: capas y flechas aparecen una por una al hacer scroll */
.tenant-diagram .td-stack > * {
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 500ms cubic-bezier(.2,.7,.2,1), transform 500ms cubic-bezier(.2,.7,.2,1);
}
[data-reveal].is-visible .tenant-diagram .td-stack > * {
  opacity: 1;
  transform: translateY(0);
}
[data-reveal].is-visible .tenant-diagram .td-stack > *:nth-child(1) { transition-delay: 80ms; }
[data-reveal].is-visible .tenant-diagram .td-stack > *:nth-child(2) { transition-delay: 180ms; }
[data-reveal].is-visible .tenant-diagram .td-stack > *:nth-child(3) { transition-delay: 280ms; }
[data-reveal].is-visible .tenant-diagram .td-stack > *:nth-child(4) { transition-delay: 380ms; }
[data-reveal].is-visible .tenant-diagram .td-stack > *:nth-child(5) { transition-delay: 480ms; }
[data-reveal].is-visible .tenant-diagram .td-stack > *:nth-child(6) { transition-delay: 600ms; }
[data-reveal].is-visible .tenant-diagram .td-stack > *:nth-child(7) { transition-delay: 720ms; }
/* Flechas sutilmente pulsan después de aparecer */
.tenant-diagram .td-arrow {
  animation: tdArrowPulse 2.6s ease-in-out 1.4s infinite;
}
@keyframes tdArrowPulse {
  0%, 100% { opacity: 0.5; transform: translateY(0); }
  50% { opacity: 1; transform: translateY(2px); }
}
.td-layer-label strong {
  display: block;
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
}
.td-layer-label span {
  display: block;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
  letter-spacing: 0.04em;
  margin-top: 2px;
}
.td-layer--platform {
  background: linear-gradient(135deg, var(--text), #1a2238);
  border-color: transparent;
}
.td-layer--platform .td-layer-label strong { color: #fff; }
.td-layer--platform .td-layer-label span { color: rgba(255,255,255,0.55); }
.td-layer--agency {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  border-color: transparent;
}
.td-layer--agency .td-layer-label strong { color: #fff; }
.td-layer--agency .td-layer-label span { color: rgba(255,255,255,0.7); }
.td-layer--clients {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  background: transparent;
  border: none;
  box-shadow: none;
  padding: 0;
}
.td-client {
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #fff;
  padding: 12px 14px;
  box-shadow: var(--shadow-sm);
  text-align: left;
}
.td-client strong {
  display: block;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--text);
}
.td-client span {
  display: block;
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--text-3);
  letter-spacing: 0.04em;
  margin-top: 3px;
}
.td-layer--end {
  background: var(--surface);
  border-style: dashed;
}
.td-arrow {
  color: var(--text-3);
  padding: 6px 0;
  opacity: 0.5;
}
.td-note {
  text-align: center;
  margin-top: 20px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.04em;
  color: var(--text-3);
}
@media (max-width: 760px) {
  .td-layer--clients { grid-template-columns: 1fr; }
}

.pillars-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 56px;
  padding-top: 24px;
  border-top: 1px solid var(--border-soft);
}
.pillar h3 {
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -0.015em;
  margin-bottom: 8px;
  position: relative;
  padding-left: 14px;
}
.pillar h3::before {
  content: "";
  position: absolute;
  left: 0;
  top: 7px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
}
.pillar p {
  font-size: 14px;
  line-height: 1.55;
  color: var(--text-2);
  text-wrap: pretty;
}
@media (max-width: 900px) {
  .pillars-row { grid-template-columns: 1fr; gap: 24px; }
}

.modules-section {
  padding-top: 32px;
  border-top: 1px solid var(--border-soft);
}
.modules-head {
  margin-bottom: 24px;
}
.modules-head h3 {
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.018em;
  margin-top: 10px;
  max-width: 640px;
  text-wrap: balance;
}
.modules-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.module-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: #fff;
  transition: border-color 160ms ease, transform 160ms ease, box-shadow 160ms ease;
  min-height: 168px;
}
.module-card:hover {
  border-color: var(--border-strong);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.module-icon {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: var(--accent-soft);
  color: var(--accent);
  display: grid;
  place-items: center;
}
.module-category {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-3);
}
.module-card h4 {
  font-size: 15.5px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--text);
}
.module-card p {
  font-size: 13px;
  line-height: 1.5;
  color: var(--text-2);
  flex: 1;
}
.module-arrow {
  position: absolute;
  top: 18px;
  right: 18px;
  color: var(--text-3);
  opacity: 0;
  transform: translateX(-4px);
  transition: opacity 160ms ease, transform 160ms ease;
}
.module-card:hover .module-arrow {
  opacity: 1;
  transform: translateX(0);
  color: var(--accent);
}
@media (max-width: 900px) { .modules-strip { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .modules-strip { grid-template-columns: 1fr; } }

/* ---------- home: agency math stat ---------- */
.agency-math {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 22px 24px;
  margin: 10px 0 6px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 16px;
  position: relative;
  overflow: hidden;
}
.agency-math::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(60% 90% at 100% 0%, rgba(6, 182, 212, 0.18), transparent 60%);
  pointer-events: none;
}
.agency-math-eyebrow {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.5);
  position: relative;
}
.agency-math-headline {
  font-family: var(--font-mono);
  font-size: 44px;
  font-weight: 600;
  letter-spacing: -0.04em;
  color: #fff;
  line-height: 1.05;
  position: relative;
}
.agency-math-sublabel {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.78);
  font-weight: 500;
  position: relative;
}
.agency-math-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  margin-top: 8px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  position: relative;
}
.agency-math-margin {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 600;
  color: var(--cyan);
}
.agency-math-note {
  font-size: 12.5px;
  color: rgba(255, 255, 255, 0.6);
  text-align: right;
  flex: 1;
}
@media (max-width: 600px) {
  .agency-math-row { flex-direction: column; align-items: flex-start; gap: 4px; }
  .agency-math-note { text-align: left; }
  .agency-math-headline { font-size: 36px; }
}

/* ---------- home: government per-project pricing note ---------- */
.gov-pricing-note {
  margin-top: 28px;
  padding: 20px 22px;
  border-left: 3px solid var(--accent);
  background: var(--accent-soft);
  border-radius: 0 12px 12px 0;
}
.gov-pricing-note .eyebrow {
  background: #fff;
  border-color: var(--border-soft);
}
.gov-pricing-note h3 {
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.015em;
  color: var(--text);
  margin: 10px 0 6px;
}
.gov-pricing-note p {
  font-size: 14px;
  line-height: 1.55;
  color: var(--text-2);
  text-wrap: pretty;
}

/* ---------- home: commercial transparency (pricing table + why-now + honesty) ---------- */
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.pricing-wrap {
  border: 1px solid var(--border);
  border-radius: 18px;
  background: #fff;
  overflow-x: auto;
  margin-top: 8px;
}
.pricing-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 13.5px;
  min-width: 720px;
}
.pricing-table th,
.pricing-table td {
  padding: 12px 16px;
  text-align: left;
  vertical-align: middle;
  border-bottom: 1px solid var(--border-soft);
}
.pricing-table thead th {
  border-bottom: 1px solid var(--border);
  background: var(--surface-2);
  vertical-align: bottom;
  padding: 18px 16px;
}
.pricing-corner { width: 30%; min-width: 220px; }
.pricing-tier-head {
  border-left: 1px solid var(--border-soft);
  white-space: nowrap;
}
.pricing-tier-head .pricing-plan-name {
  display: block;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--text);
  margin-bottom: 10px;
}
.pricing-tier-head .pricing-price {
  display: block;
  font-family: var(--font-mono);
  font-size: 22px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.02em;
  margin-bottom: 4px;
}
.pricing-tier-head .pricing-note {
  display: block;
  font-size: 11px;
  color: var(--text-3);
  font-family: var(--font-mono);
  letter-spacing: 0.02em;
  font-weight: 400;
  white-space: normal;
  max-width: 14ch;
}
.pricing-tier-head.is-highlight {
  background: linear-gradient(180deg, var(--accent-soft), #fff);
  border-left-color: var(--accent);
  border-right: 1px solid var(--accent);
  position: relative;
}
.pricing-tier-head.is-highlight .pricing-price { color: var(--accent); }
.pricing-label {
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text);
  background: #fff;
  border-right: 1px solid var(--border-soft);
}
.pricing-table tbody tr:hover .pricing-label,
.pricing-table tbody tr:hover .pricing-cell { background-color: var(--surface-2); }
.pricing-cell {
  font-family: var(--font-mono);
  color: var(--text-2);
  border-left: 1px solid var(--border-soft);
  border-right: 1px solid transparent;
}
.pricing-cell.is-yes { color: #047857; font-weight: 500; }
.pricing-cell.is-empty { color: var(--muted); }
.pricing-cell.is-highlight {
  background: rgba(37, 99, 235, 0.04);
  border-left-color: var(--accent);
  border-right-color: var(--accent);
}
.pricing-table tbody tr:last-child th,
.pricing-table tbody tr:last-child td { border-bottom: none; }
.pricing-no-share {
  margin-top: 18px;
  padding: 14px 20px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  background: linear-gradient(90deg, var(--accent-soft), transparent 80%);
  border-left: 3px solid var(--accent);
  border-radius: 0 10px 10px 0;
  letter-spacing: -0.005em;
}

@media (max-width: 1000px) {
  .pricing-table { font-size: 12.5px; }
  .pricing-table th, .pricing-table td { padding: 10px 12px; }
  .pricing-tier-head .pricing-tier { font-size: 13.5px; }
  .pricing-tier-head .pricing-price { font-size: 19px; }
}

.why-now {
  margin-top: 56px;
  padding: 32px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background:
    radial-gradient(60% 100% at 100% 0%, rgba(6, 182, 212, 0.10), transparent 60%),
    linear-gradient(180deg, #fff, var(--surface-2));
}
.why-now h3 {
  font-size: 32px;
  font-weight: 600;
  letter-spacing: -0.025em;
  margin: 14px 0 14px;
  max-width: 600px;
  text-wrap: balance;
}
.why-now p {
  font-size: 15.5px;
  line-height: 1.6;
  color: var(--text-2);
  max-width: 720px;
  text-wrap: pretty;
}

.honesty {
  margin-top: 40px;
  padding: 28px 32px;
  border: 1px dashed var(--border-strong);
  border-radius: 18px;
  background: var(--surface-2);
}
.honesty-head h3 {
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.018em;
  margin: 10px 0 8px;
}
.honesty-head p {
  font-size: 14px;
  color: var(--text-2);
  max-width: 640px;
}
.honesty-list {
  list-style: none;
  padding: 0;
  margin: 20px 0 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.honesty-item {
  display: grid;
  grid-template-columns: minmax(220px, 0.85fr) minmax(0, 1.4fr);
  gap: 24px;
  padding: 16px 20px;
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  align-items: start;
  position: relative;
}
.honesty-item::before {
  content: "✕";
  position: absolute;
  left: -10px;
  top: 18px;
  width: 22px;
  height: 22px;
  background: #fff;
  border: 1px solid var(--border-strong);
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-3);
  font-weight: 600;
}
.honesty-tradeoff {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.005em;
  line-height: 1.4;
}
.honesty-rationale {
  font-size: 13.5px;
  color: var(--text-2);
  line-height: 1.55;
  position: relative;
  padding-left: 20px;
}
.honesty-rationale::before {
  content: "→";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--accent);
  font-weight: 600;
}
@media (max-width: 760px) {
  .honesty-item { grid-template-columns: 1fr; gap: 8px; padding-left: 24px; }
  .honesty-item::before { left: -6px; top: 14px; }
  .honesty-rationale { padding-left: 18px; }
}

/* ---------- home: next steps (3 lanes, distinct treatments) ---------- */
.nextsteps {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: 18px;
  align-items: stretch;
}
.nextstep {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 28px;
  border-radius: 20px;
  position: relative;
}
.nextstep-num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--text-3);
  font-weight: 500;
}
.nextstep h3 {
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.02em;
  text-wrap: balance;
}
.nextstep p {
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--text-2);
  flex: 1;
  text-wrap: pretty;
}
.nextstep--primary {
  background: linear-gradient(160deg, var(--text), #1a2238);
  color: #fff;
}
.nextstep--primary .nextstep-num { color: rgba(255, 255, 255, 0.5); }
.nextstep--primary h3 { color: #fff; }
.nextstep--primary p { color: rgba(255, 255, 255, 0.78); }
.nextstep--explore {
  background: #fff;
  border: 1px solid var(--border);
}
.nextstep--partner {
  background: var(--accent-soft);
  border: 1px solid #dbe4ff;
}
.nextstep-links {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.nextstep-links a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 9px 0;
  border-bottom: 1px solid var(--border-soft);
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  transition: color 120ms ease;
}
.nextstep-links a:last-child { border-bottom: none; }
.nextstep-links a:hover { color: var(--accent); }
.nextstep-links a svg { color: var(--text-3); }
.nextstep-links a:hover svg { color: var(--accent); }
.nextstep-cta {
  align-self: flex-start;
  margin-top: auto;
}
.nextstep--primary .nextstep-cta {
  background: #fff;
  color: var(--text);
}
.nextstep--primary .nextstep-cta:hover { background: #f1f5f9; }
@media (max-width: 1000px) {
  .nextsteps { grid-template-columns: 1fr; }
}

/* ---------- explore directory (resources home block) ---------- */
.explore {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 48px;
  max-width: 1040px;
}
.explore-col h4 {
  font-size: 12px;
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-3);
  font-weight: 500;
  margin: 0 0 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border-soft);
}
.explore-col ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.explore-col li a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  font-weight: 500;
  color: var(--text);
  padding: 8px 0;
  letter-spacing: -0.005em;
  transition: color 120ms ease;
}
.explore-col li a span {
  border-bottom: 1px solid transparent;
  padding-bottom: 1px;
  transition: border-color 120ms ease;
}
.explore-col li a:hover { color: var(--accent); }
.explore-col li a:hover span { border-bottom-color: var(--accent); }
.explore-col li a .arrow {
  opacity: 0;
  transform: translateX(-4px);
  transition: opacity 160ms ease, transform 160ms ease;
  color: var(--accent);
  flex-shrink: 0;
}
.explore-col li a:hover .arrow {
  opacity: 1;
  transform: translateX(0);
}
@media (max-width: 760px) {
  .explore { grid-template-columns: 1fr; gap: 32px; }
}

/* ---------- home: client dashboard peek (below hero) ---------- */
.home-preview { padding-top: 6px; }
.home-preview .container { max-width: 1120px; }
.home-preview-frame {
  position: relative;
  border-radius: 16px 16px 0 0;
  border: 1px solid var(--border);
  background: #fff;
  box-shadow: 0 24px 60px -30px rgba(15, 23, 42, 0.24), 0 6px 18px -12px rgba(15, 23, 42, 0.10);
  overflow: hidden;
  /* "peek": fade the bottom so only the top of the product is clearly visible */
  -webkit-mask-image: linear-gradient(to bottom, #000 60%, transparent 100%);
  mask-image: linear-gradient(to bottom, #000 60%, transparent 100%);
}
.hpf-chrome {
  display: flex; align-items: center; gap: 8px;
  padding: 11px 14px;
  border-bottom: 1px solid var(--border-soft);
  background: var(--surface);
}
.hpf-dot { width: 10px; height: 10px; border-radius: 50%; }
.hpf-dot:nth-child(1) { background: #ef6a5f; }
.hpf-dot:nth-child(2) { background: #f5bd4f; }
.hpf-dot:nth-child(3) { background: #5ec45a; }
.hpf-url {
  margin-left: 10px; display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 11.5px; color: var(--text-3);
  background: #fff; border: 1px solid var(--border-soft); border-radius: 999px; padding: 4px 12px;
}
.hpf-app { display: grid; grid-template-columns: 186px 1fr; min-height: 560px; }
.hpf-side { border-right: 1px solid var(--border-soft); background: var(--surface-2); padding: 16px 12px; }
.hpf-brand { padding: 4px 8px 14px; }
.hpf-brand img { display: block; height: 22px; width: auto; }
.hpf-nav { display: flex; flex-direction: column; gap: 2px; }
.hpf-nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; border-radius: 8px;
  font-size: 13px; color: var(--text-2);
}
.hpf-nav-item svg { width: 14px; height: 14px; color: var(--text-3); flex: none; }
.hpf-nav-item.is-active { background: var(--text); color: #fff; }
.hpf-nav-item.is-active svg { color: #fff; }
.hpf-main { padding: 18px 22px; min-width: 0; }
.hpf-top { display: flex; align-items: center; justify-content: space-between; }
.hpf-org { display: inline-flex; align-items: center; gap: 7px; font-weight: 600; font-size: 14px; }
.hpf-lang { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; color: var(--text-3); border: 1px solid var(--border); border-radius: 999px; padding: 4px 10px; }
.hpf-headline { margin-top: 16px; }
.hpf-headline strong { display: block; font-size: 22px; letter-spacing: -0.02em; }
.hpf-headline span { font-size: 13px; color: var(--text-3); }
.hpf-banners { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 18px; }
.hpf-banner { position: relative; border-radius: 14px; padding: 18px; color: #fff; overflow: hidden; }
.hpf-banner--blue { background: linear-gradient(120deg, #2563eb, #3b82f6); }
.hpf-banner--violet { background: linear-gradient(120deg, #6d28d9, #7c3aed); }
.hpf-pill { display: inline-block; font-size: 10.5px; font-weight: 600; background: rgba(255, 255, 255, 0.22); border-radius: 999px; padding: 3px 9px; }
.hpf-banner strong { display: block; margin-top: 10px; font-size: 16px; letter-spacing: -0.01em; }
.hpf-banner p { margin-top: 6px; font-size: 12px; color: rgba(255, 255, 255, 0.85); }
.hpf-btn { display: inline-block; margin-top: 12px; font-size: 12px; font-weight: 600; background: #fff; color: var(--text); border-radius: 8px; padding: 7px 12px; }
.hpf-btn--ghost { background: rgba(255, 255, 255, 0.16); color: #fff; }
.hpf-kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 16px; }
.hpf-kpi { border: 1px solid var(--border); border-radius: 14px; padding: 16px; background: #fff; }
.hpf-kpi-head { display: flex; align-items: center; justify-content: space-between; font-size: 12px; color: var(--text-2); }
.hpf-kpi-head em { font-style: normal; font-size: 11px; color: var(--accent); background: var(--accent-soft); border-radius: 999px; padding: 2px 7px; }
.hpf-kpi-head em.hpf-kpi-tag { color: #0f9d58; background: #e8f7ee; }
.hpf-kpi > strong { display: block; margin-top: 6px; font-size: 28px; letter-spacing: -0.03em; }
.hpf-kpi-bars { display: flex; align-items: flex-end; gap: 4px; height: 40px; margin-top: 10px; }
.hpf-kpi-bars span { flex: 1; height: var(--h); border-radius: 3px 3px 0 0; background: linear-gradient(180deg, var(--accent), #c7d6fb); }
.hpf-kpi-spark { height: 40px; margin-top: 10px; }
.hpf-kpi-spark svg { width: 100%; height: 100%; }
.hpf-kpi-meter { height: 5px; border-radius: 3px; background: var(--surface); margin-top: 16px; overflow: hidden; }
.hpf-kpi-meter span { display: block; width: 22%; height: 100%; border-radius: 3px; background: var(--accent); }
.hpf-kpi small { display: block; margin-top: 10px; font-size: 11px; color: var(--text-3); }
.hpf-actions { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-top: 16px; }
.hpf-action { border: 1px solid var(--border); border-radius: 14px; padding: 16px; background: #fff; }
.hpf-action-ic { display: inline-flex; width: 34px; height: 34px; border-radius: 9px; align-items: center; justify-content: center; background: var(--accent-soft); color: var(--accent); }
.hpf-action strong { display: block; margin-top: 12px; font-size: 13px; }
.home-preview-copy { max-width: 720px; margin: 26px auto 0; text-align: center; }
.home-preview-copy--top { margin: 0 auto 24px; }
.home-preview-copy .eyebrow { display: inline-flex; justify-content: center; }
.home-preview-copy p { margin-top: 12px; font-size: 15px; color: var(--text-2); }

/* My Chatbots screen */
.cbs-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-top: 16px; }
.cbs-headline strong { display: block; font-size: 22px; letter-spacing: -0.02em; }
.cbs-headline span { font-size: 13px; color: var(--text-3); }
.cbs-head-actions { display: flex; align-items: center; gap: 8px; flex: none; }
.cbs-quota { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; color: var(--text-3); border: 1px solid var(--border); border-radius: 8px; padding: 6px 10px; }
.cbs-ghost { background: #fff; border: 1px solid var(--border); color: var(--text); display: inline-flex; align-items: center; gap: 5px; margin-top: 0; }
.cbs-dark { background: var(--text); color: #fff; margin-top: 0; }
.cbs-folders-head { display: flex; align-items: center; justify-content: space-between; margin-top: 18px; font-family: var(--font-mono); font-size: 10.5px; text-transform: uppercase; letter-spacing: .06em; color: var(--text-3); }
.cbs-link { color: var(--accent); }
.cbs-folders { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 8px; }
.cbs-folder { display: flex; align-items: center; gap: 10px; padding: 12px; border: 1px solid var(--border); border-radius: 12px; background: #fff; }
.cbs-folder.is-active { border-color: var(--text); }
.cbs-folder-ic { display: inline-flex; width: 28px; height: 28px; border-radius: 8px; align-items: center; justify-content: center; background: var(--accent-soft); color: var(--accent); flex: none; }
.cbs-tone-b .cbs-folder-ic { background: #f3e8ff; color: #7c3aed; }
.cbs-tone-c .cbs-folder-ic { background: #ccfbf1; color: #0d9488; }
.cbs-tone-d .cbs-folder-ic { background: #ffedd5; color: #ea580c; }
.cbs-folder strong { display: block; font-size: 13px; }
.cbs-folder span { font-size: 11px; color: var(--text-3); }
.cbs-filters { display: flex; align-items: center; gap: 8px; margin-top: 16px; }
.cbs-chip { font-size: 12px; color: var(--text-2); border: 1px solid var(--border); border-radius: 999px; padding: 4px 12px; }
.cbs-chip.is-active { background: #fef3c7; border-color: #fcd34d; color: #92400e; }
.cbs-chip--a::before, .cbs-chip--b::before, .cbs-chip--c::before { content: "\\2022\\00a0"; }
.cbs-chip--a { color: #ca8a04; } .cbs-chip--b { color: #7c3aed; } .cbs-chip--c { color: #0d9488; }
.cbs-sort { margin-left: auto; display: inline-flex; align-items: center; gap: 5px; font-size: 12px; color: var(--text-3); border: 1px solid var(--border); border-radius: 8px; padding: 5px 10px; }
.cbs-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 14px; }
.cbs-card { border: 1px solid var(--border); border-radius: 14px; padding: 16px; background: #fff; }
.cbs-card--new { border-style: dashed; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; gap: 4px; color: var(--text-3); }
.cbs-new-plus { width: 38px; height: 38px; border-radius: 50%; background: var(--surface); display: flex; align-items: center; justify-content: center; font-size: 22px; color: var(--text-2); margin-bottom: 6px; }
.cbs-card--new strong { font-size: 13px; color: var(--text); }
.cbs-card--new span { font-size: 11px; }
.cbs-card-top { display: flex; align-items: center; gap: 10px; }
.cbs-avatar { width: 30px; height: 30px; border-radius: 50%; background: linear-gradient(135deg, #f59e0b, #ef4444); flex: none; }
.cbs-card-id { flex: 1; min-width: 0; }
.cbs-card-id strong { display: block; font-size: 13.5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cbs-card-id span { font-size: 11px; color: var(--text-3); }
.cbs-kebab { color: var(--text-3); }
.cbs-tags { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 10px; }
.cbs-tags span { display: inline-flex; align-items: center; gap: 3px; font-size: 10px; color: var(--text-2); background: var(--surface); border-radius: 5px; padding: 2px 6px; }
.cbs-tag--pub { color: #0d9488 !important; background: #ccfbf1 !important; }
.cbs-msg-head { display: flex; align-items: center; justify-content: space-between; margin-top: 12px; font-family: var(--font-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: .05em; color: var(--text-3); }
.cbs-trend { color: var(--accent); }
.cbs-msg { display: flex; align-items: flex-end; gap: 10px; margin-top: 6px; }
.cbs-msg > strong { font-size: 26px; letter-spacing: -0.03em; }
.cbs-bars { flex: 1; display: flex; align-items: flex-end; gap: 3px; height: 34px; }
.cbs-bars span { flex: 1; height: var(--h); border-radius: 2px; background: var(--border-strong); }
.cbs-bars span.is-hot { background: #f59e0b; }
.cbs-card-foot { display: flex; align-items: center; gap: 8px; margin-top: 12px; }
.cbs-status { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; color: var(--text-2); background: var(--surface); border-radius: 999px; padding: 3px 9px; }
.cbs-status .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--text-3); }
.cbs-status--on { color: #047857; background: #d1fae5; }
.cbs-status--on .dot { background: #10b981; }

@media (max-width: 860px) {
  .cbs-head { flex-direction: column; }
  .cbs-folders { grid-template-columns: 1fr 1fr; }
  .cbs-grid { grid-template-columns: 1fr; }
  .cbs-filters { flex-wrap: wrap; }
}

/* Usage & Analytics screen */
.aus-range { display: flex; gap: 14px; margin-top: 16px; }
.aus-range label { display: flex; flex-direction: column; gap: 5px; font-size: 11px; color: var(--text-3); }
.aus-date { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; color: var(--text); background: #fff; border: 1px solid var(--border); border-radius: 8px; padding: 7px 11px; }
.aus-kpis { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; margin-top: 14px; }
.aus-kpi { border: 1px solid var(--border); border-radius: 12px; padding: 14px; background: #fff; }
.aus-kpi-head { display: flex; align-items: center; justify-content: space-between; font-size: 12px; color: var(--text-2); }
.aus-kpi-head svg { color: var(--text-3); }
.aus-kpi > strong { display: block; margin-top: 6px; font-size: 18px; letter-spacing: -0.02em; }
.aus-kpi-bar { height: 4px; border-radius: 2px; background: var(--surface); margin-top: 12px; overflow: hidden; position: relative; }
.aus-kpi-bar span { position: absolute; inset: 0; width: var(--w); border-radius: 2px; background: linear-gradient(90deg, var(--accent), var(--cyan)); }
.aus-kpi:last-child .aus-kpi-bar span { background: var(--text); }
.aus-kpi small { display: block; margin-top: 8px; font-size: 10px; color: var(--text-3); }
.aus-chart-card { border: 1px solid var(--border); border-radius: 14px; padding: 16px 16px 6px; background: #fff; margin-top: 16px; }
.aus-chart-head { display: flex; align-items: center; gap: 7px; font-weight: 600; font-size: 14px; }
.aus-chart-head svg { color: var(--accent); }
.aus-chart { width: 100%; height: 190px; margin-top: 8px; display: block; }
.aus-toptable { border: 1px solid var(--border); border-radius: 14px; padding: 16px; background: #fff; margin-top: 16px; }
.aus-tt-head { display: flex; align-items: center; gap: 7px; font-weight: 600; font-size: 14px; }
.aus-tt-head svg { color: var(--accent); }
.aus-tt-cols { display: flex; align-items: center; justify-content: space-between; margin-top: 14px; padding-bottom: 10px; border-bottom: 1px solid var(--border-soft); font-size: 12px; color: var(--text-3); }

@media (max-width: 860px) {
  .aus-kpis { grid-template-columns: 1fr 1fr; }
}

/* Workspaces screen */
.wks-overview { border: 1px solid var(--border); border-radius: 14px; padding: 16px; background: var(--surface-2); margin-top: 16px; }
.wks-overview-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.wks-overview-head strong { font-size: 14px; }
.wks-overview-head > div span { display: block; font-size: 12px; color: var(--text-3); margin-top: 2px; }
.wks-live { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; color: var(--text-2); background: #fff; border: 1px solid var(--border); border-radius: 999px; padding: 5px 11px; flex: none; }
.wks-live .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--green); }
.wks-overview-stats { display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px; margin-top: 14px; }
.wks-ov { background: #fff; border: 1px solid var(--border-soft); border-radius: 10px; padding: 12px; }
.wks-ov-head { display: flex; align-items: center; justify-content: space-between; font-family: var(--font-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: .05em; color: var(--text-3); }
.wks-ov-head svg { color: var(--text-3); }
.wks-ov > strong { display: block; margin-top: 8px; font-size: 24px; letter-spacing: -0.03em; }
.wks-filters { display: flex; align-items: center; gap: 8px; margin-top: 16px; }
.wks-search { flex: 1; max-width: 280px; display: inline-flex; align-items: center; gap: 7px; font-size: 12.5px; color: var(--text-3); background: #fff; border: 1px solid var(--border); border-radius: 8px; padding: 8px 12px; }
.wks-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 14px; }
.wks-card { border: 1px solid var(--border); border-radius: 14px; padding: 16px; background: #fff; }
.wks-card-top { display: flex; align-items: center; justify-content: space-between; }
.wks-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 10.5px; font-weight: 600; border-radius: 999px; padding: 3px 9px; }
.wks-badge--members { color: #2563eb; background: #e7eefe; }
.wks-badge--team { color: #0d9488; background: #ccfbf1; }
.wks-name { display: block; margin-top: 12px; font-size: 16px; letter-spacing: -0.01em; }
.wks-assistant { display: flex; align-items: center; gap: 5px; margin-top: 6px; font-size: 12px; color: var(--text-2); }
.wks-team { margin-top: 8px; font-size: 11.5px; color: var(--text-2); background: var(--surface); border-radius: 7px; padding: 6px 9px; }
.wks-team span { color: var(--text-3); }
.wks-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 12px; }
.wks-stats > div { background: var(--surface); border-radius: 8px; padding: 9px 11px; }
.wks-stats strong { display: block; font-size: 15px; }
.wks-stats span { font-size: 10.5px; color: var(--text-3); }
.wks-foot { display: flex; flex-direction: column; gap: 5px; margin-top: 12px; font-size: 10.5px; color: var(--text-3); }
.wks-foot span { display: inline-flex; align-items: center; gap: 5px; }

@media (max-width: 860px) {
  .wks-overview-stats { grid-template-columns: 1fr 1fr; }
  .wks-grid { grid-template-columns: 1fr; }
  .wks-filters { flex-wrap: wrap; }
}

/* Data & Privacy (export) screen */
.dpv-tabs { display: flex; align-items: center; gap: 4px; border-bottom: 1px solid var(--border-soft); padding-bottom: 12px; margin-top: 14px; }
.dpv-tab { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; color: var(--text-2); border-radius: 8px; padding: 7px 12px; }
.dpv-tab svg { color: var(--text-3); }
.dpv-tab.is-active { border: 1px solid var(--border); background: #fff; color: var(--text); font-weight: 600; }
.dpv-sec { border: 1px solid var(--border); border-radius: 14px; padding: 20px; margin-top: 16px; background: #fff; }
.dpv-h { display: flex; align-items: center; gap: 9px; font-size: 20px; font-weight: 600; letter-spacing: -0.02em; }
.dpv-h svg { color: var(--accent); }
.dpv-desc { margin-top: 12px; font-size: 13px; line-height: 1.55; color: var(--text-2); max-width: 92%; }
.dpv-howto { display: inline-flex; align-items: center; gap: 6px; margin-top: 14px; font-size: 12.5px; color: var(--text-2); border: 1px solid var(--border); border-radius: 8px; padding: 7px 12px; }
.dpv-actions { display: flex; gap: 10px; margin-top: 16px; }
.dpv-actions .hpf-btn { margin-top: 0; display: inline-flex; align-items: center; gap: 7px; }
.dpv-actions .cbs-ghost { border: 1px solid var(--border); background: #fff; color: var(--text); }
.dpv-limit { margin-top: 14px; font-size: 11.5px; color: var(--text-3); }
.dpv-card { border: 1px solid var(--border); border-radius: 14px; padding: 20px; margin-top: 16px; background: #fff; }
.dpv-card > strong { font-size: 16px; letter-spacing: -0.01em; }
.dpv-card-strong { display: inline-flex; align-items: center; gap: 8px; }
.dpv-card-strong svg { color: var(--accent); }
.dpv-card > p { margin-top: 8px; font-size: 12.5px; line-height: 1.5; color: var(--text-3); }
.dpv-empty { margin-top: 16px; border: 1px dashed var(--border); border-radius: 12px; padding: 26px; text-align: center; font-size: 12.5px; color: var(--text-3); }
.dpv-bundles { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 16px; }
.dpv-bundle { border: 1px solid var(--border-soft); border-radius: 10px; padding: 14px; background: var(--surface-2); }
.dpv-bundle strong { font-size: 13px; }
.dpv-bundle span { display: block; margin-top: 6px; font-size: 11.5px; line-height: 1.45; color: var(--text-3); }

@media (max-width: 860px) {
  .dpv-tabs { flex-wrap: wrap; }
  .dpv-bundles { grid-template-columns: 1fr; }
  .dpv-desc { max-width: 100%; }
}

/* Media Library screen */
.mlb-filters { display: grid; grid-template-columns: repeat(3, 1fr) 130px 130px; gap: 12px; margin-top: 16px; border: 1px solid var(--border); border-radius: 12px; padding: 14px; background: var(--surface-2); }
.mlb-filter { display: flex; flex-direction: column; gap: 5px; font-size: 11px; color: var(--text-3); }
.mlb-select { display: inline-flex; align-items: center; justify-content: space-between; gap: 8px; font-size: 12.5px; color: var(--text); background: #fff; border: 1px solid var(--border); border-radius: 8px; padding: 8px 11px; }
.mlb-filter .aus-date { justify-content: flex-start; }
.mlb-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-top: 16px; }
.mlb-card { border: 1px solid var(--border); border-radius: 14px; overflow: hidden; background: #fff; }
.mlb-img { position: relative; aspect-ratio: 4 / 3; display: flex; align-items: center; justify-content: center; }
.mlb-img--a { background: linear-gradient(135deg, #ede9fe, #c4b5fd); }
.mlb-img--b { background: linear-gradient(135deg, #dbeafe, #93c5fd); }
.mlb-img--c { background: linear-gradient(135deg, #ccfbf1, #5eead4); }
.mlb-img--d { background: linear-gradient(135deg, #1e293b, #334155); }
.mlb-img-ic { color: rgba(255, 255, 255, 0.85); }
.mlb-img--a .mlb-img-ic, .mlb-img--b .mlb-img-ic, .mlb-img--c .mlb-img-ic { color: rgba(255, 255, 255, 0.9); }
.mlb-badge { position: absolute; top: 8px; left: 8px; display: inline-flex; align-items: center; gap: 4px; font-size: 9.5px; font-weight: 600; color: #047857; background: #d1fae5; border-radius: 6px; padding: 3px 7px; }
.mlb-check { position: absolute; top: 8px; right: 8px; width: 16px; height: 16px; border-radius: 5px; background: #fff; border: 1px solid var(--border); }
.mlb-acts { position: absolute; bottom: 8px; right: 8px; display: flex; gap: 6px; }
.mlb-act { display: inline-flex; width: 26px; height: 26px; border-radius: 7px; align-items: center; justify-content: center; background: rgba(255, 255, 255, 0.92); color: var(--text-2); }
.mlb-act--del { background: #ef4444; color: #fff; }
.mlb-caption { padding: 12px 12px 0; font-size: 12px; line-height: 1.4; color: var(--text-2); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.mlb-foot { display: flex; align-items: center; justify-content: space-between; padding: 10px 12px 12px; font-size: 10px; }
.mlb-foot span:first-child { font-family: var(--font-mono); text-transform: uppercase; letter-spacing: .05em; color: var(--text-3); }
.mlb-foot span:last-child { color: var(--text-3); }

@media (max-width: 860px) {
  .mlb-filters { grid-template-columns: 1fr 1fr; }
  .mlb-grid { grid-template-columns: 1fr 1fr; }
}

/* Content Studio: editor + in-editor image generator */
.cse-app { grid-template-columns: 46px 1fr; }
.cse-rail { display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 14px 0; border-right: 1px solid var(--border-soft); background: var(--surface-2); }
.cse-rail-item { display: inline-flex; width: 30px; height: 30px; align-items: center; justify-content: center; border-radius: 8px; color: var(--text-3); }
.cse-rail-item.is-active { background: var(--text); color: #fff; }
.cse-editor { display: grid; grid-template-columns: 232px 1fr 96px; border: 1px solid var(--border); border-radius: 12px; overflow: hidden; margin-top: 14px; background: #fff; min-height: 520px; }
.cse-assistant { border-right: 1px solid var(--border-soft); display: flex; flex-direction: column; }
.cse-assistant-head { display: flex; align-items: center; gap: 7px; padding: 12px 14px; border-bottom: 1px solid var(--border-soft); font-size: 12.5px; font-weight: 600; }
.cse-assistant-body { flex: 1; padding: 14px; display: flex; flex-direction: column; gap: 10px; font-size: 12px; line-height: 1.5; color: var(--text-2); }
.cse-user { align-self: flex-end; max-width: 85%; background: var(--text); color: #fff; border-radius: 12px 12px 4px 12px; padding: 8px 11px; }
.cse-ctx { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin: 0 14px; padding: 8px 0; border-top: 1px solid var(--border-soft); font-size: 10.5px; color: var(--text-3); }
.cse-ctx span:first-child { display: inline-flex; align-items: center; gap: 5px; }
.cse-ask { display: flex; align-items: center; justify-content: space-between; margin: 10px 14px 14px; border: 1px solid var(--border); border-radius: 10px; padding: 10px 12px; font-size: 12px; color: var(--text-3); }
.cse-send { display: inline-flex; width: 26px; height: 26px; align-items: center; justify-content: center; border-radius: 7px; background: var(--surface); color: var(--text-2); }
.cse-doc { display: flex; flex-direction: column; min-width: 0; }
.cse-toolbar { display: flex; align-items: center; gap: 8px; padding: 9px 14px; border-bottom: 1px solid var(--border-soft); color: var(--text-3); font-size: 12px; }
.cse-toolbar svg { color: var(--text-3); }
.cse-tb-sel { display: inline-flex; align-items: center; gap: 5px; border: 1px solid var(--border); border-radius: 7px; padding: 4px 9px; color: var(--text-2); }
.cse-tb-b { font-weight: 600; color: var(--text-2); width: 18px; text-align: center; }
.cse-tb-div { width: 1px; height: 16px; background: var(--border); }
.cse-page { flex: 1; padding: 22px 28px; }
.cse-page h3 { font-size: 24px; letter-spacing: -0.02em; line-height: 1.15; }
.cse-sub { margin-top: 10px; font-style: italic; font-size: 13.5px; color: var(--text-2); }
.cse-figure { margin-top: 16px; border-radius: 12px; padding: 22px; background: linear-gradient(135deg, #0f2547, #15325f); color: #fff; }
.cse-figure strong { font-size: 16px; }
.cse-figure span { display: block; margin-top: 6px; font-size: 11.5px; color: rgba(255, 255, 255, 0.7); }
.cse-page h4 { margin-top: 18px; font-size: 17px; }
.cse-doc-foot { display: flex; gap: 14px; padding: 10px 28px; border-top: 1px solid var(--border-soft); font-size: 10.5px; color: var(--text-3); }
.cse-doc-foot span { display: inline-flex; align-items: center; gap: 4px; }
.cse-media { border-left: 1px solid var(--border-soft); padding: 12px 10px; display: flex; flex-direction: column; gap: 10px; background: var(--surface-2); }
.cse-thumb { aspect-ratio: 4 / 3; border-radius: 8px; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, #1e293b, #334155); }
.cse-thumb .mlb-img-ic { color: rgba(255, 255, 255, 0.8); }

.cse-backdrop { position: absolute; inset: 0; background: rgba(15, 23, 42, 0.34); }
.cse-modal { position: absolute; top: 54px; left: 50%; transform: translateX(-50%); width: 90%; max-width: 1000px; background: #fff; border: 1px solid var(--border); border-radius: 16px; box-shadow: var(--shadow-lg); overflow: hidden; }
.cse-modal-head { display: flex; align-items: flex-start; gap: 12px; padding: 18px 20px; border-bottom: 1px solid var(--border-soft); }
.cse-modal-ic { display: inline-flex; width: 30px; height: 30px; border-radius: 8px; align-items: center; justify-content: center; background: var(--surface); color: var(--accent); flex: none; }
.cse-modal-head strong { font-size: 16px; }
.cse-modal-head > div span { display: block; margin-top: 2px; font-size: 12px; color: var(--text-3); }
.cse-modal-x { margin-left: auto; color: var(--text-3); }
.cse-modes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; padding: 14px 20px; }
.cse-mode { display: flex; align-items: center; gap: 9px; border: 1px solid var(--border); border-radius: 10px; padding: 11px 13px; }
.cse-mode.is-active { border-color: var(--text); }
.cse-mode-ic { display: inline-flex; width: 26px; height: 26px; border-radius: 7px; align-items: center; justify-content: center; background: var(--surface); color: var(--text-2); flex: none; }
.cse-mode strong { font-size: 12.5px; }
.cse-mode span { font-size: 11px; color: var(--text-3); }
.cse-mode svg { margin-left: auto; color: var(--accent); }
.cse-modal-cols { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; padding: 0 20px 20px; border-top: 1px solid var(--border-soft); padding-top: 16px; }
.cse-col-label { display: block; font-size: 11.5px; color: var(--text-3); margin-bottom: 10px; }
.cse-types { display: flex; flex-direction: column; gap: 8px; }
.cse-type { border: 1px solid var(--border); border-radius: 10px; padding: 10px 12px; }
.cse-type.is-active { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent); }
.cse-type-ic { display: inline-flex; width: 24px; height: 24px; border-radius: 7px; align-items: center; justify-content: center; background: var(--accent-soft); color: var(--accent); }
.cse-type strong { display: block; margin-top: 8px; font-size: 12.5px; }
.cse-type span { font-size: 11px; color: var(--text-3); }
.cse-set { border: 1px solid var(--border); border-radius: 10px; padding: 11px 13px; margin-bottom: 10px; }
.cse-set-row { display: flex; align-items: center; justify-content: space-between; }
.cse-set-row strong { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; }
.cse-set-row strong svg { color: var(--accent); }
.cse-set-change { font-size: 11px; color: var(--text-3); border: 1px solid var(--border); border-radius: 6px; padding: 2px 8px; }
.cse-set > span { display: block; margin-top: 6px; font-size: 11.5px; color: var(--text-3); }
.cse-guides { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.cse-guide { border: 1px solid var(--border); border-radius: 9px; padding: 10px; }
.cse-guide.is-active { border-color: var(--text); }
.cse-guide strong { display: block; font-size: 11.5px; }
.cse-guide span { font-size: 10px; color: var(--text-3); }
.cse-figure--prev { margin-top: 0; padding: 16px; }
.cse-figure--prev strong { font-size: 13px; }
.cse-modal-cta { display: flex; flex-direction: column; gap: 8px; margin-top: 12px; }
.cse-modal-cta .hpf-btn { margin-top: 0; text-align: center; justify-content: center; }
.cse-modal-cta .cbs-ghost { border: 1px solid var(--border); background: #fff; color: var(--text); }

@media (max-width: 860px) {
  .cse-editor { grid-template-columns: 1fr; }
  .cse-assistant, .cse-media { display: none; }
  .cse-modal-cols, .cse-modes { grid-template-columns: 1fr; }
  .cse-modal { width: 96%; }
}

/* Content Studio v2 — fuller editor, faithful comparison infographic,
   and almost the whole screen revealed (minimal bottom fade). */
.cse-frame { -webkit-mask-image: linear-gradient(to bottom, #000 96%, transparent); mask-image: linear-gradient(to bottom, #000 96%, transparent); }
.cse-editor { grid-template-columns: 228px 1fr 130px; min-height: 0; }
.cse-assistant-body { overflow: hidden; }
.cse-ctx-bar { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin: 0 14px; padding: 10px 0; border-top: 1px solid var(--border-soft); font-size: 10.5px; color: var(--text-3); }
.cse-ctx-bar > span:first-child { display: inline-flex; align-items: center; gap: 5px; }
.cse-ctx-chip { display: inline-flex; align-items: center; gap: 5px; color: var(--text-2); background: var(--surface); border-radius: 6px; padding: 3px 8px; }
.cse-body { margin-top: 12px; font-size: 13px; line-height: 1.6; color: var(--text-2); }
.cse-doc-foot { flex-wrap: wrap; }
.cse-saved { color: #10b981; }
/* media strip */
.cse-media-head { display: flex; align-items: center; justify-content: space-between; padding-bottom: 10px; font-size: 11px; color: var(--text-3); }
.cse-mcard { margin-bottom: 12px; }
.cse-mthumb { aspect-ratio: 4 / 3; border-radius: 8px; background: linear-gradient(135deg, #0f2547, #1e3a6b); display: flex; align-items: flex-end; gap: 3px; padding: 8px; }
.cse-mthumb span { flex: 1; border-radius: 2px; background: rgba(255, 255, 255, 0.18); }
.cse-mthumb span:nth-child(1) { height: 42%; }
.cse-mthumb span:nth-child(2) { height: 72%; background: rgba(96, 165, 250, 0.55); }
.cse-mthumb span:nth-child(3) { height: 56%; background: rgba(94, 234, 212, 0.5); }
.cse-macts { display: flex; align-items: center; justify-content: center; gap: 5px; margin-top: 7px; }
.cse-mact { display: inline-flex; width: 22px; height: 22px; align-items: center; justify-content: center; border-radius: 6px; background: var(--surface); color: var(--text-3); }
.cse-mact--ok { background: #d1fae5; color: #047857; }
.cse-mact--del { background: #fee2e2; color: #ef4444; }
/* comparison infographic */
.csi { margin-top: 18px; border-radius: 14px; padding: 18px; background: linear-gradient(160deg, #0b2148, #0a1628); color: #fff; }
.csi-head { text-align: center; }
.csi-head strong { font-size: 17px; letter-spacing: -0.01em; }
.csi-head span { display: block; margin-top: 4px; font-size: 11px; color: rgba(255, 255, 255, 0.6); }
.csi-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 16px; }
.csi-col { border-radius: 12px; padding: 14px; }
.csi-col--a { background: rgba(37, 99, 235, 0.14); border: 1px solid rgba(96, 165, 250, 0.3); }
.csi-col--b { background: rgba(255, 255, 255, 0.04); border: 1px solid rgba(255, 255, 255, 0.09); }
.csi-ch { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.csi-brand { display: inline-flex; align-items: center; gap: 6px; font-weight: 700; font-size: 13px; }
.csi-brand--a { color: #93c5fd; }
.csi-ch em { font-style: normal; font-size: 7.5px; letter-spacing: .05em; color: rgba(255, 255, 255, 0.5); text-align: right; max-width: 90px; }
.csi-lead { margin-top: 8px; font-size: 11.5px; color: rgba(255, 255, 255, 0.8); }
.csi-diagram { display: grid; grid-template-columns: 1fr 1.15fr 1fr; gap: 7px; margin-top: 12px; }
.csi-dc { background: rgba(255, 255, 255, 0.05); border-radius: 8px; padding: 8px; }
.csi-dc--hl { background: rgba(37, 99, 235, 0.24); border: 1px solid rgba(96, 165, 250, 0.4); }
.csi-dc > span { display: block; font-size: 8px; font-weight: 700; text-transform: uppercase; letter-spacing: .03em; color: rgba(255, 255, 255, 0.55); margin-bottom: 6px; }
.csi-dc i { display: block; font-style: normal; font-size: 9px; color: rgba(255, 255, 255, 0.85); background: rgba(255, 255, 255, 0.07); border-radius: 5px; padding: 4px 6px; margin-bottom: 4px; }
.csi-dc--hl i { background: rgba(96, 165, 250, 0.2); }
.csi-gov { margin-top: 12px; background: rgba(255, 255, 255, 0.04); border-radius: 8px; padding: 10px; }
.csi-gov > strong { font-size: 9.5px; text-transform: uppercase; letter-spacing: .04em; color: #a5b4fc; }
.csi-gov-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; margin-top: 8px; }
.csi-gov-row i { display: inline-flex; align-items: center; gap: 4px; font-style: normal; font-size: 8px; color: rgba(255, 255, 255, 0.75); }
.csi-foot { margin-top: 12px; display: flex; align-items: center; gap: 6px; font-size: 10.5px; color: #6ee7b7; }
.csi-indiv { display: flex; align-items: center; gap: 10px; margin-top: 12px; }
.csi-iuser { display: inline-flex; align-items: center; gap: 6px; font-size: 10px; color: rgba(255, 255, 255, 0.8); }
.csi-arrow { color: rgba(255, 255, 255, 0.4); display: inline-flex; }
.csi-logos { display: flex; gap: 6px; }
.csi-logos i { display: inline-flex; width: 26px; height: 26px; align-items: center; justify-content: center; border-radius: 7px; font-style: normal; font-size: 9px; font-weight: 700; background: rgba(255, 255, 255, 0.09); }
.csi-bullets { list-style: none; padding: 0; margin: 12px 0 0; display: flex; flex-direction: column; gap: 7px; }
.csi-bullets li { position: relative; padding-left: 15px; font-size: 10.5px; color: rgba(255, 255, 255, 0.78); }
.csi-bullets li::before { content: ''; position: absolute; left: 4px; top: 6px; width: 4px; height: 4px; border-radius: 50%; background: rgba(255, 255, 255, 0.45); }
.csi-short { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 12px; margin-top: 14px; background: rgba(37, 99, 235, 0.16); border: 1px solid rgba(96, 165, 250, 0.28); border-radius: 10px; padding: 12px 14px; }
.csi-short-ic { display: inline-flex; align-items: center; gap: 6px; font-weight: 700; font-size: 11px; color: #93c5fd; }
.csi-short p { font-size: 10.5px; color: rgba(255, 255, 255, 0.82); }
.csi-right { display: inline-flex; align-items: center; gap: 5px; font-size: 10px; color: #6ee7b7; white-space: nowrap; }

@media (max-width: 980px) {
  .cse-editor { grid-template-columns: 1fr; }
  .cse-assistant, .cse-media { display: none; }
  .csi-cols { grid-template-columns: 1fr; }
  .csi-short { grid-template-columns: 1fr; }
}

/* App-screen mockups on phones: drop the desktop chrome (sidebar / icon rail)
   and reflow to a single readable column — no tiny-scaled or horizontally
   scrolled desktop UI. Keeps the meaningful content (document, cards, table). */
@media (max-width: 760px) {
  .hpf-app, .cse-app { grid-template-columns: 1fr; }
  .hpf-side, .cse-rail { display: none; }
  .hpf-main, .cse-main { padding: 14px 14px 18px; }
  .home-preview-frame { -webkit-mask-image: none; mask-image: none; }
  /* Content Studio editor → just the document */
  .cse-editor { grid-template-columns: 1fr; }
  .cse-assistant, .cse-media { display: none; }
  .cse-toolbar { flex-wrap: wrap; row-gap: 6px; }
  .cse-page { padding: 16px; }
  .csi { padding: 14px; }
  .csi-cols, .csi-short, .csi-diagram { grid-template-columns: 1fr; }
  .csi-gov-row { grid-template-columns: 1fr 1fr; }
  .csi-ch { flex-direction: column; align-items: flex-start; gap: 4px; }
  .csi-ch em { text-align: left; max-width: none; }
}

/* Chatbot Sources screen */
.src-layout { display: grid; grid-template-columns: 1fr 290px; gap: 16px; margin-top: 16px; align-items: start; }
.src-add { display: flex; align-items: center; justify-content: space-between; border: 1px solid var(--border); border-radius: 12px; padding: 16px 18px; background: #fff; margin-bottom: 12px; font-weight: 600; font-size: 14px; }
.src-add > span { display: inline-flex; align-items: center; gap: 9px; }
.src-add svg { color: var(--text-3); }
.src-links { border: 1px solid var(--border); border-radius: 12px; padding: 18px; background: #fff; margin-top: 4px; }
.src-links > strong { font-size: 18px; letter-spacing: -0.01em; }
.src-links > p { margin-top: 8px; font-size: 12px; color: var(--text-3); line-height: 1.5; }
.src-group { border: 1px solid var(--border); border-radius: 12px; padding: 14px; margin-top: 16px; }
.src-group-head { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; font-size: 13px; }
.src-group-url { display: inline-flex; align-items: center; gap: 6px; font-weight: 600; }
.src-crawl { font-size: 11px; font-weight: 600; color: #047857; background: #d1fae5; border-radius: 6px; padding: 3px 8px; }
.src-updating { font-size: 11.5px; color: var(--text-3); }
.src-group-acts { margin-left: auto; display: inline-flex; align-items: center; gap: 8px; font-size: 12px; color: var(--text-3); }
.src-progress { height: 6px; border-radius: 3px; background: var(--surface); margin-top: 12px; overflow: hidden; }
.src-progress span { display: block; height: 100%; width: var(--w); border-radius: 3px; background: linear-gradient(90deg, #10b981, #34d399); }
.src-filters { display: flex; gap: 10px; margin-top: 14px; }
.src-filter { flex: 1; font-size: 12px; color: var(--text-3); border: 1px solid var(--border); border-radius: 8px; padding: 8px 12px; }
.src-filter--sel { flex: none; min-width: 130px; display: inline-flex; align-items: center; justify-content: space-between; }
.src-table { margin-top: 8px; }
.src-tr { display: grid; grid-template-columns: 22px 1fr 90px 70px 80px; align-items: center; gap: 8px; padding: 11px 4px; border-bottom: 1px solid var(--border-soft); font-size: 12px; }
.src-tr--head { color: var(--text-3); font-size: 11px; }
.src-tr--head span { display: inline-flex; align-items: center; gap: 4px; }
.src-cb { width: 15px; height: 15px; border: 1px solid var(--border); border-radius: 4px; }
.src-url { display: inline-flex; align-items: center; gap: 5px; color: var(--text-2); min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.src-url svg { color: var(--text-3); flex: none; }
.src-status { font-size: 10.5px; font-weight: 600; border-radius: 999px; padding: 3px 9px; }
.src-status--ok { color: #fff; background: #10b981; }
.src-status--pend { color: var(--text-2); background: var(--surface); border: 1px solid var(--border); }
.src-date { color: var(--text-3); }
.src-acts { display: inline-flex; gap: 6px; color: var(--text-3); }
.src-acts svg:last-child { color: #ef4444; }
.src-side { border: 1px solid var(--border); border-radius: 12px; padding: 18px; background: #fff; }
.src-side > strong { font-size: 18px; }
.src-side > p { margin-top: 8px; font-size: 12px; color: var(--text-3); line-height: 1.5; }
.src-usage { margin-top: 16px; display: flex; flex-direction: column; gap: 12px; }
.src-use { display: flex; align-items: center; justify-content: space-between; font-size: 13px; }
.src-use > span:first-child { display: inline-flex; align-items: center; gap: 8px; color: var(--text-2); }
.src-use svg { color: var(--text-3); }
.src-total { display: flex; align-items: center; justify-content: space-between; margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--border-soft); font-size: 12.5px; }
.src-total span:last-child { color: var(--text-3); font-size: 11px; }
.src-stop { display: flex; align-items: center; justify-content: center; gap: 7px; margin-top: 16px; background: #ef4444; color: #fff; border-radius: 9px; padding: 10px; font-size: 13px; font-weight: 600; }
.src-indexing { display: flex; align-items: center; justify-content: center; gap: 7px; margin-top: 8px; border: 1px solid var(--border); border-radius: 9px; padding: 9px; font-size: 12.5px; color: var(--text-3); }

@media (max-width: 860px) {
  .src-layout { grid-template-columns: 1fr; }
  .src-tr { grid-template-columns: 18px 1fr 70px; }
  .src-tr span:nth-child(4), .src-tr span:nth-child(5) { display: none; }
}

/* Chatbot Actions builder screen */
.act-tabs { display: flex; align-items: center; gap: 2px; flex-wrap: wrap; border-bottom: 1px solid var(--border-soft); padding-bottom: 10px; margin-top: 14px; }
.act-tab { font-size: 12.5px; color: var(--text-2); border-radius: 7px; padding: 6px 11px; }
.act-tab.is-active { border: 1px solid var(--border); background: #fff; color: var(--text); font-weight: 600; }
.act-head { display: flex; align-items: center; gap: 12px; margin-top: 16px; }
.act-back { display: inline-flex; width: 28px; height: 28px; align-items: center; justify-content: center; border: 1px solid var(--border); border-radius: 8px; color: var(--text-3); }
.act-back svg { transform: rotate(180deg); }
.act-head > strong { font-size: 22px; letter-spacing: -0.02em; }
.act-draft { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; color: var(--text-2); background: var(--surface); border: 1px solid var(--border); border-radius: 999px; padding: 4px 10px; }
.act-draft .dot { width: 5px; height: 5px; border-radius: 50%; background: #f59e0b; }
.act-sub { margin-top: 8px; font-size: 13px; color: var(--text-3); }
.act-bar { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.act-toggle { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; color: var(--text-2); margin-right: 4px; }
.act-sw { width: 30px; height: 17px; border-radius: 999px; background: var(--border-strong); position: relative; }
.act-sw::after { content: ''; position: absolute; top: 2px; left: 2px; width: 13px; height: 13px; border-radius: 50%; background: #fff; }
.act-btn { margin-top: 0; display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; }
.act-bar .cbs-ghost { border: 1px solid var(--border); background: #fff; color: var(--text); }
.act-del { margin-top: 0; display: inline-flex; align-items: center; gap: 6px; background: #ef4444; color: #fff; font-size: 12.5px; }
.act-layout { display: grid; grid-template-columns: 1fr 300px; gap: 16px; margin-top: 18px; align-items: start; }
.act-wizard { border: 1px solid var(--border); border-radius: 14px; padding: 18px; background: #fff; }
.act-steps { display: flex; flex-wrap: wrap; gap: 8px 18px; }
.act-step { display: inline-flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--text-3); }
.act-step.is-active { color: var(--text); font-weight: 600; }
.act-step-n { display: inline-flex; width: 22px; height: 22px; align-items: center; justify-content: center; border-radius: 50%; background: var(--surface); border: 1px solid var(--border); font-size: 11px; }
.act-step.is-active .act-step-n { background: var(--text); color: #fff; border-color: var(--text); }
.act-wizard h4 { margin-top: 16px; font-size: 19px; letter-spacing: -0.01em; }
.act-wizard > p { margin-top: 6px; font-size: 12.5px; color: var(--text-3); }
.act-card { border: 1px solid var(--border); border-radius: 14px; padding: 18px; background: #fff; margin-top: 16px; }
.act-card > strong { font-size: 17px; }
.act-card > p { margin-top: 6px; font-size: 12.5px; color: var(--text-3); }
.act-field { display: flex; flex-direction: column; gap: 6px; margin-top: 16px; }
.act-field > span:first-child { font-size: 12.5px; font-weight: 500; }
.act-sublabel { font-size: 11px; color: var(--text-3); margin-top: -2px; }
.act-input { border: 1px solid var(--border); border-radius: 9px; padding: 11px 13px; font-size: 13px; color: var(--text); background: #fff; }
.act-input--ph { color: var(--text-3); }
.act-textarea { border: 1px solid var(--border); border-radius: 9px; padding: 11px 13px; font-size: 13px; color: var(--text-2); background: #fff; min-height: 64px; }
.act-side { display: flex; flex-direction: column; gap: 16px; }
.act-side-card { border: 1px solid var(--border); border-radius: 14px; padding: 18px; background: #fff; }
.act-side-card > strong { display: inline-flex; align-items: center; gap: 7px; font-size: 15px; }
.act-side-card > strong svg { color: var(--accent); }
.act-side-card > p { margin-top: 8px; font-size: 12px; color: var(--text-3); line-height: 1.5; }
.act-side-label { display: block; margin-top: 14px; margin-bottom: 6px; font-size: 12px; font-weight: 500; }
.act-side-card .act-input { display: block; }
.act-side-hint { display: block; margin-top: 10px; font-size: 11px; font-style: italic; color: var(--text-3); }
.act-checks { margin-top: 14px; display: flex; flex-direction: column; gap: 11px; }
.act-check { display: flex; align-items: center; gap: 9px; font-size: 12.5px; color: var(--text-2); }
.act-check::before { content: ''; width: 16px; height: 16px; border-radius: 50%; border: 1.5px solid var(--border-strong); flex: none; }
.act-check.is-done { color: var(--text); }
.act-check.is-done::before { display: none; }
.act-check.is-done svg { width: 16px; height: 16px; color: #10b981; flex: none; }

@media (max-width: 860px) {
  .act-layout { grid-template-columns: 1fr; }
  .act-bar { gap: 6px; }
}

/* Agency → client Budget & Access screen */
.acm-h { margin-top: 14px; }
.acm-h strong { font-size: 24px; letter-spacing: -0.02em; }
.acm-h span { display: block; margin-top: 2px; font-size: 13px; color: var(--text-3); }
.acm-body { display: grid; grid-template-columns: 188px 1fr; gap: 22px; margin-top: 18px; align-items: start; }
.acm-subnav { display: flex; flex-direction: column; gap: 2px; }
.acm-subnav-item { display: flex; align-items: center; gap: 9px; padding: 9px 11px; border-radius: 8px; font-size: 13px; color: var(--text-2); }
.acm-subnav-item svg { color: var(--text-3); flex: none; }
.acm-subnav-item.is-active { background: var(--text); color: #fff; }
.acm-subnav-item.is-active svg { color: #fff; }
.acm-main-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.acm-main-head strong { font-size: 19px; letter-spacing: -0.01em; }
.acm-main-head span { display: block; margin-top: 3px; font-size: 12.5px; color: var(--text-3); }
.acm-main-head em { font-style: normal; color: var(--text); font-weight: 600; }
.acm-edit { margin-top: 0; display: inline-flex; align-items: center; gap: 6px; border: 1px solid var(--border); background: #fff; color: var(--text); flex: none; }
.acm-caps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 16px; }
.acm-cap { border: 1px solid var(--border); border-radius: 12px; padding: 16px; background: #fff; }
.acm-cap-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; font-family: var(--font-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: .04em; color: var(--text-3); line-height: 1.3; }
.acm-cap-ic { display: inline-flex; width: 28px; height: 28px; align-items: center; justify-content: center; border-radius: 8px; background: var(--surface); color: var(--text-2); flex: none; }
.acm-cap > strong { display: block; margin-top: 12px; font-size: 24px; letter-spacing: -0.03em; }
.acm-cap > small { display: block; margin-top: 12px; font-size: 11px; color: var(--text-3); }
.acm-cap-bar { height: 6px; border-radius: 3px; background: var(--surface); margin-top: 14px; overflow: hidden; position: relative; }
.acm-cap-bar span { position: absolute; inset: 0; width: var(--w); border-radius: 3px; background: linear-gradient(90deg, #7c3aed, #a855f7); }
.acm-feat-head { margin-top: 24px; }
.acm-feat-head strong { font-size: 17px; }
.acm-feat-head span { display: block; margin-top: 4px; font-size: 12.5px; color: var(--text-3); }
.acm-feats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 14px; }
.acm-feat { display: flex; align-items: center; gap: 10px; border: 1px solid var(--border); border-radius: 12px; padding: 13px 14px; background: #fff; }
.acm-feat-ic { display: inline-flex; width: 26px; height: 26px; align-items: center; justify-content: center; border-radius: 50%; background: #d1fae5; color: #047857; flex: none; }
.acm-feat strong { display: block; font-size: 12.5px; }
.acm-feat span { font-size: 10.5px; color: #10b981; }
.acm-banner { position: relative; overflow: hidden; margin-top: 22px; border-radius: 14px; padding: 20px 22px; background: linear-gradient(120deg, #4c1d95, #7c3aed); color: #fff; }
.acm-banner strong { display: inline-flex; align-items: center; gap: 8px; font-size: 15px; }
.acm-banner span { display: block; margin-top: 6px; font-size: 12.5px; color: rgba(255, 255, 255, 0.82); }

@media (max-width: 980px) {
  .acm-caps { grid-template-columns: 1fr 1fr; }
  .acm-feats { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px) {
  .acm-body { grid-template-columns: 1fr; }
  .acm-subnav { display: none; }
  .acm-caps, .acm-feats { grid-template-columns: 1fr; }
}

@media (max-width: 860px) {
  .hpf-app { grid-template-columns: 1fr; min-height: 0; }
  .hpf-side { display: none; }
  .hpf-banners, .hpf-kpis, .hpf-actions { grid-template-columns: 1fr; }
  .home-preview-frame {
    -webkit-mask-image: linear-gradient(to bottom, #000 72%, transparent 100%);
    mask-image: linear-gradient(to bottom, #000 72%, transparent 100%);
  }
}

/* ---------- live mock animations (loop only while in viewport) ----------
   Driven by .is-live, toggled by an IntersectionObserver in site.js. Wrapped
   in no-preference so they never run under reduced-motion. Tuned to read as
   simulated, ongoing activity — not just a one-time load. */
@media (prefers-reduced-motion: no-preference) {

  /* ---- Signature: rows light up in sequence, like live data streaming ---- */
  .is-live .pmock-flow-log > *,
  .is-live .pmock-security-audit > *,
  .is-live .pmock-operations-activity > *,
  .is-live .pmock-workspace-sessions > *,
  .is-live .pmock-dashboard-alerts > *,
  .is-live .pmock-pipeline-sources > *,
  .is-live .pmock-operations-clients > *,
  .is-live .pmock-workspace-roles > *,
  .is-live .pmock-security-rbac > *,
  .is-live .agency-mock-rows > *,
  .is-live .gov-audit > *,
  .is-live .gov-deps > * {
    animation: live-row 4.2s ease-in-out infinite;
    border-radius: 8px;
  }
  .is-live .pmock-flow-log > :nth-child(2), .is-live .pmock-security-audit > :nth-child(2),
  .is-live .pmock-operations-activity > :nth-child(2), .is-live .pmock-workspace-sessions > :nth-child(2),
  .is-live .pmock-dashboard-alerts > :nth-child(2), .is-live .pmock-pipeline-sources > :nth-child(2),
  .is-live .pmock-operations-clients > :nth-child(2), .is-live .pmock-workspace-roles > :nth-child(2),
  .is-live .pmock-security-rbac > :nth-child(2), .is-live .agency-mock-rows > :nth-child(2),
  .is-live .gov-audit > :nth-child(2), .is-live .gov-deps > :nth-child(2) { animation-delay: .5s; }
  .is-live .pmock-flow-log > :nth-child(3), .is-live .pmock-security-audit > :nth-child(3),
  .is-live .pmock-operations-activity > :nth-child(3), .is-live .pmock-workspace-sessions > :nth-child(3),
  .is-live .pmock-dashboard-alerts > :nth-child(3), .is-live .pmock-pipeline-sources > :nth-child(3),
  .is-live .pmock-operations-clients > :nth-child(3), .is-live .pmock-workspace-roles > :nth-child(3),
  .is-live .pmock-security-rbac > :nth-child(3), .is-live .agency-mock-rows > :nth-child(3),
  .is-live .gov-audit > :nth-child(3), .is-live .gov-deps > :nth-child(3) { animation-delay: 1s; }
  .is-live .pmock-pipeline-sources > :nth-child(4), .is-live .pmock-operations-clients > :nth-child(4),
  .is-live .pmock-workspace-roles > :nth-child(4), .is-live .pmock-security-rbac > :nth-child(4),
  .is-live .gov-deps > :nth-child(4) { animation-delay: 1.5s; }
  .is-live .pmock-security-rbac > :nth-child(5) { animation-delay: 2s; }

  /* ---- Automation graph: data flows along the dashed connectors ---- */
  .is-live .pmock-flow-edges path { animation: live-dash .9s linear infinite; stroke-opacity: .9; }
  .is-live .pmock-flow-edges path:nth-of-type(2) { animation-duration: 1.2s; }
  .is-live .pf-node { animation: live-bob 4.5s ease-in-out infinite; }
  .is-live .pf-node--action { animation-delay: -1.5s; }
  .is-live .pf-node--webhook { animation-delay: -3s; }

  /* ---- Meters: a bright light sweeps the track like a live readout ---- */
  .is-live .usage-bar::after, .is-live .mini-bar::after, .is-live .pp-source-bar::after,
  .is-live .po-client-bar::after, .is-live .signal-meter::after, .is-live .gov-dep .dm > div::after {
    content: ''; position: absolute; inset: 0; border-radius: inherit; pointer-events: none;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.85), transparent);
    transform: translateX(-130%); animation: live-sheen 2.4s ease-in-out infinite;
  }
  .is-live .mini-bar::after { animation-delay: -.7s; }
  .is-live .pp-source-bar::after { animation-delay: -1.2s; }
  .is-live .po-client-bar::after { animation-delay: -1.7s; }
  .is-live .signal-meter::after { animation-delay: -2s; }
  .is-live .bar, .is-live .usage-mini { animation: live-breathe 3s ease-in-out infinite; transform-origin: left center; }

  /* ---- Status dots pulse with a soft ring (color-agnostic) ---- */
  .is-live .pulse-dot, .is-live .chip .dot, .is-live .row-dot, .is-live .pb-status .dot {
    animation: live-ping 2s ease-in-out infinite;
  }
  .is-live .chip--warn .dot { animation-delay: -.5s; }
  .is-live .chip--info .dot { animation-delay: -1s; }
  .is-live .chip--violet .dot { animation-delay: -1.5s; }

  /* ---- Builder: active step breathes; gallery tiles lift in sequence ---- */
  .is-live .pb-step--active { animation: live-step 1.9s ease-in-out infinite; }
  .is-live .pmock-gallery-card { animation: live-tile 3.6s ease-in-out infinite; }
  .is-live .pmock-gallery-card:nth-child(2) { animation-delay: .3s; }
  .is-live .pmock-gallery-card:nth-child(3) { animation-delay: .6s; }
  .is-live .pmock-gallery-card:nth-child(4) { animation-delay: .9s; }
  .is-live .pmock-gallery-card:nth-child(5) { animation-delay: 1.2s; }
  .is-live .pmock-gallery-card:nth-child(6) { animation-delay: 1.5s; }

  /* ---- Security/role check marks scan; editor AI accents glow ---- */
  .is-live .ps-r-on, .is-live .pw-r-on { animation: live-ping 2.4s ease-in-out infinite; transform-origin: center; }
  .is-live .ps-rbac-row:nth-child(3) .ps-r-on, .is-live .pw-role-row:nth-child(3) .pw-r-on { animation-delay: -.8s; }
  .is-live .ps-rbac-row:nth-child(4) .ps-r-on, .is-live .pw-role-row:nth-child(4) .pw-r-on { animation-delay: -1.6s; }
  .is-live .pe-tb--ai, .is-live .pe-aibadge, .is-live .pe-selected,
  .is-live .ps-encrypt, .is-live .pe-tb--ai { animation: live-glow 2.6s ease-in-out infinite; }

  /* ---- Dashboard sparkline pulses like a live feed; accent arrows nudge ---- */
  .is-live .pd-spark-svg polyline:first-of-type { animation: live-fade 3s ease-in-out infinite; }
  .is-live .pd-spark-svg polyline:last-of-type { animation: live-line 3s ease-in-out infinite; }
  .is-live .prp-mark, .is-live .php-mark { animation: live-nudge 2.2s ease-in-out infinite; }

  /* ---- Solutions hero canvas: a current flows down the connector line,
     rows stream, nodes glow softly (no scaling — text must not grow) ---- */
  .is-live .solution-canvas-lines::before {
    background-size: 100% 200%;
    animation: live-stream 2.6s linear infinite;
  }
  .is-live .solution-canvas-lines > * { animation: live-row 4.2s ease-in-out infinite; border-radius: 8px; }
  .is-live .solution-canvas-lines > :nth-child(2) { animation-delay: .5s; }
  .is-live .solution-canvas-lines > :nth-child(3) { animation-delay: 1s; }
  .is-live .solution-canvas-lines > :nth-child(4) { animation-delay: 1.5s; }
  .is-live .solution-node { animation: live-glow 3s ease-in-out infinite; }
  .is-live .solution-node--soft { animation-delay: -1.5s; }

  /* ---- Government landing visual: units light up in sequence ---- */
  .is-live .government-unit-grid > * { animation: live-row 4.4s ease-in-out infinite; border-radius: 10px; }
  .is-live .government-unit-grid > :nth-child(2) { animation-delay: .5s; }
  .is-live .government-unit-grid > :nth-child(3) { animation-delay: 1s; }
  .is-live .government-unit-grid > :nth-child(4) { animation-delay: 1.5s; }

  /* ---- Pricing rail teaser: stops pulse ---- */
  .is-live .pricing-rail-dot { animation: live-ping 2.2s ease-in-out infinite; transform-origin: center; }
  .is-live .pricing-rail-stop:nth-child(2) .pricing-rail-dot { animation-delay: -.6s; }
  .is-live .pricing-rail-stop:nth-child(3) .pricing-rail-dot { animation-delay: -1.2s; }
  .is-live .pricing-rail-stop:nth-child(4) .pricing-rail-dot { animation-delay: -1.8s; }

  /* ---- Editor: version history streams in ---- */
  .is-live .pmock-editor-versions > * { animation: live-row 4.2s ease-in-out infinite; border-radius: 8px; }
  .is-live .pmock-editor-versions > :nth-child(2) { animation-delay: .5s; }
  .is-live .pmock-editor-versions > :nth-child(3) { animation-delay: 1s; }
  .is-live .pmock-editor-versions > :nth-child(4) { animation-delay: 1.5s; }

  /* ---- Client-dashboard preview: live chart, spark, meter, accents ---- */
  .is-live .hpf-kpi-bars span { animation: hpf-bar 2.6s ease-in-out infinite; transform-origin: bottom; }
  .is-live .hpf-kpi-bars span:nth-child(2) { animation-delay: .12s; }
  .is-live .hpf-kpi-bars span:nth-child(3) { animation-delay: .24s; }
  .is-live .hpf-kpi-bars span:nth-child(4) { animation-delay: .36s; }
  .is-live .hpf-kpi-bars span:nth-child(5) { animation-delay: .48s; }
  .is-live .hpf-kpi-bars span:nth-child(6) { animation-delay: .6s; }
  .is-live .hpf-kpi-bars span:nth-child(7) { animation-delay: .72s; }
  .is-live .hpf-kpi-bars span:nth-child(8) { animation-delay: .84s; }
  .is-live .hpf-kpi-bars span:nth-child(9) { animation-delay: .96s; }
  .is-live .hpf-kpi-bars span:nth-child(10) { animation-delay: 1.08s; }
  .is-live .hpf-kpi-spark polyline { animation: live-line 2.6s ease-in-out infinite; }
  .is-live .hpf-kpi-meter { position: relative; overflow: hidden; }
  .is-live .hpf-kpi-meter::after {
    content: ''; position: absolute; inset: 0; border-radius: inherit; pointer-events: none;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.85), transparent);
    transform: translateX(-130%); animation: live-sheen 2.6s ease-in-out infinite;
  }
  .is-live .hpf-banner::after {
    content: ''; position: absolute; inset: 0; pointer-events: none;
    background: linear-gradient(115deg, transparent 30%, rgba(255, 255, 255, 0.16) 50%, transparent 70%);
    transform: translateX(-120%); animation: hpf-banner-sheen 4.2s ease-in-out infinite;
  }
  .is-live .hpf-banner--violet::after { animation-delay: -2.1s; }
  .is-live .hpf-action-ic { animation: live-glow 3s ease-in-out infinite; }
  .is-live .hpf-action:nth-child(2) .hpf-action-ic { animation-delay: -.7s; }
  .is-live .hpf-action:nth-child(3) .hpf-action-ic { animation-delay: -1.4s; }
  .is-live .hpf-action:nth-child(4) .hpf-action-ic { animation-delay: -2.1s; }

  /* ---- My Chatbots screen: per-bot volume bars ripple, folders stream ---- */
  .is-live .cbs-bars span { animation: hpf-bar 2.4s ease-in-out infinite; transform-origin: bottom; }
  .is-live .cbs-bars span:nth-child(2) { animation-delay: .1s; }
  .is-live .cbs-bars span:nth-child(3) { animation-delay: .2s; }
  .is-live .cbs-bars span:nth-child(4) { animation-delay: .3s; }
  .is-live .cbs-bars span:nth-child(5) { animation-delay: .4s; }
  .is-live .cbs-bars span:nth-child(6) { animation-delay: .5s; }
  .is-live .cbs-bars span:nth-child(7) { animation-delay: .6s; }
  .is-live .cbs-bars span:nth-child(8) { animation-delay: .7s; }
  .is-live .cbs-folders > * { animation: live-row 4.2s ease-in-out infinite; border-radius: 12px; }
  .is-live .cbs-folders > :nth-child(2) { animation-delay: .5s; }
  .is-live .cbs-folders > :nth-child(3) { animation-delay: 1s; }
  .is-live .cbs-folders > :nth-child(4) { animation-delay: 1.5s; }
  .is-live .cbs-status--on .dot { animation: live-ping 2s ease-in-out infinite; transform-origin: center; }

  /* ---- Usage & Analytics: chart line pulses, usage bars sweep ---- */
  .is-live .aus-chart polyline:last-of-type { animation: live-line 2.8s ease-in-out infinite; }
  .is-live .aus-chart polyline:first-of-type { animation: live-fade 3.4s ease-in-out infinite; }
  .is-live .aus-kpi-bar::after {
    content: ''; position: absolute; inset: 0; border-radius: inherit; pointer-events: none;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.85), transparent);
    transform: translateX(-130%); animation: live-sheen 2.6s ease-in-out infinite;
  }
  .is-live .aus-kpi:nth-child(2) .aus-kpi-bar::after { animation-delay: -.5s; }
  .is-live .aus-kpi:nth-child(3) .aus-kpi-bar::after { animation-delay: -1s; }
  .is-live .aus-kpi:nth-child(4) .aus-kpi-bar::after { animation-delay: -1.5s; }
  .is-live .aus-kpi:nth-child(5) .aus-kpi-bar::after { animation-delay: -2s; }

  /* ---- Workspaces: overview stats stream, cards stream, live dot ---- */
  .is-live .wks-overview-stats > * { animation: live-row 4.2s ease-in-out infinite; border-radius: 10px; }
  .is-live .wks-overview-stats > :nth-child(2) { animation-delay: .4s; }
  .is-live .wks-overview-stats > :nth-child(3) { animation-delay: .8s; }
  .is-live .wks-overview-stats > :nth-child(4) { animation-delay: 1.2s; }
  .is-live .wks-overview-stats > :nth-child(5) { animation-delay: 1.6s; }
  .is-live .wks-grid > * { animation: live-row 4.6s ease-in-out infinite; border-radius: 14px; }
  .is-live .wks-grid > :nth-child(2) { animation-delay: .6s; }
  .is-live .wks-grid > :nth-child(3) { animation-delay: 1.2s; }
  .is-live .wks-live .dot { animation: live-ping 2s ease-in-out infinite; transform-origin: center; }

  /* ---- Data & Privacy: export bundles stream, primary button glows ---- */
  .is-live .dpv-bundles > * { animation: live-row 4.2s ease-in-out infinite; border-radius: 10px; }
  .is-live .dpv-bundles > :nth-child(2) { animation-delay: .7s; }
  .is-live .dpv-actions .cbs-dark { animation: live-glow 3s ease-in-out infinite; }

  /* ---- Media Library: tiles lift in sequence, generate button glows ---- */
  .is-live .mlb-card { animation: live-tile 3.8s ease-in-out infinite; }
  .is-live .mlb-card:nth-child(2) { animation-delay: .35s; }
  .is-live .mlb-card:nth-child(3) { animation-delay: .7s; }
  .is-live .mlb-card:nth-child(4) { animation-delay: 1.05s; }
  .is-live .cbs-head .cbs-dark { animation: live-glow 3.2s ease-in-out infinite; }

  /* ---- Content Studio: send glow, media tiles lift, infographic dc stream ---- */
  .is-live .cse-send { animation: live-glow 2.6s ease-in-out infinite; }
  .is-live .cse-mcard { animation: live-tile 3.6s ease-in-out infinite; }
  .is-live .cse-mcard:nth-child(3) { animation-delay: .4s; }
  .is-live .cse-mcard:nth-child(4) { animation-delay: .8s; }
  .is-live .csi-dc--hl i { animation: live-row 3.4s ease-in-out infinite; border-radius: 5px; }
  .is-live .csi-dc--hl i:nth-child(3) { animation-delay: .4s; }
  .is-live .csi-dc--hl i:nth-child(4) { animation-delay: .8s; }
  .is-live .csi-dc--hl i:nth-child(5) { animation-delay: 1.2s; }

  /* ---- Sources: crawl bar flows, rows stream, indexing spinner turns ---- */
  .is-live .src-progress span { position: relative; overflow: hidden; }
  .is-live .src-progress span::after {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.55), transparent);
    transform: translateX(-130%); animation: live-sheen 1.6s ease-in-out infinite;
  }
  .is-live .src-table .src-tr:not(.src-tr--head) { animation: live-row 4.2s ease-in-out infinite; border-radius: 8px; }
  .is-live .src-table .src-tr:nth-child(3) { animation-delay: .6s; }
  .is-live .src-table .src-tr:nth-child(4) { animation-delay: 1.2s; }
  .is-live .src-crawl { animation: live-glow 2s ease-in-out infinite; }
  .is-live .src-spin { display: inline-flex; animation: live-spin 1.6s linear infinite; }

  /* ---- Actions builder: readiness checks stream, publish glows ---- */
  .is-live .act-checks > * { animation: live-row 4.4s ease-in-out infinite; border-radius: 8px; }
  .is-live .act-checks > :nth-child(2) { animation-delay: .45s; }
  .is-live .act-checks > :nth-child(3) { animation-delay: .9s; }
  .is-live .act-checks > :nth-child(4) { animation-delay: 1.35s; }
  .is-live .act-checks > :nth-child(5) { animation-delay: 1.8s; }
  .is-live .act-step.is-active .act-step-n { animation: live-step 2.2s ease-in-out infinite; }
  /* the Enabled toggle flips on and off (simulated activation) */
  .is-live .act-sw { animation: act-track 3.6s ease-in-out infinite; }
  .is-live .act-sw::after { animation: act-knob 3.6s ease-in-out infinite; }
  /* a caret blinks in the "Try it out" field (simulated typing) */
  .is-live .act-input--ph::after { content: ''; display: inline-block; width: 2px; height: 14px; margin-left: 2px; vertical-align: -2px; background: var(--accent); animation: blink 1.1s steps(2) infinite; }
  /* a light sweeps the Publish button */
  .is-live .act-bar .cbs-dark { position: relative; overflow: hidden; }
  .is-live .act-bar .cbs-dark::after { content: ''; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent); transform: translateX(-130%); animation: live-sheen 2.8s ease-in-out infinite; }
  /* the pending checklist item gently pulses to draw the eye */
  .is-live .act-check:not(.is-done)::before { animation: live-ping 1.8s ease-in-out infinite; }
}
@keyframes act-knob { 0%, 38%, 100% { transform: translateX(0); } 52%, 86% { transform: translateX(13px); } }
@keyframes act-track { 0%, 38%, 100% { background: var(--border-strong); } 52%, 86% { background: var(--accent); } }

/* Agency Budget & Access: cards stream, capacity bar + banner sweep */
@media (prefers-reduced-motion: no-preference) {
  .is-live .acm-caps > * { animation: live-row 4.2s ease-in-out infinite; border-radius: 12px; }
  .is-live .acm-caps > :nth-child(2) { animation-delay: .4s; }
  .is-live .acm-caps > :nth-child(3) { animation-delay: .8s; }
  .is-live .acm-caps > :nth-child(4) { animation-delay: 1.2s; }
  .is-live .acm-feats > * { animation: live-row 4.6s ease-in-out infinite; border-radius: 12px; }
  .is-live .acm-feats > :nth-child(2) { animation-delay: .3s; }
  .is-live .acm-feats > :nth-child(3) { animation-delay: .6s; }
  .is-live .acm-feats > :nth-child(4) { animation-delay: .9s; }
  .is-live .acm-feats > :nth-child(5) { animation-delay: 1.2s; }
  .is-live .acm-feats > :nth-child(6) { animation-delay: 1.5s; }
  .is-live .acm-cap-bar { position: relative; overflow: hidden; }
  .is-live .acm-cap-bar::after { content: ''; position: absolute; inset: 0; border-radius: inherit; pointer-events: none; background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.85), transparent); transform: translateX(-130%); animation: live-sheen 2.6s ease-in-out infinite; }
  .is-live .acm-feat-ic { animation: live-ping 2.4s ease-in-out infinite; transform-origin: center; }
  .is-live .acm-banner::after { content: ''; position: absolute; inset: 0; pointer-events: none; background: linear-gradient(115deg, transparent 35%, rgba(255, 255, 255, 0.14) 50%, transparent 65%); transform: translateX(-120%); animation: hpf-banner-sheen 4.4s ease-in-out infinite; }
}
@keyframes live-spin { to { transform: rotate(360deg); } }

@keyframes live-row {
  0%, 26%, 100% { background-color: transparent; }
  9% { background-color: rgba(37, 99, 235, 0.10); }
}
@keyframes live-dash { to { stroke-dashoffset: -16; } }
@keyframes live-bob { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-4px); } }
@keyframes live-sheen { 0% { transform: translateX(-130%); } 60%, 100% { transform: translateX(340%); } }
@keyframes live-breathe { 0%, 100% { transform: scaleX(1); } 50% { transform: scaleX(0.9); } }
@keyframes live-ping { 0%, 100% { transform: scale(1); opacity: 1; } 50% { transform: scale(1.55); opacity: 0.6; } }
@keyframes live-step { 0%, 100% { box-shadow: 0 0 0 1px var(--accent); } 50% { box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.22); } }
@keyframes live-tile { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-4px); } }
@keyframes live-glow { 0%, 100% { box-shadow: 0 0 0 0 rgba(37, 99, 235, 0); } 50% { box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.2); } }
@keyframes live-fade { 0%, 100% { opacity: 0.95; } 50% { opacity: 0.4; } }
@keyframes live-line { 0%, 100% { opacity: 1; } 50% { opacity: 0.55; } }
@keyframes live-nudge { 0%, 100% { transform: translateX(0); } 50% { transform: translateX(3px); } }
@keyframes live-stream { 0% { background-position: 0 -120%; } 100% { background-position: 0 120%; } }
@keyframes hpf-bar { 0%, 100% { transform: scaleY(1); } 50% { transform: scaleY(0.74); } }
@keyframes hpf-banner-sheen { 0% { transform: translateX(-120%); } 55%, 100% { transform: translateX(260%); } }

/* ---------- prefers-reduced-motion ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  [data-reveal] {
    opacity: 1 !important;
    transform: none !important;
  }
  .floats .float,
  .logo-marquee-track,
  .caret-blink,
  .hero-micro .pulse,
  .kpi .bar::after,
  .mini-bar::after,
  .signal-meter span {
    animation: none !important;
  }
  .float--a, .float--b, .float--c, .float--d { transform: none !important; }
}

/* ============================================================
   Contact page
   ============================================================ */
.contact-section { padding-top: 64px; padding-bottom: 96px; }
.contact-head { max-width: 760px; margin: 0 auto 48px; text-align: center; }
.contact-head h1 { font-size: clamp(34px, 4.4vw, 52px); line-height: 1.04; letter-spacing: -0.02em; margin: 14px 0 16px; }
.contact-head .lead { font-size: 18px; color: var(--text-2); margin: 0 auto; max-width: 640px; }

.contact-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
  gap: 32px;
  align-items: start;
}

/* ---- Aside (info column) ---- */
.contact-aside { display: flex; flex-direction: column; gap: 16px; }
.contact-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 22px;
}
.contact-card-label {
  display: block;
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 14px;
}
.contact-steps ol { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 16px; }
.contact-steps li { display: flex; gap: 12px; align-items: flex-start; }
.cstep-num {
  flex: none; width: 24px; height: 24px; border-radius: 999px;
  display: grid; place-items: center;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff; font-size: 12px; font-weight: 700; font-family: var(--font-mono);
}
.contact-steps li strong { display: block; font-size: 14.5px; margin-bottom: 2px; }
.contact-steps li span { display: block; font-size: 13.5px; color: var(--text-2); line-height: 1.5; }

.contact-email {
  display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--font-mono); font-size: 14px; font-weight: 600;
  color: var(--accent); text-decoration: none; word-break: break-all;
}
.contact-email:hover { text-decoration: underline; }
.contact-email svg { color: var(--accent); flex: none; }
.contact-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }

.contact-door-list { display: flex; flex-direction: column; gap: 4px; }
.contact-door {
  display: flex; align-items: center; gap: 12px;
  padding: 10px; margin: 0 -10px; border-radius: 12px;
  text-decoration: none; color: inherit; transition: background 0.16s ease;
}
.contact-door:hover { background: var(--surface-2); }
.contact-door-ico {
  flex: none; width: 34px; height: 34px; border-radius: 9px;
  display: grid; place-items: center;
  background: #fff; border: 1px solid var(--border); color: var(--accent);
}
.contact-door-text { flex: 1; min-width: 0; }
.contact-door-text strong { display: block; font-size: 14px; }
.contact-door-text span { display: block; font-size: 12.5px; color: var(--text-3); }
.contact-door-arrow { color: var(--muted); transition: transform 0.16s ease; }
.contact-door:hover .contact-door-arrow { transform: translateX(3px); color: var(--accent); }

/* ---- Form card ---- */
.contact-form-card {
  position: relative;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 32px;
  box-shadow: 0 24px 60px -32px rgba(15, 23, 42, 0.28);
  overflow: hidden;
}
.contact-form-glow {
  position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background:
    radial-gradient(60% 50% at 100% 0%, rgba(37,99,235,0.07), transparent 70%),
    radial-gradient(50% 50% at 0% 100%, rgba(6,182,212,0.06), transparent 70%);
}
.contact-form, .cf-success { position: relative; z-index: 1; }
.contact-form { display: flex; flex-direction: column; gap: 18px; }
/* Explicit display rules above override the UA [hidden] style, so re-assert it
   for the form/success swap to actually hide the inactive panel. */
.contact-form[hidden], .cf-success[hidden] { display: none !important; }
/* Honeypot: off-screen, never shown to humans, ignored by tab + screen readers. */
.cf-hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.cf-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.cf-field { display: flex; flex-direction: column; gap: 7px; min-width: 0; }
.cf-field label, .cf-label {
  font-size: 13px; font-weight: 600; color: var(--text);
}
.cf-req { color: var(--accent); }
.contact-form input,
.contact-form select,
.contact-form textarea {
  width: 100%;
  font: inherit; font-size: 14.5px;
  color: var(--text);
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: 11px;
  padding: 11px 13px;
  transition: border-color 0.16s ease, box-shadow 0.16s ease, background 0.16s ease;
}
.contact-form textarea { resize: vertical; min-height: 96px; }
.contact-form input::placeholder,
.contact-form textarea::placeholder { color: var(--muted); }
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
  outline: none;
  border-color: var(--accent);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(37,99,235,0.14);
}
.contact-form select { appearance: none; -webkit-appearance: none; cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 13px center; padding-right: 34px;
}

/* Segmented "interested in" */
.cf-segments { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.cf-seg { position: relative; cursor: pointer; }
.cf-seg input { position: absolute; opacity: 0; inset: 0; cursor: pointer; }
.cf-seg-inner {
  display: flex; align-items: center; gap: 8px;
  padding: 11px 12px; border-radius: 11px;
  border: 1px solid var(--border); background: var(--surface-2);
  font-size: 13.5px; font-weight: 500; color: var(--text-2);
  transition: all 0.16s ease;
}
.cf-seg-inner svg { color: var(--muted); transition: color 0.16s ease; }
.cf-seg:hover .cf-seg-inner { border-color: var(--border-strong); }
.cf-seg input:checked + .cf-seg-inner {
  border-color: var(--accent); background: rgba(37,99,235,0.06); color: var(--text);
  box-shadow: 0 0 0 1px var(--accent) inset;
}
.cf-seg input:checked + .cf-seg-inner svg { color: var(--accent); }
.cf-seg input:focus-visible + .cf-seg-inner { box-shadow: 0 0 0 3px rgba(37,99,235,0.18); }

.cf-consent {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 13px; color: var(--text-2); line-height: 1.5; cursor: pointer;
}
.cf-consent input { flex: none; width: 17px; height: 17px; margin-top: 1px; accent-color: var(--accent); cursor: pointer; }

.cf-submit { position: relative; align-self: flex-start; min-width: 190px; justify-content: center; }
.cf-submit .cf-spinner {
  position: absolute; width: 18px; height: 18px; border-radius: 999px;
  border: 2px solid rgba(255,255,255,0.45); border-top-color: #fff;
  opacity: 0;
}
.cf-submit.is-loading .cf-submit-label { opacity: 0; }
.cf-submit.is-loading .cf-spinner { opacity: 1; animation: cf-spin 0.7s linear infinite; }
.cf-submit.is-loading { pointer-events: none; }
@keyframes cf-spin { to { transform: rotate(360deg); } }

.cf-error {
  font-size: 13.5px; color: #b91c1c; margin: 0;
  background: rgba(220,38,38,0.07); border: 1px solid rgba(220,38,38,0.2);
  border-radius: 10px; padding: 10px 13px;
}
.cf-error a { color: #b91c1c; font-weight: 600; }
.cf-fine { font-size: 13px; color: var(--text-3); margin: -4px 0 0; }
.cf-fine a { color: var(--accent); font-weight: 600; }

.cf-success { text-align: center; padding: 28px 8px; display: flex; flex-direction: column; align-items: center; gap: 8px; }
.cf-success-ico {
  width: 56px; height: 56px; border-radius: 999px; display: grid; place-items: center;
  background: rgba(22,163,74,0.12); color: #16a34a; margin-bottom: 8px;
}
.cf-success h3 { font-size: 22px; margin: 0; }
.cf-success p { font-size: 15px; color: var(--text-2); max-width: 420px; margin: 0 0 10px; }

@media (prefers-reduced-motion: no-preference) {
  .contact-form-card.is-live .contact-form-glow { animation: live-glow 6s ease-in-out infinite; }
}

@media (max-width: 920px) {
  .contact-layout { grid-template-columns: 1fr; gap: 24px; }
  .contact-form-card { order: -1; }
}
@media (max-width: 560px) {
  .contact-section { padding-top: 40px; padding-bottom: 64px; }
  .cf-grid { grid-template-columns: 1fr; }
  .cf-segments { grid-template-columns: 1fr; }
  .contact-form-card { padding: 22px; }
  .cf-submit { align-self: stretch; width: 100%; }
}

/* ============================================================
   Government overview — operating model diagram
   ============================================================ */
.govmodel-section { padding-top: 56px; padding-bottom: 72px; }
.section-head--center { text-align: center; max-width: 720px; margin-left: auto; margin-right: auto; }

.govmodel {
  --gm-line: #cdd5df;
  --gm-accent: var(--cyan);
  max-width: 1060px;
  margin: 0 auto;
  position: relative;
}

/* ---- top band: callouts + central ---- */
.govmodel-top {
  display: grid;
  grid-template-columns: 1fr minmax(250px, 340px) 1fr;
  align-items: center;
  gap: 20px;
}
.gm-side { display: flex; flex-direction: column; gap: 30px; }
.gm-side--left { align-items: flex-end; }
.gm-side--right { align-items: flex-start; }

.gm-callout { display: flex; align-items: center; gap: 12px; max-width: 320px; }
.gm-callout--left { text-align: right; }
.gm-callout--right { text-align: left; }
.gm-callout-icon {
  flex: none; width: 46px; height: 46px; border-radius: 999px;
  display: grid; place-items: center;
  border: 1.5px solid var(--gm-line); color: var(--accent); background: #fff;
}
.gm-callout-text strong {
  display: block; font-size: 12px; font-weight: 700; letter-spacing: .06em;
  text-transform: uppercase; color: var(--text); font-family: var(--font-mono);
}
.gm-callout-text span { display: block; font-size: 12.5px; color: var(--text-2); line-height: 1.45; margin-top: 3px; }
.gm-callout-line {
  flex: none; width: 54px; height: 2px; position: relative;
  background-image: linear-gradient(to right, var(--gm-line) 0 6px, transparent 6px 12px);
  background-size: 12px 2px; background-repeat: repeat-x;
}
.gm-callout-dot {
  position: absolute; top: 50%; width: 8px; height: 8px; border-radius: 999px;
  background: var(--gm-accent); transform: translateY(-50%);
}
.gm-callout--left .gm-callout-dot { right: -2px; }
.gm-callout--right .gm-callout-dot { left: -2px; }

.gm-central { display: flex; justify-content: center; }
.gm-central-card {
  position: relative; overflow: hidden;
  width: 100%; max-width: 340px;
  border: 1.5px solid var(--gm-line); border-radius: 16px; background: #fff;
  padding: 26px 24px 22px; text-align: center;
  box-shadow: 0 20px 50px -34px rgba(15,23,42,.3);
}
.gm-central-ico { display: inline-grid; place-items: center; color: var(--text); margin-bottom: 10px; }
.gm-central-card strong { display: block; font-size: 19px; letter-spacing: .04em; text-transform: uppercase; color: var(--text); }
.gm-central-sub {
  display: block; margin-top: 8px; padding-top: 10px; border-top: 1px solid var(--border-soft);
  font-size: 12.5px; color: var(--text-3); font-family: var(--font-mono);
}
.gm-central-glow { position: absolute; inset: 0; pointer-events: none; background: radial-gradient(60% 60% at 50% 0%, rgba(6,182,212,.10), transparent 70%); }

/* ---- bus connector ---- */
.gm-bus { display: flex; flex-direction: column; align-items: center; }
.gm-bus-stem { width: 2px; height: 26px; background: var(--gm-line); }
.gm-bus-node {
  width: 30px; height: 30px; border-radius: 999px; display: grid; place-items: center;
  background: var(--gm-accent); color: #fff; box-shadow: 0 0 0 5px rgba(6,182,212,.14);
}
.gm-bus-line { width: 84%; height: 2px; background: var(--gm-line); margin-top: 16px; }

/* ---- dependencies ---- */
.gm-deps {
  display: grid; grid-template-columns: repeat(4, 1fr) auto 1fr;
  gap: 16px; align-items: start; margin-top: 16px;
}
.gm-dep {
  position: relative;
  border: 1.5px solid var(--gm-line); border-radius: 14px; background: #fff;
  padding: 18px 12px 14px; text-align: center;
}
.gm-dep-stem { position: absolute; top: -16px; left: 50%; transform: translateX(-50%); width: 2px; height: 16px; background: var(--gm-line); }
.gm-dep-ico { display: inline-grid; place-items: center; color: var(--text); margin-bottom: 8px; }
.gm-dep strong { display: block; font-size: 12px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--text); font-family: var(--font-mono); }
.gm-dep-foot { display: flex; align-items: center; justify-content: center; gap: 10px; margin-top: 12px; padding-top: 10px; border-top: 1px dashed var(--border); }
.gm-dep-tag { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; color: var(--text-2); }
.gm-dep-tag svg { color: var(--accent); }
.gm-dep-div { width: 1px; height: 14px; background: var(--border); }
.gm-ellipsis { display: flex; align-items: center; justify-content: center; gap: 5px; align-self: center; }
.gm-ellipsis span { width: 5px; height: 5px; border-radius: 999px; background: var(--muted); }

/* ---- legend ---- */
.gm-legend {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px;
  margin-top: 30px; padding: 18px 20px;
  border: 1px solid var(--border); border-radius: 14px; background: var(--surface);
}
.gm-legend-item { display: flex; align-items: center; gap: 10px; }
.gm-legend-ico { flex: none; width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center; background: #fff; border: 1px solid var(--border); color: var(--accent); }
.gm-legend-text strong { display: block; font-size: 12.5px; color: var(--text); }
.gm-legend-text span { display: block; font-size: 11.5px; color: var(--text-3); }

/* ---- animations ---- */
@media (prefers-reduced-motion: no-preference) {
  .govmodel.is-live .gm-callout-line { animation: gm-flow 1.8s linear infinite; }
  .govmodel.is-live .gm-callout-dot,
  .govmodel.is-live .gm-bus-node { animation: live-ping 2.4s ease-out infinite; }
  .govmodel.is-live .gm-central-glow { animation: live-glow 5s ease-in-out infinite; }
  .govmodel.is-live .gm-dep { animation: live-stream 3s ease-in-out infinite; }
  .govmodel.is-live .gm-dep:nth-child(2) { animation-delay: .3s; }
  .govmodel.is-live .gm-dep:nth-child(3) { animation-delay: .6s; }
  .govmodel.is-live .gm-dep:nth-child(4) { animation-delay: .9s; }
  .govmodel.is-live .gm-dep:last-child { animation-delay: 1.2s; }
  .govmodel.is-live .gm-ellipsis span { animation: live-fade 1.4s ease-in-out infinite; }
  .govmodel.is-live .gm-ellipsis span:nth-child(2) { animation-delay: .2s; }
  .govmodel.is-live .gm-ellipsis span:nth-child(3) { animation-delay: .4s; }
}
@keyframes gm-flow { to { background-position: 12px 0; } }

/* ---- responsive ---- */
@media (max-width: 860px) {
  .govmodel-top { grid-template-columns: 1fr; gap: 24px; }
  .gm-side { flex-direction: row; flex-wrap: wrap; justify-content: center; gap: 16px; }
  .gm-side--left, .gm-side--right { align-items: stretch; }
  .gm-callout { flex-direction: column; align-items: center; text-align: center; max-width: 200px; }
  .gm-callout--left, .gm-callout--right { text-align: center; }
  .gm-callout-line { display: none; }
  .gm-central { order: -1; }
  .gm-deps { grid-template-columns: repeat(2, 1fr); }
  .gm-deps .gm-ellipsis { display: none; }
  .gm-dep-stem, .gm-bus-line { display: none; }
  .gm-legend { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
  .gm-legend { grid-template-columns: 1fr; }
}
