/* =====================================================================
   Top Qube / Quantum Qube Marketing — site stylesheet
   Hybrid: dark premium hero + header + footer, light/white body.
   Electric blue for action, green pop for accents + proof.
   Geist fonts. Mirrors the quantum-qube-client-portal brand kit.
   ===================================================================== */

:root {
  /* Light body */
  --canvas:        #F5F7FA;   /* page background */
  --canvas-alt:    #FFFFFF;   /* alt band / cards */
  --card:          #FFFFFF;
  --ink:           #0B0F14;   /* primary text */
  --ink-muted:     #475569;
  --ink-faint:     #94A3B8;
  --line:          #E2E8F0;
  --line-strong:   #CBD5E1;

  /* Dark surfaces (hero, header, footer, panels) */
  --dark:          #0B0F14;
  --dark-soft:     #11161D;
  --on-dark:       #E6EDF3;
  --on-dark-muted: rgba(230,237,243,0.72);
  --on-dark-faint: rgba(230,237,243,0.50);
  --line-dark:     rgba(230,237,243,0.12);

  /* Blues */
  --blue:          #0000FF;   /* Quantum Blue — primary CTA */
  --blue-accent:   #1E88E5;
  --blue-light:    #5BB8FF;   /* on dark only */
  --blue-border:   rgba(0,0,255,0.62);  /* bold blue outline for pop cards */
  --blue-soft:     rgba(0,0,255,0.07);  /* blue ring */

  /* Green (pop accent + proof) */
  --green:         #22C55E;   /* pop on dark */
  --green-deep:    #16A34A;   /* legible on light */
  --green-soft:    rgba(34,197,94,0.12);
  --green-border:  rgba(34,197,94,0.40);
  --gold:          #E5B567;

  --glow-blue:     0 0 22px -2px rgba(0,0,255,0.55), 0 0 10px rgba(80,100,255,0.4);

  /* Deep-blue gradient (emphasis panels) */
  --grad: radial-gradient(circle at 85% 15%, rgba(150,160,255,0.22) 0%, rgba(150,160,255,0) 50%),
          radial-gradient(circle at 15% 90%, rgba(60,80,255,0.16) 0%, rgba(60,80,255,0) 50%),
          linear-gradient(160deg, #0000B3 0%, #160B81 50%, #07045A 100%);

  --font-sans: "Geist", "Inter", system-ui, -apple-system, sans-serif;
  --font-mono: "Geist Mono", ui-monospace, "SFMono-Regular", monospace;

  --wrap: 1180px;
  --r: 8px; --r-lg: 12px; --r-xl: 18px;
  --s-1: 8px;  --s-2: 16px;  --s-3: 24px;  --s-4: 32px;
  --s-5: 48px; --s-6: 64px;  --s-7: 96px;  --s-8: 128px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; font-family: var(--font-sans); font-size: 16px; line-height: 1.65;
  color: var(--ink); background: var(--canvas); -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
figure { margin: 0; }
a { color: inherit; text-decoration: none; }

h1, h2, h3, h4 { font-family: var(--font-sans); font-weight: 600; color: var(--ink); line-height: 1.1; letter-spacing: -0.02em; margin: 0 0 var(--s-3); }
h1 { font-size: clamp(36px, 5vw, 60px); }
h2 { font-size: clamp(28px, 3.6vw, 44px); }
h3 { font-size: clamp(19px, 2vw, 24px); letter-spacing: -0.01em; }
p { margin: 0 0 var(--s-3); }
b, strong { font-weight: 600; }

.wrap { max-width: var(--wrap); margin: 0 auto; padding: 0 24px; position: relative; z-index: 2; }
.section { padding: var(--s-7) 0; }
.section--alt { background: var(--canvas-alt); }
.center { text-align: center; }
.measure { max-width: 720px; }
.lead { font-size: clamp(17px, 1.5vw, 20px); color: var(--ink-muted); line-height: 1.6; }

/* Kicker (mono uppercase) — blue on light sections, green on dark (overridden below) */
.kicker { font-family: var(--font-mono); font-size: 12px; font-weight: 500; letter-spacing: 0.18em; text-transform: uppercase; color: var(--blue-accent); margin: 0 0 var(--s-2); display: inline-block; }

/* ---- Buttons ---- */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 9px; min-height: 52px; padding: 0 26px; font-family: var(--font-sans); font-size: 15px; font-weight: 600; border: 1.5px solid transparent; border-radius: var(--r); cursor: pointer; white-space: nowrap; transition: transform .16s ease, background-color .16s, border-color .16s, box-shadow .16s; }
.btn--primary { background: var(--blue); color: #fff; box-shadow: var(--glow-blue); }
.btn--primary:hover { transform: scale(1.02); }
.btn--ghost { background: transparent; color: var(--ink); border-color: var(--line-strong); }
.btn--ghost:hover { border-color: var(--blue-accent); color: var(--blue-accent); }
.hero .btn--ghost { color: #fff; border-color: rgba(255,255,255,0.45); }
.hero .btn--ghost:hover { color: #fff; border-color: #fff; background: rgba(255,255,255,0.08); }
.btn--lg { min-height: 58px; padding: 0 34px; font-size: 16px; }
.btn svg { width: 18px; height: 18px; }

/* =====================================================================
   HEADER (dark)
   ===================================================================== */
.site-header { position: sticky; top: 0; z-index: 50; background: rgba(11,15,20,0.85); backdrop-filter: saturate(140%) blur(10px); border-bottom: 1px solid var(--line-dark); }
.site-header__inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; min-height: 72px; }
.brand { flex: 0 0 auto; }
.brand img { height: 30px; width: 180px; max-width: none; }
.nav { display: flex; align-items: center; gap: 26px; }
.nav a { font-size: 14.5px; font-weight: 500; color: var(--on-dark-muted); transition: color .15s; }
.nav a:hover { color: var(--on-dark); }
.nav__cta { display: none; }
.has-dropdown { position: relative; }
.nav__trigger { display: inline-flex; align-items: center; gap: 5px; cursor: pointer; background: none; border: 0; font-family: var(--font-sans); font-size: 14.5px; font-weight: 500; color: var(--on-dark-muted); padding: 0; }
.nav__trigger:hover, .has-dropdown:hover .nav__trigger { color: var(--on-dark); }
.nav__trigger svg { width: 13px; height: 13px; transition: transform .2s; }
.has-dropdown:hover .nav__trigger svg { transform: rotate(180deg); }
.dropdown { position: absolute; top: calc(100% + 14px); left: 50%; transform: translateX(-50%) translateY(6px); min-width: 230px; background: var(--dark-soft); border: 1px solid var(--line-dark); border-radius: var(--r-lg); padding: 8px; box-shadow: 0 24px 60px rgba(0,0,20,0.6); opacity: 0; visibility: hidden; transition: opacity .16s, transform .16s; z-index: 60; }
.dropdown--wide { min-width: 460px; display: grid; grid-template-columns: 1fr 1fr; gap: 2px; }
.has-dropdown:hover .dropdown { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.dropdown::before { content: ""; position: absolute; top: -14px; left: 0; right: 0; height: 14px; }
.dropdown a { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: var(--r); font-size: 14px; font-weight: 500; color: var(--on-dark-muted); }
.dropdown a:hover { background: rgba(230,237,243,0.06); color: var(--on-dark); }
.dropdown a svg { width: 16px; height: 16px; color: var(--blue-light); flex: none; }
.dropdown__all { color: var(--blue-light) !important; font-weight: 600 !important; }
.header-cta { display: flex; align-items: center; gap: 18px; }
.nav-toggle { display: none; background: none; border: 0; font-size: 24px; color: var(--on-dark); cursor: pointer; }

/* =====================================================================
   HERO (dark, with scoped particles)
   ===================================================================== */
.hero { position: relative; overflow: hidden; background: var(--dark); color: var(--on-dark); padding: var(--s-6) 0 var(--s-7); }
.hero h1, .hero h2 { color: var(--on-dark); }
.hero__grid { display: grid; grid-template-columns: 1.02fr 0.98fr; grid-template-areas: "head form" "rest form"; column-gap: var(--s-6); row-gap: var(--s-3); align-items: start; }
.hero__head { grid-area: head; }
.hero__form { grid-area: form; align-self: start; }
.hero__rest { grid-area: rest; }
.hero__title { margin-bottom: var(--s-3); letter-spacing: -0.025em; }
.hero__title .hl { color: var(--green); text-shadow: 0 0 24px rgba(34,197,94,0.4); }
.hero .kicker { color: var(--green); text-shadow: 0 0 16px rgba(34,197,94,0.35); }
.hero__sub { font-size: clamp(16px,1.4vw,19px); color: var(--on-dark-muted); line-height: 1.6; max-width: 520px; margin: 0; }

/* particles (drifting blue motes) scoped to hero */
.particles { position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 1; }
@media (prefers-reduced-motion: no-preference) {
  .particle { position: absolute; width: 3px; border-radius: 50%; background: linear-gradient(to top, rgba(0,0,255,0) 0%, rgba(0,0,255,0.35) 35%, rgba(0,0,255,0.85) 80%, rgba(80,80,255,1) 100%); filter: blur(0.6px); box-shadow: 0 0 18px rgba(0,0,255,0.6); bottom: -160px; opacity: 0; }
  .particle-1 { left: 14%; height: 120px; animation: pd1 13s linear infinite; }
  .particle-2 { left: 40%; height: 95px;  width: 2px; animation: pd2 16s linear infinite; animation-delay: 3s; }
  .particle-3 { left: 88%; height: 140px; animation: pd3 12s linear infinite; animation-delay: 6s; }
  .particle-4 { left: 62%; height: 105px; width: 2px; animation: pd4 14s linear infinite; animation-delay: 2s; }
  .particle-5 { left: 26%; height: 130px; animation: pd5 15s linear infinite; animation-delay: 8s; }
  @keyframes pd1 { 0%{bottom:-160px;opacity:0;transform:translateX(0)} 12%{opacity:.5} 50%{transform:translateX(14px)} 85%{opacity:.35} 100%{bottom:110%;opacity:0;transform:translateX(24px)} }
  @keyframes pd2 { 0%{bottom:-160px;opacity:0;transform:translateX(0)} 12%{opacity:.45} 50%{transform:translateX(-12px)} 85%{opacity:.3} 100%{bottom:110%;opacity:0;transform:translateX(-22px)} }
  @keyframes pd3 { 0%{bottom:-160px;opacity:0;transform:translateX(0)} 12%{opacity:.45} 50%{transform:translateX(10px)} 85%{opacity:.35} 100%{bottom:110%;opacity:0;transform:translateX(18px)} }
  @keyframes pd4 { 0%{bottom:-160px;opacity:0;transform:translateX(0)} 12%{opacity:.5} 50%{transform:translateX(-8px)} 85%{opacity:.4} 100%{bottom:110%;opacity:0;transform:translateX(-16px)} }
  @keyframes pd5 { 0%{bottom:-160px;opacity:0;transform:translateX(0)} 12%{opacity:.45} 50%{transform:translateX(18px)} 85%{opacity:.35} 100%{bottom:110%;opacity:0;transform:translateX(28px)} }
}

/* =====================================================================
   OFFER FORM CARD — always WHITE, glowing blue ring on the dark hero
   ===================================================================== */
.qcard { position: relative; border-radius: var(--r-xl); padding: 26px; background: #fff; box-shadow: 0 30px 80px -28px rgba(0,0,40,0.7), 0 0 0 1px rgba(0,0,255,0.08); overflow: hidden; }
.qcard::after { content: ""; position: absolute; inset: 0; border-radius: inherit; padding: 2.5px; background: conic-gradient(from var(--ring-angle, 0deg), rgba(0,0,180,0.45) 0deg, #0000FF 70deg, rgba(0,0,140,0.5) 140deg, rgba(0,0,180,0.45) 360deg); -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0); -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none; }
@property --ring-angle { syntax: '<angle>'; initial-value: 0deg; inherits: false; }
@media (prefers-reduced-motion: no-preference) { .qcard::after { animation: ring 7s linear infinite; } }
@keyframes ring { to { --ring-angle: 360deg; } }

.qf__value h2 { font-size: 22px; color: var(--ink); margin: 0 0 12px; letter-spacing: -0.01em; }
.qf__checks { list-style: none; margin: 0 0 18px; padding: 0; }
.qf__checks li { display: flex; align-items: flex-start; gap: 9px; font-size: 14.5px; color: var(--ink-muted); margin-bottom: 8px; }
.qf__checks svg { width: 18px; height: 18px; color: var(--blue-accent); flex: none; margin-top: 2px; }
.qf__step-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-faint); }
.qf__bar { height: 4px; border-radius: 100px; background: var(--line); margin: 8px 0 18px; overflow: hidden; }
.qf__bar-fill { height: 100%; width: 20%; background: var(--blue); transition: width .3s ease; }
.qf__step { display: none; }
.qf__step.is-active { display: block; animation: qfin .25s ease; }
@keyframes qfin { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.qf__q { font-size: 20px; font-weight: 600; color: var(--ink); margin: 0 0 14px; letter-spacing: -0.01em; }
.qf__field { margin-bottom: 12px; }
.qf__field label { display: block; font-size: 12px; font-weight: 600; color: var(--ink); margin-bottom: 6px; }
.qf__opt { font-weight: 400; color: var(--ink-faint); }
.qf__field input { width: 100%; height: 50px; border-radius: var(--r); border: 1px solid var(--line-strong); background: #fff; color: var(--ink); padding: 0 14px; font-family: var(--font-sans); font-size: 16px; }
.qf__field input::placeholder { color: var(--ink-faint); }
.qf__field input:focus { outline: none; border-color: var(--blue-accent); box-shadow: 0 0 0 3px rgba(30,136,229,0.18); }
.qf__tiles { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 12px; }
.qf__tile { text-align: left; background: #fff; border: 1px solid var(--line-strong); border-radius: var(--r); padding: 13px 14px; color: var(--ink); font-size: 14.5px; font-weight: 500; cursor: pointer; transition: border-color .15s, background-color .15s; }
.qf__tile:hover { border-color: var(--blue-accent); background: #F0F6FF; }
.qf__continue { width: 100%; margin-top: 4px; }
.qf__back { background: none; border: 0; color: var(--ink-faint); font-size: 13px; cursor: pointer; margin-top: 12px; font-family: var(--font-sans); }
.qf__back:hover { color: var(--ink); }
.qf__fine { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--ink-faint); margin: 12px 0 0; }
.qf__fine svg { width: 14px; height: 14px; flex: none; }
.qf__done { text-align: center; padding: 10px 0; }
.qf__check { width: 54px; height: 54px; color: var(--blue); margin: 0 auto 12px; }

/* =====================================================================
   STAT STRIP (light)
   ===================================================================== */
.stat-strip { background: var(--canvas-alt); border-bottom: 1px solid var(--line); }
.stat-strip__inner { display: grid; grid-template-columns: repeat(4, 1fr); }
.stat { padding: 30px 24px; text-align: center; border-right: 1px solid var(--line); }
.stat:last-child { border-right: 0; }
.stat b { display: block; font-family: var(--font-mono); font-size: clamp(26px,3vw,38px); font-weight: 600; color: var(--ink); letter-spacing: -0.02em; }
.stat span { font-size: 13px; color: var(--ink-faint); }

/* =====================================================================
   CARDS / GRIDS (light)
   ===================================================================== */
.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--s-3); }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-4); align-items: center; }
.proof-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-3); }

.card { background: var(--card); border: 2px solid var(--blue-border); border-radius: var(--r-lg); padding: 24px; box-shadow: 0 0 0 4px var(--blue-soft), 0 16px 40px -30px rgba(0,0,90,0.35); transition: border-color .18s, box-shadow .18s, transform .18s; }
a.card:hover { border-color: var(--blue); box-shadow: 0 0 0 4px rgba(0,0,255,0.10), 0 24px 50px -28px rgba(0,0,90,0.5); transform: translateY(-2px); }
.card__icon { width: 42px; height: 42px; border-radius: 10px; display: grid; place-items: center; background: rgba(0,0,255,0.06); border: 1px solid rgba(0,0,255,0.16); margin-bottom: 14px; }
.card__icon svg { width: 22px; height: 22px; color: var(--blue); }
.card h3 { margin: 0 0 6px; }
.card p { margin: 0; font-size: 14.5px; color: var(--ink-muted); }
.card__link { display: inline-flex; align-items: center; gap: 6px; margin-top: 14px; font-size: 13px; font-weight: 600; color: var(--blue-accent); }
.card--dark { background: var(--grad); border-color: transparent; box-shadow: 0 40px 100px -44px rgba(0,0,90,0.7); color: #fff; }
.card--dark h3 { color: #fff; }
.card--dark p { color: rgba(255,255,255,0.85); }
.card--dark .card__icon { background: rgba(255,255,255,0.12); border-color: rgba(255,255,255,0.25); }
.card--dark .card__icon svg { color: #fff; }
.card--dark .card__link { color: #fff; }

/* Industry chips */
.ind-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; }
.ind { display: flex; align-items: center; gap: 10px; background: var(--card); border: 2px solid var(--blue-border); border-radius: var(--r); padding: 16px 18px; font-size: 14.5px; font-weight: 500; color: var(--ink); box-shadow: 0 0 0 3px var(--blue-soft), 0 12px 28px -20px rgba(0,0,90,0.45); transition: border-color .15s, box-shadow .15s, transform .15s; }
.ind:hover { border-color: var(--blue); box-shadow: 0 0 0 3px rgba(0,0,255,0.12), 0 18px 36px -20px rgba(0,0,90,0.6); transform: translateY(-2px); }
.ind svg { width: 18px; height: 18px; color: var(--blue-accent); flex: none; }

/* =====================================================================
   PROOF / RESULT CARDS (light, green accent)
   ===================================================================== */
.proof { background: var(--card); border: 1px solid var(--green-border); border-radius: var(--r-lg); padding: 22px 24px; box-shadow: 0 0 0 4px var(--green-soft), 0 18px 44px -28px rgba(11,40,20,0.35); }
.proof__head { display: flex; align-items: center; gap: 9px; margin-bottom: 12px; }
.proof__badge { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--green-deep); font-weight: 500; display: inline-flex; align-items: center; gap: 6px; }
.proof__badge svg { width: 15px; height: 15px; }
.proof__metric { font-family: var(--font-mono); font-size: clamp(22px,2.4vw,30px); font-weight: 600; color: var(--ink); letter-spacing: -0.02em; margin: 0 0 6px; }
.proof__metric .up { color: var(--green-deep); }
.proof__text { font-size: 14.5px; color: var(--ink-muted); margin: 0 0 12px; line-height: 1.55; }
.proof__who { font-size: 13px; color: var(--ink-faint); }
.proof__who b { color: var(--ink); }

.proof-imgs { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin-top: var(--s-5); }
.proof-imgs img { border-radius: var(--r-lg); border: 1px solid var(--line); aspect-ratio: 3/4; object-fit: cover; }

/* big result band + final CTA panels (dark gradient) */
.resultband, .final-cta__panel { background: var(--grad); border-radius: var(--r-xl); padding: clamp(32px,5vw,60px) 24px; text-align: center; box-shadow: 0 40px 100px -44px rgba(0,0,90,0.7); color: #fff; }
.resultband .kicker, .final-cta__panel .kicker { color: var(--green); text-shadow: 0 0 14px rgba(34,197,94,0.3); }
.resultband h2, .final-cta__panel h2 { color: #fff; }
.resultband .big { font-family: var(--font-mono); font-size: clamp(40px,7vw,80px); font-weight: 600; color: #fff; letter-spacing: -0.03em; line-height: 1; margin: 8px 0; text-shadow: 0 0 40px rgba(120,140,255,0.5); }
.resultband p, .final-cta__panel p { color: rgba(255,255,255,0.85); }
.final-cta { text-align: center; }
.final-cta__panel p { max-width: 560px; margin-left: auto; margin-right: auto; }
.final-cta .btn--primary { background: #fff; color: var(--blue); box-shadow: 0 0 30px rgba(255,255,255,0.25); }

/* =====================================================================
   STEPS / FIT / FAQ (light)
   ===================================================================== */
.steps { display: grid; grid-template-columns: repeat(4,1fr); gap: var(--s-3); }
.step { background: var(--card); border: 2px solid var(--blue-border); border-radius: var(--r-lg); padding: 24px; box-shadow: 0 0 0 4px var(--blue-soft), 0 16px 40px -30px rgba(0,0,90,0.35); }
.step__num { font-family: var(--font-mono); font-size: 13px; color: var(--blue); letter-spacing: 0.1em; margin-bottom: 12px; }
.step h3 { font-size: 18px; margin: 0 0 6px; }
.step p { margin: 0; font-size: 14px; color: var(--ink-muted); }

.fit-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-4); }
.fit { background: var(--card); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 26px; }
.fit h3 { display: flex; align-items: center; gap: 10px; }
.fit ul { list-style: none; margin: 14px 0 0; padding: 0; }
.fit li { display: flex; gap: 10px; font-size: 14.5px; color: var(--ink-muted); margin-bottom: 12px; }
.fit li svg { width: 18px; height: 18px; flex: none; margin-top: 3px; }
.fit--yes li svg { color: var(--green-deep); }
.fit--no li svg { color: var(--ink-faint); }

.faq__list { max-width: 760px; margin: var(--s-5) auto 0; }
.faq__item { border-bottom: 1px solid var(--line); }
.faq__q { width: 100%; text-align: left; background: none; border: 0; cursor: pointer; padding: 22px 40px 22px 0; position: relative; font-family: var(--font-sans); font-size: 18px; font-weight: 600; color: var(--ink); }
.faq__q::after { content: "+"; position: absolute; right: 4px; top: 19px; font-size: 24px; color: var(--blue-accent); font-weight: 400; }
.faq__item[open] .faq__q::after { content: "\2212"; }
.faq__a { padding: 0 0 22px; color: var(--ink-muted); font-size: 15px; max-width: 680px; }

.section-cta { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; margin-top: var(--s-5); }

/* =====================================================================
   FOOTER (dark)
   ===================================================================== */
.footer { background: var(--dark); color: var(--on-dark-muted); padding: var(--s-6) 0 var(--s-4); font-size: 14px; border-top: 1px solid var(--line-dark); }
.footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: var(--s-5) var(--s-4); }
.footer a { color: var(--on-dark-muted); }
.footer a:hover { color: var(--blue-light); }
.footer__brand img { height: 28px; width: 168px; max-width: none; margin-bottom: 14px; }
.footer__brand p { color: var(--on-dark-faint); max-width: 320px; margin: 0; font-size: 14px; }
.footer h4 { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--on-dark-faint); margin: 0 0 14px; font-weight: 500; }
.footer ul { list-style: none; margin: 0; padding: 0; }
.footer li { margin-bottom: 10px; }
.footer__legal { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 8px; margin-top: var(--s-5); padding-top: var(--s-3); border-top: 1px solid var(--line-dark); font-size: 12.5px; color: var(--on-dark-faint); font-family: var(--font-mono); }

/* =====================================================================
   FLOATING MOBILE CTA (no phone)
   ===================================================================== */
.float-cta { position: fixed; bottom: 0; left: 0; right: 0; z-index: 65; display: none; align-items: center; justify-content: space-between; gap: 12px; background: rgba(11,15,20,0.97); border-top: 1px solid var(--line-dark); padding: max(12px, env(safe-area-inset-bottom)) 16px 12px; backdrop-filter: blur(10px); transition: transform .28s ease, opacity .22s; }
.float-cta--hidden { transform: translateY(110%); opacity: 0; }
.float-cta__label { font-family: var(--font-mono); font-size: 12px; color: var(--on-dark-muted); }
.float-cta__cta { flex: 1; justify-content: center; background: var(--blue); color: #fff; box-shadow: var(--glow-blue); border-radius: var(--r); padding: 15px 18px; font-size: 15px; font-weight: 600; display: inline-flex; align-items: center; gap: 8px; }

/* breadcrumb (inner pages) */
.crumbs { border-bottom: 1px solid var(--line); background: var(--canvas-alt); }
.crumbs .wrap { padding-top: 14px; padding-bottom: 14px; font-family: var(--font-mono); font-size: 12px; color: var(--ink-faint); }
.crumbs a:hover { color: var(--blue-accent); }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 900px) {
  .hero__grid { grid-template-columns: 1fr; grid-template-areas: "head" "form" "rest"; }
  .grid-3, .steps, .ind-grid, .proof-imgs { grid-template-columns: 1fr 1fr; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .stat-strip__inner { grid-template-columns: 1fr 1fr; }
  .stat:nth-child(2) { border-right: 0; }
  .stat { border-bottom: 1px solid var(--line); }
}
@media (max-width: 720px) {
  .nav { display: none; position: absolute; top: 72px; left: 0; right: 0; flex-direction: column; align-items: stretch; gap: 0; background: var(--dark-soft); border-bottom: 1px solid var(--line-dark); padding: 8px 0 16px; }
  .nav.nav--open { display: flex; }
  .nav > a, .nav .has-dropdown { padding: 14px 24px; border-top: 1px solid var(--line-dark); }
  .nav__trigger { width: 100%; justify-content: space-between; }
  .dropdown, .dropdown--wide { position: static; transform: none; opacity: 1; visibility: visible; display: block; box-shadow: none; border: 0; background: transparent; padding: 8px 0 0; min-width: 0; }
  .nav__cta { display: flex !important; margin: 16px 24px 0; }
  .nav-toggle { display: block; }
  .header-cta .btn { display: none; }
  .grid-3, .steps, .ind-grid, .grid-2, .fit-grid, .proof-imgs, .proof-grid { grid-template-columns: 1fr; }
  .stat-strip__inner { grid-template-columns: 1fr 1fr; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .float-cta { display: flex; }
  .section { padding: var(--s-6) 0; }
  .hero__sub { margin-top: var(--s-3); }
  /* Long CTA copy must wrap inside its panel on narrow screens, not overflow the rounded corners */
  .btn { white-space: normal; max-width: 100%; text-align: center; }
}
@media (max-width: 460px) { .footer__grid { grid-template-columns: 1fr; } }

/* Blog featured covers (generated SVG) */
.card__img{width:100%;aspect-ratio:1200 / 630;height:auto;object-fit:cover;border-radius:12px;margin-bottom:16px;display:block;background:#0B0F14;}
.article-cover{width:100%;max-width:760px;aspect-ratio:1200 / 630;height:auto;object-fit:cover;border-radius:16px;margin:26px auto 0;display:block;border:1px solid rgba(255,255,255,0.10);}
