/* ZeldTrade — Landing cinématique dark (port du design "zeldaron", v0.9.397)
   Palette data trader-grade, type display éditoriale, data en mono.
   Accent vert #00ff88. Positionnement large : prop firm + crypto + fonds propres. */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600;700&family=Caveat:wght@600&display=swap');

/* ─── Skip-link accessibilité (WCAG 2.1 AA) ─────────────────── */
.skip-link {
  position: absolute;
  top: -100%;
  left: 16px;
  z-index: 99999;
  padding: 10px 18px;
  background: var(--fg, #fff);
  color: var(--bg, #070a10);
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  font-weight: 600;
  border-radius: 8px;
  text-decoration: none;
  transition: top .15s;
}
.skip-link:focus {
  top: 16px;
}

:root {
  /* v0.9.408 — MONOCHROME BLANC, assorti à l'app (accent noir, surfaces claires).
     Le vert d'accent a disparu ; on garde le rouge pour le « mauvais » (compte cramé). */
  /* Surfaces */
  --bg-0: #fbfbfc;          /* page */
  --bg-1: #ffffff;          /* cartes */
  --bg-2: #f3f4f6;          /* surfaces secondaires */
  --bg-3: #e9ebee;
  --bg-glass: rgba(255, 255, 255, 0.8);

  /* Lines */
  --line: rgba(0,0,0,0.12);
  --line-2: rgba(0,0,0,0.16);
  --line-strong: rgba(0,0,0,0.26);

  /* Text */
  --fg: #0d0d0f;
  --fg-2: #2a2a2e;
  --fg-dim: #5a5a61;
  /* WCAG AA fix : #6b6b73 = 4.6:1 sur #fbfbfc (was #8a8a91 = 2.9:1, fail) */
  --fg-mute: #6b6b73;

  /* Accent NEUTRE = noir (plus de vert). « green » = accent monochrome. */
  --green: #111111;
  --green-2: #333333;
  --green-soft: rgba(0, 0, 0, 0.06);
  --red: #d11a2a;
  --red-soft: rgba(209, 26, 42, 0.08);
  --amber: #6b6b70;          /* neutralisé en gris */
  --amber-soft: rgba(0, 0, 0, 0.05);
  --blue: #444446;           /* neutralisé en gris */
  --blue-soft: rgba(0, 0, 0, 0.05);

  /* Type */
  --font-display: 'Space Grotesk', 'Inter', sans-serif;
  --font-body: 'Inter', system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', 'Menlo', monospace;
  --font-hand: 'Caveat', cursive;

  /* Motion */
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);

  /* Radii */
  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 16px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
a, button, [role="button"] { touch-action: manipulation; } /* supprime le 300ms tap delay mobile */

html, body {
  background: var(--bg-0);
  color: var(--fg);
  font-family: var(--font-body);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: 'ss01', 'cv11';
  line-height: 1.55;
  overflow-x: clip;          /* v0.9.421 — clip (et non hidden) : annule tout scroll horizontal sub-pixel créé par les boutons magnétiques translatés */
  max-width: 100%;
}

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

/* ─── Backdrops (v0.9.408 : épurés pour le fond blanc) ─────────────────────── */
.bg-mesh {
  position: fixed; inset: 0; z-index: -3;
  background: var(--bg-0);
}
.bg-mesh::after { content: none; }
.bg-grid {
  position: fixed; inset: 0; z-index: -2;
  background-image:
    linear-gradient(to right, rgba(0, 0, 0, 0.035) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(0, 0, 0, 0.035) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 25%, #000, transparent 78%);
  mask-image: radial-gradient(ellipse 70% 60% at 50% 25%, #000, transparent 78%);
  opacity: 0.6;
}
.bg-noise { display: none; }

/* ─── Layout ─────────────────────── */
.container { max-width: 1280px; margin: 0 auto; padding: 0 32px; position: relative; }
@media (max-width: 768px) { .container { padding: 0 20px; } }

/* ─── Status bar ─────────────────────── */
.statusbar {
  position: sticky; top: 0; z-index: 60;
  background: rgba(6, 8, 13, 0.88); backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.04em; color: var(--fg-mute);
}
.statusbar-inner { display: flex; gap: 22px; padding: 7px 32px; align-items: center; }
.statusbar .ok { color: var(--green); }
.statusbar .sep { color: var(--fg-mute); opacity: 0.4; }
.statusbar .pulse { display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: var(--green); box-shadow: 0 0 8px var(--green); animation: pulseDot 1.6s infinite; }
@keyframes pulseDot { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.5; transform: scale(0.85); } }
@media (max-width: 768px) { .statusbar-inner { gap: 12px; padding: 7px 20px; font-size: 10px; overflow: hidden; } .statusbar .hide-sm { display: none; } }

/* ─── Nav ─────────────────────── */
nav.main {
  position: sticky; top: 18px; z-index: 50;
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 24px; margin: 14px auto 0; max-width: 1280px;
  background: rgba(10, 14, 22, 0.6); backdrop-filter: blur(14px) saturate(150%);
  border: 1px solid var(--line); border-radius: 14px;
  transition: transform 0.32s var(--ease), opacity 0.25s var(--ease);
}
/* v1.0.0 — auto-hide : la nav se rétracte quand on descend, réapparaît quand on remonte */
nav.main.nav-hidden { transform: translateY(-160%); opacity: 0; pointer-events: none; }
@media (max-width: 768px) { nav.main { margin: 12px; padding: 12px 16px; } }
.brand { display: flex; align-items: center; gap: 10px; font-family: var(--font-display); font-weight: 600; font-size: 15px; letter-spacing: -0.01em; }
.brand-mark {
  width: 26px; height: 26px; border-radius: 7px;
  background: linear-gradient(135deg, var(--green), var(--green-2)); color: #000;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-family: var(--font-display); font-size: 14px;
  box-shadow: 0 0 18px rgba(0,0,0, 0.35), inset 0 0 0 1px rgba(255,255,255,0.15);
  position: relative;
}
/* v0.9.421 — V-02 : point rose en bas à droite, comme le logo de l'app */
.brand-mark::after {
  content: ''; position: absolute; right: -2px; bottom: -2px;
  width: 7px; height: 7px; border-radius: 50%;
  background: #ff3d8b; box-shadow: 0 0 0 2px var(--bg-0);
}
.nav-links { display: flex; gap: 28px; align-items: center; }
.nav-link { color: var(--fg-dim); font-size: 14px; transition: color 0.18s var(--ease); }
.nav-link:hover { color: var(--fg); }

/* lang switch */
.lang-switch { display: inline-flex; gap: 5px; align-items: center; }
.lang-btn { background: transparent; border: 1px solid var(--line-2); border-radius: 7px; padding: 4px 7px; font-size: 14px; line-height: 1; cursor: pointer; transition: opacity .15s, border-color .15s; opacity: 0.6; }
.lang-btn:hover { opacity: 1; border-color: var(--line-strong); }
.lang-btn.active { opacity: 1; border-color: var(--green); }

/* mobile nav toggle */
.nav-toggle { display: none; flex-direction: column; gap: 5px; width: 38px; height: 38px; align-items: center; justify-content: center; border: 1px solid var(--line-2); border-radius: 9px; }
.nav-toggle span { width: 18px; height: 2px; background: var(--fg); border-radius: 2px; transition: transform 0.25s var(--ease), opacity 0.2s; }
.nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; }
.nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
@media (max-width: 900px) {
  .nav-toggle { display: flex; }
  .nav-links {
    position: absolute; top: calc(100% + 10px); left: 0; right: 0;
    flex-direction: column; align-items: stretch; gap: 6px; padding: 16px;
    background: rgba(10, 14, 22, 0.96); backdrop-filter: blur(16px);
    border: 1px solid var(--line); border-radius: 14px;
    opacity: 0; transform: translateY(-8px); pointer-events: none; transition: opacity 0.22s var(--ease), transform 0.22s var(--ease);
  }
  .nav-links.open { opacity: 1; transform: translateY(0); pointer-events: auto; }
  .nav-links .nav-link { padding: 10px 8px; border-radius: 8px; min-height: 44px; display: flex; align-items: center; }
  .nav-links .nav-link:hover { background: rgba(255,255,255,0.03); }
  .nav-links .btn { justify-content: center; }
  .lang-switch { justify-content: center; margin-top: 4px; }
}

/* ─── Promo bar ─────────────────────── */
.promo-bar {
  display: flex; align-items: center; justify-content: center; gap: 14px; flex-wrap: wrap;
  padding: 9px 20px; font-family: var(--font-mono); font-size: 12px; color: var(--amber);
  background: linear-gradient(90deg, transparent, rgba(255,181,71,0.07), transparent);
  border-bottom: 1px solid var(--line);
}
.promo-code { display: inline-flex; align-items: center; gap: 8px; padding: 3px 10px; border: 1px solid var(--amber); border-radius: 6px; color: var(--amber); font-weight: 600; letter-spacing: 0.08em; transition: background 0.18s; }
.promo-code:hover { background: var(--amber-soft); }
.promo-code .copy { font-size: 10px; opacity: 0.7; }

/* ─── Buttons ─────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 8px; padding: 13px 22px;
  border-radius: 10px; font-size: 14px; font-weight: 500; font-family: var(--font-display);
  letter-spacing: -0.005em; white-space: nowrap; position: relative;
  transition: transform 0.22s var(--ease), background 0.22s var(--ease), border-color 0.22s var(--ease), box-shadow 0.22s var(--ease);
}
.btn svg { width: 17px; height: 17px; }
.btn-primary {
  background: var(--green); color: #000; font-weight: 600;
  box-shadow: 0 0 0 0 rgba(0,0,0,0.5), 0 10px 32px -8px rgba(0,0,0,0.5), inset 0 0 0 1px rgba(255,255,255,0.15);
}
.btn-primary:hover { background: #000000; box-shadow: 0 0 0 4px rgba(0,0,0,0.18), 0 14px 40px -8px rgba(0,0,0,0.7), inset 0 0 0 1px rgba(255,255,255,0.2); }
.btn-ghost { background: rgba(255,255,255,0.02); color: var(--fg); border: 1px solid var(--line-2); }
.btn-ghost:hover { background: rgba(255,255,255,0.04); border-color: var(--line-strong); }
.btn-sm { padding: 8px 14px; font-size: 13px; border-radius: 8px; }
.magnetic { display: inline-block; transition: transform 0.4s var(--ease); will-change: transform; }

/* ─── Type ─────────────────────── */
.eyebrow {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--green); display: inline-flex; align-items: center; gap: 8px; padding: 6px 12px;
  border: 1px solid var(--line-2); border-radius: 999px; background: rgba(0,0,0, 0.04);
}
.eyebrow .pulse { width: 5px; height: 5px; display: inline-block; border-radius: 50%; background: var(--green); box-shadow: 0 0 8px var(--green); animation: pulseDot 1.6s infinite; }

h1.display {
  font-family: var(--font-display); font-size: clamp(46px, 7.5vw, 104px);
  font-weight: 600; line-height: 0.96; letter-spacing: -0.045em; margin-bottom: 28px;
}
h1.display .accent { color: var(--green); }

.lead { font-size: 18px; color: var(--fg-dim); max-width: 580px; line-height: 1.55; }
.lead b { color: var(--fg); }

h2.section-title {
  font-family: var(--font-display); font-size: clamp(34px, 4.2vw, 56px);
  font-weight: 600; line-height: 1.05; letter-spacing: -0.03em; margin-bottom: 16px; max-width: 840px;
}
h2.section-title .accent { color: var(--green); }
.section-eyebrow { font-family: var(--font-mono); font-size: 11px; color: var(--green); letter-spacing: 0.16em; text-transform: uppercase; margin-bottom: 18px; }
.section-sub { color: var(--fg-dim); font-size: 17px; max-width: 640px; }

/* ─── Sections wrapper ─────────────────────── */
section.block { padding: 120px 0; position: relative; }
section.block + section.block { border-top: 1px solid var(--line); }
@media (max-width: 768px) { section.block { padding: 80px 0; } }

/* ─── Hero ─────────────────────── */
.hero { padding: 80px 0 60px; position: relative; }
.hero-grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: 72px; align-items: center; }
@media (max-width: 980px) { .hero-grid { grid-template-columns: 1fr; gap: 32px; } }

.hero-headline { position: relative; display: inline-block; }
.word-reveal { display: inline-block; overflow: hidden; vertical-align: bottom; }
.word-reveal > span { display: inline-block; transform: translateY(110%); animation: wordUp 0.45s var(--ease-out) forwards; }
.word-reveal:nth-child(1) > span { animation-delay: 0.04s; }
.word-reveal:nth-child(2) > span { animation-delay: 0.10s; }
.word-reveal:nth-child(3) > span { animation-delay: 0.16s; }
.word-reveal:nth-child(4) > span { animation-delay: 0.22s; }
.word-reveal:nth-child(5) > span { animation-delay: 0.28s; }
.word-reveal:nth-child(6) > span { animation-delay: 0.34s; }
.word-reveal:nth-child(7) > span { animation-delay: 0.40s; }
@keyframes wordUp { to { transform: translateY(0); } }

.fade-up { opacity: 0; transform: translateY(20px); animation: fadeUp 0.45s var(--ease-out) forwards; }
.fade-up.d1 { animation-delay: 0.55s; }
.fade-up.d2 { animation-delay: 0.65s; }
.fade-up.d3 { animation-delay: 0.75s; }
.fade-up.d4 { animation-delay: 0.85s; }
@keyframes fadeUp { to { opacity: 1; transform: translateY(0); } }

.cta-row { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 38px; align-items: center; }
.cta-meta { display: inline-flex; gap: 10px; align-items: center; color: var(--fg-mute); font-family: var(--font-mono); font-size: 12px; margin-left: 6px; }
.cta-meta .check { color: var(--green); display: inline-flex; }
.cta-meta .check svg { width: 14px; height: 14px; }

.live-counter {
  display: inline-flex; align-items: center; gap: 12px; padding: 10px 16px;
  background: var(--bg-glass); border: 1px solid var(--line-2); border-radius: 12px;
  font-family: var(--font-mono); font-size: 12px; color: var(--fg-dim); margin-top: 32px; backdrop-filter: blur(8px);
}
.live-counter .num { color: var(--green); font-weight: 600; font-size: 14px; min-width: 50px; display: inline-block; }
.live-counter .arrow { color: var(--green); animation: arrowBob 1.6s infinite ease-in-out; }
@keyframes arrowBob { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-3px); } }

/* ─── Hero dashboard widget ─────────────────────── */
.dash {
  position: relative; background: linear-gradient(180deg, rgba(20, 26, 36, 0.7), rgba(10, 14, 22, 0.8));
  border: 1px solid var(--line-2); border-radius: 16px; overflow: hidden; font-family: var(--font-mono);
  box-shadow: 0 30px 80px -20px rgba(0,0,0,0.6), 0 0 0 1px rgba(255,255,255,0.02) inset, 0 0 60px -20px rgba(0,0,0,0.15);
  transform: perspective(1400px) rotateY(-3deg) rotateX(2deg); transform-style: preserve-3d;
}
@media (max-width: 980px) { .dash { transform: none; } }
.dash-header { display: flex; justify-content: space-between; align-items: center; padding: 12px 16px; background: linear-gradient(180deg, rgba(30,38,52,0.5), rgba(20,26,36,0.5)); border-bottom: 1px solid var(--line); font-size: 11px; color: var(--fg-dim); }
.dash-header .tabs { display: flex; gap: 6px; }
.dash-header .tabs .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--line-strong); }
.dash-header .tabs .dot.live { background: var(--green); box-shadow: 0 0 8px var(--green); }
.dash-header .acct { color: var(--fg); }
.dash-body { padding: 22px 22px 18px; }
.dash-balance-row { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 4px; }
.dash-balance { font-size: 36px; font-weight: 600; color: var(--fg); letter-spacing: -0.02em; line-height: 1; font-variant-numeric: tabular-nums; }
.dash-balance .currency { color: var(--fg-mute); font-size: 18px; font-weight: 400; margin-right: 4px; }
.dash-label { font-size: 10px; color: var(--fg-mute); letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 4px; }
.dash-pnl { display: inline-flex; align-items: center; gap: 6px; font-size: 14px; font-weight: 500; padding: 5px 10px; border-radius: 6px; background: var(--green-soft); color: var(--green); font-variant-numeric: tabular-nums; }
.dash-pnl.red { background: var(--red-soft); color: var(--red); }
.dash-chart { height: 100px; margin: 18px -8px 14px; position: relative; }
.dash-chart svg { width: 100%; height: 100%; overflow: visible; }
.chart-area { fill: url(#gradGreen); opacity: 0.6; }
.chart-line { fill: none; stroke: var(--green); stroke-width: 1.6; filter: drop-shadow(0 0 6px rgba(0,0,0,0.5)); }
.chart-dot { fill: var(--green); filter: drop-shadow(0 0 6px var(--green)); }
.dash-meta-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: 8px; overflow: hidden; }
.dash-meta { background: var(--bg-1); padding: 12px 14px; }
.dash-meta-label { color: var(--fg-mute); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 4px; }
.dash-meta-value { color: var(--fg); font-size: 14px; font-variant-numeric: tabular-nums; font-weight: 500; }
.dash-meta-value.green { color: var(--green); }
.dash-drawdown { margin-top: 14px; padding: 14px; background: rgba(0,0,0,0.3); border: 1px solid var(--line); border-radius: 8px; }
.dash-dd-head { display: flex; justify-content: space-between; font-size: 11px; color: var(--fg-dim); margin-bottom: 8px; }
.dash-dd-head .safe { color: var(--green); display: flex; align-items: center; gap: 4px; }
.dash-dd-head .safe i { display: inline-block; width: 5px; height: 5px; border-radius: 50%; background: var(--green); }
.dash-dd-bar { height: 6px; background: var(--bg-3); border-radius: 999px; overflow: hidden; position: relative; }
.dash-dd-fill { height: 100%; background: linear-gradient(90deg, var(--green), var(--amber) 80%, var(--red)); border-radius: 999px; transition: width 1.2s var(--ease); }
.dash-dd-marks { display: flex; justify-content: space-between; font-size: 9px; color: var(--fg-mute); margin-top: 6px; font-variant-numeric: tabular-nums; }

/* ─── Split comparison ─────────────────────── */
.split-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border: 1px solid var(--line-2); border-radius: 16px; overflow: hidden; position: relative; }
@media (max-width: 900px) { .split-grid { grid-template-columns: 1fr; } }
.split-side { padding: 36px 32px 32px; position: relative; min-height: 360px; }
.split-side.before { background: linear-gradient(180deg, rgba(255,51,85,0.04), transparent 60%); border-right: 1px solid var(--line-2); }
.split-side.after { background: linear-gradient(180deg, rgba(0,0,0,0.04), transparent 60%); }
@media (max-width: 900px) { .split-side.before { border-right: 0; border-bottom: 1px solid var(--line-2); } }
.split-tag { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; padding: 4px 10px; border-radius: 4px; margin-bottom: 18px; }
.split-tag.before { background: var(--red-soft); color: var(--red); }
.split-tag.after { background: var(--green-soft); color: var(--green); }
.split-head { font-family: var(--font-display); font-size: 22px; font-weight: 600; letter-spacing: -0.02em; margin-bottom: 6px; }
.split-side .sub { color: var(--fg-dim); font-size: 14px; margin-bottom: 24px; }
.split-chart { height: 160px; margin: 14px -6px; }
.split-chart svg { width: 100%; height: 100%; overflow: visible; }
.split-list { list-style: none; }
.split-list li { display: flex; gap: 10px; align-items: center; font-size: 14px; padding: 6px 0; color: var(--fg-2); }
.split-list .icon { width: 16px; height: 16px; display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; flex-shrink: 0; font-size: 11px; font-weight: 700; }
.split-list .icon.red { background: var(--red-soft); color: var(--red); }
.split-list .icon.green { background: var(--green-soft); color: var(--green); }

/* ─── Prop firms ─────────────────────── */
.firms-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; margin-top: 40px; }
@media (max-width: 900px) { .firms-grid { grid-template-columns: repeat(2, 1fr); } }
.firm-card { position: relative; padding: 28px 18px; background: var(--bg-1); border: 1px solid var(--line); border-radius: 14px; text-align: center; cursor: pointer; transition: border-color 0.22s var(--ease), background 0.22s var(--ease); }
.firm-card:hover { border-color: var(--green); background: var(--bg-2); }
/* v0.9.421 — F-06 : la carte survolée/focus passe au-dessus pour que son popover ne soit pas masqué par les cartes voisines */
.firm-card:hover, .firm-card:focus-within { z-index: 50; }
.firm-logo { font-family: var(--font-display); font-weight: 700; font-size: 22px; letter-spacing: -0.02em; color: var(--fg); margin-bottom: 4px; }
.firm-name { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; color: var(--fg-mute); text-transform: uppercase; }
/* v0.9.419 : ouverture vers le BAS (évite le chevauchement du titre de section) */
.firm-popover { position: absolute; top: calc(100% + 12px); bottom: auto; left: 50%; transform: translateX(-50%) translateY(-8px); width: 280px; max-width: 80vw; background: var(--bg-2); border: 1px solid var(--line-strong); border-radius: 12px; padding: 16px; box-shadow: 0 24px 60px -20px rgba(0,0,0,0.35); opacity: 0; pointer-events: none; transition: opacity 0.22s var(--ease), transform 0.22s var(--ease); z-index: 40; text-align: left; }
.firm-card:hover .firm-popover, .firm-card:focus-within .firm-popover { opacity: 1; transform: translateX(-50%) translateY(0); }
/* v1.0.4 : les 2 dernières cards alignent leur popover à droite pour éviter le débordement
   horizontal (~13px) visible à 1061px de viewport (right-align annule translateX(-50%)). */
.firms-grid .firm-card:nth-last-child(-n+2) .firm-popover { left: auto; right: 0; transform: translateY(-8px); }
.firms-grid .firm-card:nth-last-child(-n+2):hover .firm-popover,
.firms-grid .firm-card:nth-last-child(-n+2):focus-within .firm-popover { transform: translateY(0); }
/* v0.9.422 — F-07 : sur mobile (grille multi-lignes) le popover devient une feuille
   centrée fixe au lieu de déborder sur les cartes des lignes inférieures. */
@media (max-width: 900px) {
  .firm-popover {
    position: fixed; left: 50%; right: auto; top: auto; bottom: 20px;
    width: min(360px, calc(100vw - 32px)); max-width: none;
    transform: translateX(-50%) translateY(12px);
    box-shadow: 0 24px 80px -16px rgba(0,0,0,0.45); z-index: 200;
  }
  .firm-card:hover .firm-popover, .firm-card:focus-within .firm-popover { transform: translateX(-50%) translateY(0); }
}
.promo-code.copied { background: var(--green-soft); border-color: var(--fg); color: var(--fg); }
.firm-popover h4 { font-family: var(--font-display); font-size: 14px; margin-bottom: 10px; }
.firm-popover ul { list-style: none; font-size: 12px; font-family: var(--font-mono); }
.firm-popover li { padding: 4px 0; color: var(--fg-dim); display: flex; justify-content: space-between; gap: 10px; }
.firm-popover li span:last-child { color: var(--fg); font-weight: 500; }
.firms-disclaimer { margin-top: 26px; font-size: 11px; color: var(--fg-mute); max-width: 760px; line-height: 1.5; }

/* ─── Demo product mockup ─────────────────────── */
.demo { background: var(--bg-1); border: 1px solid var(--line-2); border-radius: 16px; overflow: hidden; box-shadow: 0 40px 100px -30px rgba(0,0,0,0.7); display: grid; grid-template-columns: 220px 1fr; min-height: 540px; }
@media (max-width: 900px) { .demo { grid-template-columns: 1fr; min-height: auto; } .demo-sidebar { display: none; } }
.demo-sidebar { background: rgba(0,0,0,0.25); border-right: 1px solid var(--line); padding: 18px 14px; font-family: var(--font-mono); font-size: 12px; }
.demo-sb-section { color: var(--fg-mute); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; margin: 18px 0 8px; padding: 0 8px; }
.demo-sb-section:first-of-type { margin-top: 0; }
.demo-sb-item { display: flex; gap: 10px; align-items: center; padding: 8px; border-radius: 6px; color: var(--fg-dim); cursor: default; }
.demo-sb-item.active { background: rgba(0,0,0,0.08); color: var(--green); }
.demo-sb-item .dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; opacity: 0.7; flex-shrink: 0; }
.demo-sb-item .pnl { margin-left: auto; font-size: 10px; }
.demo-sb-item .pnl.green { color: var(--green); }
.demo-sb-item .pnl.red { color: var(--red); }
.demo-main { padding: 24px 28px; display: flex; flex-direction: column; gap: 22px; }
.demo-toolbar { display: flex; align-items: center; gap: 12px; justify-content: space-between; }
.demo-toolbar h3 { font-family: var(--font-display); font-size: 18px; font-weight: 600; }
.demo-toolbar .pill-row { display: flex; gap: 6px; font-family: var(--font-mono); font-size: 11px; }
.demo-toolbar .pill { padding: 4px 10px; border: 1px solid var(--line-2); border-radius: 999px; color: var(--fg-dim); }
.demo-toolbar .pill.active { color: var(--fg); border-color: var(--line-strong); background: rgba(255,255,255,0.03); }
.demo-ai-strip { display: flex; gap: 14px; align-items: flex-start; padding: 14px 16px; border: 1px solid rgba(0,0,0,0.3); background: rgba(0,0,0,0.04); border-radius: 10px; font-size: 13px; }
.demo-ai-strip .ai-icon { width: 28px; height: 28px; border-radius: 6px; background: var(--blue-soft); color: var(--blue); display: flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-weight: 700; font-size: 11px; flex-shrink: 0; }
.demo-ai-strip .ai-text { color: var(--fg-2); line-height: 1.55; }
.demo-ai-strip .ai-text b { color: var(--fg); font-weight: 600; }
.demo-ai-strip .ai-text .tag { display: inline-block; padding: 1px 7px; border-radius: 4px; font-family: var(--font-mono); font-size: 11px; margin: 0 3px; }
.demo-ai-strip .ai-text .tag.green { background: var(--green-soft); color: var(--green); }
.demo-trade-card { border: 1px solid var(--line); border-radius: 10px; padding: 18px; background: rgba(0,0,0,0.2); display: grid; grid-template-columns: 1fr 200px; gap: 20px; align-items: stretch; }
@media (max-width: 600px) { .demo-trade-card { grid-template-columns: 1fr; } }
.demo-trade-card .head { display: flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-size: 13px; }
.demo-trade-card .ticker { color: var(--fg); font-weight: 600; }
.demo-trade-card .side { padding: 2px 8px; border-radius: 4px; font-size: 10px; letter-spacing: 0.08em; }
.demo-trade-card .side.long { background: var(--green-soft); color: var(--green); }
.demo-trade-card .side.short { background: var(--red-soft); color: var(--red); }
.demo-trade-card .meta { display: grid; grid-template-columns: repeat(3, auto); gap: 18px; margin-top: 12px; font-family: var(--font-mono); font-size: 12px; }
.demo-trade-card .meta > div { color: var(--fg-mute); }
.demo-trade-card .meta b { color: var(--fg); font-weight: 500; display: block; font-size: 13px; font-variant-numeric: tabular-nums; }
.demo-chart-mini { background: var(--bg-2); border-radius: 8px; padding: 12px; display: flex; flex-direction: column; gap: 6px; border: 1px solid var(--line); }
.demo-chart-mini .label { font-family: var(--font-mono); font-size: 10px; color: var(--fg-mute); letter-spacing: 0.06em; text-transform: uppercase; }
.demo-chart-mini svg { width: 100%; flex: 1; min-height: 60px; }
.demo-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; font-family: var(--font-mono); }
@media (max-width: 600px) { .demo-stats { grid-template-columns: repeat(2, 1fr); } }
.demo-stat { padding: 12px 14px; background: rgba(0,0,0,0.25); border: 1px solid var(--line); border-radius: 8px; }
.demo-stat .k { color: var(--fg-mute); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 4px; }
.demo-stat .v { color: var(--fg); font-size: 16px; font-weight: 500; }
.demo-stat .v.green { color: var(--green); }
.demo-stat .v.amber { color: var(--amber); }

/* ─── Calculator ─────────────────────── */
.calc { background: linear-gradient(180deg, var(--bg-1), var(--bg-2)); border: 1px solid var(--line-2); border-radius: 16px; padding: 36px; display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: stretch; }
@media (max-width: 900px) { .calc { grid-template-columns: 1fr; padding: 28px; } }
.calc-side h3 { font-family: var(--font-display); font-size: 20px; font-weight: 600; margin-bottom: 6px; }
.calc-side .sub { color: var(--fg-dim); font-size: 14px; margin-bottom: 24px; }
.calc-field { margin-bottom: 18px; }
.calc-field label { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 11px; color: var(--fg-mute); letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 8px; }
.calc-field label .value { color: var(--fg); font-size: 13px; font-weight: 500; text-transform: none; letter-spacing: 0; font-variant-numeric: tabular-nums; }
.calc-field input[type=range] { width: 100%; -webkit-appearance: none; appearance: none; height: 4px; background: var(--bg-3); border-radius: 999px; outline: none; }
.calc-field input[type=range]::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 16px; height: 16px; background: var(--green); border-radius: 50%; cursor: pointer; box-shadow: 0 0 12px var(--green); transition: transform 0.15s; }
.calc-field input[type=range]::-webkit-slider-thumb:hover { transform: scale(1.2); }
.calc-field input[type=range]::-moz-range-thumb { width: 16px; height: 16px; background: var(--green); border-radius: 50%; cursor: pointer; border: 0; box-shadow: 0 0 12px var(--green); }
.calc-firm-row { display: grid; grid-template-columns: repeat(5, 1fr); gap: 6px; }
.calc-firm-row button { padding: 8px; border: 1px solid var(--line-2); border-radius: 6px; font-family: var(--font-mono); font-size: 11px; color: var(--fg-dim); background: var(--bg-1); transition: border-color 0.18s var(--ease), background 0.18s var(--ease), color 0.18s var(--ease); }
.calc-firm-row button:hover { border-color: var(--line-strong); color: var(--fg); }
.calc-firm-row button.active { background: var(--green-soft); border-color: var(--green); color: var(--green); }
.calc-firm-note { font-family: var(--font-mono); font-size: 11px; color: var(--fg-mute); margin-top: 10px; }
.calc-output { background: rgba(0,0,0,0.3); border: 1px solid var(--line); border-radius: 12px; padding: 28px; display: flex; flex-direction: column; justify-content: center; gap: 18px; }
.calc-output-status { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; padding: 6px 12px; border-radius: 4px; align-self: flex-start; }
.calc-output-status i { display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.calc-output-status.safe { background: var(--green-soft); color: var(--green); }
.calc-output-status.warn { background: var(--amber-soft); color: var(--amber); }
.calc-output-status.danger { background: var(--red-soft); color: var(--red); }
.calc-big { font-family: var(--font-display); font-size: 56px; font-weight: 600; letter-spacing: -0.04em; line-height: 1; font-variant-numeric: tabular-nums; }
.calc-big.safe { color: var(--green); }
.calc-big.warn { color: var(--amber); }
.calc-big.danger { color: var(--red); }
.calc-big-sub { color: var(--fg-mute); font-family: var(--font-mono); font-size: 12px; margin-top: 4px; }
.calc-rows { display: grid; gap: 10px; }
.calc-row { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 13px; padding: 8px 0; border-top: 1px solid var(--line); }
.calc-row span:first-child { color: var(--fg-mute); }
.calc-row span:last-child { color: var(--fg); font-variant-numeric: tabular-nums; }

/* ─── About ─────────────────────── */
.about-grid { display: grid; grid-template-columns: 1fr; gap: 32px; align-items: start; max-width: 820px; }
.about-text { font-size: 17px; line-height: 1.78; color: var(--fg-2); max-width: 660px; }
.about-text p + p { margin-top: 14px; }
.about-text strong { color: var(--fg); font-weight: 600; }
.about-sign { margin-top: 22px; padding-top: 22px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; align-items: center; gap: 20px; flex-wrap: wrap; }
.about-sign-text { font-family: var(--font-mono); font-size: 13px; color: var(--fg-dim); }
.about-sign-text b { color: var(--green); font-weight: 500; }
.signature { font-family: var(--font-hand); font-size: 30px; line-height: 1; transform: rotate(-3deg); color: var(--green); text-shadow: 0 0 12px rgba(0,0,0,0.3); }
.about-socials { display: flex; gap: 8px; margin-top: 18px; flex-wrap: wrap; }
.about-socials a { display: inline-flex; align-items: center; gap: 8px; padding: 8px 14px; border: 1px solid var(--line-2); border-radius: 999px; font-family: var(--font-mono); font-size: 12px; color: var(--fg-dim); transition: border-color 0.18s var(--ease), background 0.18s var(--ease), color 0.18s var(--ease); }
.about-socials a:hover { border-color: var(--green); color: var(--green); }
.about-socials svg { width: 14px; height: 14px; }

/* ─── FAQ ─────────────────────── */
.faq-list { max-width: 820px; margin: 0 auto; }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-item:first-child { border-top: 1px solid var(--line); }
.faq-q { width: 100%; text-align: left; display: flex; justify-content: space-between; align-items: center; gap: 20px; padding: 22px 0; font-family: var(--font-display); font-size: 17px; font-weight: 500; letter-spacing: -0.01em; color: var(--fg); }
.faq-q:hover { color: var(--green); }
.faq-icon { width: 22px; height: 22px; flex-shrink: 0; border: 1px solid var(--line-strong); border-radius: 50%; display: flex; align-items: center; justify-content: center; transition: transform 0.3s var(--ease), background 0.2s, color 0.2s; color: var(--fg-dim); font-size: 14px; }
.faq-item.open .faq-icon { transform: rotate(45deg); background: var(--green); color: #000; border-color: var(--green); }
.faq-a { display: grid; grid-template-rows: 0fr; transition: grid-template-rows 0.35s var(--ease); }
.faq-a > .faq-a-inner { overflow: hidden; min-height: 0; }
.faq-item.open .faq-a { grid-template-rows: 1fr; }
.faq-a-inner { padding: 0 30px 0 0; color: var(--fg-dim); font-size: 15px; line-height: 1.65; }
.faq-item.open .faq-a-inner { padding-bottom: 22px; }
.faq-a-inner a { color: var(--green); }

/* ─── Avis clients (cartes) ───────────────────────────── */
.reviews-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 16px; max-width: 940px; margin: 0 auto; }
.review-card { background: var(--bg-1); border: 1px solid var(--line-2); border-radius: 14px; padding: 24px 26px; display: flex; flex-direction: column; }
.review-head { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.review-avatar { width: 42px; height: 42px; border-radius: 50%; background: linear-gradient(135deg, #6366f1, #8b5cf6); color: #fff; font-family: var(--font-display); font-weight: 700; font-size: 17px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.review-name { font-family: var(--font-display); font-weight: 600; font-size: 15px; color: var(--fg); }
.review-role { font-size: 12px; color: var(--fg-mute); margin-top: 1px; }
.review-stars { color: #00b67a; font-size: 15px; letter-spacing: 2px; margin-bottom: 10px; }
.review-text { font-size: 14px; line-height: 1.65; color: var(--fg-2); margin: 0; }
.review-card-cta { text-align: center; align-items: center; justify-content: center; text-decoration: none; border-style: dashed; transition: border-color 0.2s var(--ease), transform 0.2s var(--ease); }
.review-card-cta:hover { border-color: #00b67a; transform: translateY(-3px); }
.review-cta-star { color: #00b67a; font-size: 30px; line-height: 1; margin-bottom: 10px; }
.review-cta-title { font-family: var(--font-display); font-weight: 600; font-size: 15px; color: var(--fg); margin-bottom: 4px; }
.review-cta-sub { font-size: 13px; color: #00b67a; }

/* ─── Pricing ─────────────────────── */
.pricing-toggle { display: inline-flex; gap: 4px; padding: 4px; border: 1px solid var(--line-2); border-radius: 999px; margin: 0 auto 40px; }
/* v0.9.421 — rangée des deux switchs (période + devise) + note « facturé en € » */
.pricing-toggles { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; margin-bottom: 14px; }
.pricing-currency-note { font-family: var(--font-mono); font-size: 11px; color: var(--fg-mute); letter-spacing: 0.04em; margin-bottom: 26px; min-height: 14px; }
.pricing-toggle button { padding: 8px 18px; border-radius: 999px; font-family: var(--font-mono); font-size: 12px; color: var(--fg-dim); transition: background 0.18s var(--ease), color 0.18s var(--ease), opacity 0.18s var(--ease); }
.pricing-toggle button.active { background: var(--green-soft); color: var(--green); }
.pricing-toggle .save { color: var(--amber); font-size: 10px; margin-left: 4px; }
.pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 900px) { .pricing-grid { grid-template-columns: 1fr; } }
.price-card { position: relative; padding: 32px 28px; background: var(--bg-1); border: 1px solid var(--line-2); border-radius: 14px; display: flex; flex-direction: column; transition: transform 0.3s var(--ease), border-color 0.3s var(--ease); }
.price-card:hover { transform: translateY(-4px); border-color: var(--line-strong); }
.price-card.featured { background: linear-gradient(180deg, rgba(0,0,0,0.06), transparent 50%), var(--bg-1); border-color: var(--green); box-shadow: 0 0 0 1px var(--green), 0 30px 80px -30px rgba(0,0,0,0.3); }
.price-card.featured::before { display: none; }
.price-badge { position: absolute; top: -12px; left: 24px; background: var(--green); color: #000; font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: 0.1em; padding: 4px 12px; border-radius: 4px; }
.price-reassure { text-align: center; font-size: 11px; color: var(--fg-mute); margin-top: 10px; font-family: var(--font-mono); letter-spacing: 0.03em; }
.price-name { font-family: var(--font-mono); font-size: 11px; color: var(--fg-dim); letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 18px; }
.price-amount { font-family: var(--font-display); font-size: 44px; font-weight: 600; letter-spacing: -0.03em; line-height: 1; font-variant-numeric: tabular-nums; }
.price-amount .unit { font-size: 14px; color: var(--fg-mute); font-weight: 400; margin-left: 6px; }
.price-old { font-family: var(--font-mono); color: var(--fg-mute); text-decoration: line-through; font-size: 13px; margin-top: 6px; }
.price-discount { font-family: var(--font-mono); color: var(--amber); font-size: 11px; margin-top: 4px; letter-spacing: 0.04em; }
.price-desc { color: var(--fg-dim); font-size: 14px; line-height: 1.55; margin: 20px 0; padding-top: 18px; border-top: 1px solid var(--line); }
.price-features { list-style: none; margin-bottom: 24px; flex: 1; }
.price-features li { padding: 7px 0; color: var(--fg-2); font-size: 14px; display: flex; align-items: flex-start; gap: 10px; }
.price-features li svg { width: 14px; height: 14px; flex-shrink: 0; margin-top: 4px; color: var(--green); }
.price-cta { display: block; text-align: center; padding: 12px; border-radius: 8px; font-family: var(--font-display); font-size: 14px; font-weight: 500; border: 1px solid var(--line-2); background: transparent; transition: background 0.18s var(--ease), border-color 0.18s var(--ease), color 0.18s var(--ease), opacity 0.18s var(--ease); }
.price-cta:hover { background: rgba(255,255,255,0.04); border-color: var(--line-strong); }
.price-card.featured .price-cta { background: var(--green); color: #000; border-color: var(--green); font-weight: 600; }
.price-card.featured .price-cta:hover { background: #000000; }

/* ─── Discord CTA ─────────────────────── */
.discord { background: radial-gradient(ellipse 80% 80% at 80% 20%, rgba(0,0,0,0.15), transparent 60%), radial-gradient(ellipse 60% 80% at 20% 80%, rgba(0,0,0,0.08), transparent 60%), var(--bg-1); border: 1px solid var(--line-2); border-radius: 20px; padding: 56px; text-align: center; position: relative; overflow: hidden; }
@media (max-width: 768px) { .discord { padding: 36px 24px; } }
.discord h3 { font-family: var(--font-display); font-size: clamp(26px, 3.5vw, 42px); font-weight: 600; letter-spacing: -0.03em; margin-bottom: 12px; }
.discord p { color: var(--fg-dim); font-size: 16px; max-width: 540px; margin: 0 auto 28px; }
.discord .btn { margin: 0 auto; }
.discord-avatars { display: flex; justify-content: center; margin-bottom: 18px; }
.discord-avatars .av { width: 38px; height: 38px; border-radius: 50%; border: 2px solid var(--bg-1); margin-left: -10px; font-family: var(--font-mono); font-size: 13px; display: flex; align-items: center; justify-content: center; font-weight: 600; background: linear-gradient(135deg, var(--bg-3), var(--bg-2)); color: var(--fg); }
.discord-avatars .av:first-child { margin-left: 0; }
.discord-avatars .av.green { background: linear-gradient(135deg, var(--green), var(--green-2)); color: #000; }
.discord-avatars .av.blue { background: linear-gradient(135deg, var(--blue), #3578e5); color: #000; }
.discord-avatars .av.amber { background: linear-gradient(135deg, var(--amber), #e89a2c); color: #000; }
.discord-avatars .av.more { background: var(--bg-3); color: var(--fg-dim); font-size: 11px; }

/* ─── Contact ─────────────────────── */
.contact-form { max-width: 560px; margin: 0 auto; display: flex; flex-direction: column; gap: 14px; }
.contact-form .row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 600px) { .contact-form .row { grid-template-columns: 1fr; } }
.contact-form label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-mute); margin-bottom: 6px; display: block; }
.contact-form input, .contact-form textarea { width: 100%; background: var(--bg-1); border: 1px solid var(--line-2); border-radius: 8px; padding: 12px 14px; color: var(--fg); font-family: var(--font-body); font-size: 14px; outline: none; transition: border-color 0.18s; }
.contact-form input:focus, .contact-form textarea:focus { border-color: var(--green); }
.contact-form textarea { resize: vertical; min-height: 120px; }
.contact-status { font-family: var(--font-mono); font-size: 12px; min-height: 18px; }
.contact-status.ok { color: var(--green); }
.contact-status.err { color: var(--red); }

/* ─── Footer ─────────────────────── */
footer.main { padding: 60px 0 40px; border-top: 1px solid var(--line); margin-top: 60px; color: var(--fg-dim); }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 48px; }
@media (max-width: 768px) { .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; } }
.footer-brand { max-width: 320px; }
.footer-brand p { font-size: 13px; line-height: 1.6; color: var(--fg-mute); margin-top: 14px; }
.footer-col h5 { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-mute); margin-bottom: 14px; }
.footer-col ul { list-style: none; }
.footer-col li { padding: 5px 0; }
.footer-col a { font-size: 14px; color: var(--fg-dim); transition: color 0.18s; }
.footer-col a:hover { color: var(--green); }
.footer-bottom { display: flex; justify-content: space-between; padding-top: 28px; border-top: 1px solid var(--line); font-family: var(--font-mono); font-size: 11px; color: var(--fg-mute); letter-spacing: 0.04em; flex-wrap: wrap; gap: 16px; }

/* ─── Scroll reveal ─────────────────────── */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.45s var(--ease-out), transform 0.45s var(--ease-out); }
.reveal.in { opacity: 1; transform: translateY(0); }

/* Lang loader overlay (bascule FR/EN) */
#langLoader { position: fixed; inset: 0; z-index: 99999; background: var(--bg-0); display: none; align-items: center; justify-content: center; opacity: 0; transition: opacity .35s ease; }

/* ─── Focus visible (WCAG 2.1 AA — clavier & AT) ───────────────────────────
   Règle globale : outline violet 2px sur tous les éléments interactifs.
   Utilise :focus-visible pour ne pas polluer les clics souris/touch. */
:focus-visible {
  outline: 2px solid var(--violet, #6d5ad6);
  outline-offset: 3px;
  border-radius: 4px;
}
/* Éléments qui ont déjà leur propre rendu focus — on adapte le radius */
.btn:focus-visible     { border-radius: 10px; }
.btn-sm:focus-visible  { border-radius: 8px; }
.price-cta:focus-visible { border-radius: 8px; }
.faq-q:focus-visible   { outline-offset: 0; border-radius: 0; }
.firm-card:focus-visible { border-radius: 14px; }
.lang-btn:focus-visible  { border-radius: 7px; }
.nav-toggle:focus-visible { border-radius: 9px; }
.promo-code:focus-visible { border-radius: 6px; }

/* ─── Touch targets minimum 44px (WCAG 2.5.5) ───────────────────────────── */
.lang-btn {
  min-height: 36px;
  min-width: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.nav-toggle {
  min-height: 44px;
  min-width: 44px;
}

/* ─── Reduce motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
  .reveal { opacity: 1; transform: none; }
  .word-reveal > span { transform: none; }
  .fade-up { opacity: 1; transform: none; }
  .bg-mesh::after { animation: none; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   v0.9.408 — PASSAGE EN BLANC (assorti à l'app). La landing était dark-hardcodée :
   on éclaircit les panneaux, on neutralise le logo (carré sombre + Z blanc) et on
   passe les boutons en outline comme l'app. Bloc final → gagne sur l'existant.
   ═══════════════════════════════════════════════════════════════════════════ */
.statusbar { background: var(--bg-1); }
nav.main { background: var(--bg-glass); }
@media (max-width: 900px) { .nav-links { background: var(--bg-1); } }
.dash { background: var(--bg-1); box-shadow: 0 24px 60px -30px rgba(0,0,0,0.20); }
.dash-header { background: var(--bg-2); }
.dash-drawdown, .demo-sidebar, .demo-trade-card, .demo-stat, .calc-output { background: var(--bg-2); }
.demo, .calc, .firm-card, .firm-popover, .price-card, .discord, .live-counter { box-shadow: none; }

/* Logo monochrome : carré sombre + Z blanc (assorti à l'app) */
.brand-mark { background: #15171c !important; color: #fff !important; box-shadow: none; }

/* Boutons OUTLINE (comme l'app) */
.btn-primary { background: transparent; color: var(--fg); border: 1.5px solid var(--fg); box-shadow: none; }
.btn-primary:hover { background: var(--fg); color: #fff; box-shadow: none; }
.price-card.featured { border-color: var(--fg); box-shadow: none; }
.price-badge { background: var(--fg); color: #fff; }
.price-card.featured .price-cta { background: transparent; color: var(--fg); border: 1.5px solid var(--fg); }
.price-card.featured .price-cta:hover { background: var(--fg); color: #fff; }
.price-cta { color: var(--fg); }

/* Promo bar neutralisée (plus d'ambre) */
.promo-bar { background: var(--bg-2); color: var(--fg-dim); }
.promo-code { border-color: var(--line-strong); color: var(--fg); }

/* ═══════════════════════════════════════════════════════════════════════════
   v1.0.0 — THÈME SOMBRE de la landing (toggle ☾/☀ à côté de la langue).
   Activé seulement quand <html data-theme="dark"> (posé par landing-theme.js,
   staging only). Monochrome : surfaces sombres, accent clair, rouge conservé.
   `html[data-theme]` (0,1,1) > `:root` (0,1,0) → écrase les variables blanches.
   ═══════════════════════════════════════════════════════════════════════════ */
html[data-theme="dark"] {
  --bg-0: #070a10;
  --bg-1: #0e131b;
  --bg-2: #161c26;
  --bg-3: #202833;
  --bg-glass: rgba(10, 14, 20, 0.82);
  --line: rgba(255,255,255,0.12);
  --line-2: rgba(255,255,255,0.18);
  --line-strong: rgba(255,255,255,0.32);
  --fg: #f1f3f6;
  --fg-2: #d3d7de;
  --fg-dim: #a3a9b4;
  --fg-mute: #6f7682;
  --green: #f1f3f6;
  --green-2: #c4c9d2;
  --green-soft: rgba(255,255,255,0.08);
  --red: #ff5d6c;
  --red-soft: rgba(255,93,108,0.14);
  --amber: #a3a9b4;
  --amber-soft: rgba(255,255,255,0.07);
  --blue: #a3a9b4;
  --blue-soft: rgba(255,255,255,0.07);
}
/* Grille de fond : lignes claires sur sombre (sinon invisibles) */
html[data-theme="dark"] .bg-grid {
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.045) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.045) 1px, transparent 1px);
}
/* Logo : garde la boîte sombre mais avec bordure pour rester visible sur fond sombre */
html[data-theme="dark"] .brand-mark { background: #1c222e !important; border: 1px solid rgba(255,255,255,0.16); }
/* Remplissages d'accent (clair en dark) : le texte doit être SOMBRE, pas blanc.
   (le plan FUNDED est géré à part en violet plus bas — texte blanc sur violet) */
html[data-theme="dark"] .btn-primary:hover { color: var(--bg-0); }

/* Bouton bascule thème (réutilise .lang-btn) : la glyphe ☾/☀ un peu plus grande */
.lang-btn.theme-toggle { font-size: 13px; padding: 4px 8px; }

/* ═══════════════════════════════════════════════════════════════════════════
   v1.0.2 — ACCENT VIOLET DISCRET. La marque reste monochrome ; le violet ne
   ponctue QUE les points de vente (mots-clés de titres, plan FUNDED, CTA démo)
   pour casser la monotonie sans dénaturer l'identité. Une seule couleur, dosée.
   ═══════════════════════════════════════════════════════════════════════════ */
:root              { --violet: #6d5ad6; }   /* lisible sur fond clair */
html[data-theme="dark"] { --violet: #9d8cf0; }  /* plus lumineux sur fond sombre */

/* Mots-clés accentués des titres (« Une seule survit. », etc.) — sélecteurs assez
   spécifiques pour battre `h1.display .accent` / `h2.section-title .accent` (0,2,1). */
h1.display .accent, h2.section-title .accent, .accent { color: var(--violet); }
/* Petits points "live" (statusbar / eyebrow) */
.statusbar .pulse, .eyebrow .pulse { background: var(--violet); box-shadow: 0 0 8px var(--violet); }

/* Plan FUNDED mis en avant : bordure + badge POPULAR + CTA en violet, texte blanc */
.price-card.featured { border-color: var(--violet); box-shadow: 0 0 0 1px var(--violet), 0 24px 60px -28px rgba(109,90,214,0.45); }
.price-badge { background: var(--violet); color: #fff; }
.price-card.featured .price-cta { background: var(--violet); color: #fff; border-color: var(--violet); }
.price-card.featured .price-cta:hover { background: var(--violet); filter: brightness(1.08); color: #fff; }

/* Prix annuel : équivalent mensuel mis en avant + note "facturé X/an" */
.price-billed { font-family: var(--font-mono); font-size: 12px; color: var(--fg-mute); margin-top: 4px; }
/* Badge "prêt pour les prop firms" sur le plan FUNDED (le vrai différenciateur) */
.fund-ready { display: inline-block; margin: 8px 0 2px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.03em; color: var(--violet); border: 1px solid var(--violet); border-radius: 999px; padding: 4px 11px; }

/* CTA "Tester la démo" rendu plus visible (violet, c'est ton meilleur argument de conversion) */
.cta-row .btn-ghost { border-color: var(--violet); color: var(--fg); }
.cta-row .btn-ghost:hover { background: var(--violet); color: #fff; border-color: var(--violet); }

/* ── Section #partenaires (teaser landing) ─────────────────── */
#partenaires .partner-teaser-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}
#partenaires .partner-cards-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 768px) {
  #partenaires .partner-teaser-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  #partenaires .partner-cards-grid {
    grid-template-columns: 1fr 1fr; /* reste 2 col, cards assez larges */
  }
}
@media (max-width: 480px) {
  #partenaires .partner-cards-grid {
    grid-template-columns: 1fr; /* 1 col sur très petit écran */
  }
  #partenaires .partner-cards-grid > div[style*="grid-column"] {
    grid-column: span 1 !important;
  }
}

/* ─── Pricing : features verrouillées (plan Trader) ──────────────────────── */
.price-feature-locked {
  opacity: 0.45;
}
.price-feature-locked svg {
  color: var(--fg-mute);
  flex-shrink: 0;
}
.lock-badge {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 6px;
  font-size: 9px;
  font-family: var(--font-mono);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 4px;
  color: var(--fg-mute);
  vertical-align: middle;
}

/* ─── Tab bar navigation ──────────────────────────────────────────────────── */
.tab-bar {
  position: sticky;
  top: 74px; /* juste sous la nav sticky (top:18px + ~56px hauteur) */
  z-index: 40;
  background: var(--bg-0);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(12px) saturate(140%);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
}
.tab-bar-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  gap: 0;
  overflow-x: auto;
  scrollbar-width: none;
}
.tab-bar-inner::-webkit-scrollbar { display: none; }

.tab-btn {
  flex-shrink: 0;
  padding: 14px 22px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fg-mute);
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
  margin-bottom: -1px; /* overlap border-bottom of .tab-bar */
  white-space: nowrap;
}
.tab-btn:hover { color: var(--fg); }
.tab-btn.active {
  color: var(--fg);
  border-bottom-color: var(--fg);
}

/* ─── Tab panels ──────────────────────────────────────────────────────────── */
.tab-panel {
  display: none;
  animation: tabFadeIn 0.18s var(--ease-out);
}
.tab-panel.active { display: block; }

@keyframes tabFadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Mobile : tab bar plus compacte */
@media (max-width: 768px) {
  .tab-bar { top: 60px; }
  .tab-btn { padding: 12px 16px; font-size: 10px; }
  .tab-bar-inner { padding: 0 12px; }
}

/* ─── Nav link : état actif (pages secondaires) ─────────────────────────── */
.nav-link.active,
.nav-link[aria-current="page"] {
  color: var(--fg) !important;
  opacity: 1;
  font-weight: 600;
}
