/* ============================================================
   SOUS HAUTE TENSION — campaign microsite

   Single-file stylesheet for a static editorial page. Sections are grouped
   roughly by page order, followed by motion/progressive enhancement rules.
   If this file grows significantly, split by these same headings first.
============================================================ */
:root{
  /* Palette */
  --ink-0:#000000;
  --ink-1:#05070d;        /* near-black */
  --ink-2:#0a0f1a;
  --ink-3:#0f1626;
  --navy-1:#0b1a33;       /* deep navy */
  --navy-2:#11264a;
  --paper:#f3f1ea;        /* off-white */
  --paper-dim:#cfcdc6;
  --mute:#7c8597;
  --line:#1c2740;

  --danger:#ff2a2a;       /* danger red */
  --danger-deep:#a30000;
  --hazard:#ffe23a;       /* hazard yellow */
  --electric:#39a8ff;     /* electric blue */
  --electric-deep:#0e6bd6;

  /* Type */
  --f-display:"Archivo Black","Bebas Neue",Impact,system-ui,sans-serif;
  --f-condensed:"Bebas Neue",Impact,system-ui,sans-serif;
  --f-body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --f-mono:"JetBrains Mono",ui-monospace,Menlo,Consolas,monospace;

  /* Layout */
  --maxw:1280px;
  --pad:clamp(20px,4vw,56px);
  --radius:2px;

  /* Motion */
  --ease:cubic-bezier(.2,.7,.1,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--ink-1);color:var(--paper);font-family:var(--f-body);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}
body{overflow-x:hidden;line-height:1.55}
img,svg,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
::selection{background:var(--hazard);color:var(--ink-0)}

/* Focus */
:focus-visible{outline:2px solid var(--hazard);outline-offset:3px}

/* Utility */
.kicker{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--paper-dim);
}
.kicker__pulse{
  width:8px;height:8px;border-radius:50%;background:var(--danger);
  box-shadow:0 0 0 0 rgba(255,42,42,.6);
  animation:pulse 1.6s var(--ease) infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(255,42,42,.55)}
  70%{box-shadow:0 0 0 14px rgba(255,42,42,0)}
  100%{box-shadow:0 0 0 0 rgba(255,42,42,0)}
}

/* ============================================================
   TOP BAR
============================================================ */
.topbar{
  position:fixed;
  top:0;left:0;right:0;
  z-index:100;
  background:linear-gradient(
    180deg,
    rgba(5,7,13,.72) 0%,
    rgba(5,7,13,.48) 70%,
    rgba(5,7,13,0)   100%
  );
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  border-bottom:1px solid rgba(28,39,64,.55);
  transition:background .35s ease, border-color .35s ease;
}
/* When user scrolls down even a little, snap topbar to more opaque */
.topbar.is-scrolled{
  background:linear-gradient(180deg,rgba(5,7,13,.94) 60%,rgba(5,7,13,.78));
  border-bottom-color:rgba(28,39,64,.9);
}
.topbar__inner{
  max-width:none;
  width:100%;
  margin:0 auto;
  padding:0 clamp(20px,3vw,48px);
  height:56px;
  display:flex;
  align-items:center;
  gap:clamp(16px,2vw,32px);
  overflow:visible;
}
.brand{
  display:inline-flex;
  align-items:center;
  gap:9px;
  font-family:var(--f-display);
  letter-spacing:.04em;
  font-size:15px;
  flex:0 0 auto;
  margin-right:auto;
  white-space:nowrap;
}
.brand__bolt{width:24px;height:24px;display:grid;place-items:center;background:var(--hazard);clip-path:polygon(0 0,100% 0,100% 100%,0 100%);}
.brand__bolt svg{width:16px;height:16px;fill:var(--ink-0)}
.brand__txt{white-space:nowrap}
.topnav{
  display:flex;
  align-items:center;
  gap:clamp(14px,1.6vw,26px);
  flex:0 0 auto;
  font-family:var(--f-mono);
  font-size:clamp(11px,1vw,13px);
  letter-spacing:.12em;
  text-transform:uppercase;
  white-space:nowrap;
  flex-wrap:nowrap;
}
.topnav a{
  color:var(--paper-dim);
  transition:color .2s var(--ease);
  white-space:nowrap;
}
.topnav a:hover{color:var(--paper)}
.topnav__cta{
  color:var(--ink-0);
  background:var(--hazard);
  padding:7px 13px;
  border:1px solid var(--hazard);
  font-size:clamp(10px,1vw,12px);
  transition:transform .2s var(--ease),background .2s var(--ease);
  flex:0 0 auto;
}
.topnav__cta:hover{
  background:var(--paper);
  color:var(--ink-0);
  transform:translateY(-1px);
}

/* Status block — wraps langtoggle + dot + label.
   .status itself is ALWAYS visible (so .langtoggle never disappears).
   Inner .status__dot + .status__txt hide below 1280px to free row space. */
.status{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--f-mono);
  font-size:clamp(10px,.85vw,12px);
  letter-spacing:.14em;
  color:var(--paper-dim);
  flex:0 0 auto;
  white-space:nowrap;
  margin-left:0;
}
.status__dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--danger);
  animation:pulse 1.6s var(--ease) infinite;
  flex:0 0 auto;
  display:none;
}
.status__txt{display:none}
@media(min-width:1280px){
  .status__dot,.status__txt{display:inline-flex}
}

/* Mobile (≤900): brand + CTA + langtoggle only */
@media(max-width:900px){
  .topnav a:not(.topnav__cta){display:none}
  .topnav{gap:10px}
  .brand{font-size:13px}
  .status{margin-left:0;gap:8px}
  .topbar__inner{gap:12px;padding:0 16px;height:52px}
}

/* Tablet/small laptop (901–1280): hide the 7 nav labels.
   Trying to cram them with brand + status causes overlap. */
@media(min-width:901px) and (max-width:1280px){
  .topnav a:not(.topnav__cta){display:none}
  .topnav{gap:14px}
}

/* Wide desktop (≥1281): full nav visible, comfortable spacing */
@media(min-width:1281px) and (max-width:1480px){
  .topnav{
    gap:clamp(12px,1.3vw,18px);
    font-size:11.5px;
    letter-spacing:.08em;
  }
  .topnav__cta{padding:6px 12px;font-size:11px}
}

/* Ticker */
.ticker{
  border-top:1px solid var(--line);
  background:repeating-linear-gradient(
    45deg,
    #0a0f1a 0 12px,
    #0d1320 12px 24px
  );
  overflow:hidden;
}
.ticker__track{
  display:flex;
  gap:56px;
  white-space:nowrap;
  padding:10px 0;
  font-family:var(--f-mono);
  font-size:12.5px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--paper-dim);
  animation:tick 50s linear infinite;
  will-change:transform;
}
.ticker__track span{
  display:inline-flex;
  align-items:center;
  gap:16px;
}
.ticker__track span::before{
  content:"●";
  color:var(--hazard);
  font-size:8px;
}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){.ticker__track{animation:none}}

/* ============================================================
   HERO
============================================================ */
.hero{
  position:relative;min-height:100svh;
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(100px,12vh,140px) var(--pad) 80px;
  overflow:hidden;
  background:radial-gradient(80% 70% at 50% 20%,#0c1a30 0%,#06090f 60%,#000 100%);
}
.hero__bg{position:absolute;inset:0;overflow:hidden}
.hero__grid{
  position:absolute;inset:-2px;z-index:2;
  background-image:
    linear-gradient(to right,rgba(57,168,255,.08) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(57,168,255,.08) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(80% 70% at 50% 40%,#000 30%,transparent 90%);
  -webkit-mask-image:radial-gradient(80% 70% at 50% 40%,#000 30%,transparent 90%);
}
.hero__scan{
  position:absolute;inset:0;pointer-events:none;z-index:3;
  background:repeating-linear-gradient(0deg,transparent 0 3px,rgba(255,255,255,.018) 3px 4px);
  mix-blend-mode:overlay;
}
.hero__noise{
  position:absolute;inset:0;opacity:.18;mix-blend-mode:overlay;z-index:4;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .8 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  animation:grain 1.2s steps(3) infinite;
}
@keyframes grain{
  0%{transform:translate(0,0)} 33%{transform:translate(-8px,4px)}
  66%{transform:translate(6px,-3px)} 100%{transform:translate(0,0)}
}
.hero__flicker{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  opacity:.22;
  mix-blend-mode:screen;
  filter:contrast(1.08) saturate(.85) hue-rotate(-10deg);
  pointer-events:none;
  z-index:1;          /* above poster, below grid/scan/noise/vignette */
}
/* Override the existing mobile rule that repositioned it */
@media(max-width:720px){
  .hero__flicker{
    opacity:.15;
    /* no position overrides — stays full cover */
  }
}
.hero__vignette{
  position:absolute;inset:0;pointer-events:none;z-index:5;
  background:
    radial-gradient(60% 50% at 50% 40%,transparent 0,rgba(0,0,0,.55) 70%,#000 100%),
    linear-gradient(180deg,rgba(0,0,0,.4) 0%,transparent 30%,transparent 70%,rgba(0,0,0,.85) 100%);
}

.hero__inner{position:relative;z-index:10;max-width:var(--maxw);width:100%;margin:0 auto}
.hero__title{
  font-family:var(--f-display);font-weight:900;
  font-size:clamp(54px,11vw,176px);
  line-height:.86;letter-spacing:-.02em;text-transform:uppercase;
  margin:18px 0 24px;
  display:flex;flex-direction:column;
}
.hero__title .reveal{display:block;overflow:hidden}
.hero__title .danger{color:var(--hazard);position:relative}
.hero__title .danger::after{
  content:"";position:absolute;left:0;right:0;bottom:-6px;height:4px;
  background:linear-gradient(90deg,var(--danger),transparent);
  transform-origin:left;transform:scaleX(0);
  animation:slash 1.4s .8s var(--ease-out) forwards;
}
@keyframes slash{to{transform:scaleX(1)}}

.hero__sub{
  max-width:780px;font-size:clamp(15px,1.6vw,19px);color:var(--paper-dim);
  margin:0 0 32px;line-height:1.55;
}
.hero__ctas{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:60px}
.cta{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 24px;font-family:var(--f-mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  border:1px solid currentColor;
  transition:background .25s var(--ease), border-color .25s var(--ease), color .25s var(--ease);
  position:relative;overflow:hidden;
}
.cta::after{content:"→";transition:transform .25s var(--ease)}
.cta:hover::after{transform:translateX(4px)}
.cta--primary{background:var(--hazard);color:var(--ink-0);border-color:var(--hazard)}
.cta--primary:hover{background:var(--paper);border-color:var(--paper)}
.cta--ghost{background:transparent;color:var(--paper)}
.cta--ghost:hover{background:rgba(255,255,255,.06)}

.hero__meta{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);
  max-width:780px;
}
@media(min-width:780px){.hero__meta{grid-template-columns:repeat(4,1fr)}}
.meta__cell{
  background:rgba(5,7,13,.7);padding:18px 20px;
  display:flex;flex-direction:column;gap:6px;
}
.meta__num{font-family:var(--f-display);font-size:clamp(28px,3.2vw,40px);line-height:1;color:var(--hazard)}
.meta__lbl{font-family:var(--f-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--mute)}

.hero__scroll{
  position:absolute;left:50%;bottom:24px;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  font-family:var(--f-mono);font-size:10px;letter-spacing:.3em;color:var(--paper-dim);
}
.hero__scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,var(--hazard),transparent);animation:scrollLine 1.8s var(--ease) infinite}
@keyframes scrollLine{0%,100%{opacity:.4;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ============================================================
   SECTION HEAD
============================================================ */
.section__head{
  max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
  display:grid;gap:14px;margin-bottom:52px;
}
.section__kicker{
  display:flex;align-items:center;gap:14px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--paper-dim);margin:0;
}
.section__kicker span{
  background:var(--hazard);color:var(--ink-0);padding:4px 8px;font-weight:700;letter-spacing:.1em;
}
.section__title{
  font-family:var(--f-display);font-size:clamp(36px,6vw,82px);
  line-height:.92;letter-spacing:-.015em;text-transform:uppercase;margin:0;
}
.section__lead{font-size:clamp(15px,1.4vw,18px);color:var(--paper-dim);max-width:680px;margin:0}

/* ============================================================
   PRESSURE
============================================================ */
.pressure{padding:120px 0 100px;position:relative;border-top:1px solid var(--line);background:linear-gradient(180deg,#05070d,#070b14)}
.pressure__grid{
  max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
  display:grid;gap:1px;background:var(--line);border:1px solid var(--line);
  grid-template-columns:1fr;
}
@media(min-width:760px){.pressure__grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1100px){.pressure__grid{grid-template-columns:repeat(3,1fr)}}
.pcard{
  background:#070b14;padding:36px 32px;display:flex;flex-direction:column;gap:20px;
  position:relative;overflow:hidden;min-height:340px;
  transition:background .3s var(--ease);
}
.pcard:hover{background:#0a1020}
.pcard::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:repeating-linear-gradient(45deg,var(--hazard) 0 10px,var(--ink-0) 10px 20px);
}
.pcard--alleg::before{background:repeating-linear-gradient(45deg,var(--electric) 0 10px,var(--ink-0) 10px 20px)}
.pcard__tag{
  align-self:flex-start;font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--hazard);border:1px solid var(--hazard);padding:4px 8px;
}
.pcard--alleg .pcard__tag{color:var(--electric);border-color:var(--electric)}
.pcard__title{font-family:var(--f-display);font-size:clamp(22px,2.4vw,30px);line-height:1;text-transform:uppercase;margin:0;letter-spacing:-.01em}
.pcard__body{margin:0;color:var(--paper-dim);font-size:15px;line-height:1.6}
.pcard__stat{
  margin-top:auto;display:flex;align-items:baseline;gap:14px;
  border-top:1px dashed var(--line);padding-top:18px;
}
.pcard__stat-num{font-family:var(--f-display);font-size:clamp(40px,5vw,64px);line-height:1;color:var(--paper)}
.pcard__stat-lbl{font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute)}
.pcard__quote{
  margin:0;padding:16px;background:rgba(255,226,58,.06);border-left:3px solid var(--hazard);
  font-size:13.5px;line-height:1.55;color:var(--paper);
}
.pcard__quote cite{display:block;margin-top:8px;font-style:normal;font-family:var(--f-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--mute)}

.pcard__type{
  position:absolute;top:18px;right:18px;font-family:var(--f-mono);font-size:9px;letter-spacing:.2em;
  color:var(--mute);text-transform:uppercase;
}

/* ============================================================
   STICKY BACKGROUND VIDEO
============================================================ */
.bgvideo{position:relative;height:300vh;background:#000}
.bgvideo__sticky{
  position:sticky;top:0;height:100svh;width:100%;overflow:hidden;
}
.bgvideo__media,.bgvideo__poster{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
}
.bgvideo__poster{z-index:0}
.bgvideo__media{z-index:1;filter:contrast(1.05) saturate(.9)}
.bgvideo__scan{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent 0 3px,rgba(255,255,255,.025) 3px 4px);
  mix-blend-mode:overlay;
}
.bgvideo__grid{
  position:absolute;inset:0;z-index:3;pointer-events:none;
  background-image:
    linear-gradient(to right,rgba(255,226,58,.08) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(255,226,58,.08) 1px,transparent 1px);
  background-size:120px 120px;
  mask-image:linear-gradient(180deg,#000 0%,transparent 40%,transparent 60%,#000 100%);
  -webkit-mask-image:linear-gradient(180deg,#000 0%,transparent 40%,transparent 60%,#000 100%);
}
.bgvideo__overlay{
  position:absolute;inset:0;z-index:4;pointer-events:none;
  background:
    radial-gradient(60% 50% at 30% 50%,rgba(0,0,0,.2),transparent 70%),
    linear-gradient(180deg,rgba(0,0,0,.85) 0%,rgba(0,0,0,.45) 25%,rgba(0,0,0,.45) 75%,rgba(0,0,0,.92) 100%),
    linear-gradient(90deg,rgba(11,26,51,.55),transparent 60%);
}

.bgvideo__hud{
  position:absolute;top:24px;left:24px;right:24px;z-index:6;
  display:flex;justify-content:space-between;gap:12px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--paper);
  text-shadow:0 1px 2px rgba(0,0,0,.7);
}
.hud__rec{display:inline-flex;align-items:center;gap:8px;color:var(--danger)}
.hud__dot{width:9px;height:9px;border-radius:50%;background:var(--danger);animation:pulse 1.4s var(--ease) infinite}
@media(max-width:600px){.hud__loc{display:none}}

.bgvideo__phases{
  position:absolute;inset:0;z-index:5;display:grid;place-items:center;padding:0 var(--pad);
}
.phase{
  position:absolute;max-width:880px;width:100%;text-align:left;
  opacity:0;transform:translateY(40px);
  transition:opacity .8s var(--ease),transform .8s var(--ease);
  pointer-events:none;
}
.phase.is-on{opacity:1;transform:translateY(0);pointer-events:auto}
.phase__kicker{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--hazard);margin:0 0 18px;
  display:inline-block;border-left:3px solid var(--hazard);padding-left:12px;
}
.phase__title{
  font-family:var(--f-display);
  font-size:clamp(36px,7vw,90px);line-height:.92;letter-spacing:-.015em;text-transform:uppercase;
  margin:0 0 22px;
  text-shadow:0 4px 30px rgba(0,0,0,.85);
}
.phase--3 .phase__title{color:var(--hazard)}
.phase__body{
  font-size:clamp(15px,1.5vw,19px);color:var(--paper);max-width:640px;margin:0;
  text-shadow:0 2px 12px rgba(0,0,0,.85);
}

.bgvideo__progress{
  position:absolute;left:24px;right:24px;bottom:24px;z-index:6;
  display:flex;align-items:center;gap:14px;
  font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;color:var(--paper-dim);
}
.progress__bar{position:relative;flex:1;height:2px;background:rgba(255,255,255,.15);overflow:hidden}
.progress__bar::after{
  content:"";position:absolute;left:0;top:0;height:100%;width:var(--p,0%);
  background:var(--hazard);transition:width .2s var(--ease);
}
.progress__phases{display:flex;gap:14px}
.progress__phases span{opacity:.4;transition:opacity .25s var(--ease),color .25s var(--ease)}
.progress__phases span.is-on{opacity:1;color:var(--hazard)}

/* Scroll cue — bottom-center vertical line + chevron + label.
   Sits above the existing horizontal progress bar and fades after the
   user has scrolled past ~12% of the section (toggled via .is-faded). */
.bgvideo__cue{
  position:absolute;left:50%;bottom:78px;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  z-index:5;color:rgba(255,255,255,.78);
  pointer-events:none;
  transition:opacity .5s var(--ease), transform .5s var(--ease);
}
.bgvideo__cue.is-faded{opacity:0;transform:translate(-50%,8px)}
.cue__lbl{
  font-family:var(--f-mono);font-size:10.5px;letter-spacing:.32em;
  text-transform:uppercase;color:rgba(255,255,255,.62);
  text-shadow:0 1px 8px rgba(0,0,0,.6);
}
.cue__line{
  position:relative;width:1px;height:48px;
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.45) 35%,rgba(255,255,255,.05));
  overflow:hidden;
}
.cue__dot{
  position:absolute;left:50%;top:0;width:5px;height:5px;
  margin-left:-2.5px;border-radius:50%;
  background:var(--hazard);box-shadow:0 0 10px rgba(255,226,58,.7);
  animation:cue-travel 1.8s cubic-bezier(.4,0,.4,1) infinite;
}
.cue__chev{
  color:rgba(255,255,255,.78);filter:drop-shadow(0 2px 6px rgba(0,0,0,.5));
  animation:cue-bob 1.8s ease-in-out infinite;
}
@keyframes cue-travel{
  0%   { top:-6px; opacity:0; }
  20%  { opacity:1; }
  80%  { opacity:1; }
  100% { top:48px; opacity:0; }
}
@keyframes cue-bob{
  0%,100% { transform:translateY(0); opacity:.7; }
  50%     { transform:translateY(4px); opacity:1; }
}
@media (max-width:780px){
  .bgvideo__cue{bottom:68px;gap:8px}
  .cue__line{height:38px}
  @keyframes cue-travel{
    0% { top:-6px; opacity:0; }
    20% { opacity:1; }
    80% { opacity:1; }
    100% { top:38px; opacity:0; }
  }
}

/* Reduced motion fallback for video */
@media (prefers-reduced-motion: reduce){
  .bgvideo{height:auto}
  .bgvideo__sticky{position:relative;height:auto;min-height:80svh;padding:80px 0}
  .bgvideo__media{display:none}
  .bgvideo__phases{position:relative;display:flex;flex-direction:column;gap:60px;padding:60px var(--pad)}
  .phase{position:relative;opacity:1;transform:none;pointer-events:auto}
  .bgvideo__cue{display:none}
  .cue__dot,.cue__chev{animation:none}
}

/* ============================================================
   TIMELINE
============================================================ */
.timeline{padding:120px 0;border-top:1px solid var(--line);background:#06090f;position:relative}
.timeline::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(to right,rgba(57,168,255,.04) 1px,transparent 1px);
  background-size:80px 100%;
}
.timeline__list{
  list-style:none;margin:0;padding:0 var(--pad);max-width:var(--maxw);margin:0 auto;position:relative;
}
.timeline__list::before{
  content:"";position:absolute;left:calc(var(--pad) + 12px);top:0;bottom:0;width:1px;
  background:linear-gradient(to bottom,transparent,var(--line) 8%,var(--line) 92%,transparent);
}
@media(min-width:780px){
  .timeline__list::before{left:calc(50% - 0.5px)}
}
.tnode{
  position:relative;padding:18px 0 18px 44px;
  display:grid;gap:6px;
}
@media(min-width:780px){
  .tnode{width:50%;padding:30px 40px 30px 50px}
  .tnode:nth-child(even){margin-left:50%}
  .tnode:nth-child(odd){text-align:right;padding:30px 50px 30px 40px}
}
.tnode__dot{
  position:absolute;left:6px;top:24px;width:14px;height:14px;border-radius:50%;
  background:var(--ink-1);border:2px solid var(--electric);box-shadow:0 0 0 4px rgba(57,168,255,.12);
}
@media(min-width:780px){
  .tnode__dot{left:auto;right:-7px}
  .tnode:nth-child(even) .tnode__dot{left:-7px;right:auto}
}
.tnode--ok .tnode__dot{border-color:#34d399;box-shadow:0 0 0 4px rgba(52,211,153,.12)}
.tnode--warn .tnode__dot{border-color:var(--hazard);box-shadow:0 0 0 4px rgba(255,226,58,.12)}
.tnode--alert .tnode__dot{border-color:var(--danger);box-shadow:0 0 0 4px rgba(255,42,42,.18);animation:pulse 1.6s var(--ease) infinite}
.tnode__date{font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--hazard)}
.tnode--ok .tnode__date{color:#34d399}
.tnode--alert .tnode__date{color:var(--danger)}
.tnode__title{font-family:var(--f-display);font-size:clamp(20px,2vw,26px);line-height:1.05;text-transform:uppercase;margin:0;letter-spacing:-.01em}
.tnode__body{margin:0;color:var(--paper-dim);font-size:14.5px;line-height:1.55;max-width:46ch}
@media(min-width:780px){.tnode:nth-child(odd) .tnode__body{margin-left:auto}}

/* ============================================================
   STAKES
============================================================ */
.stakes{padding:120px 0;border-top:1px solid var(--line);background:linear-gradient(180deg,#070b14,#05070d)}
.stakes__split{
  max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
  display:grid;gap:40px;
}
@media(min-width:900px){.stakes__split{grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line)}}
.stakes__col{padding:28px;background:#070b14;display:flex;flex-direction:column;gap:22px}
@media(max-width:899px){.stakes__col{border:1px solid var(--line)}}
.stakes__head{display:flex;flex-direction:column;gap:12px;padding-bottom:14px;border-bottom:1px dashed var(--line)}
.stakes__head h3{font-family:var(--f-display);font-size:clamp(22px,2.4vw,30px);line-height:1;text-transform:uppercase;margin:0}
.stakes__pill{
  align-self:flex-start;font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  padding:5px 10px;border:1px solid currentColor;
}
.stakes__pill--fact{color:var(--hazard)}
.stakes__pill--alle{color:var(--electric)}
.stakes__cards{display:flex;flex-direction:column;gap:14px}
.scard{display:grid;grid-template-columns:48px 1fr;gap:16px;padding:16px;background:rgba(255,255,255,.02);border:1px solid var(--line)}
.scard__icon{
  width:48px;height:48px;display:grid;place-items:center;background:var(--ink-0);border:1px solid var(--line);
}
.scard__icon svg{width:24px;height:24px;stroke:var(--paper);stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.stakes__col--facts .scard__icon svg{stroke:var(--hazard)}
.stakes__col--alle .scard__icon svg{stroke:var(--electric)}
.scard__t{font-family:var(--f-display);font-size:18px;text-transform:uppercase;line-height:1.05;margin:0 0 6px;letter-spacing:-.005em}
.scard__b{margin:0;color:var(--paper-dim);font-size:14px;line-height:1.55}
.scard__src{display:block;margin-top:8px;font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute)}

/* ============================================================
   ACTION
============================================================ */
.action{position:relative;padding:140px 0 120px;overflow:hidden;border-top:1px solid var(--line)}
.action__bg{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(50% 60% at 80% 20%,rgba(255,42,42,.22),transparent 70%),
    radial-gradient(60% 70% at 10% 90%,rgba(255,226,58,.12),transparent 70%),
    linear-gradient(180deg,#060912,#0a0f1c);
}
.action__bg::after{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(45deg,rgba(255,226,58,.05) 0 22px,transparent 22px 44px);
}
.action__inner{position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.action__title{font-family:var(--f-display);font-size:clamp(40px,7vw,96px);line-height:.92;text-transform:uppercase;letter-spacing:-.02em;margin:18px 0 26px}
.action__body{font-size:clamp(15px,1.5vw,18px);color:var(--paper-dim);max-width:680px;margin:0 0 50px}
.action__grid{display:grid;gap:14px;grid-template-columns:1fr;margin-bottom:40px}
@media(min-width:680px){.action__grid{grid-template-columns:1fr 1fr}}
@media(min-width:1000px){.action__grid{grid-template-columns:repeat(4,1fr)}}
.acard{
  display:flex;flex-direction:column;gap:14px;justify-content:space-between;
  padding:24px;background:rgba(0,0,0,.55);border:1px solid var(--line);
  transition:transform .25s var(--ease),background .25s var(--ease),border-color .25s var(--ease);
  min-height:160px;
}
.acard:hover{transform:translateY(-3px);background:rgba(255,226,58,.06);border-color:var(--hazard)}
.acard__tag{font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--hazard)}
.acard__lbl{font-family:var(--f-display);font-size:20px;line-height:1.1;text-transform:uppercase;letter-spacing:-.005em}
.acard__arrow{font-family:var(--f-mono);font-size:14px;color:var(--paper-dim);align-self:flex-end}

.action__share{display:flex;flex-wrap:wrap;align-items:center;gap:18px;font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--paper-dim)}
.action__share a{color:var(--paper);border-bottom:1px solid var(--line);padding-bottom:2px}
.action__share a:hover{color:var(--hazard);border-color:var(--hazard)}

/* ============================================================
   FOOTER
============================================================ */
.foot{background:#03050a;border-top:1px solid var(--line);padding:60px 0 40px}
.foot__inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);display:grid;gap:32px}
@media(min-width:820px){.foot__inner{grid-template-columns:1.4fr 1fr 1fr}}
.foot__brand{font-family:var(--f-display);letter-spacing:.04em;font-size:18px;margin:0 0 12px}
.foot__disclaimer{font-size:12.5px;line-height:1.6;color:var(--mute);margin:0;max-width:60ch}
.foot__title{font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--paper-dim);margin:0 0 12px}
.foot__links{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;font-size:13px}
.foot__links a{color:var(--paper);border-bottom:1px solid transparent;transition:border-color .2s var(--ease)}
.foot__links a:hover{border-color:var(--hazard)}
.foot__date{font-family:var(--f-mono);font-size:13px;color:var(--hazard);margin:0 0 8px}
.foot__credit{font-size:12px;color:var(--mute);margin:0;line-height:1.5}

/* ============================================================
   REFERENCE CHIPS  + SOURCES SECTION
============================================================ */
.refs{
  display:inline-flex;gap:3px;margin-left:6px;vertical-align:super;font-size:0;
  line-height:1;
}
.ref-chip{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:22px;height:18px;padding:0 5px;
  font-family:var(--f-mono);font-size:10px;font-weight:700;letter-spacing:.04em;line-height:1;
  color:var(--hazard);background:rgba(255,226,58,.06);
  border:1px solid rgba(255,226,58,.45);
  text-decoration:none;
  transition:background .18s var(--ease), border-color .18s var(--ease), color .18s var(--ease), transform .18s var(--ease);
  cursor:pointer;
}
.ref-chip:hover,.ref-chip:focus-visible{
  background:var(--hazard);color:var(--ink-0);border-color:var(--hazard);
  transform:translateY(-1px);
}
.pcard--alleg .ref-chip,
.stakes__col--alle .ref-chip{
  color:var(--electric);background:rgba(57,168,255,.08);border-color:rgba(57,168,255,.45);
}
.pcard--alleg .ref-chip:hover,
.stakes__col--alle .ref-chip:hover{
  background:var(--electric);color:var(--ink-0);border-color:var(--electric);
}

.hero__refs{
  margin:-18px 0 26px;display:flex;flex-wrap:wrap;align-items:center;gap:8px;
  font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);
}
.hero__refs::before{content:"Sources";margin-right:2px}
.hero__refs .refs{margin-left:0;vertical-align:baseline;font-size:0}

.meta__refs{display:inline-flex;margin-top:4px}
.meta__refs .refs{margin-left:0;vertical-align:baseline;font-size:0}

/* Sources / receipts section */
.sources{
  padding:120px 0;border-top:1px solid var(--line);
  background:linear-gradient(180deg,#06090f,#04060b);
  position:relative;
}
.sources::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(45deg,rgba(255,226,58,.03) 0 18px,transparent 18px 36px);
}
.sources__list{
  position:relative;list-style:none;margin:0 auto;padding:0 var(--pad);
  max-width:var(--maxw);
  display:grid;gap:1px;background:var(--line);border:1px solid var(--line);
}
.src{
  display:grid;grid-template-columns:54px 1fr;gap:18px;
  background:#070b14;padding:22px 24px;
  transition:background .35s var(--ease);
  scroll-margin-top:120px;
}
.src.is-flash{background:rgba(255,226,58,.16);box-shadow:inset 4px 0 0 var(--hazard)}
.src__num{
  font-family:var(--f-mono);font-size:13px;letter-spacing:.04em;color:var(--hazard);
  padding-top:4px;
}
.src__body{display:flex;flex-direction:column;gap:8px;min-width:0}
.src__title{
  font-family:var(--f-display);font-size:clamp(15px,1.6vw,19px);line-height:1.25;
  color:var(--paper);text-decoration:none;letter-spacing:-.005em;
  display:inline-flex;align-items:baseline;gap:8px;flex-wrap:wrap;
}
.src__title:hover{color:var(--hazard)}
.src__ext{font-family:var(--f-mono);font-size:13px;color:var(--mute)}
.src__title:hover .src__ext{color:var(--hazard)}
.src__meta{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--mute);display:flex;flex-wrap:wrap;gap:8px;align-items:center;
}
.src__outlet{color:var(--paper-dim)}
.src__sep{opacity:.4}
.src__host{color:var(--electric)}

@media (prefers-reduced-motion: reduce){
  .src{transition:none}
  .ref-chip{transition:none}
}

/* ============================================================
   REVEALS / SCROLL
============================================================ */.reveal{transform:translateY(100%);transition:transform 1.1s var(--ease-out)}
.reveal.is-in{transform:translateY(0)}
.fade-up{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.fade-up.is-in{opacity:1;transform:translateY(0)}

@media (prefers-reduced-motion: reduce){
  .reveal,.fade-up{transition:none;transform:none;opacity:1}
  .hero__noise,.hero__flicker,.hero__scroll-line,.kicker__pulse,.status__dot,.tnode--alert .tnode__dot,.hud__dot{animation:none}
  .hero__title .danger::after{animation:none;transform:scaleX(1)}
}

/* ============================================================
   LIVE COUNTER BAND  (Section A)
============================================================ */
.livectr{
  position:relative;padding:80px var(--pad);
  background:linear-gradient(180deg,#070b14 0%,#04060b 100%);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;
}
.livectr__bg{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 20% 30%, rgba(255,42,42,.18), transparent 55%),
    repeating-linear-gradient(90deg, rgba(255,42,42,.05) 0 1px, transparent 1px 80px);
}
.livectr__inner{position:relative;max-width:var(--maxw);margin:0 auto}
.livectr .kicker{margin-bottom:24px}
.livectr__stack{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  gap:clamp(18px,3vw,32px);max-width:100%;
}
.livectr__lbl{
  font-family:var(--f-display);
  font-size:clamp(28px,5.2vw,64px);
  line-height:1.02;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--paper);
  font-weight:900;
  margin:0;
  max-width:18ch;
  background:linear-gradient(180deg,#fff 0%,#fff 55%,rgba(255,42,42,.85) 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  text-shadow:0 0 30px rgba(255,42,42,.18);
  position:relative;
}
.livectr__lbl::before,
.livectr__lbl::after{
  content:"";display:block;width:clamp(40px,8vw,90px);height:2px;
  background:linear-gradient(90deg,transparent,var(--danger),transparent);
  margin:12px auto;opacity:.7;
}
.livectr__num{
  display:block;width:100%;
  font-variant-numeric:tabular-nums;
  animation:livectr-pulse 2.4s ease-in-out infinite;
}
.livectr__foot{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  max-width:560px;
}
.livectr__hours{display:none}
.livectr__sub{
  font-family:var(--f-body);font-size:13px;color:var(--mute);line-height:1.5;
}
.livectr__refs{display:inline-flex;justify-content:center}
@keyframes livectr-pulse{
  0%,100%{filter:drop-shadow(0 0 28px rgba(255,42,42,.18))}
  50%{filter:drop-shadow(0 0 48px rgba(255,42,42,.42))}
}
@media (max-width:780px){
  .livectr__stack{gap:18px}
}
@media (prefers-reduced-motion: reduce){
  .livectr__num{animation:none}
}

/* ============================================================
   TWO REALITIES SPLIT  (Section B)
============================================================ */
.tworeal{padding:120px var(--pad);max-width:var(--maxw);margin:0 auto}
.tworeal__split{
  display:grid;grid-template-columns:1fr auto 1fr;gap:0;
  align-items:stretch;border:1px solid var(--line);background:#070b14;
}
.tworeal__col{padding:clamp(28px,4vw,48px);display:flex;flex-direction:column;gap:24px;position:relative;overflow:hidden}
.tworeal__col--mgmt{background:linear-gradient(160deg, rgba(255,226,58,.05), transparent 60%)}
.tworeal__col--wrk {background:linear-gradient(200deg, rgba(57,168,255,.06), transparent 60%)}
.tworeal__col--mgmt::before,
.tworeal__col--wrk::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(45deg,rgba(255,255,255,.015) 0 12px,transparent 12px 24px);
}
.tworeal__head{display:flex;flex-direction:column;gap:10px}
.tworeal__pill{
  display:inline-flex;align-self:flex-start;
  font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  padding:6px 10px;border:1px solid currentColor;
}
.tworeal__pill--mgmt{color:var(--hazard)}
.tworeal__pill--wrk{color:var(--electric)}
.tworeal__h{
  font-family:var(--f-display);font-size:clamp(20px,2.4vw,30px);line-height:1.05;
  margin:0;letter-spacing:-.01em;
}
.tworeal__col--mgmt .tworeal__h{color:var(--hazard)}
.tworeal__col--wrk  .tworeal__h{color:var(--paper)}
.tworeal__items{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:22px;position:relative}
.trit{display:flex;flex-direction:column;gap:4px;padding:14px 0;border-top:1px dashed rgba(255,255,255,.08)}
.trit:first-child{border-top:0;padding-top:0}
.trit__big{
  font-family:var(--f-display);font-size:clamp(28px,4vw,52px);line-height:.95;
  letter-spacing:-.02em;
}
.tworeal__col--mgmt .trit__big{color:var(--hazard)}
.tworeal__col--wrk  .trit__big{color:#e9eef7}
.trit__lbl{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--paper-dim);margin-top:4px;
}
.trit__note{font-size:14px;color:var(--mute);line-height:1.45}
.tworeal__vs{
  display:flex;align-items:center;justify-content:center;
  background:var(--ink-1);border-left:1px solid var(--line);border-right:1px solid var(--line);
  padding:0 18px;
}
.tworeal__vs span{
  font-family:var(--f-display);font-size:22px;letter-spacing:.1em;color:var(--danger);
  writing-mode:vertical-rl;transform:rotate(180deg);
}
/* slide-in entrance */
.tworeal__col--mgmt{transform:translateX(-30px);opacity:0;transition:transform .9s var(--ease-out),opacity .9s var(--ease-out)}
.tworeal__col--wrk {transform:translateX(30px); opacity:0;transition:transform .9s var(--ease-out),opacity .9s var(--ease-out)}
.tworeal__col.is-in{transform:translateX(0);opacity:1}
@media (max-width:880px){
  .tworeal__split{grid-template-columns:1fr}
  .tworeal__vs{border-left:0;border-right:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px}
  .tworeal__vs span{writing-mode:initial;transform:none}
}
@media (prefers-reduced-motion: reduce){
  .tworeal__col--mgmt,.tworeal__col--wrk{transform:none;opacity:1;transition:none}
}

/* ============================================================
   SOUS-TRAITANCE EXPLAINER  (Section C)
============================================================ */
.subc{padding:120px var(--pad);max-width:var(--maxw);margin:0 auto;border-top:1px solid var(--line)}
.subc__grid{
  display:grid;gap:18px;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
}
.subcard{
  position:relative;padding:28px;background:#070b14;border:1px solid var(--line);
  display:flex;flex-direction:column;gap:14px;
  overflow:hidden;
}
.subcard::before{
  content:"";position:absolute;inset:-1px;border:1px solid transparent;pointer-events:none;
  background:linear-gradient(120deg, transparent 30%, rgba(255,42,42,.5), transparent 70%) border-box;
  -webkit-mask:linear-gradient(#000 0 0) padding-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .6s var(--ease);
}
.subcard:hover::before{opacity:1;animation:subc-glow 2.4s linear infinite}
@keyframes subc-glow{
  0%{background:linear-gradient(120deg, transparent 30%, rgba(255,42,42,.55), transparent 70%) border-box}
  50%{background:linear-gradient(300deg, transparent 30%, rgba(255,226,58,.55), transparent 70%) border-box}
  100%{background:linear-gradient(120deg, transparent 30%, rgba(255,42,42,.55), transparent 70%) border-box}
}
.subcard--alleg{border-left:3px solid var(--electric)}
.subcard--fact {border-left:3px solid var(--hazard)}
.subcard__type{
  font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--mute);
}
.subcard--alleg .subcard__type{color:var(--electric)}
.subcard--fact  .subcard__type{color:var(--hazard)}
.subcard__icon{width:44px;height:44px;color:var(--paper-dim)}
.subcard__icon svg{width:100%;height:100%;stroke:currentColor;stroke-width:1.4;fill:none;stroke-linecap:round;stroke-linejoin:round}
.subcard__t{
  font-family:var(--f-display);font-size:22px;line-height:1.1;margin:0;letter-spacing:-.005em;color:var(--paper);
}
.subcard__b{margin:0;font-size:15px;line-height:1.55;color:var(--paper-dim)}
.subcard__src{
  font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);
  margin-top:auto;padding-top:10px;border-top:1px dashed rgba(255,255,255,.08);
}
@media (prefers-reduced-motion: reduce){
  .subcard::before{display:none}
}

/* ============================================================
   TIMELINE QUOTE
============================================================ */
.tnode__quote{
  margin:14px 0 0;padding:14px 18px;
  background:rgba(57,168,255,.05);border-left:3px solid var(--electric);
  font-style:italic;color:var(--paper);font-size:14.5px;line-height:1.5;
}
.tnode__quote cite{
  display:block;margin-top:8px;font-style:normal;
  font-family:var(--f-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--mute);
}

/* ============================================================
   ACTION — UPGRADED SHARE BUTTONS + NEWSLETTER
============================================================ */
.action__sharebox{margin-top:48px}
.action__sharelbl{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--paper-dim);margin:0 0 14px;
}
.action__share{
  display:flex;flex-wrap:wrap;gap:10px;align-items:center;
}
.sbtn{
  display:inline-flex;align-items:center;gap:10px;
  padding:12px 18px;border:1px solid var(--line);background:#070b14;color:var(--paper);
  font-family:var(--f-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  text-decoration:none;cursor:pointer;
  transition:background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease);
}
.sbtn svg{width:18px;height:18px;fill:currentColor}
.sbtn:hover,.sbtn:focus-visible{background:var(--paper);color:var(--ink-0);border-color:var(--paper)}
.sbtn--x:hover{background:#1da1f2;color:#fff;border-color:#1da1f2}
.sbtn--wa:hover{background:#25d366;color:#fff;border-color:#25d366}
.sbtn--fb:hover{background:#1877f2;color:#fff;border-color:#1877f2}
.sbtn--copy.is-copied{background:var(--hazard);color:var(--ink-0);border-color:var(--hazard)}

/* ============================================================
   FAQ / MYTHS ACCORDION
============================================================ */
.faq{padding:120px var(--pad);max-width:var(--maxw);margin:0 auto;border-top:1px solid var(--line)}
.faq__list{display:flex;flex-direction:column;gap:1px;background:var(--line);border:1px solid var(--line)}
.faqi{background:#070b14;border:0}
.faqi__q{
  list-style:none;cursor:pointer;
  display:flex;align-items:flex-start;gap:14px;
  padding:22px 24px;
  font-family:var(--f-display);font-size:clamp(17px,1.9vw,22px);line-height:1.25;letter-spacing:-.005em;
  color:var(--paper);
  transition:background .2s var(--ease),color .2s var(--ease);
}
.faqi__q::-webkit-details-marker{display:none}
.faqi__q:hover{background:rgba(255,226,58,.04);color:var(--hazard)}
.faqi__qmark{
  flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;margin-top:4px;
  font-family:var(--f-mono);font-size:11px;color:var(--hazard);
  transition:transform .25s var(--ease);
}
.faqi[open] .faqi__qmark{transform:rotate(90deg)}
.faqi__qtxt{flex:1;min-width:0}
.faqi__a{
  padding:0 24px 24px 60px;
  color:var(--paper-dim);font-size:15.5px;line-height:1.6;
  border-top:1px dashed rgba(255,255,255,.05);
}
.faqi__a p{margin:14px 0 0}
@media (max-width:640px){.faqi__a{padding-left:24px}}
@media (prefers-reduced-motion: reduce){
  .faqi__qmark{transition:none}
}

/* ============================================================
   3 PDG EN 5 ANS — section-pdg
============================================================ */
.section-pdg{
  position:relative;
  padding:120px var(--pad);
  background:linear-gradient(180deg, var(--ink-1) 0%, var(--ink-2) 50%, var(--ink-1) 100%);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.section-pdg::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 20% 0%, rgba(255,42,42,.06), transparent 50%),
    radial-gradient(ellipse at 80% 100%, rgba(57,168,255,.05), transparent 50%);
}
.section-pdg .container{position:relative;max-width:var(--maxw);margin:0 auto}
.section-pdg .section-kicker{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--danger);margin:0 0 18px;
}
.section-pdg .section-headline{
  font-family:var(--f-display);
  font-size:clamp(40px,6vw,84px);line-height:.95;letter-spacing:-.02em;
  color:var(--paper);margin:0 0 18px;
}
.section-pdg .section-sub{
  max-width:680px;font-size:clamp(15px,1.5vw,18px);line-height:1.55;
  color:var(--paper-dim);margin:0 0 56px;
}

/* Track grid */
.pdg-track{
  display:grid;gap:28px;
  grid-template-columns:repeat(3, minmax(0,1fr));
}
@media (max-width:1024px){.pdg-track{grid-template-columns:repeat(2, minmax(0,1fr))}}
@media (max-width:680px){.pdg-track{grid-template-columns:1fr;gap:20px}}

/* Card */
.pdg-card{
  position:relative;
  display:flex;flex-direction:column;gap:18px;
  padding:2rem;
  background:#06080f;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:0 8px 28px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.02);
  transition:transform .35s var(--ease), border-color .25s var(--ease), box-shadow .25s var(--ease);
}
.pdg-card:hover{
  transform:translateY(-3px);
  border-color:rgba(255,255,255,.16);
  box-shadow:0 14px 38px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.04);
}

/* Tenure + tag row */
.pdg-card__tenure{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--paper-dim);
}
.pdg-card__years{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Tag pills (global) */
.tag{
  display:inline-block;padding:4px 10px;border-radius:999px;
  font-family:var(--f-mono);font-size:10px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;
  border:1px solid currentColor;line-height:1.2;white-space:nowrap;
}
.tag--alert{color:var(--danger);background:rgba(255,42,42,.08)}
.tag--warn {color:var(--hazard);background:rgba(255,226,58,.08)}
.tag--info {color:var(--electric);background:rgba(57,168,255,.08)}

/* Name */
.pdg-card__name{
  font-family:var(--f-display);
  font-size:clamp(28px,2.6vw,36px);line-height:1;letter-spacing:-.01em;
  color:var(--paper);margin:0;
}

/* Body */
.pdg-card__body{
  margin:0;color:var(--paper-dim);
  font-size:14.5px;line-height:1.6;
}

/* Stats sub-grid */
.pdg-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
  padding:18px 0;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.pdg-stat{display:flex;flex-direction:column;gap:6px;min-width:0}
.pdg-stat__val{
  font-family:var(--f-display);
  font-size:clamp(22px,2.2vw,30px);line-height:1;letter-spacing:-.01em;
  color:var(--hazard);
  word-break:break-word;
}
.pdg-stat--alt .pdg-stat__val{color:var(--paper);font-size:clamp(18px,1.8vw,22px)}
.pdg-stat__lbl{
  font-family:var(--f-mono);font-size:10px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--paper-dim);line-height:1.35;
}

/* Notable callout */
.pdg-card__notable{
  margin:0;padding:10px 0 10px 14px;
  border-left:4px solid var(--hazard);
  font-style:italic;font-size:13.5px;line-height:1.5;
  color:var(--paper-dim);
}
.pdg-card__notable-ico{font-style:normal;margin-right:6px}

/* Per-card accent (notable border color tracks tag level) */
.pdg-card:has(.tag--alert) .pdg-card__notable{border-left-color:var(--danger)}
.pdg-card:has(.tag--info)  .pdg-card__notable{border-left-color:var(--electric)}

/* Refs */
.pdg-card__refs{margin:0;font-family:var(--f-mono);font-size:11px;color:var(--paper-dim)}
.pdg-card__refs:empty{display:none}

/* Stagger entrance — uses existing .fade-up + IntersectionObserver hook */
.pdg-card.fade-up{transition-delay:calc(var(--pdg-i, 0) * 120ms)}

@media (prefers-reduced-motion: reduce){
  .pdg-card{transition:none}
  .pdg-card:hover{transform:none}
  .pdg-card.fade-up{transition-delay:0ms !important}
}

/* ============================================================
   FR/EN LANGUAGE TOGGLE
============================================================ */
.langtoggle{
  display:inline-flex;align-items:stretch;
  border:1px solid var(--line);border-radius:999px;
  overflow:hidden;background:#04060b;
  margin-right:0;
  flex:0 0 auto;
}
.langtoggle__btn{
  appearance:none;-webkit-appearance:none;
  background:transparent;border:0;cursor:pointer;
  padding:4px 9px;
  font-family:var(--f-mono);font-size:10.5px;font-weight:700;
  letter-spacing:.14em;color:var(--paper-dim);
  transition:background .2s var(--ease),color .2s var(--ease);
  line-height:1;
}
.langtoggle__btn:hover,.langtoggle__btn:focus-visible{color:var(--paper);outline:none}
.langtoggle__btn.is-on{background:var(--hazard);color:var(--ink-0)}
.langtoggle__btn + .langtoggle__btn{border-left:1px solid var(--line)}

@media (prefers-reduced-motion: reduce){
  .langtoggle__btn{transition:none}
}

/* ============ HERITAGE — 1962 LÉVESQUE ============ */
.heritage{position:relative;padding:clamp(64px,9vw,128px) 0;overflow:hidden;background:linear-gradient(180deg,#05070d 0%,#0a1224 60%,#05070d 100%);border-top:1px solid rgba(255,226,58,.12);border-bottom:1px solid rgba(255,226,58,.12)}
.heritage__bg{position:absolute;inset:0;pointer-events:none;background:
  radial-gradient(ellipse at 18% 30%, rgba(255,226,58,.08), transparent 55%),
  radial-gradient(ellipse at 82% 70%, rgba(54,140,255,.08), transparent 55%);
  mix-blend-mode:screen}
.heritage__inner{position:relative;z-index:1;max-width:1180px;margin:0 auto;padding:0 clamp(20px,4vw,48px)}
.heritage__split{display:grid;grid-template-columns:minmax(180px,260px) 1fr;gap:clamp(28px,5vw,72px);align-items:start;margin-top:18px}
.heritage__year{display:flex;flex-direction:column;align-items:flex-start;gap:6px;padding:clamp(20px,3vw,32px) clamp(24px,3.5vw,40px) clamp(20px,3vw,32px) clamp(20px,2.8vw,32px);border:1px solid rgba(255,226,58,.35);border-radius:6px;background:linear-gradient(160deg,rgba(255,226,58,.08),rgba(255,226,58,.02));position:relative;overflow:hidden}
.heritage__year::before{content:"";position:absolute;left:-1px;top:-1px;bottom:-1px;width:3px;background:var(--hazard);box-shadow:0 0 18px rgba(255,226,58,.55)}
.heritage__year-num{font-family:"Archivo Black","Bebas Neue",system-ui,sans-serif;font-size:clamp(56px,8vw,96px);line-height:1;color:var(--hazard);letter-spacing:0;padding-right:.08em}
.heritage__year-lbl{font-family:"JetBrains Mono",ui-monospace,monospace;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:rgba(232,236,243,.7)}
.heritage__title{font-family:"Archivo Black","Bebas Neue",system-ui,sans-serif;font-size:clamp(28px,4.2vw,52px);line-height:1.05;letter-spacing:-.01em;color:var(--paper);margin:0 0 18px}
.heritage__lead{font-size:clamp(16px,1.5vw,19px);line-height:1.65;color:rgba(232,236,243,.88);margin:0 0 18px;max-width:62ch}
.heritage__tiein{font-size:clamp(15px,1.4vw,17px);line-height:1.6;color:var(--paper);font-weight:600;border-left:3px solid var(--hazard);padding:6px 0 6px 18px;margin:0 0 18px;max-width:62ch}
.heritage__attrib{font-family:"JetBrains Mono",ui-monospace,monospace;font-size:11.5px;text-transform:uppercase;letter-spacing:.16em;color:rgba(232,236,243,.55);margin:0}
@media (max-width:780px){
  .heritage__split{grid-template-columns:1fr}
  .heritage__year{flex-direction:row;align-items:baseline;gap:14px;padding:14px 18px}
  .heritage__year-num{font-size:54px}
}

/* === LIVE COUNTER REDESIGN === */
.ctr-display{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:clamp(14px, 2.5vw, 28px);
  width:100%;
}
.ctr-row{
  display:flex;
  align-items:flex-end;
  justify-content:center;
  gap:clamp(8px, 2vw, 24px);
  flex-wrap:wrap;
}
.ctr-row--hms{ gap:clamp(6px, 1.5vw, 18px); }
.ctr-unit{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
}
.ctr-digits{
  display:flex;
  gap:2px;
}
.ctr-digit{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:clamp(3rem, 10vw, 8rem);
  font-weight:900;
  font-variant-numeric:tabular-nums;
  line-height:1;
  min-width:0.65ch;
  color:#fff;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:6px;
  padding:0.05em 0.08em;
  transition:color 0.15s;
  will-change:transform, opacity;
}
.ctr-unit__lbl{
  font-size:0.65rem;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.4);
  font-weight:600;
}
.ctr-sep{
  font-size:clamp(2rem, 6vw, 5rem);
  color:var(--accent, #e8002d);
  font-weight:900;
  line-height:1;
  align-self:flex-start;
  padding-top:4px;
  opacity:0.7;
  animation:sep-pulse 1s ease-in-out infinite alternate;
}

@keyframes digit-flip{
  0%   { transform:translateY(0) scaleY(1); opacity:1; }
  30%  { transform:translateY(-18%) scaleY(0.6); opacity:0.3; }
  60%  { transform:translateY(12%) scaleY(0.8); opacity:0.6; }
  100% { transform:translateY(0) scaleY(1); opacity:1; }
}
.ctr-digit.is-flipping{
  animation:digit-flip 0.28s cubic-bezier(0.22, 1, 0.36, 1) forwards;
  color:var(--accent, #e8002d);
}
@keyframes sep-pulse{
  from { opacity:0.35; }
  to   { opacity:0.9; }
}

#ctr-days .ctr-digit{
  font-size:clamp(4rem, 14vw, 11rem);
}
#ctr-days .ctr-unit__lbl{
  font-size:0.75rem;
  color:rgba(255,255,255,0.55);
}

@media (max-width: 480px){
  .ctr-digit{ font-size:clamp(2.2rem, 8vw, 3.5rem); }
  #ctr-days .ctr-digit{ font-size:clamp(3rem, 12vw, 5rem); }
  .ctr-sep{ font-size:clamp(1.5rem, 5vw, 2.5rem); }
}
@media (prefers-reduced-motion: reduce){
  .ctr-digit.is-flipping{ animation:none; color:#fff; }
  .ctr-sep{ animation:none; opacity:0.7; }
}

/* ============================================================
   SECTION SCROLL TRANSITIONS
   - .sec-fx is opted-in on each major section (not .hero, not .bgvideo).
   - Soft top/bottom edge gradient pseudo-elements blend section seams
     so consecutive blocks feel like one continuous scroll surface
     rather than abrupt blocks.
   - Modern browsers get a true scroll-driven entrance via
     `animation-timeline: view()` (Chrome/Edge 115+, Safari 18+):
     opacity, translateY and a faint blur are tied to viewport position,
     so the effect feels GPU-smooth and editorial.
   - Browsers without `view()` use the JS IntersectionObserver fallback
     toggling .is-revealed (set by app.js).
   - Hard opt-out under prefers-reduced-motion.
============================================================ */
.sec-fx{ position:relative; isolation:isolate; }

/* Edge gradients — bottom of one section + top of the next blend
   into the page background so the seam disappears.  Kept very subtle
   so they never compete with section content. */
.sec-fx::before,
.sec-fx::after{
  content:""; position:absolute; left:0; right:0; height:96px;
  pointer-events:none; z-index:3;
}
.sec-fx::before{
  top:0;
  background:linear-gradient(180deg, rgba(2,4,8,.55) 0%, rgba(2,4,8,0) 100%);
}
.sec-fx::after{
  bottom:0;
  background:linear-gradient(0deg, rgba(2,4,8,.55) 0%, rgba(2,4,8,0) 100%);
}

/* JS fallback: start hidden, reveal when IO adds .is-revealed. */
.sec-fx{
  opacity:0;
  transform:translate3d(0, 28px, 0);
  filter:blur(4px);
  transition:
    opacity .9s var(--ease-out, cubic-bezier(.22,1,.36,1)),
    transform 1s var(--ease-out, cubic-bezier(.22,1,.36,1)),
    filter .9s var(--ease-out, cubic-bezier(.22,1,.36,1));
  will-change:opacity, transform, filter;
}
.sec-fx.is-revealed{
  opacity:1;
  transform:none;
  filter:none;
}

/* Modern: scroll-driven, frame-perfect, no JS needed.
   When supported, this overrides the JS fallback transition. */
@supports (animation-timeline: view()){
  .sec-fx{
    /* Reset transition / static base — animation drives everything. */
    transition:none;
    opacity:1;
    transform:none;
    filter:none;
    animation: sec-enter linear both;
    animation-timeline: view();
    animation-range: entry 0% cover 22%;
  }
  @keyframes sec-enter{
    0%   { opacity:0; transform:translate3d(0, 36px, 0); filter:blur(5px); }
    60%  { opacity:1; }
    100% { opacity:1; transform:none; filter:none; }
  }
}

@media (prefers-reduced-motion: reduce){
  .sec-fx{
    opacity:1 !important;
    transform:none !important;
    filter:none !important;
    animation:none !important;
    transition:none !important;
  }
  .sec-fx::before,
  .sec-fx::after{ display:none; }
}
