/* ==========================================================================
   Sendarix — Control Plane Design System
   Dark "operator console" visual language for the category-defining redesign.
   Scoped to `body.sx-cp` so interior light pages are unaffected.
   References: Linear (density/speed), Vercel (geometric calm), Stripe
   (precision), Warp (terminal-native), Datadog (operational legibility).
   ========================================================================== */

body.sx-cp {
  /* Surfaces */
  --cp-bg: #0a0b0d;
  --cp-bg-2: #0d0f13;
  --cp-surface: #111317;
  --cp-elevated: #16191f;
  --cp-raised: #1b1f27;

  /* Lines */
  --cp-border: #23262d;
  --cp-border-strong: #2e323b;
  --cp-hairline: rgba(255, 255, 255, 0.06);

  /* Text */
  --cp-text: #f4f5f7;
  --cp-text-2: #9ba1ad;
  --cp-text-3: #6b7280;

  /* Brand accent — Sendarix logo blue (site.css --sx-blue / --accent_solid_color) */
  --cp-accent: #009af2;
  --cp-accent-2: #0786d1;
  --cp-accent-hover: #0088d6;
  --cp-accent-dim: rgba(0, 154, 242, 0.12);
  --cp-accent-glow: rgba(0, 154, 242, 0.28);

  /* Operational status palette (shared by site + product diagrams) */
  --cp-green: #34d399;
  --cp-amber: #fbbf24;
  --cp-red: #f87171;
  --cp-route: #009af2;

  --cp-shell: 1200px;
  --cp-shell-wide: 1320px;
  --cp-pad: 24px;
  --cp-radius: 14px;
  --cp-radius-sm: 10px;
  --cp-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
  --cp-sans: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  background: var(--cp-bg);
  color: var(--cp-text);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body.sx-cp .body_wrapper { background: var(--cp-bg); overflow-x: clip; }

/* ---- shared layout ---- */
.cp-shell { width: 100%; max-width: var(--cp-shell); margin: 0 auto; padding: 0 var(--cp-pad); box-sizing: border-box; }
.cp-shell--wide { max-width: var(--cp-shell-wide); }
.cp-section { padding: 104px 0; position: relative; }
.cp-section--tight { padding: 72px 0; }
.cp-section--alt { background: var(--cp-bg-2); border-top: 1px solid var(--cp-hairline); border-bottom: 1px solid var(--cp-hairline); }

.cp-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  margin: 0 0 18px;
  font: 600 12px/1 var(--cp-mono);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--cp-accent);
}
.cp-eyebrow::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--cp-accent); box-shadow: 0 0 12px var(--cp-accent-glow); }

.cp-h2 { margin: 0 0 16px; font: 600 40px/1.12 var(--cp-sans); letter-spacing: -0.02em; color: var(--cp-text); }
.cp-h3 { margin: 0 0 10px; font: 600 20px/1.3 var(--cp-sans); letter-spacing: -0.01em; color: var(--cp-text); }
.cp-lead { margin: 0; max-width: 680px; font: 400 17px/1.65 var(--cp-sans); color: var(--cp-text-2); }
.cp-section-head { max-width: 760px; margin: 0 0 48px; }
.cp-section-head.is-center { margin-left: auto; margin-right: auto; text-align: center; }

/* ---- buttons ---- */
.cp-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  height: 46px; padding: 0 22px;
  border-radius: 10px; border: 1px solid transparent;
  font: 600 14px/1 var(--cp-sans); letter-spacing: -0.01em;
  text-decoration: none; cursor: pointer;
  transition: transform .12s ease, background-color .15s ease, border-color .15s ease, box-shadow .15s ease;
}
.cp-btn--primary { background: var(--cp-accent); color: #fff; box-shadow: 0 0 0 1px var(--cp-accent), 0 8px 30px rgba(0,154,242,.18); }
.cp-btn--primary:hover { background: var(--cp-accent-hover); color: #fff; transform: translateY(-1px); }
.cp-btn--ghost { background: transparent; border-color: var(--cp-border-strong); color: var(--cp-text); }
.cp-btn--ghost:hover { border-color: var(--cp-accent); color: var(--cp-accent); }
.cp-btn:focus-visible,
.cp-tab:focus-visible,
.cp-faq summary:focus-visible,
.cp-textlink:focus-visible {
  outline: 2px solid var(--cp-accent);
  outline-offset: 2px;
}
.cp-btn--sm { height: 38px; padding: 0 16px; font-size: 13px; }
.cp-btn-row { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }

.cp-textlink { display: inline-flex; align-items: center; gap: 6px; color: var(--cp-accent); font: 600 14px/1 var(--cp-sans); text-decoration: none; }
.cp-textlink:hover { color: var(--cp-accent-hover); }
.cp-textlink .cp-arrow { transition: transform .15s ease; }
.cp-textlink:hover .cp-arrow { transform: translateX(3px); }

/* ---- panels / cards ---- */
.cp-panel {
  background: var(--cp-surface);
  border: 1px solid var(--cp-border);
  border-radius: var(--cp-radius);
  position: relative;
}
.cp-panel--inset { background: var(--cp-bg-2); }
.cp-card { background: var(--cp-surface); border: 1px solid var(--cp-border); border-radius: var(--cp-radius); padding: 26px; transition: border-color .18s ease, transform .18s ease; }
.cp-card:hover { border-color: var(--cp-border-strong); }
.cp-card p { margin: 0; font: 400 14.5px/1.65 var(--cp-sans); color: var(--cp-text-2); }

/* window chrome shared by product screenshots / diagrams */
.cp-window { background: var(--cp-surface); border: 1px solid var(--cp-border); border-radius: var(--cp-radius); overflow: hidden; box-shadow: 0 30px 80px rgba(0,0,0,.45); }
.cp-window__bar { display: flex; align-items: center; gap: 10px; padding: 11px 16px; background: var(--cp-elevated); border-bottom: 1px solid var(--cp-border); }
.cp-window__dots { display: flex; gap: 6px; }
.cp-window__dots i { width: 10px; height: 10px; border-radius: 50%; background: #2c313b; display: block; }
.cp-window__title { font: 500 12px/1 var(--cp-mono); color: var(--cp-text-3); letter-spacing: .02em; }
.cp-window__title b { color: var(--cp-text-2); font-weight: 600; }
.cp-window__body { padding: 18px; }

/* status pills / dots */
.cp-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; flex: none; }
.cp-dot--green { background: var(--cp-green); box-shadow: 0 0 8px rgba(52,211,153,.5); }
.cp-dot--amber { background: var(--cp-amber); box-shadow: 0 0 8px rgba(251,191,36,.5); }
.cp-dot--red { background: var(--cp-red); box-shadow: 0 0 8px rgba(248,113,113,.5); }
.cp-dot--route { background: var(--cp-route); box-shadow: 0 0 8px var(--cp-accent-glow); }
.cp-pill { display: inline-flex; align-items: center; gap: 7px; padding: 4px 10px; border-radius: 999px; border: 1px solid var(--cp-border); font: 600 11px/1 var(--cp-mono); letter-spacing: .04em; text-transform: uppercase; color: var(--cp-text-2); background: var(--cp-bg-2); }
.cp-pill--green { color: var(--cp-green); border-color: rgba(52,211,153,.3); }
.cp-pill--amber { color: var(--cp-amber); border-color: rgba(251,191,36,.3); }
.cp-pill--red { color: var(--cp-red); border-color: rgba(248,113,113,.3); }

.cp-mono { font-family: var(--cp-mono); }

/* ==========================================================================
   HERO
   ========================================================================== */
.cp-hero { position: relative; padding: 168px 0 88px; overflow: hidden; }
.cp-hero--compact { padding: 148px 0 72px; }
.cp-hero::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(900px 520px at 78% 14%, rgba(0,154,242,.10), transparent 60%),
    linear-gradient(180deg, #0c0e12 0%, var(--cp-bg) 70%);
  z-index: 0;
}
.cp-hero::after {
  content: ""; position: absolute; inset: 0; z-index: 0; opacity: .5;
  background-image: linear-gradient(var(--cp-hairline) 1px, transparent 1px), linear-gradient(90deg, var(--cp-hairline) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: radial-gradient(800px 600px at 70% 20%, #000 0%, transparent 75%);
          mask-image: radial-gradient(800px 600px at 70% 20%, #000 0%, transparent 75%);
}
.cp-hero__grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, 1.1fr); gap: 56px; align-items: center; }
.cp-hero h1 { margin: 0 0 22px; font: 600 60px/1.04 var(--cp-sans); letter-spacing: -0.035em; color: #fff; }
.cp-hero h1 em { font-style: normal; color: var(--cp-accent); }
.cp-hero__sub { margin: 0; max-width: 560px; font: 400 18px/1.6 var(--cp-sans); color: var(--cp-text-2); }
.cp-hero__verbs { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 24px; }
.cp-hero__verb { font: 600 12px/1 var(--cp-mono); letter-spacing: .12em; text-transform: uppercase; color: var(--cp-text-3); padding: 7px 12px; border: 1px solid var(--cp-border); border-radius: 8px; }
.cp-hero__verb b { color: var(--cp-accent); font-weight: 600; }
.cp-hero__trust { margin: 22px 0 0; font: 500 13px/1.6 var(--cp-mono); color: var(--cp-text-3); }

/* ==========================================================================
   TOPOLOGY (hero live failover) + generic diagram svg
   ========================================================================== */
.cp-topo { position: relative; }
.cp-topo svg { display: block; width: 100%; height: auto; }
.cp-edge { stroke: var(--cp-border-strong); stroke-width: 1.5; fill: none; }
.cp-edge--active { stroke: var(--cp-route); stroke-width: 2; filter: drop-shadow(0 0 4px var(--cp-accent-glow)); }
.cp-edge--degraded { stroke: var(--cp-amber); stroke-width: 2; stroke-dasharray: 5 5; }
.cp-node-box { fill: var(--cp-elevated); stroke: var(--cp-border-strong); }
.cp-node-box--accent { stroke: var(--cp-accent); fill: rgba(0,154,242,.06); }
.cp-node-label { font: 600 12px var(--cp-mono); fill: var(--cp-text); }
.cp-node-sub { font: 500 10px var(--cp-mono); fill: var(--cp-text-3); }
.cp-flow-dot { fill: var(--cp-route); }

.cp-toast {
  position: absolute; left: 16px; bottom: 16px;
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; border-radius: 10px;
  background: rgba(13,15,19,.92); border: 1px solid var(--cp-border-strong);
  font: 500 12px/1.3 var(--cp-mono); color: var(--cp-text);
  box-shadow: 0 12px 40px rgba(0,0,0,.5);
  opacity: 0; transform: translateY(8px); transition: opacity .35s ease, transform .35s ease;
  max-width: 80%;
}
.cp-toast.is-on { opacity: 1; transform: translateY(0); }
.cp-toast b { color: var(--cp-accent); font-weight: 600; }

/* ==========================================================================
   VERB STRIP (Route / Isolate / Monitor / Recover)
   ========================================================================== */
.cp-verbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.cp-verb {
  padding: 24px; border: 1px solid var(--cp-border); border-radius: var(--cp-radius);
  background: var(--cp-surface); position: relative; overflow: hidden;
  transition: border-color .18s ease, background-color .18s ease;
}
.cp-verb:hover { border-color: var(--cp-accent); }
.cp-verb__idx { font: 600 12px/1 var(--cp-mono); color: var(--cp-text-3); letter-spacing: .1em; }
.cp-verb h3 { margin: 14px 0 8px; font: 600 19px/1.2 var(--cp-sans); color: var(--cp-text); }
.cp-verb p { margin: 0; font: 400 14px/1.6 var(--cp-sans); color: var(--cp-text-2); }
.cp-verb__bar { position: absolute; left: 0; top: 0; height: 3px; width: 100%; background: linear-gradient(90deg, var(--cp-accent), transparent); opacity: .0; transition: opacity .2s ease; }
.cp-verb:hover .cp-verb__bar { opacity: 1; }

/* ==========================================================================
   PRODUCT CANVAS (tabbed real-UI section)
   ========================================================================== */
.cp-tabs { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 22px; }
.cp-tab {
  appearance: none; border: 1px solid var(--cp-border); background: var(--cp-surface);
  color: var(--cp-text-2); border-radius: 9px; padding: 9px 15px; cursor: pointer;
  font: 600 13px/1 var(--cp-sans); display: inline-flex; align-items: center; gap: 8px;
  transition: color .15s ease, border-color .15s ease, background-color .15s ease;
}
.cp-tab:hover { color: var(--cp-text); border-color: var(--cp-border-strong); }
.cp-tab.is-active { color: #fff; background: var(--cp-accent); border-color: var(--cp-accent); }
.cp-tabpanel { display: none; }
.cp-tabpanel.is-active { display: block; animation: cpFade .18s ease; }
@keyframes cpFade { from { opacity: .4; } to { opacity: 1; } }

/* generic data table inside product UI */
.cp-table { width: 100%; border-collapse: collapse; font-family: var(--cp-mono); }
.cp-table th { text-align: left; font: 600 11px/1 var(--cp-mono); letter-spacing: .06em; text-transform: uppercase; color: var(--cp-text-3); padding: 0 14px 12px; border-bottom: 1px solid var(--cp-border); }
.cp-table td { padding: 13px 14px; border-bottom: 1px solid var(--cp-hairline); font: 500 13px/1.3 var(--cp-mono); color: var(--cp-text-2); }
.cp-table tr:last-child td { border-bottom: 0; }
.cp-table td b { color: var(--cp-text); font-weight: 600; }
.cp-table .num { text-align: right; color: var(--cp-text); }

/* routing rule builder UI */
.cp-rule { display: grid; gap: 10px; }
.cp-rule__row { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; padding: 13px 14px; background: var(--cp-bg-2); border: 1px solid var(--cp-border); border-radius: 10px; font: 500 13px/1.4 var(--cp-mono); color: var(--cp-text-2); }
.cp-kw { color: var(--cp-accent); font-weight: 600; }
.cp-token { padding: 3px 8px; border-radius: 6px; background: var(--cp-elevated); border: 1px solid var(--cp-border-strong); color: var(--cp-text); }
.cp-token--amber { color: var(--cp-amber); border-color: rgba(251,191,36,.3); }
.cp-token--green { color: var(--cp-green); border-color: rgba(52,211,153,.3); }

/* event timeline */
.cp-timeline { display: grid; gap: 0; }
.cp-tl-row { display: grid; grid-template-columns: 92px 18px 1fr auto; align-items: center; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--cp-hairline); }
.cp-tl-row:last-child { border-bottom: 0; }
.cp-tl-time { font: 500 12px/1 var(--cp-mono); color: var(--cp-text-3); }
.cp-tl-label { font: 500 13px/1 var(--cp-mono); color: var(--cp-text); }
.cp-tl-meta { font: 500 12px/1 var(--cp-mono); color: var(--cp-text-3); }

/* webhook retry */
.cp-wh { display: grid; gap: 8px; }
.cp-wh__row { display: flex; align-items: center; gap: 12px; padding: 12px 14px; background: var(--cp-bg-2); border: 1px solid var(--cp-border); border-radius: 10px; font: 500 12.5px/1 var(--cp-mono); }
.cp-wh__code { color: var(--cp-text); }
.cp-wh__attempt { margin-left: auto; color: var(--cp-text-3); }

.cp-illus-note { margin: 14px 0 0; font: 500 11px/1.5 var(--cp-mono); color: var(--cp-text-3); }

/* warmup progression */
.cp-warmup { display: grid; gap: 12px; }
.cp-warmup__row { display: grid; grid-template-columns: 88px 1fr 72px minmax(0, 1fr); gap: 12px; align-items: center; padding: 10px 0; border-bottom: 1px solid var(--cp-hairline); }
.cp-warmup__row:last-child { border-bottom: 0; }
.cp-warmup__day { font: 600 12px/1.3 var(--cp-mono); color: var(--cp-text); }
.cp-warmup__track { height: 8px; border-radius: 999px; background: var(--cp-bg-2); overflow: hidden; }
.cp-warmup__fill { display: block; height: 100%; border-radius: 999px; background: var(--cp-accent); opacity: .85; }
.cp-warmup__fill.is-seed { background: var(--cp-text-3); opacity: .55; }
.cp-warmup__fill.is-stable { background: var(--cp-green); }
.cp-warmup__vol { font: 600 12px/1 var(--cp-mono); color: var(--cp-text); text-align: right; }
.cp-warmup__note { font: 500 12px/1.4 var(--cp-sans); color: var(--cp-text-3); }

/* contact form (control-plane pages) */
.cp-contact-grid { display: flex; flex-wrap: wrap; margin: -10px; }
.cp-contact-col { padding: 10px; width: 100%; }
.cp-contact-col--third { width: 33.3333%; }
.cp-contact-col--half { width: 50%; }
.cp-contact-col--full { width: 100%; }
.cp-contact-card { padding: 28px; border: 1px solid var(--cp-border); border-radius: var(--cp-radius); background: var(--cp-surface); }
.cp-contact-card label { display: block; margin: 0 0 6px; font: 600 13px/1.4 var(--cp-sans); color: var(--cp-text); }
.cp-contact-card input,
.cp-contact-card select,
.cp-contact-card textarea { width: 100%; padding: 11px 12px; border: 1px solid var(--cp-border-strong); border-radius: 8px; background: var(--cp-bg); color: var(--cp-text); font: 400 14px/1.5 var(--cp-sans); }
.cp-contact-card input:focus-visible,
.cp-contact-card select:focus-visible,
.cp-contact-card textarea:focus-visible {
  outline: 2px solid var(--cp-accent);
  outline-offset: 1px;
  border-color: var(--cp-accent);
}
.cp-contact-card textarea { min-height: 140px; resize: vertical; }
.cp-contact-feedback { border-radius: 8px; padding: 14px 16px; margin: 0 0 18px; font: 500 14px/1.6 var(--cp-sans); }
.cp-contact-feedback--error { background: rgba(255,107,107,.08); border: 1px solid rgba(255,107,107,.35); color: #ffb4b4; }
.cp-contact-feedback--success { background: rgba(52,211,153,.08); border: 1px solid rgba(52,211,153,.35); color: #86efac; }
.cp-contact-routing { margin-top: 18px; padding: 14px 16px; border: 1px solid var(--cp-border); border-radius: var(--cp-radius-sm); font: 400 13.5px/1.6 var(--cp-sans); color: var(--cp-text-2); }

/* code block */
.cp-code { background: var(--cp-bg-2); border: 1px solid var(--cp-border); border-radius: var(--cp-radius); overflow: hidden; }
.cp-code__bar { display: flex; gap: 4px; padding: 8px 10px; background: var(--cp-elevated); border-bottom: 1px solid var(--cp-border); }
.cp-code__tab { font: 600 12px/1 var(--cp-mono); color: var(--cp-text-3); padding: 6px 11px; border-radius: 7px; cursor: pointer; }
.cp-code__tab.is-active { color: var(--cp-text); background: var(--cp-surface); }
.cp-code pre { margin: 0; padding: 18px 20px; overflow-x: auto; font: 500 13px/1.7 var(--cp-mono); color: var(--cp-text-2); }
.cp-code .c-key { color: var(--cp-accent); }
.cp-code .c-str { color: #9be6a0; }
.cp-code .c-com { color: var(--cp-text-3); }
.cp-code .c-mut { color: var(--cp-text-3); }
.cp-code__panel { display: none; }
.cp-code__panel.is-active { display: block; }

/* reputation / sparkline */
.cp-spark { display: block; width: 100%; height: auto; }
.cp-spark__line { fill: none; stroke: var(--cp-green); stroke-width: 2; }
.cp-spark__line--dip { stroke: var(--cp-amber); }
.cp-spark__area { fill: url(#cpSparkFill); opacity: .25; }

/* ==========================================================================
   BLAST RADIUS
   ========================================================================== */
.cp-blast { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.cp-blast__col { padding: 22px; border: 1px solid var(--cp-border); border-radius: var(--cp-radius); background: var(--cp-surface); }
.cp-blast__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.cp-blast__head h4 { margin: 0; font: 600 14px/1 var(--cp-sans); color: var(--cp-text); }
.cp-tenants { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.cp-tenant { aspect-ratio: 1 / 1; border-radius: 9px; border: 1px solid var(--cp-border-strong); background: var(--cp-bg-2); display: flex; align-items: center; justify-content: center; font: 600 10px/1 var(--cp-mono); color: var(--cp-text-3); transition: background-color .4s ease, border-color .4s ease, color .4s ease; }
.cp-tenant[data-state="healthy"] { border-color: rgba(52,211,153,.35); color: var(--cp-green); }
.cp-tenant[data-state="bad"] { border-color: var(--cp-red); color: var(--cp-red); background: rgba(248,113,113,.12); }
.cp-tenant[data-state="contaminated"] { border-color: rgba(248,113,113,.4); color: var(--cp-red); background: rgba(248,113,113,.07); }
.cp-tenant[data-state="isolated"] { border-color: rgba(52,211,153,.35); color: var(--cp-green); }
.cp-tenant[data-state="quarantined"] { border-color: var(--cp-red); color: var(--cp-red); background: rgba(248,113,113,.12); outline: 2px dashed rgba(248,113,113,.4); outline-offset: 2px; }

/* ==========================================================================
   SOLUTIONS / WHY-SWITCH / TRUST / PRICING preview
   ========================================================================== */
.cp-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.cp-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }

.cp-sol { display: block; text-decoration: none; }
.cp-sol h3 { color: var(--cp-text); }
.cp-sol:hover { border-color: var(--cp-accent); }
.cp-sol .cp-textlink { margin-top: 14px; }

.cp-matrix { position: relative; border: 1px solid var(--cp-border); border-radius: var(--cp-radius); background: var(--cp-surface); padding: 28px; }
.cp-matrix__plot { position: relative; aspect-ratio: 16 / 9; border-left: 1px solid var(--cp-border-strong); border-bottom: 1px solid var(--cp-border-strong); }
.cp-axis-x { position: absolute; bottom: -26px; right: 0; font: 600 11px/1 var(--cp-mono); color: var(--cp-text-3); text-transform: uppercase; letter-spacing: .06em; }
.cp-axis-y { position: absolute; top: 0; left: -10px; transform: rotate(-90deg) translateX(-100%); transform-origin: left top; font: 600 11px/1 var(--cp-mono); color: var(--cp-text-3); text-transform: uppercase; letter-spacing: .06em; }
.cp-mark { position: absolute; transform: translate(-50%, 50%); display: flex; align-items: center; gap: 8px; }
.cp-mark i { width: 12px; height: 12px; border-radius: 50%; background: var(--cp-text-3); display: block; }
.cp-mark span { font: 500 12px/1 var(--cp-mono); color: var(--cp-text-2); white-space: nowrap; }
.cp-mark.is-sx i { background: var(--cp-accent); box-shadow: 0 0 14px var(--cp-accent-glow); width: 16px; height: 16px; }
.cp-mark.is-sx span { color: var(--cp-accent); font-weight: 600; }

.cp-trust-band { display: flex; flex-wrap: wrap; gap: 12px; align-items: stretch; }
.cp-trust-tile { flex: 1 1 150px; padding: 18px; border: 1px solid var(--cp-border); border-radius: var(--cp-radius-sm); background: var(--cp-surface); }
.cp-trust-tile .k { display: block; font: 600 12px/1 var(--cp-mono); color: var(--cp-text-3); letter-spacing: .04em; text-transform: uppercase; margin-bottom: 8px; }
.cp-trust-tile .v { font: 600 15px/1.3 var(--cp-sans); color: var(--cp-text); display: flex; align-items: center; gap: 8px; }

/* maturity ladder pricing preview */
.cp-ladder { display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px; align-items: end; }
.cp-step { border: 1px solid var(--cp-border); border-radius: var(--cp-radius-sm); background: var(--cp-surface); padding: 18px 16px; }
.cp-step__name { font: 600 15px/1 var(--cp-sans); color: var(--cp-text); margin: 0 0 6px; }
.cp-step__cap { font: 500 12.5px/1.5 var(--cp-mono); color: var(--cp-text-3); margin: 0; }
.cp-step.is-rec { border-color: var(--cp-accent); background: linear-gradient(180deg, rgba(0,154,242,.07), transparent); }
.cp-step.is-rec .cp-step__name { color: var(--cp-accent); }

/* ==========================================================================
   PRICING
   ========================================================================== */
.cp-plans { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; align-items: stretch; }
.cp-plan { display: flex; flex-direction: column; padding: 26px 22px; border: 1px solid var(--cp-border); border-radius: var(--cp-radius); background: var(--cp-surface); position: relative; }
.cp-plan.is-rec { border-color: var(--cp-accent); background: linear-gradient(180deg, rgba(0,154,242,.06), transparent 60%); box-shadow: 0 0 0 1px var(--cp-accent), 0 18px 50px rgba(0,154,242,.1); }
.cp-plan__badge { position: absolute; top: -10px; left: 22px; font: 600 10px/1 var(--cp-mono); letter-spacing: .1em; text-transform: uppercase; color: #fff; background: var(--cp-accent); padding: 5px 10px; border-radius: 6px; }
.cp-plan__tag { font: 600 11px/1 var(--cp-mono); letter-spacing: .08em; text-transform: uppercase; color: var(--cp-text-3); }
.cp-plan__name { margin: 12px 0 4px; font: 600 22px/1.1 var(--cp-sans); color: var(--cp-text); }
.cp-plan__cap { margin: 0 0 16px; font: 500 13px/1.4 var(--cp-mono); color: var(--cp-accent); min-height: 36px; }
.cp-plan__price { display: flex; align-items: baseline; gap: 6px; margin-bottom: 4px; }
.cp-plan__price b { font: 600 34px/1 var(--cp-sans); color: var(--cp-text); letter-spacing: -0.02em; }
.cp-plan__price span { font: 500 13px/1 var(--cp-mono); color: var(--cp-text-3); }
.cp-plan__vol { margin: 0 0 18px; font: 500 12.5px/1.4 var(--cp-mono); color: var(--cp-text-2); }
.cp-plan__list { list-style: none; margin: 0 0 22px; padding: 18px 0 0; border-top: 1px solid var(--cp-hairline); display: grid; gap: 10px; flex: 1; }
.cp-plan__list li { display: flex; align-items: flex-start; gap: 9px; font: 500 13px/1.45 var(--cp-sans); color: var(--cp-text-2); }
.cp-plan__list li::before { content: "→"; color: var(--cp-accent); font-family: var(--cp-mono); flex: none; }
.cp-plan__metrics { list-style: none; margin: 0 0 22px; padding: 0; display: grid; gap: 7px; }
.cp-plan__metrics li { display: flex; justify-content: space-between; font: 500 12px/1.3 var(--cp-mono); color: var(--cp-text-3); }
.cp-plan__metrics li b { color: var(--cp-text); font-weight: 600; }
.cp-plan .cp-btn { width: 100%; margin-top: auto; }

.cp-ent-band { margin-top: 14px; display: grid; grid-template-columns: 1.3fr 1fr 1fr auto; gap: 28px; align-items: center; padding: 28px; border: 1px solid var(--cp-border); border-radius: var(--cp-radius); background: var(--cp-surface); }
.cp-ent-band h3 { margin: 0 0 6px; font: 600 22px/1.1 var(--cp-sans); color: var(--cp-text); }
.cp-ent-band p { margin: 0; font: 500 13px/1.5 var(--cp-mono); color: var(--cp-text-3); }
.cp-ent-band ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 8px; }
.cp-ent-band ul li { display: flex; align-items: center; gap: 8px; font: 500 13px/1.3 var(--cp-sans); color: var(--cp-text-2); }

/* comparison matrix */
.cp-compare { width: 100%; border-collapse: collapse; font-family: var(--cp-sans); }
.cp-compare th { padding: 14px 16px; text-align: center; font: 600 13px/1.2 var(--cp-sans); color: var(--cp-text); border-bottom: 1px solid var(--cp-border); }
.cp-compare th:first-child { text-align: left; }
.cp-compare th.is-rec { color: var(--cp-accent); }
.cp-compare td { padding: 12px 16px; text-align: center; border-bottom: 1px solid var(--cp-hairline); font: 500 13px/1.3 var(--cp-mono); color: var(--cp-text-2); }
.cp-compare td:first-child { text-align: left; font-family: var(--cp-sans); color: var(--cp-text); }
.cp-compare .cp-sec td { background: var(--cp-bg-2); font: 600 11px/1 var(--cp-mono); letter-spacing: .1em; text-transform: uppercase; color: var(--cp-accent); text-align: left; }
.cp-compare .yes { color: var(--cp-green); }
.cp-compare .no { color: var(--cp-text-3); }
.cp-compare .add { color: var(--cp-amber); font-size: 11px; }
.cp-compare-wrap { overflow-x: auto; border: 1px solid var(--cp-border); border-radius: var(--cp-radius); }

@media (max-width: 1024px) {
  .cp-plans { grid-template-columns: repeat(2, 1fr); }
  .cp-ent-band { grid-template-columns: 1fr; gap: 18px; text-align: left; }
}
@media (max-width: 768px) {
  .cp-plans { grid-template-columns: 1fr; }
}

/* ==========================================================================
   PRODUCT PAGE UTILITIES (prose, steps, FAQ, related, callout)
   ========================================================================== */
.cp-prose { font: 400 15.5px/1.75 var(--cp-sans); color: var(--cp-text-2); max-width: 760px; }
.cp-prose a, .cp-card p a, .cp-faq a { color: var(--cp-accent); text-decoration: none; }
.cp-prose a:hover, .cp-card p a:hover, .cp-faq a:hover { color: var(--cp-accent-hover); }

.cp-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; counter-reset: cpstep; }
.cp-stepcard { padding: 22px; border: 1px solid var(--cp-border); border-left: 2px solid var(--cp-accent); border-radius: var(--cp-radius-sm); background: var(--cp-surface); }
.cp-stepcard h4 { margin: 0 0 8px; font: 600 16px/1.25 var(--cp-sans); color: var(--cp-text); }
.cp-stepcard p { margin: 0; font: 400 13.5px/1.6 var(--cp-sans); color: var(--cp-text-2); }

.cp-callout { padding: 22px 24px; border: 1px solid var(--cp-border); border-radius: var(--cp-radius); background: linear-gradient(180deg, rgba(0,154,242,.06), transparent 70%); }
.cp-callout p { margin: 0; font: 400 15px/1.7 var(--cp-sans); color: var(--cp-text-2); }
.cp-callout b { color: var(--cp-text); }

.cp-faq { display: grid; gap: 10px; }
.cp-faq details { border: 1px solid var(--cp-border); border-radius: var(--cp-radius-sm); background: var(--cp-surface); overflow: hidden; }
.cp-faq summary { cursor: pointer; list-style: none; padding: 16px 18px; font: 600 15.5px/1.4 var(--cp-sans); color: var(--cp-text); display: flex; justify-content: space-between; gap: 12px; }
.cp-faq summary::-webkit-details-marker { display: none; }
.cp-faq summary::after { content: "+"; color: var(--cp-accent); font-family: var(--cp-mono); }
.cp-faq details[open] summary::after { content: "−"; }
.cp-faq details p { margin: 0; padding: 0 18px 16px; font: 400 14.5px/1.7 var(--cp-sans); color: var(--cp-text-2); }

.cp-related { display: flex; flex-wrap: wrap; gap: 10px; }
.cp-related a { display: inline-flex; align-items: center; padding: 9px 15px; border: 1px solid var(--cp-border); border-radius: 999px; font: 500 13px/1 var(--cp-sans); color: var(--cp-text-2); text-decoration: none; transition: border-color .15s ease, color .15s ease; }
.cp-related a:hover { border-color: var(--cp-accent); color: var(--cp-accent); }

.cp-pre { margin: 0; padding: 18px 20px; background: var(--cp-bg); border: 1px solid var(--cp-border); border-radius: var(--cp-radius-sm); font: 400 13px/1.65 var(--cp-mono); color: var(--cp-text-2); overflow-x: auto; }
.cp-pre .k { color: var(--cp-accent); }

.cp-thresholds { display: grid; gap: 10px; }
.cp-thr { display: grid; grid-template-columns: 200px 1fr; gap: 18px; align-items: center; padding: 14px 18px; border: 1px solid var(--cp-border); border-radius: var(--cp-radius-sm); background: var(--cp-surface); }
.cp-thr__label { font: 600 13.5px/1.3 var(--cp-mono); display: flex; align-items: center; gap: 9px; }
.cp-thr__label::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: currentColor; flex: none; }
.cp-thr__label.is-crit { color: #ff6b6b; } .cp-thr__label.is-warn { color: #f5c451; } .cp-thr__label.is-ok { color: var(--cp-accent); }
.cp-thr p { margin: 0; font: 400 13.5px/1.55 var(--cp-sans); color: var(--cp-text-2); }

@media (max-width: 1024px) { .cp-steps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 768px) { .cp-steps { grid-template-columns: 1fr; } .cp-thr { grid-template-columns: 1fr; gap: 6px; } .cp-warmup__row { grid-template-columns: 1fr; gap: 6px; } .cp-warmup__vol { text-align: left; } .cp-contact-col--third, .cp-contact-col--half { width: 100%; } }

/* final CTA */
.cp-final { position: relative; text-align: center; padding: 120px 0; overflow: hidden; }
.cp-final::before { content: ""; position: absolute; inset: 0; background: radial-gradient(700px 380px at 50% 30%, rgba(0,154,242,.12), transparent 65%); }
.cp-final h2 { position: relative; margin: 0 auto 16px; max-width: 760px; font: 600 44px/1.1 var(--cp-sans); letter-spacing: -0.025em; color: #fff; }
.cp-final p { position: relative; margin: 0 auto 28px; max-width: 560px; font: 400 17px/1.6 var(--cp-sans); color: var(--cp-text-2); }
.cp-final .cp-btn-row { position: relative; justify-content: center; }

/* ==========================================================================
   GLOBAL SHELL — header / footer on body.sx-cp (operator console)
   ========================================================================== */
body.sx-cp {
  font-size: 16px;
}

/* Pre-scroll + scrolled header bar */
body.sx-cp .header_area.header_stick:not(.navbar_fixed),
body.sx-cp .header_area.header_stick:not(.navbar_fixed) .navbar,
body.sx-cp .header_area.header_stick:not(.navbar_fixed) .site-header-inner {
  background: rgba(10, 11, 13, 0.72) !important;
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--cp-border);
}
body.sx-cp .header_area.header_stick:not(.navbar_fixed)::before {
  background: transparent !important;
}

body.sx-cp .header_area.navbar_fixed,
body.sx-cp .header_area.navbar_fixed .navbar,
body.sx-cp .header_area.navbar_fixed .site-header-inner { background: rgba(10,11,13,.88) !important; backdrop-filter: blur(12px); }
body.sx-cp .header_area.navbar_fixed::before { background: transparent !important; }
body.sx-cp .header_area.navbar_fixed { box-shadow: 0 1px 0 var(--cp-border); border-bottom: 1px solid var(--cp-border); }

/* Nav text — readable before and after scroll */
body.sx-cp .header_area .site-nav > .site-nav-item > .nav-link,
body.sx-cp .header_area .site-nav .nav-link { color: var(--cp-text) !important; }
body.sx-cp .header_area .site-nav .nav-link:hover,
body.sx-cp .header_area .site-nav .nav-link:focus-visible,
body.sx-cp .header_area .site-nav .nav-link.is-active,
body.sx-cp .header_area .site-nav .nav-link[aria-current="page"] { color: var(--cp-accent) !important; }

body.sx-cp .header_area .main_logo_img { display: block !important; }
body.sx-cp .header_area .sticky_logo_img { display: none !important; }
body.sx-cp .header_area .menu_toggle .hamburger span,
body.sx-cp .header_area .menu_toggle .hamburger-cross span { background: var(--cp-text) !important; }

/* Header actions */
body.sx-cp .sx-nav-login { color: var(--cp-text) !important; }
body.sx-cp .sx-nav-login:hover,
body.sx-cp .sx-nav-login:focus-visible { color: var(--cp-accent) !important; }
body.sx-cp .sx-nav-cta {
  background: var(--cp-accent) !important;
  border-color: var(--cp-accent) !important;
  color: #fff !important;
  box-shadow: 0 0 0 1px var(--cp-accent), 0 6px 20px rgba(0, 154, 242, 0.16);
}
body.sx-cp .sx-nav-cta:hover {
  background: var(--cp-accent-hover) !important;
  border-color: var(--cp-accent-hover) !important;
  color: #fff !important;
}
body.sx-cp .sx-nav-cta:focus-visible,
body.sx-cp .navbar-toggler:focus-visible,
body.sx-cp .sx-lang-selector__btn:focus-visible {
  outline: 2px solid var(--cp-accent);
  outline-offset: 2px;
}

body.sx-cp .sx-lang-selector__btn {
  background: var(--cp-surface);
  border-color: var(--cp-border-strong);
  color: var(--cp-text);
}
body.sx-cp .sx-lang-selector__btn:hover {
  border-color: var(--cp-accent);
  color: var(--cp-accent);
}

/* Logo compression on control-plane pages */
body.sx-cp .navbar-brand img,
body.sx-cp .navbar-brand .main_logo_img,
body.sx-cp .navbar-brand .sticky_logo_img {
  height: 58px;
  max-height: 58px;
}

/* Footer — dark operator console (override legacy light gradient) */
body.sx-cp .footer_bg {
  background: var(--cp-bg-2) !important;
  border-top: 1px solid var(--cp-border);
}
body.sx-cp .site-footer-inner {
  border-bottom-color: var(--cp-border);
  padding-bottom: 48px;
}
body.sx-cp .site-footer-grid {
  gap: 28px 20px;
}
body.sx-cp .footer-col h5 {
  color: var(--cp-text) !important;
  font: 600 14px/1.3 var(--cp-sans) !important;
  margin: 0 0 12px;
  letter-spacing: 0.02em;
}
body.sx-cp .footer-col a {
  color: var(--cp-text-2) !important;
  font: 400 14px/1.65 var(--cp-sans) !important;
}
body.sx-cp .footer-col a:hover,
body.sx-cp .footer-col a:focus-visible {
  color: var(--cp-accent) !important;
}
body.sx-cp .footer-strapline {
  border-color: var(--cp-border);
}
body.sx-cp .footer-strapline .footer-tagline,
body.sx-cp .footer-tagline {
  color: var(--cp-text-3) !important;
  font: 400 13px/1.55 var(--cp-sans) !important;
}
body.sx-cp .footer-bottom {
  border-top-color: var(--cp-border);
}
body.sx-cp .footer-bottom p {
  color: var(--cp-text-3) !important;
  font: 400 13px/1.55 var(--cp-sans) !important;
}
body.sx-cp .footer-bottom a {
  color: var(--cp-accent) !important;
  font-weight: 600;
  text-decoration: none;
}
body.sx-cp .footer-bottom a:hover,
body.sx-cp .footer-bottom a:focus-visible {
  color: var(--cp-accent) !important;
  text-decoration: underline;
}
body.sx-cp .footer-social a {
  background: var(--cp-surface);
  border-color: var(--cp-border-strong);
  color: var(--cp-text);
}
body.sx-cp .footer-social a:hover,
body.sx-cp .footer-social a:focus-visible {
  color: var(--cp-accent);
  border-color: rgba(0, 154, 242, 0.45);
}
body.sx-cp .sx-cookie-manage {
  background: var(--cp-surface);
  border-color: var(--cp-border-strong);
  color: var(--cp-text-2);
}
body.sx-cp .sx-cookie-manage:hover,
body.sx-cp .sx-cookie-manage:focus-visible {
  border-color: var(--cp-accent);
  color: var(--cp-accent);
}

/* Desktop mega dropdowns — control-plane dark tokens */
body.sx-cp .header_area .site-nav > .site-nav-item.submenu > .dropdown-menu.sx-mega {
  background: var(--cp-surface) !important;
  border: 1px solid var(--cp-border) !important;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.45) !important;
}
body.sx-cp .sx-mega__feature a {
  background: linear-gradient(180deg, rgba(0, 154, 242, 0.12), rgba(0, 154, 242, 0.03)) !important;
  border: 1px solid rgba(0, 154, 242, 0.28) !important;
}
body.sx-cp .sx-mega__feature a:hover,
body.sx-cp .sx-mega__feature a:focus-visible {
  border-color: rgba(0, 154, 242, 0.5) !important;
  background: rgba(0, 154, 242, 0.14) !important;
}
body.sx-cp .sx-mega__feature-eyebrow { color: var(--cp-accent); }
body.sx-cp .sx-mega__feature-title { color: var(--cp-text); }
body.sx-cp .sx-mega__feature-desc { color: var(--cp-text-2); }
body.sx-cp .sx-mega__label { color: var(--cp-text-3); }
body.sx-cp .sx-mega .sx-mega__group a,
body.sx-cp .sx-mega .sx-mega__links a {
  color: var(--cp-text) !important;
}
body.sx-cp .sx-mega .sx-mega__group a:hover,
body.sx-cp .sx-mega .sx-mega__group a:focus-visible,
body.sx-cp .sx-mega .sx-mega__links a:hover,
body.sx-cp .sx-mega .sx-mega__links a:focus-visible {
  background: rgba(0, 154, 242, 0.1) !important;
  color: var(--cp-accent) !important;
}
body.sx-cp .sx-lang-selector__menu {
  background: var(--cp-surface) !important;
  border-color: var(--cp-border) !important;
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.45) !important;
}
body.sx-cp .sx-lang-selector__menu a {
  color: var(--cp-text) !important;
}
body.sx-cp .sx-lang-selector__menu a:hover,
body.sx-cp .sx-lang-selector__menu a:focus-visible {
  background: rgba(0, 154, 242, 0.1) !important;
  color: var(--cp-accent) !important;
}

/* Footer semantic lists */
body.sx-cp .footer-links {
  list-style: none;
  margin: 0;
  padding: 0;
}
body.sx-cp .footer-links li { margin: 0; }
body.sx-cp .footer-col .footer-links a {
  display: inline-block;
  line-height: 1.65;
  padding: 3px 0;
}

/* Mobile shell */
@media (max-width: 991px) {
  body.sx-cp .navbar-brand img,
  body.sx-cp .navbar-brand .main_logo_img,
  body.sx-cp .navbar-brand .sticky_logo_img {
    height: 46px;
    max-height: 46px;
  }
  body.sx-cp .navbar-collapse.show {
    background: var(--cp-surface) !important;
    border-color: var(--cp-border) !important;
    box-shadow: 0 18px 46px rgba(0, 0, 0, 0.45);
  }
  body.sx-cp .header_area .site-nav > .site-nav-item {
    border-bottom-color: var(--cp-hairline) !important;
  }
  body.sx-cp .header_area .site-nav > .site-nav-login-mobile > .site-nav-login-link {
    border-color: var(--cp-border-strong) !important;
    border-radius: 10px !important;
    color: var(--cp-accent) !important;
  }
  body.sx-cp .header_area .site-nav > .site-nav-login-mobile > .site-nav-login-link:focus-visible {
    outline: 2px solid var(--cp-accent);
    outline-offset: 2px;
  }
  body.sx-cp .sx-nav-cta {
    display: inline-flex !important;
  }
  body.sx-cp .header_area .site-nav > .site-nav-item.submenu.show > .dropdown-menu.sx-mega {
    background: var(--cp-bg-2) !important;
    border-color: var(--cp-border) !important;
  }
  body.sx-cp .sx-mega__group + .sx-mega__group {
    border-top-color: var(--cp-hairline) !important;
  }
  body.sx-cp .sx-mega__details > summary.sx-mega__label {
    color: var(--cp-text-2);
  }
}

/* CP prose links — intentional, no legacy underline bleed */
body.sx-cp .cp-prose a,
body.sx-cp .cp-card p a,
body.sx-cp .cp-faq a,
body.sx-cp .cp-compare a {
  text-decoration: none;
}
body.sx-cp .cp-prose a:hover,
body.sx-cp .cp-card p a:hover,
body.sx-cp .cp-faq a:hover,
body.sx-cp .cp-compare a:hover {
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* CP interactive links — no legacy underline */
body.sx-cp section a.cp-btn,
body.sx-cp section a.cp-verb,
body.sx-cp section a.cp-sol,
body.sx-cp .cp-related a,
body.sx-cp .cp-textlink {
  text-decoration: none !important;
}

/* ==========================================================================
   MOTION + ACCESSIBILITY
   ========================================================================== */
.cp-reveal { opacity: 0; transform: translateY(16px); transition: opacity .6s ease, transform .6s ease; }
.cp-reveal.is-in { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  .cp-reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
  .cp-flow-dot, .cp-edge--active { animation: none !important; }
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 1024px) {
  body.sx-cp { --cp-pad: 20px; }
  .cp-hero__grid { grid-template-columns: 1fr; gap: 40px; }
  .cp-hero h1 { font-size: 48px; }
  .cp-verbs { grid-template-columns: repeat(2, 1fr); }
  .cp-ladder { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .cp-section { padding: 72px 0; }
  .cp-hero { padding: 132px 0 64px; }
  .cp-hero h1 { font-size: 38px; }
  .cp-h2 { font-size: 30px; }
  .cp-final h2 { font-size: 32px; }
  .cp-verbs, .cp-grid-3, .cp-grid-2, .cp-blast { grid-template-columns: 1fr; }
  .cp-ladder { grid-template-columns: 1fr; }
  .cp-tenants { grid-template-columns: repeat(4, 1fr); }
}
