/* ============================================================
   TrendTrader Pro — design system
   Deep-space navy + trend-green/cyan gradient identity
   ============================================================ */

:root {
  --bg: #04070f;
  --bg-soft: #070d1a;
  --surface: #0a1322;
  --card: #0c1628;
  --card-2: #101c33;
  --line: rgba(148, 163, 184, 0.13);
  --line-strong: rgba(148, 163, 184, 0.25);

  --text: #e8eef8;
  --muted: #94a3b8;
  --faint: #5b6b84;

  --accent: #34d399;
  --accent-2: #22d3ee;
  --grad: linear-gradient(92deg, #34d399 0%, #22d3ee 100%);
  --grad-soft: linear-gradient(92deg, rgba(52, 211, 153, .14), rgba(34, 211, 238, .14));

  --up: #34d399;
  --down: #fb7185;

  --font-display: "Sora", sans-serif;
  --font-body: "Instrument Sans", sans-serif;
  --font-mono: "JetBrains Mono", monospace;

  --radius: 18px;
  --radius-lg: 26px;
  --maxw: 1200px;

  --shadow-card: 0 24px 70px -28px rgba(0, 0, 0, 0.75);
  --shadow-glow: 0 0 60px -10px rgba(34, 211, 238, 0.35);
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;   /* stop iOS bumping text size on rotate */
  text-size-adjust: 100%;
}

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  /* horizontal overflow is prevented structurally (no element exceeds the viewport).
     Keep `hidden` (not `clip`): clip on the root breaks position:sticky + backdrop-filter on iOS Safari. */
  overflow-x: hidden;
}

/* subtle grain over everything */
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
  opacity: 0.5;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3CfeComponentTransfer%3E%3CfeFuncA type='linear' slope='0.035'/%3E%3C/feComponentTransfer%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E");
}

h1, h2, h3 { font-family: var(--font-display); letter-spacing: -0.02em; }

h1, h2 {
  font-size: clamp(2rem, 4.4vw, 3.4rem);
  font-weight: 700;
  line-height: 1.1;
}

a { color: inherit; text-decoration: none; }
button { font-family: inherit; color: inherit; background: none; border: none; cursor: pointer; }
.mono { font-family: var(--font-mono); }

.grad-text {
  background: var(--grad);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

/* ============ Buttons ============ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 0.95rem;
  padding: 13px 26px;
  border-radius: 999px;
  transition: transform 0.25s cubic-bezier(.2,.9,.3,1.4), box-shadow 0.25s, background 0.25s, color 0.25s, border-color .25s;
  white-space: nowrap;
}
.btn__arrow { transition: transform 0.25s; }
.btn:hover .btn__arrow { transform: translateX(4px); }

.btn--solid {
  background: #f3f7fc;
  color: #06101f;
}
.btn--solid:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 34px -8px rgba(240, 248, 255, 0.45);
}

.btn--ghost {
  background: rgba(148, 163, 184, 0.1);
  border: 1px solid var(--line);
}
.btn--ghost:hover { background: rgba(148, 163, 184, 0.18); }

.btn--outline {
  border: 1px solid var(--line-strong);
  background: rgba(10, 19, 34, 0.5);
}
.btn--outline:hover {
  border-color: var(--accent-2);
  box-shadow: 0 0 30px -8px rgba(34, 211, 238, 0.5);
  transform: translateY(-2px);
}

.btn--lg { padding: 17px 36px; font-size: 1.05rem; }
.btn--block { justify-content: center; width: 100%; }

/* Non-clickable CTA (e.g. "Coming soon" for a plan not yet purchasable).
   pointer-events:none blocks clicks; no href is set on the element. */
.btn--disabled {
  background: rgba(148, 163, 184, 0.12);
  color: var(--muted);
  border: 1px solid var(--line);
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
}

/* ============ Countdown ============ */
.countdown { display: flex; align-items: center; gap: 8px; }
.countdown__unit { display: flex; flex-direction: column; align-items: center; min-width: 34px; }
.countdown__num {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 1.05rem;
  color: #fff;
  font-variant-numeric: tabular-nums;
}
.countdown__label {
  font-size: 0.58rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}
.countdown__sep { color: var(--faint); margin-top: -12px; }

.countdown--big { justify-content: center; gap: 14px; margin: 26px 0 8px; }
.countdown--big .countdown__unit {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 14px 8px 10px;
  min-width: 86px;
}
.countdown--big .countdown__num { font-size: 2.4rem; line-height: 1; }
.countdown--big .countdown__label { margin-top: 6px; font-size: 0.68rem; }
.countdown--big .countdown__sep { font-size: 1.6rem; margin-top: 0; }

/* ============ Nav ============ */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  /* frosted glass — stays see-through with a strong blur (LuxAlgo-style) */
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  background: rgba(6, 10, 20, 0.55);
  border-bottom: 1px solid transparent;
  transition: border-color 0.3s, background 0.3s, box-shadow 0.3s;
}
.nav.is-scrolled {
  border-bottom-color: var(--line);
  background: rgba(6, 10, 20, 0.68);
  box-shadow: 0 8px 30px -18px rgba(0, 0, 0, 0.8);
}
/* Fallback for browsers without backdrop-filter: use a near-opaque bg so text stays legible */
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .nav { background: rgba(4, 7, 15, 0.92); }
  .nav.is-scrolled { background: rgba(4, 7, 15, 0.96); }
}

.nav__inner {
  max-width: 2200px;
  margin: 0 auto;
  padding: 18px 44px;
  display: flex;
  align-items: center;
  gap: 0;
}

.brand { display: inline-flex; align-items: center; }
.brand__img { height: 36px; width: auto; display: block; }
.brand__img--footer { height: 34px; }

.nav__links { display: flex; align-items: center; gap: 34px; margin-left: auto; }
.nav__links a {
  font-size: 1rem;
  font-weight: 500;
  color: #c7d2e1;
  transition: color 0.2s;
  position: relative;
}
.nav__links a:hover { color: var(--text); }
.nav__links a::after {
  content: "";
  position: absolute;
  left: 0; right: 100%;
  bottom: -6px;
  height: 2px;
  background: var(--grad);
  transition: right 0.3s;
}
.nav__links a:hover::after { right: 0; }

.nav__actions { display: flex; align-items: center; gap: 10px; margin-left: 30px; }
.nav__actions .btn { font-size: 0.95rem; padding: 11px 24px; }

.nav__burger { display: none; flex-direction: column; gap: 5px; padding: 8px; }
.nav__burger span { width: 22px; height: 2px; background: var(--text); transition: transform .3s, opacity .3s; }
.nav__burger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__burger.is-open span:nth-child(2) { opacity: 0; }
.nav__burger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.nav__mobile {
  display: none;
  flex-direction: column;
  gap: 0;
  padding: 6px 20px 22px;
  background: rgba(6, 10, 20, 0.92);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  border-top: 1px solid var(--line);
}
/* :not(.btn) so the CTA buttons keep their own colors/shape (otherwise this
   would override .btn--solid's dark text → invisible white-on-white "Sign Up") */
.nav__mobile a:not(.btn) {
  padding: 15px 2px;
  color: var(--text);
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.05rem;
  border-bottom: 1px solid var(--line);
  transition: color 0.2s;
}
.nav__mobile a:not(.btn):active { color: var(--accent-2); }
/* full-width, equal CTAs (was a loose flex row that squished them into ovals) */
.nav__mobile-cta { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 20px; }
.nav__mobile-cta .btn { width: 100%; justify-content: center; padding: 14px 18px; }
.nav__mobile.is-open { display: flex; }

/* ============ Hero ============ */
.hero {
  position: relative;
  padding: 110px 24px 0;
  text-align: center;
  overflow: hidden;
}
.hero__glow {
  position: absolute;
  inset: -20% -10% auto;
  height: 900px;
  background:
    radial-gradient(720px 480px at 50% 18%, rgba(34, 211, 238, 0.16), transparent 65%),
    radial-gradient(900px 600px at 64% 8%, rgba(52, 211, 153, 0.1), transparent 60%),
    radial-gradient(600px 500px at 36% 4%, rgba(59, 130, 246, 0.12), transparent 60%);
  pointer-events: none;
}
.hero__stars {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  opacity: 0.8;
}

.hero__copy { position: relative; max-width: 880px; margin: 0 auto; }

.hero__title {
  font-size: clamp(2.1rem, 7.4vw, 5.4rem);
  font-weight: 800;
  line-height: 1.04;
  letter-spacing: -0.03em;
}

.hero__sub {
  max-width: 620px;
  margin: 28px auto 0;
  font-size: clamp(1.05rem, 1.6vw, 1.25rem);
  color: var(--muted);
}

.hero__cta { margin-top: 38px; }
.hero__note { margin-top: 18px; font-size: 0.85rem; color: var(--faint); }

/* --- Hero product terminal --- */
.hero__product {
  position: relative;
  max-width: 1100px;
  margin: 80px auto 0;
}
.hero__product-glow {
  position: absolute;
  inset: 10% -6% -10%;
  background: radial-gradient(60% 60% at 50% 40%, rgba(34, 211, 238, 0.14), transparent 70%);
  filter: blur(30px);
  z-index: -1;
}

.terminal {
  background: linear-gradient(180deg, rgba(16, 28, 51, 0.9), rgba(8, 14, 26, 0.96));
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card), inset 0 1px 0 rgba(255, 255, 255, 0.06);
  overflow: hidden;
  text-align: left;
}

.terminal__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  border-bottom: 1px solid var(--line);
  background: rgba(10, 19, 34, 0.6);
}
.terminal__id { display: flex; align-items: center; gap: 12px; }
.terminal__logo { height: 20px; width: auto; }
.terminal__pair { font-weight: 700; font-size: 0.95rem; }
.terminal__tf {
  font-size: 0.7rem;
  padding: 3px 8px;
  border-radius: 6px;
  background: rgba(148, 163, 184, 0.12);
  color: var(--muted);
}
.terminal__status {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  color: var(--accent);
}
.pulse-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 0 rgba(52, 211, 153, 0.6);
  animation: pulse 2s infinite;
}
@keyframes pulse {
  0% { box-shadow: 0 0 0 0 rgba(52, 211, 153, 0.55); }
  70% { box-shadow: 0 0 0 9px rgba(52, 211, 153, 0); }
  100% { box-shadow: 0 0 0 0 rgba(52, 211, 153, 0); }
}

.terminal__body {
  display: grid;
  grid-template-columns: 230px 1fr 210px;
  min-height: 420px;
}

.terminal__panel { padding: 18px 16px; }
.terminal__panel--left { border-right: 1px solid var(--line); }
.terminal__panel--right { border-left: 1px solid var(--line); }

.panel__title {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--faint);
  margin-bottom: 14px;
}

.signal-feed { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.signal-feed__item {
  background: rgba(148, 163, 184, 0.06);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 10px 12px;
  animation: slideIn 0.5s cubic-bezier(.2,.9,.3,1.2) both;
}
@keyframes slideIn {
  from { opacity: 0; transform: translateX(-14px); }
  to { opacity: 1; transform: none; }
}
.signal-feed__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 0.78rem;
}
.signal-feed__sym { font-weight: 700; }
.signal-feed__side { font-size: 0.66rem; font-weight: 700; padding: 2px 8px; border-radius: 5px; letter-spacing: .08em; }
.signal-feed__side.buy { color: #052e1f; background: var(--up); }
.signal-feed__side.sell { color: #4a0a18; background: var(--down); }
.signal-feed__conf {
  margin-top: 8px;
  height: 4px;
  border-radius: 3px;
  background: rgba(148, 163, 184, 0.15);
  overflow: hidden;
}
.signal-feed__conf i {
  display: block;
  height: 100%;
  border-radius: 3px;
  background: var(--grad);
}
.signal-feed__meta {
  display: flex;
  justify-content: space-between;
  margin-top: 6px;
  font-family: var(--font-mono);
  font-size: 0.62rem;
  color: var(--faint);
}

.terminal__chart { position: relative; }
.terminal__chart canvas { display: block; width: 100%; height: 100%; }

.chart__badge {
  position: absolute;
  top: 14px;
  left: 14px;
  font-size: 0.64rem;
  letter-spacing: 0.18em;
  color: var(--accent-2);
  background: rgba(34, 211, 238, 0.08);
  border: 1px solid rgba(34, 211, 238, 0.3);
  border-radius: 8px;
  padding: 6px 10px;
}
.dots i { animation: blink 1.4s infinite; font-style: normal; }
.dots i:nth-child(2) { animation-delay: 0.2s; }
.dots i:nth-child(3) { animation-delay: 0.4s; }
@keyframes blink { 0%, 60%, 100% { opacity: 0.2; } 30% { opacity: 1; } }

.watchlist { list-style: none; display: flex; flex-direction: column; }
.watchlist__item {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 9px 4px;
  border-bottom: 1px dashed rgba(148, 163, 184, 0.1);
  font-family: var(--font-mono);
  font-size: 0.78rem;
}
.watchlist__sym { color: var(--text); font-weight: 500; }
.watchlist__chg { font-size: 0.72rem; font-variant-numeric: tabular-nums; }
.watchlist__chg.up { color: var(--up); }
.watchlist__chg.down { color: var(--down); }

/* --- Ticker tape --- */
.tape {
  margin-top: 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: rgba(7, 13, 26, 0.8);
  overflow: hidden;
  padding: 12px 0;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.tape__track {
  display: flex;
  gap: 44px;
  width: max-content;
  animation: tape 42s linear infinite;
}
@keyframes tape { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.tape__item {
  display: inline-flex;
  align-items: baseline;
  gap: 9px;
  font-family: var(--font-mono);
  font-size: 0.8rem;
  white-space: nowrap;
}
.tape__sym { color: var(--muted); }
.tape__price { color: var(--text); font-variant-numeric: tabular-nums; }
.tape__chg.up { color: var(--up); }
.tape__chg.down { color: var(--down); }

/* ============ Logos ============ */
.logos { padding: 70px 24px 30px; text-align: center; }
.logos__label {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--faint);
  margin-bottom: 30px;
}
.logos__row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 22px 54px;
  max-width: 1000px;
  margin: 0 auto;
}
.logos__item {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.15rem;
  color: rgba(148, 163, 184, 0.45);
  letter-spacing: 0.01em;
  transition: color 0.3s;
}
.logos__item:hover { color: rgba(232, 238, 248, 0.85); }

/* ============ Feature sections ============ */
.feature { padding: 60px 24px; }
.feature__card {
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 60px;
  align-items: center;
  background:
    radial-gradient(700px 360px at 12% 0%, rgba(34, 211, 238, 0.07), transparent 60%),
    linear-gradient(180deg, var(--card), var(--surface));
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 64px;
  box-shadow: var(--shadow-card);
  position: relative;
  overflow: hidden;
}
.feature--flip .feature__card {
  grid-template-columns: 1fr 1.1fr;
  background:
    radial-gradient(700px 360px at 88% 100%, rgba(52, 211, 153, 0.07), transparent 60%),
    linear-gradient(180deg, var(--card), var(--surface));
}
.feature--flip .feature__media { order: 2; }
.feature--flip .feature__copy { order: 1; }

.eyebrow {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.1rem;
  margin-bottom: 14px;
}
.feature__copy h2 { margin-bottom: 22px; }
.feature__desc { color: var(--muted); font-size: 1.08rem; margin-bottom: 32px; max-width: 460px; }

.feature__card--wide {
  grid-template-columns: 1fr 1.1fr;
  background:
    radial-gradient(700px 400px at 80% 0%, rgba(59, 130, 246, 0.09), transparent 60%),
    linear-gradient(180deg, var(--card), var(--surface));
}
.feature__copy--center { align-self: center; }
.feature__media--stack {
  display: flex;
  flex-direction: column;
  gap: 16px;
  justify-content: center;
}

/* --- mock chart frames --- */
.mock {
  position: relative;
  background: rgba(5, 10, 19, 0.7);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}
.mock--trend { aspect-ratio: 16 / 11; }
.mock__chrome { position: absolute; top: 12px; left: 12px; z-index: 3; }
.mock__tag {
  font-size: 0.62rem;
  letter-spacing: 0.16em;
  color: var(--accent-2);
  background: rgba(8, 14, 26, 0.85);
  border: 1px solid rgba(34, 211, 238, 0.35);
  border-radius: 8px;
  padding: 6px 10px;
}
.mock__canvas { position: absolute; inset: 0; width: 100%; height: 100%; }
.mock__overlay-card {
  position: absolute;
  bottom: 16px;
  right: 16px;
  z-index: 3;
  display: flex;
  align-items: center;
  gap: 12px;
  background: rgba(10, 19, 34, 0.92);
  border: 1px solid var(--line-strong);
  border-radius: 14px;
  padding: 12px 16px;
  backdrop-filter: blur(8px);
}
.mock__check {
  width: 34px; height: 34px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(52, 211, 153, 0.15);
  color: var(--up);
  font-weight: 700;
}
.mock__overlay-title { font-weight: 600; font-size: 0.92rem; }
.mock__overlay-sub { font-size: 0.68rem; color: var(--faint); margin-top: 2px; }

/* --- AI chat mock --- */
.mock--signals { padding: 26px; }
.ai-chat { display: flex; flex-direction: column; gap: 16px; }
.ai-chat__msg { display: flex; gap: 12px; }
.ai-chat__msg--user { justify-content: flex-end; }
.ai-chat__avatar {
  flex: 0 0 36px;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, #0b1d33, #061222);
  border: 1px solid var(--line-strong);
  display: grid;
  place-items: center;
}
.ai-chat__avatar svg { width: 20px; height: 20px; }
.ai-chat__avatar img { height: 17px; width: auto; }
.ai-chat__bubble {
  background: rgba(34, 211, 238, 0.07);
  border: 1px solid rgba(34, 211, 238, 0.22);
  border-radius: 4px 16px 16px 16px;
  padding: 13px 16px;
  font-size: 0.92rem;
  max-width: 85%;
}
.ai-chat__bubble--user {
  background: rgba(148, 163, 184, 0.09);
  border: 1px solid var(--line);
  border-radius: 16px 4px 16px 16px;
}
.ai-chat__name {
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--accent-2);
  margin-bottom: 6px;
}

.stat-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-top: 6px;
  background: rgba(5, 10, 19, 0.8);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 14px;
}
.stat-strip__item { display: flex; flex-direction: column; gap: 4px; }
.stat-strip__label { font-size: 0.56rem; letter-spacing: 0.12em; color: var(--faint); }
.stat-strip__val { font-size: 0.92rem; font-weight: 700; }
.stat-strip__val.up { color: var(--up); }
.stat-strip__val.down { color: var(--down); }

/* --- alert cards --- */
.alert-card {
  display: flex;
  align-items: center;
  gap: 16px;
  background: linear-gradient(180deg, rgba(16, 28, 51, 0.85), rgba(10, 19, 34, 0.9));
  border: 1px solid var(--line-strong);
  border-radius: 16px;
  padding: 18px 20px;
  box-shadow: var(--shadow-card);
  transition: transform .3s, border-color .3s;
}
.alert-card:hover { transform: translateY(-3px) scale(1.01); }
.alert-card--buy:hover { border-color: rgba(52, 211, 153, .5); }
.alert-card--sell:hover { border-color: rgba(251, 113, 133, .5); }
.alert-card--dim { opacity: 0.65; }
.alert-card__icon {
  width: 44px; height: 44px;
  flex: 0 0 44px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  font-size: 1.3rem;
  font-weight: 700;
}
.alert-card__icon.up { background: rgba(52, 211, 153, 0.14); color: var(--up); }
.alert-card__icon.down { background: rgba(251, 113, 133, 0.14); color: var(--down); }
.alert-card__body { flex: 1; }
.alert-card__title { font-weight: 600; font-size: 0.98rem; }
.alert-card__title .mono { color: var(--faint); font-size: .8rem; }
.alert-card__sub { font-size: 0.72rem; color: var(--faint); margin-top: 3px; }
.alert-card__time { font-size: 0.72rem; color: var(--faint); }

/* ============ Markets ============ */
.markets { padding: 90px 24px 40px; }
.markets__head { max-width: 760px; margin: 0 auto 50px; text-align: center; }
.markets__sub { color: var(--muted); margin-top: 18px; font-size: 1.08rem; }

.markets__grid {
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.market-card {
  background: linear-gradient(180deg, var(--card), var(--surface));
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: transform .3s, border-color .3s, box-shadow .3s;
  position: relative;
  overflow: hidden;
}
.market-card:hover {
  transform: translateY(-4px);
  border-color: rgba(34, 211, 238, 0.4);
  box-shadow: var(--shadow-glow);
}
.market-card__head { display: flex; justify-content: space-between; align-items: center; }
.market-card__name { font-family: var(--font-display); font-weight: 600; font-size: 1.05rem; }
.market-card__count { font-family: var(--font-mono); font-size: .68rem; color: var(--faint); }
.market-card__spark { width: 100%; height: 46px; }
.market-card__foot {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 0.74rem;
}
.market-card__foot .up { color: var(--up); }
.market-card__foot .down { color: var(--down); }
.market-card__foot .sym { color: var(--muted); }

/* ============ Stats band ============ */
.stats { padding: 70px 24px; }
.stats__grid {
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  border-block: 1px solid var(--line);
  padding: 46px 0;
}
.stats__item { text-align: center; }
.stats__num {
  display: block;
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  background: var(--grad);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-variant-numeric: tabular-nums;
}
.stats__label { color: var(--faint); font-size: 0.88rem; }

/* ============ Testimonials ============ */
.testimonials { padding: 60px 24px 80px; }
.testimonials__head {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 36px;
  margin-bottom: 50px;
}
.t-arrow {
  width: 46px; height: 46px;
  border-radius: 50%;
  border: 1px solid var(--line-strong);
  color: var(--muted);
  font-size: 1.1rem;
  transition: all 0.25s;
  flex: 0 0 46px;
}
.t-arrow:hover { color: var(--text); border-color: var(--accent-2); box-shadow: 0 0 20px -6px rgba(34, 211, 238, .6); }

.testimonials__track {
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(310px, 1fr);
  gap: 20px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 10px;
  scrollbar-width: none;
}
.testimonials__track::-webkit-scrollbar { display: none; }

.t-card {
  scroll-snap-align: start;
  background: linear-gradient(180deg, var(--card), var(--surface));
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 30px 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.t-card h3 { font-size: 1.3rem; line-height: 1.3; }
.t-card p { color: var(--muted); font-size: 0.95rem; flex: 1; }
.t-card__stars { color: #2dd4a7; letter-spacing: 4px; font-size: 1.05rem; }
.t-card__who {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 600;
  font-size: 0.9rem;
}
.t-card__avatar {
  width: 38px; height: 38px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: var(--grad-soft);
  border: 1px solid var(--line-strong);
  font-family: var(--font-display);
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--accent-2);
}
.t-card--trust { align-items: flex-start; justify-content: center; }
.t-card__trust-logo { font-family: var(--font-display); font-weight: 700; font-size: 1.3rem; }
.t-card__trust-star { color: #2dd4a7; }
.t-card__trust-big { font-size: 3rem; font-weight: 700; color: var(--text) !important; }
.t-card__trust-big span { font-size: 1.2rem; color: var(--faint); }

/* ============ Pricing ============ */
.pricing {
  padding: 100px 24px 60px;
  position: relative;
}
.pricing::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(800px 500px at 20% 100%, rgba(34, 211, 238, 0.06), transparent 60%),
    radial-gradient(800px 500px at 85% 80%, rgba(139, 92, 246, 0.07), transparent 60%);
  pointer-events: none;
}
.pricing__head { text-align: center; position: relative; }
.pricing__deal {
  display: inline-block;
  margin-top: 22px;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  padding: 10px 22px;
  color: var(--muted);
  font-size: 0.95rem;
}
.pricing__deal strong { color: var(--text); }

.toggle {
  display: inline-flex;
  margin: 22px auto 0;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 4px;
}
.toggle__opt {
  padding: 9px 26px;
  border-radius: 999px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--muted);
  transition: all 0.25s;
}
.toggle__opt--active { background: #f3f7fc; color: #06101f; }

.pricing__grid {
  position: relative;
  max-width: 960px;
  margin: 56px auto 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  align-items: stretch;
}

.plan {
  background: linear-gradient(180deg, var(--card-2), var(--surface));
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 36px 34px;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}
.plan--featured {
  border-color: rgba(139, 92, 246, 0.4);
  background:
    radial-gradient(400px 240px at 85% 0%, rgba(139, 92, 246, 0.16), transparent 60%),
    linear-gradient(180deg, var(--card-2), var(--surface));
  box-shadow: 0 30px 80px -30px rgba(139, 92, 246, 0.35);
}

.plan__top { position: relative; }
.plan__name-row { display: flex; justify-content: space-between; align-items: center; }
.plan h3 { font-size: 2.05rem; font-weight: 700; }
.plan__gem { font-size: 1.9rem; line-height: 1; }
.plan__gem--blue {
  background: linear-gradient(135deg, #38bdf8, #2563eb);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 0 14px rgba(56, 189, 248, .6));
}
.plan__gem--violet {
  background: linear-gradient(135deg, #c084fc, #6366f1);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 0 14px rgba(167, 139, 250, .7));
}

/* Badge row: fixed min-height so the price block stays vertically aligned
   across plans whether 0, 1, or 2 chips are shown (the discount chip is
   hidden in monthly view, where there is no discount to advertise). */
.plan__chips {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-top: 14px;
  min-height: 30px;
}
.plan__chip {
  display: inline-block;
  border: 1px solid var(--line-strong);
  border-radius: 10px;
  padding: 5px 12px;
  font-size: 0.78rem;
  color: var(--muted);
}
.plan__chip--pop { border-color: rgba(192, 132, 252, .5); color: #d8c6ff; }

.plan__was { margin-top: 20px; color: var(--faint); font-size: 1rem; }
.plan__price {
  font-size: 4.4rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.02em;
}
.plan__price sup { font-size: 1.7rem; vertical-align: 32px; margin-right: 2px; color: var(--muted); }
.plan__per { font-size: 1.15rem; color: var(--muted); font-weight: 400; margin-left: 4px; }
.plan__bill { color: var(--faint); font-size: 0.85rem; margin-top: 8px; }
.plan__tag {
  margin-top: 18px;
  font-weight: 600;
  font-size: 0.92rem;
  line-height: 1.5;
}

.plan__feats {
  margin: 26px 0 28px;
  background: rgba(5, 10, 19, 0.55);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 22px;
  flex: 1;
}
.plan__feats--light { background: rgba(139, 92, 246, 0.06); border-color: rgba(139, 92, 246, 0.2); }
.plan__feats-title { font-weight: 600; font-size: 0.9rem; margin-bottom: 14px; }
.plan__feats ul { list-style: none; display: flex; flex-direction: column; gap: 11px; }
.plan__feats li {
  position: relative;
  padding-left: 30px;
  font-size: 0.92rem;
  color: var(--muted);
}
.plan__feats li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  width: 20px; height: 20px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 0.66rem;
  font-weight: 700;
  background: rgba(52, 211, 153, 0.16);
  color: var(--up);
}

.plan__mbg { text-align: center; margin-top: 14px; font-size: 0.8rem; color: var(--faint); }

/* ============ Trust / checkout ============ */
.trust {
  max-width: var(--maxw);
  margin: 60px auto;
  padding: 0 24px;
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 50px;
  align-items: center;
}
.trust__copy h2 { margin-bottom: 18px; }
.trust__copy > p { color: var(--muted); max-width: 520px; }
.trust__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 30px;
  align-items: center;
}
.trust__badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 9px 16px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.85rem;
  color: var(--muted);
  background: var(--card);
}
.trust__badge small { font-weight: 400; font-size: 0.56rem; color: var(--faint); display: block; }
.trust__badge--secure { color: var(--text); }

.trust__mbg {
  background:
    radial-gradient(300px 200px at 80% 0%, rgba(34, 211, 238, 0.12), transparent 60%),
    linear-gradient(180deg, var(--card-2), var(--surface));
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-lg);
  text-align: center;
  padding: 46px 30px;
  box-shadow: var(--shadow-card);
}
.trust__check {
  font-size: 2.6rem;
  background: var(--grad);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 700;
}
.trust__mbg-big {
  font-family: var(--font-display);
  font-size: 3.2rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.1;
}
.trust__mbg-sub { color: var(--muted); font-size: 1.1rem; }

/* ============ FAQ ============ */
.faq {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 80px 24px;
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 60px;
  align-items: start;
}
.faq__title { position: sticky; top: 120px; }

.faq__item {
  border-bottom: 1px solid var(--line);
  padding: 6px 0;
}
.faq__item summary {
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  cursor: pointer;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.18rem;
  padding: 22px 0;
  transition: color 0.2s;
}
.faq__item summary::-webkit-details-marker { display: none; }
.faq__item summary:hover { color: var(--accent-2); }
.faq__plus {
  font-size: 1.5rem;
  font-weight: 400;
  color: var(--faint);
  transition: transform 0.3s;
  flex: 0 0 auto;
}
.faq__item[open] .faq__plus { transform: rotate(45deg); color: var(--accent-2); }
.faq__item p {
  color: var(--muted);
  padding: 0 40px 24px 0;
  font-size: 0.98rem;
}

/* ============ Atmospheric lower-page backdrop (cosmic aurora glow) ============ */
.atmos {
  position: relative;
  isolation: isolate;
}
.atmos::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  background:
    radial-gradient(1200px 760px at 5% 88%, rgba(34, 211, 238, 0.20), transparent 58%),
    radial-gradient(1150px 840px at 99% 100%, rgba(139, 92, 246, 0.22), transparent 55%),
    radial-gradient(900px 520px at 78% 4%, rgba(52, 211, 153, 0.08), transparent 60%),
    linear-gradient(180deg, transparent, rgba(8, 14, 30, 0.55) 36%, rgba(6, 11, 24, 0) 100%);
}
.atmos__stars {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  pointer-events: none;
}

/* ============ CTA duo ============ */
.cta-duo {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 40px 24px 120px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
}
.cta-card {
  position: relative;
  min-height: 440px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  background:
    radial-gradient(520px 320px at 88% 8%, rgba(34, 211, 238, 0.16), transparent 60%),
    linear-gradient(180deg, rgba(10, 19, 34, 0.74), rgba(7, 13, 26, 0.88));
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-lg);
  padding: 46px 46px 44px;
  overflow: hidden;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  box-shadow: var(--shadow-card);
  transition: transform .35s, border-color .35s, box-shadow .35s;
}
.cta-card:hover {
  transform: translateY(-5px);
  border-color: rgba(34, 211, 238, 0.35);
  box-shadow: 0 40px 90px -36px rgba(0, 0, 0, 0.8), 0 0 60px -20px rgba(34, 211, 238, 0.3);
}
.cta-card__icon {
  position: absolute;
  top: 38px;
  right: 42px;
  width: 92px;
  height: 92px;
  display: grid;
  place-items: center;
}
.cta-card__icon::before {
  content: "";
  position: absolute;
  inset: -16px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(34, 211, 238, 0.30), transparent 70%);
  filter: blur(6px);
}
.cta-card__icon svg {
  position: relative;
  width: 74px;
  height: 74px;
  filter: drop-shadow(0 10px 24px rgba(34, 211, 238, 0.45));
}
.cta-card__body { position: relative; }
.cta-card h2 { font-size: clamp(2rem, 2.7vw, 2.6rem); margin-bottom: 16px; line-height: 1.05; }
.cta-card p { color: var(--muted); margin-bottom: 30px; max-width: 420px; font-size: 1.05rem; }
.cta-card .btn { align-self: flex-start; }

/* ============ Footer ============ */
.footer {
  border-top: 1px solid var(--line);
  background:
    radial-gradient(900px 400px at 50% 0%, rgba(34, 211, 238, 0.04), transparent 60%),
    var(--bg-soft);
  padding: 80px 24px 40px;
}
.footer__grid {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 2fr repeat(5, minmax(0, 1fr));
  gap: 40px;
}
.footer__brand { display: flex; flex-direction: column; gap: 24px; align-items: flex-start; }
.footer__social { display: flex; gap: 18px; }
.footer__social a { color: var(--faint); transition: color 0.2s; }
.footer__social a:hover { color: var(--text); }

.footer__col { display: flex; flex-direction: column; gap: 14px; }
.footer__col h4 {
  font-family: var(--font-body);
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.13em;
  color: var(--text);
  margin-bottom: 8px;
}
.footer__col a { color: var(--muted); font-weight: 400; font-size: 0.97rem; transition: color 0.2s; }
.footer__col a:hover { color: var(--text); }

.footer__legal {
  max-width: 1400px;
  margin: 70px auto 0;
  border-top: 1px solid var(--line);
  padding-top: 36px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.footer__legal p { color: var(--faint); font-size: 0.78rem; line-height: 1.7; }
.footer__legal a {
  color: var(--muted);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color 0.2s;
}
.footer__legal a:hover { color: var(--text); }
.footer__copyright { margin-top: 10px; color: var(--muted) !important; }

/* ============ Legal pages (disclaimer) ============ */
.legal {
  max-width: 1060px;
  margin: 0 auto;
  padding: 100px 24px 80px;
}
.legal__intro {
  font-size: clamp(1.45rem, 2.8vw, 2.05rem);
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: -0.01em;
  max-width: 980px;
}
.legal__divider {
  border: none;
  border-top: 1px solid var(--line);
  margin: 44px 0 8px;
}
.legal h2 {
  font-size: clamp(1.4rem, 2.2vw, 1.8rem);
  font-weight: 700;
  margin: 48px 0 20px;
}
.legal p {
  color: #c4cfe1;
  font-size: 1.02rem;
  line-height: 1.75;
  margin-bottom: 18px;
}
.legal a {
  color: var(--text);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.legal a:hover { color: var(--accent-2); }

.legal__title {
  font-family: var(--font-display);
  font-size: clamp(2.6rem, 6vw, 4rem);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.03em;
  margin-bottom: 36px;
}
.legal h3 {
  font-family: var(--font-display);
  font-size: clamp(1.12rem, 1.6vw, 1.3rem);
  font-weight: 700;
  margin: 32px 0 12px;
}
.legal strong { color: var(--text); font-weight: 600; }
.legal__break { margin-top: 12px; }
.legal__eyebrow {
  text-align: center;
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text);
  margin-bottom: 44px;
}
.legal ul {
  margin: 0 0 18px;
  padding-left: 24px;
  list-style: disc;
}
.legal li {
  color: #c4cfe1;
  font-size: 1.02rem;
  line-height: 1.75;
  margin-bottom: 8px;
}
.legal li::marker { color: var(--faint); }

/* ============ Cookie consent ============ */
.cookie-consent {
  position: fixed;
  left: 22px;
  bottom: 22px;
  z-index: 300;
  width: 600px;
  max-width: calc(100vw - 44px);
  background: #ffffff;
  border-radius: 16px;
  padding: 22px 24px;
  box-shadow: 0 24px 60px -16px rgba(0, 0, 0, 0.55), 0 4px 14px -6px rgba(0, 0, 0, 0.35);
  font-family: var(--font-body);
  animation: cookieIn 0.5s cubic-bezier(.2, .8, .3, 1.2) both;
}
.cookie-consent.is-hidden { display: none; }
@keyframes cookieIn {
  from { opacity: 0; transform: translateY(16px); }
  to { opacity: 1; transform: none; }
}
.cookie-consent__text {
  color: #232c3d;
  font-size: 0.92rem;
  line-height: 1.5;
  margin: 0 0 16px;
}
.cookie-consent__text a {
  color: #98a2b3;
  text-decoration: none;
  transition: color 0.2s;
}
.cookie-consent__text a:hover { color: #5b6478; text-decoration: underline; }
.cookie-consent__actions { display: flex; gap: 12px; }
.cookie-consent__btn {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 0.9rem;
  color: #fff;
  padding: 10px 22px;
  border-radius: 999px;
  cursor: pointer;
  transition: transform 0.2s cubic-bezier(.2, .9, .3, 1.4), box-shadow 0.2s, background 0.2s;
}
.cookie-consent__btn:hover { transform: translateY(-2px); }
.cookie-consent__btn--deny { background: #5b6477; }
.cookie-consent__btn--deny:hover { background: #687288; box-shadow: 0 8px 20px -8px rgba(91, 100, 119, 0.6); }
.cookie-consent__btn--accept { background: #1f2839; }
.cookie-consent__btn--accept:hover { background: #28344a; box-shadow: 0 8px 20px -8px rgba(15, 20, 32, 0.7); }

@media (max-width: 640px) {
  .cookie-consent { left: 12px; right: 12px; bottom: 12px; width: auto; padding: 20px 18px; }
}

/* ============ Reveal animations ============ */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.8s cubic-bezier(.2,.65,.3,1), transform 0.8s cubic-bezier(.2,.65,.3,1);
}
.reveal.is-visible { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001s !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001s !important;
  }
  .reveal { opacity: 1; transform: none; }
  html { scroll-behavior: auto; }
}

/* ============ Responsive ============ */
@media (max-width: 1080px) {
  .terminal__body { grid-template-columns: 1fr; min-height: 0; }
  .terminal__panel--left, .terminal__panel--right { display: none; }
  .terminal__chart { height: 380px; }

  .feature__card,
  .feature--flip .feature__card,
  .feature__card--wide { grid-template-columns: 1fr; gap: 40px; padding: 40px 28px; }
  .feature--flip .feature__media { order: 0; }
  .feature--flip .feature__copy { order: 0; }

  .markets__grid { grid-template-columns: repeat(2, 1fr); }
  .footer__grid { grid-template-columns: repeat(3, 1fr); }
  .footer__brand { grid-column: 1 / -1; flex-direction: row; justify-content: space-between; align-items: center; }
}

@media (max-width: 820px) {
  /* --- nav: compact logo + tighter padding (desktop 36px logo = ~274px wide, far too big on phones) --- */
  .nav__inner { padding: 14px 20px; }
  .brand__img { height: 28px; }
  .nav__links, .nav__actions .btn { display: none; }
  .nav__actions { margin-left: auto; }
  .nav__burger { display: flex; padding: 10px; }   /* larger tap target */

  /* --- trim oversized desktop vertical rhythm for a tighter mobile flow --- */
  .logos { padding: 36px 18px 10px; }
  .logos__label { margin-bottom: 16px; }
  .logos__row { gap: 11px 20px; }
  .logos__item { font-size: 1rem; }

  /* features: tighter card padding, media↔copy gap, and copy spacing (each card was ~800-1100px tall) */
  .feature { padding: 26px 16px; }
  .feature__card,
  .feature--flip .feature__card,
  .feature__card--wide { gap: 22px; padding: 26px 20px; }
  .eyebrow { font-size: 1rem; margin-bottom: 9px; }
  .feature__copy h2 { margin-bottom: 13px; }
  .feature__desc { font-size: 1rem; margin-bottom: 20px; }
  .feature__media--stack { gap: 12px; }
  .alert-card { padding: 13px 15px; gap: 12px; }
  .alert-card__icon { width: 38px; height: 38px; flex-basis: 38px; font-size: 1.15rem; }
  .mock--signals { padding: 20px; }
  .markets { padding: 64px 20px 32px; }
  .stats { padding: 52px 20px; }
  .testimonials { padding: 48px 16px 60px; }
  .testimonials__head { gap: 16px; margin-bottom: 26px; }
  .t-arrow { display: none; }                       /* swipe instead of arrows on mobile */
  .testimonials__track {
    margin-inline: -16px;                           /* bleed to screen edges */
    padding: 2px 16px 12px;
    gap: 14px;
    scroll-padding-left: 16px;
    overscroll-behavior-x: contain;                 /* don't chain the swipe to the page / iOS back-gesture */
    -webkit-overflow-scrolling: touch;
  }
  .t-card { scroll-snap-align: start; }
  .pricing { padding: 64px 20px 44px; }

  .faq { grid-template-columns: 1fr; gap: 26px; padding: 56px 20px; }
  .faq__title { position: static; }

  .trust { grid-template-columns: 1fr; padding: 0 20px; }

  /* --- pricing: horizontal swipe carousel (LuxAlgo-style) so the section is one card tall, not two --- */
  .pricing__grid {
    grid-template-columns: none;
    grid-auto-flow: column;
    grid-auto-columns: 85%;                 /* card width; ~15% peek of the next plan */
    gap: 14px;
    max-width: none;
    margin: 40px 0 0;
    margin-inline: -20px;                   /* bleed past the section padding to screen edges */
    padding: 4px 20px 16px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-padding-left: 20px;
    overscroll-behavior-x: contain;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .pricing__grid::-webkit-scrollbar { display: none; }
  .plan { scroll-snap-align: start; }
  /* CTA duo: min-height 360px left a big empty gap above the bottom-aligned text */
  .cta-duo { grid-template-columns: 1fr; gap: 16px; padding: 16px 16px 60px; }
  .cta-card { min-height: 196px; padding: 26px 24px 26px; }
  .cta-card h2 { margin-bottom: 9px; padding-right: 56px; }   /* clear the top-right icon */
  .cta-card p { margin-bottom: 20px; font-size: 1rem; }
  .cta-card__icon { width: 56px; height: 56px; top: 24px; right: 24px; }
  .cta-card__icon svg { width: 44px; height: 44px; }
  .stats__grid { grid-template-columns: repeat(2, 1fr); gap: 30px 12px; }

  .countdown--big .countdown__unit { min-width: 64px; padding: 10px 6px 8px; }
  .countdown--big .countdown__num { font-size: 1.7rem; }

  .hero { padding-top: 64px; }
  .hero__product { margin-top: 38px; }
  .terminal__chart { height: 300px; }   /* was 380px — trim the hero showcase */
}

@media (max-width: 560px) {
  /* markets: 2-up so 6 cards are 3 rows tall, not 6 (less vertical scrolling) */
  .markets__grid { grid-template-columns: 1fr 1fr; gap: 12px; }
  .market-card { padding: 16px 16px 14px; }
  .market-card__name { font-size: 0.98rem; }
  .market-card__count { font-size: 0.62rem; }
  .market-card__spark { height: 40px; }

  /* --- footer: stack brand so the wide logo + socials no longer overflow the row
         (root cause of the horizontal scroll: 259px logo + 167px socials > footer width) --- */
  .footer { padding: 56px 20px 36px; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .footer__brand { flex-direction: column; align-items: flex-start; gap: 22px; }
  .brand__img--footer { height: 30px; }
  .footer__legal { margin-top: 44px; gap: 10px; }
  .footer__legal p { font-size: 0.66rem; line-height: 1.6; }   /* smaller disclaimer = less scrolling */

  .stat-strip { grid-template-columns: repeat(2, 1fr); }
  .testimonials__track { grid-auto-columns: 86%; }

  .plan { padding: 30px 22px; }
  .plan h3 { font-size: 1.8rem; }
  .plan__price { font-size: 3.4rem; }
  .plan__price sup { font-size: 1.4rem; vertical-align: 24px; }
  .plan__per { font-size: 1rem; }
}

@media (max-width: 400px) {
  .nav__inner { padding: 13px 16px; }
  .brand__img { height: 26px; }
  .hero { padding-left: 18px; padding-right: 18px; }
  .hero__title { font-size: clamp(1.95rem, 8.4vw, 2.4rem); }
}
