/* ═══════════════════════════════════════════════════════════════════════
   QUESTDROP V3
   Cyberpunk · Synthwave · Neon
   ═══════════════════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
/* Suppress blue tap-flash on iOS Safari for all interactive elements */
a,button,[role="button"],[role="tab"]{-webkit-tap-highlight-color:transparent}

:root{
  --void:#0A0014;
  --void-2:#14081F;
  --deep:#1A0B2E;
  --purple:#2D1B4E;

  --magenta:#FF006E;
  --magenta-glow:rgba(255,0,110,.6);
  --cyan:#00F0FF;
  --cyan-glow:rgba(0,240,255,.6);
  --lime:#CCFF00;
  --lime-glow:rgba(204,255,0,.6);
  --yellow:#FFD600;
  --ice:#E0F7FF;
  --ice-dim:rgba(224,247,255,.5);
  --ice-soft:rgba(224,247,255,.15);
  --grid-line:rgba(255,0,110,.3);

  --ff-display:"Orbitron",sans-serif;
  --ff-body:"Chakra Petch",sans-serif;
  --ff-mono:"Share Tech Mono",monospace;

  --ease:cubic-bezier(.2,.8,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

html{scroll-behavior:smooth;background:var(--void)}

body{
  background:var(--void);
  color:var(--ice);
  font-family:var(--ff-body);
  font-weight:400;
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  position:relative;
}

/* ─── Radial gradient void backdrop ────────────────────────────────── */
body::before{
  content:'';
  position:fixed;
  inset:0;
  background:
    radial-gradient(ellipse at 20% 10%, rgba(255,0,110,.15) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 90%, rgba(0,240,255,.12) 0%, transparent 50%),
    radial-gradient(ellipse at 50% 50%, rgba(204,255,0,.05) 0%, transparent 70%);
  pointer-events:none;
  z-index:0;
}

/* ─── CRT scanlines ────────────────────────────────────────────────── */
body::after{
  content:'';
  position:fixed;
  inset:0;
  background:repeating-linear-gradient(
    to bottom,
    transparent 0,
    transparent 2px,
    rgba(0,0,0,.15) 2px,
    rgba(0,0,0,.15) 3px
  );
  pointer-events:none;
  z-index:9999;
  mix-blend-mode:overlay;
  opacity:.6;
}

::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--void)}
::-webkit-scrollbar-thumb{
  background:var(--magenta);
  box-shadow:0 0 10px var(--magenta-glow);
}

::selection{background:var(--magenta);color:var(--void)}

/* ─── a11y: Skip to content link ─────────────────────────────────────── */
.skip-link{
  position:absolute;
  top:-100px;left:8px;
  z-index:10000;
  padding:12px 20px;
  background:var(--lime);color:var(--void);
  font-family:var(--ff-mono);
  font-size:12px;font-weight:700;
  text-transform:uppercase;letter-spacing:.15em;
  text-decoration:none;
  transition:top .2s var(--ease);
}
.skip-link:focus{top:8px;outline:2px solid var(--magenta);outline-offset:2px}

/* ─── a11y: Focus visible styles ──────────────────────────────────────── */
button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--cyan);
  outline-offset:2px;
  box-shadow:0 0 0 4px rgba(0,240,255,.2);
}

/* ═══════════════════════════════════════════════════════════════════════
   NAVIGATION HUD
   ═══════════════════════════════════════════════════════════════════════ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:grid;grid-template-columns:1fr auto 1fr;
  align-items:center;
  padding:16px 32px;
  background:rgba(10,0,20,.85);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--grid-line);
}

.nav-left{
  font-family:var(--ff-mono);
  font-size:11px;
  color:var(--cyan);
  text-transform:uppercase;
  letter-spacing:.2em;
  text-shadow:0 0 10px var(--cyan-glow);
  display:flex;align-items:center;gap:10px;
}
.nav-left::before{
  content:'';
  width:8px;height:8px;
  background:var(--lime);
  border-radius:50%;
  box-shadow:0 0 12px var(--lime-glow);
  animation:pulse 1.5s infinite;
}

@keyframes pulse{
  50%{opacity:.4;transform:scale(.8)}
}

/* ═══ LOGO : SVG Q+D mark + wordmark (remplace l'ancien glitch texte) ═══ */
.logo{
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  cursor:pointer;
  user-select:none;
  padding:4px 10px 4px 4px;
  transition:transform .2s cubic-bezier(.2,.9,.3,1);
  color:var(--ice);
}
.logo:hover{transform:translateY(-1px)}
.logo:focus-visible{
  outline:2px solid var(--cyan);
  outline-offset:3px;
}
.logo-mark{
  flex:0 0 auto;
  transition:filter .3s ease;
  display:block;
}
.logo:hover .logo-mark{
  filter:drop-shadow(0 0 8px rgba(255,0,110,.45));
}
.logo-wordmark{
  font:900 18px/1 var(--ff-display);
  letter-spacing:.12em;
  color:var(--ice);
  white-space:nowrap;
}
.logo-wordmark .accent{
  color:var(--magenta);
  text-shadow:0 0 8px rgba(255,0,110,.55);
}
/* Mobile : Q+D seul, wordmark masqué pour laisser de la place */
@media (max-width:767px){
  .logo-wordmark{display:none}
  .logo{padding:4px}
  .logo-mark{width:42px; height:23px}
}

@keyframes glitch{
  0%,90%,100%{transform:translate(0)}
  92%{transform:translate(-2px,1px)}
  94%{transform:translate(2px,-1px)}
  96%{transform:translate(-1px,-2px)}
  98%{transform:translate(1px,2px)}
}

.nav-right{display:flex;gap:10px;justify-content:flex-end;align-items:center}

.nav-link{
  font-family:var(--ff-mono);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.15em;
  color:var(--ice-dim);
  background:none;border:none;
  cursor:pointer;
  padding:10px 0;
  transition:color .3s var(--ease),text-shadow .3s var(--ease);
}
.nav-link:hover{
  color:var(--cyan);
  text-shadow:0 0 10px var(--cyan-glow);
}

.nav-btn{
  font-family:var(--ff-mono);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.15em;
  padding:10px 18px;
  background:transparent;
  border:1px solid var(--magenta);
  color:var(--magenta);
  cursor:pointer;
  display:inline-flex;align-items:center;gap:10px;
  clip-path:polygon(8px 0,100% 0,calc(100% - 8px) 100%,0 100%);
  transition:all .3s var(--ease);
  box-shadow:
    0 0 0 var(--magenta-glow),
    inset 0 0 0 rgba(255,0,110,0);
}
.nav-btn:hover{
  background:var(--magenta);
  color:var(--void);
  box-shadow:
    0 0 20px var(--magenta-glow),
    0 0 40px var(--magenta-glow),
    inset 0 0 20px rgba(255,255,255,.2);
}

.badge{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--lime);color:var(--void);
  font-weight:700;font-size:10px;
  min-width:18px;height:18px;padding:0 5px;
  font-family:var(--ff-mono);
  box-shadow:0 0 8px var(--lime-glow);
}
.badge.hidden{display:none}

/* ═══════════════════════════════════════════════════════════════════════
   HERO ARENA
   ═══════════════════════════════════════════════════════════════════════ */
.hero{
  min-height:100vh;
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:120px 24px 80px;
  z-index:1;
  isolation:isolate;
}

/* Brand watermark subtil — plaque identité bas-droite */
.hero-watermark{
  position:absolute;
  bottom:-30px;
  right:-60px;
  width:min(600px, 80vw);
  height:auto;
  opacity:.10;
  mix-blend-mode:screen;
  pointer-events:none;
  z-index:0;
  filter:saturate(1.2);
  animation:hero-watermark-drift 24s ease-in-out infinite;
}
@keyframes hero-watermark-drift{
  0%,100%{transform:translate(0,0) rotate(0deg); opacity:.10}
  50%{transform:translate(-18px,-10px) rotate(-.8deg); opacity:.14}
}
.hero > *:not(.grid-floor):not(.sun):not(.particles):not(.hero-watermark){position:relative; z-index:1}

@media (max-width:767px){
  .hero-watermark{
    bottom:-40px;
    right:-100px;
    width:125vw;
    opacity:.06;
  }
}

/* ─── Animated grid floor ────────────────────────────────────────────── */
.grid-floor{
  position:absolute;
  bottom:0;left:0;right:0;
  height:50vh;
  perspective:400px;
  perspective-origin:center top;
  overflow:hidden;
  pointer-events:none;
  opacity:.7;
}
.grid-floor::before{
  content:'';
  position:absolute;
  inset:-50% -50% 0 -50%;
  background-image:
    linear-gradient(var(--grid-line) 1px,transparent 1px),
    linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);
  background-size:60px 60px;
  transform:rotateX(60deg);
  animation:gridMove 8s linear infinite;
  mask-image:linear-gradient(to top,black 0%,black 30%,transparent 100%);
  -webkit-mask-image:linear-gradient(to top,black 0%,black 30%,transparent 100%);
}
.grid-floor::after{
  content:'';
  position:absolute;
  bottom:0;left:0;right:0;height:120px;
  background:linear-gradient(to top,var(--void),transparent);
}

@keyframes gridMove{
  from{transform:rotateX(60deg) translateY(0)}
  to{transform:rotateX(60deg) translateY(60px)}
}

/* ─── Sun / horizon ──────────────────────────────────────────────────── */
.sun{
  position:absolute;
  bottom:30vh;left:50%;
  width:400px;height:400px;
  transform:translateX(-50%);
  background:radial-gradient(circle,var(--magenta) 0%,var(--yellow) 40%,transparent 70%);
  border-radius:50%;
  filter:blur(40px);
  opacity:.4;
  pointer-events:none;
}

/* ─── Floating particles ─────────────────────────────────────────────── */
.particles{
  position:absolute;inset:0;
  pointer-events:none;
  overflow:hidden;
}
.particle{
  position:absolute;
  width:2px;height:2px;
  background:var(--cyan);
  border-radius:50%;
  box-shadow:0 0 8px var(--cyan-glow);
  animation:float 20s linear infinite;
}

@keyframes float{
  from{transform:translateY(100vh)}
  to{transform:translateY(-10vh)}
}

.hero-eyebrow{
  position:relative;z-index:2;
  font-family:var(--ff-mono);
  font-size:12px;
  color:var(--cyan);
  text-transform:uppercase;
  letter-spacing:.4em;
  margin-bottom:40px;
  display:flex;align-items:center;gap:20px;
  opacity:0;animation:fadeIn .8s .3s forwards;
  text-shadow:0 0 10px var(--cyan-glow);
}
.hero-eyebrow .line{
  width:60px;height:1px;
  background:var(--cyan);
  box-shadow:0 0 8px var(--cyan-glow);
}

.hero-title{
  position:relative;z-index:2;
  font-family:var(--ff-display);
  font-weight:900;
  font-size:clamp(48px,10vw,140px);
  line-height:.95;
  letter-spacing:-.01em;
  text-align:center;
  color:var(--ice);
  text-shadow:
    0 0 20px var(--ice-dim),
    0 0 40px var(--magenta-glow),
    0 0 80px var(--magenta-glow);
  opacity:0;animation:fadeIn 1s .6s forwards;
}
.hero-title .accent{
  color:var(--magenta);
  text-shadow:
    0 0 20px var(--magenta),
    0 0 40px var(--magenta-glow),
    0 0 80px var(--magenta-glow);
  position:relative;
  display:inline-block;
}

.hero-sub{
  position:relative;z-index:2;
  font-family:var(--ff-mono);
  font-size:clamp(14px,1.3vw,18px);
  color:var(--ice-dim);
  text-transform:uppercase;
  letter-spacing:.15em;
  margin:32px auto 48px;
  max-width:700px;
  text-align:center;
  opacity:0;animation:fadeIn 1s .9s forwards;
}
.hero-sub .cursor{
  display:inline-block;
  width:8px;height:16px;
  background:var(--lime);
  margin-left:4px;
  vertical-align:middle;
  animation:blink 1s infinite;
  box-shadow:0 0 10px var(--lime-glow);
}

@keyframes blink{
  50%{opacity:0}
}

.hero-cta{
  position:relative;z-index:2;
  display:flex;gap:16px;flex-wrap:wrap;justify-content:center;
  opacity:0;animation:fadeIn 1s 1.2s forwards;
}

/* ─── HUD stats ──────────────────────────────────────────────────────── */
.hero-hud{
  position:relative;z-index:2;
  margin-top:80px;
  display:flex;gap:60px;
  flex-wrap:wrap;justify-content:center;
  opacity:0;animation:fadeIn 1s 1.5s forwards;
}
.hud-stat{
  text-align:center;
  padding:16px 24px;
  border:1px solid var(--ice-soft);
  clip-path:polygon(10px 0,100% 0,calc(100% - 10px) 100%,0 100%);
  background:rgba(255,0,110,.03);
  min-width:140px;
}
.hud-label{
  font-family:var(--ff-mono);
  font-size:9px;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--ice-dim);
  margin-bottom:6px;
}
.hud-value{
  font-family:var(--ff-display);
  font-weight:900;
  font-size:32px;
  color:var(--lime);
  text-shadow:0 0 15px var(--lime-glow);
  line-height:1;
}

/* ─── Neon buttons ───────────────────────────────────────────────────── */
.btn{
  font-family:var(--ff-mono);
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.2em;
  padding:16px 32px;
  border:1px solid currentColor;
  background:transparent;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:12px;
  position:relative;
  transition:all .3s var(--ease);
  clip-path:polygon(10px 0,100% 0,calc(100% - 10px) 100%,0 100%);
}

.btn-primary{
  color:var(--lime);
  border-color:var(--lime);
  box-shadow:0 0 0 var(--lime-glow);
}
.btn-primary:hover{
  background:var(--lime);
  color:var(--void);
  box-shadow:0 0 30px var(--lime-glow),0 0 60px var(--lime-glow);
}

.btn-magenta{
  color:var(--magenta);
  border-color:var(--magenta);
}
.btn-magenta:hover{
  background:var(--magenta);
  color:var(--void);
  box-shadow:0 0 30px var(--magenta-glow);
}

.btn-cyan{
  color:var(--cyan);
  border-color:var(--cyan);
}
.btn-cyan:hover{
  background:var(--cyan);
  color:var(--void);
  box-shadow:0 0 30px var(--cyan-glow);
}

.btn-ghost{
  color:var(--ice);
  border-color:var(--ice-soft);
}
.btn-ghost:hover{
  border-color:var(--ice);
  box-shadow:0 0 15px rgba(224,247,255,.3);
}

.btn-sm{padding:10px 18px;font-size:10px}
.btn-lg{padding:20px 40px;font-size:13px}

.btn .arrow{transition:transform .3s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

/* ═══════════════════════════════════════════════════════════════════════
   TERMINAL TICKER
   ═══════════════════════════════════════════════════════════════════════ */
.ticker{
  position:relative;z-index:1;
  background:linear-gradient(90deg,transparent,var(--deep) 20%,var(--deep) 80%,transparent);
  border-top:1px solid var(--magenta);
  border-bottom:1px solid var(--cyan);
  padding:14px 0;
  overflow:hidden;
  box-shadow:
    0 0 30px rgba(255,0,110,.3),
    inset 0 0 30px rgba(0,240,255,.1);
}
.ticker-track{
  display:flex;gap:60px;
  animation:tickerRun 40s linear infinite;
  white-space:nowrap;
  width:max-content;
}
.ticker-item{
  font-family:var(--ff-mono);
  font-size:13px;
  color:var(--ice-dim);
  letter-spacing:.1em;
  text-transform:uppercase;
  flex-shrink:0;
}
.ticker-item::before{
  content:'◆';
  color:var(--magenta);
  margin-right:16px;
  text-shadow:0 0 8px var(--magenta-glow);
}

@keyframes tickerRun{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ═══════════════════════════════════════════════════════════════════════
   ARENA MODE — Gallery with category shelves
   ═══════════════════════════════════════════════════════════════════════ */
.arena{
  position:relative;z-index:1;
  padding:80px 0 120px;
}

.arena-header{
  padding:0 40px 40px;
  max-width:1600px;margin:0 auto;
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:32px;
  align-items:end;
  border-bottom:1px solid var(--ice-soft);
  margin-bottom:60px;
}

.arena-num{
  font-family:var(--ff-mono);
  font-size:11px;
  color:var(--cyan);
  letter-spacing:.3em;
  text-transform:uppercase;
  text-shadow:0 0 8px var(--cyan-glow);
}

.arena-title{
  font-family:var(--ff-display);
  font-weight:900;
  font-size:clamp(40px,6vw,80px);
  line-height:.95;
  letter-spacing:.02em;
  text-transform:uppercase;
  color:var(--ice);
  text-shadow:0 0 20px var(--magenta-glow);
}
.arena-title .accent{
  color:var(--magenta);
  text-shadow:0 0 30px var(--magenta-glow);
}

.arena-meta{
  font-family:var(--ff-mono);
  font-size:11px;
  color:var(--ice-dim);
  letter-spacing:.15em;
  text-transform:uppercase;
  text-align:right;
}
.arena-meta .online{
  color:var(--lime);
  text-shadow:0 0 8px var(--lime-glow);
}

/* ─── Search + controls ─────────────────────────────────────────────── */
.controls{
  padding:0 40px 32px;
  max-width:1600px;margin:0 auto;
  display:grid;
  grid-template-columns:1fr auto;
  gap:20px;
  align-items:center;
}

.search-box{
  position:relative;
  display:flex;align-items:center;
  padding:12px 20px;
  background:rgba(26,11,46,.6);
  border:1px solid var(--cyan);
  box-shadow:0 0 20px rgba(0,240,255,.15),inset 0 0 20px rgba(0,240,255,.05);
}
.search-prompt{
  font-family:var(--ff-mono);
  color:var(--lime);
  margin-right:12px;
  text-shadow:0 0 8px var(--lime-glow);
}
.search-input{
  flex:1;
  background:transparent;
  border:none;
  color:var(--ice);
  font-family:var(--ff-mono);
  font-size:14px;
  outline:none;
  caret-color:var(--lime);
}
.search-input::placeholder{color:var(--ice-dim)}

.view-mode{
  display:flex;gap:0;
  border:1px solid var(--ice-soft);
}
.view-btn{
  padding:12px 18px;
  background:transparent;
  border:none;
  color:var(--ice-dim);
  font-family:var(--ff-mono);
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.15em;
  cursor:pointer;
  transition:all .3s var(--ease);
  border-right:1px solid var(--ice-soft);
}
.view-btn:last-child{border-right:none}
.view-btn.active{
  background:var(--magenta);
  color:var(--void);
  box-shadow:0 0 20px var(--magenta-glow);
}
.view-btn:hover:not(.active){color:var(--cyan)}

/* ─── SHELVES (horizontal category rows) ────────────────────────────── */
.shelf{
  margin-bottom:60px;
  position:relative;
}

.shelf-header{
  padding:0 40px 20px;
  max-width:1600px;margin:0 auto;
  display:flex;align-items:baseline;justify-content:space-between;gap:20px;
}

.shelf-title{
  font-family:var(--ff-display);
  font-weight:900;
  font-size:clamp(28px,3.5vw,48px);
  letter-spacing:.02em;
  text-transform:uppercase;
  color:var(--ice);
  display:flex;align-items:baseline;gap:20px;
  text-shadow:0 0 15px currentColor;
}
.shelf-title .idx{
  font-family:var(--ff-mono);
  font-size:12px;
  color:var(--ice-dim);
  letter-spacing:.2em;
  text-shadow:none;
}

.shelf-count{
  font-family:var(--ff-mono);
  font-size:11px;
  color:var(--ice-dim);
  letter-spacing:.15em;
  text-transform:uppercase;
}

.shelf-scroll{
  padding:20px 40px;
  overflow-x:auto;
  overflow-y:visible;
  scrollbar-width:thin;
  -webkit-overflow-scrolling:touch;
  position:relative;
}
.shelf-scroll::-webkit-scrollbar{height:4px}
.shelf-scroll::-webkit-scrollbar-thumb{background:currentColor;opacity:.3}

/* ─── LIVE shelf for ACTUALITÉ ──────────────────────────────────────── */
.shelf[data-cat="ACTUALITÉ"]{
  position:relative;
  padding:20px 0;
  background:
    linear-gradient(90deg,transparent,rgba(255,51,102,.04) 20%,rgba(255,51,102,.04) 80%,transparent);
  border-top:1px solid rgba(255,51,102,.3);
  border-bottom:1px solid rgba(255,51,102,.3);
  margin-bottom:80px;
}
.shelf[data-cat="ACTUALITÉ"]::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,#FF3366,transparent);
  animation:liveScan 3s linear infinite;
  box-shadow:0 0 15px #FF3366;
}
@keyframes liveScan{
  0%{transform:translateX(-100%)}
  100%{transform:translateX(100%)}
}

.live-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:4px 12px;
  background:#FF3366;
  color:var(--void);
  font-family:var(--ff-mono);
  font-size:10px;
  font-weight:700;
  letter-spacing:.25em;
  text-transform:uppercase;
  margin-left:16px;
  animation:livePulse 1.5s infinite;
  box-shadow:0 0 12px rgba(255,51,102,.8);
}
.live-badge::before{
  content:'';
  width:8px;height:8px;
  background:var(--void);
  border-radius:50%;
}
@keyframes livePulse{
  50%{box-shadow:0 0 25px rgba(255,51,102,1),0 0 50px rgba(255,51,102,.5)}
}

.shelf-row{
  display:flex;
  gap:20px;
  padding-bottom:20px;
  width:max-content;
}

/* ═══════════════════════════════════════════════════════════════════════
   QUESTION CARDS — Holographic
   ═══════════════════════════════════════════════════════════════════════ */
.q-card{
  flex-shrink:0;
  width:320px;
  min-height:400px;
  padding:28px 24px;
  background:
    linear-gradient(135deg,rgba(255,0,110,.06) 0%,rgba(0,240,255,.04) 100%),
    var(--void-2);
  border:1px solid var(--ice-soft);
  position:relative;
  transition:all .4s var(--ease);
  display:flex;
  flex-direction:column;
  cursor:pointer;
  overflow:hidden;
  transform-style:preserve-3d;
}

/* corner decorations */
.q-card::before,
.q-card::after{
  content:'';
  position:absolute;
  width:20px;height:20px;
  border:1px solid var(--magenta);
  transition:all .3s var(--ease);
}
.q-card::before{
  top:-1px;left:-1px;
  border-right:none;border-bottom:none;
  box-shadow:0 0 8px var(--magenta-glow);
}
.q-card::after{
  bottom:-1px;right:-1px;
  border-left:none;border-top:none;
  box-shadow:0 0 8px var(--magenta-glow);
}

.q-card:hover{
  transform:translateY(-6px) scale(1.02);
  border-color:var(--magenta);
  box-shadow:
    0 0 40px var(--magenta-glow),
    0 0 80px rgba(255,0,110,.3),
    inset 0 0 30px rgba(255,0,110,.08);
  z-index:10;
}

.q-card:hover::before,
.q-card:hover::after{
  width:40px;height:40px;
}

.q-card.in-thread{
  border-color:var(--lime);
  background:
    linear-gradient(135deg,rgba(204,255,0,.08) 0%,rgba(0,240,255,.04) 100%),
    var(--void-2);
  box-shadow:
    0 0 30px var(--lime-glow),
    inset 0 0 20px rgba(204,255,0,.05);
}
.q-card.in-thread::before,
.q-card.in-thread::after{
  border-color:var(--lime);
  box-shadow:0 0 12px var(--lime-glow);
}

/* Landing card — when arriving via /q/N/ */
.q-card.card-landing{
  animation:cardLanding 2.5s var(--ease-out);
  z-index:20;
}
@keyframes cardLanding{
  0%{
    box-shadow:0 0 80px var(--magenta),0 0 160px var(--magenta-glow);
    transform:translateY(-8px) scale(1.06);
  }
  50%{
    box-shadow:0 0 60px var(--magenta-glow),0 0 120px var(--magenta-glow);
  }
  100%{
    box-shadow:0 0 0 transparent;
    transform:translateY(0) scale(1);
  }
}

.q-card-num{
  font-family:var(--ff-mono);
  font-size:11px;
  color:var(--cyan);
  letter-spacing:.2em;
  text-shadow:0 0 8px var(--cyan-glow);
  margin-bottom:20px;
  display:flex;justify-content:space-between;align-items:center;
}
.q-card-num .status{
  width:8px;height:8px;
  background:var(--lime);
  box-shadow:0 0 10px var(--lime-glow);
  border-radius:50%;
  animation:pulse 2s infinite;
}

.q-card-cat{
  font-family:var(--ff-mono);
  font-size:10px;
  letter-spacing:.25em;
  text-transform:uppercase;
  margin-bottom:20px;
  padding:4px 10px;
  display:inline-block;
  align-self:flex-start;
  border:1px solid currentColor;
}

.q-card-text{
  font-family:var(--ff-body);
  font-weight:500;
  font-size:17px;
  line-height:1.4;
  color:var(--ice);
  margin-bottom:auto;
  padding-bottom:24px;
}

.q-card-actions{
  display:flex;gap:8px;flex-wrap:wrap;
  margin-top:auto;
  padding-top:20px;
  border-top:1px solid var(--ice-soft);
}

.q-btn{
  font-family:var(--ff-mono);
  font-size:10px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.15em;
  padding:8px 12px;
  background:transparent;
  border:1px solid var(--ice-soft);
  color:var(--ice-dim);
  cursor:pointer;
  transition:all .3s var(--ease);
  display:inline-flex;align-items:center;gap:6px;
  flex:1;justify-content:center;
}
.q-btn:hover{
  color:var(--lime);
  border-color:var(--lime);
  text-shadow:0 0 8px var(--lime-glow);
  box-shadow:0 0 15px rgba(204,255,0,.2);
}
.q-btn-primary{
  color:var(--cyan);
  border-color:var(--cyan);
}
.q-btn-primary:hover{
  background:var(--cyan);
  color:var(--void);
  box-shadow:0 0 15px var(--cyan-glow);
}
.q-btn-active{
  color:var(--lime);
  border-color:var(--lime);
  background:rgba(204,255,0,.1);
  text-shadow:0 0 8px var(--lime-glow);
}

/* Category colors */
/* Note: multi-word category names use dashes (cat-RELATION-AMOUREUSE,
   cat-MISE-EN-SITUATION) because the HTML class attribute splits on whitespace.
   The JS helper `catSlug()` converts spaces → dashes for both FR and EN cats. */
.cat-ACTUALITÉ{color:#FF3366}
.cat-NEWS{color:#FF3366}
.cat-SOCIAL{color:#00FFA3}
.cat-RELATION-AMOUREUSE{color:#FF00AA}
.cat-DATING{color:#FF00AA}
.cat-IDENTITÉ{color:#FF006E}
.cat-IDENTITY{color:#FF006E}
.cat-COURAGE{color:#FFD600}
.cat-CONVICTIONS{color:#FF8800}
.cat-BELIEFS{color:#FF8800}
.cat-CONFRONTATION{color:#FF3B30}
.cat-SOCIÉTÉ{color:#00F0FF}
.cat-SOCIETY{color:#00F0FF}
.cat-PHILOSOPHIE{color:#B026FF}
.cat-PHILOSOPHY{color:#B026FF}
.cat-AMBITION{color:#FF6A00}
.cat-RELATIONS{color:#FF00D4}
.cat-RELATIONSHIPS{color:#FF00D4}
.cat-INTROSPECTION{color:#00FFA3}
.cat-PROVOCATION{color:#CCFF00}
.cat-MISE-EN-SITUATION{color:#A0FF41}
.cat-SCENARIOS{color:#A0FF41}

/* ═══════════════════════════════════════════════════════════════════════
   FEATURED — Hero drop
   ═══════════════════════════════════════════════════════════════════════ */
.featured{
  max-width:1600px;margin:0 auto 60px;
  padding:0 40px;
}

.featured-inner{
  position:relative;
  padding:60px;
  background:
    linear-gradient(135deg,rgba(255,0,110,.1) 0%,rgba(0,240,255,.05) 50%,rgba(204,255,0,.08) 100%),
    var(--deep);
  border:1px solid var(--magenta);
  overflow:hidden;
  box-shadow:
    0 0 40px rgba(255,0,110,.3),
    inset 0 0 60px rgba(0,240,255,.08);
  clip-path:polygon(20px 0,100% 0,100% calc(100% - 20px),calc(100% - 20px) 100%,0 100%,0 20px);
}

.featured-inner::before{
  content:'';
  position:absolute;inset:0;
  background-image:
    linear-gradient(var(--grid-line) 1px,transparent 1px),
    linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);
  background-size:40px 40px;
  opacity:.15;
  pointer-events:none;
}

.featured-label{
  font-family:var(--ff-mono);
  font-size:11px;
  color:var(--yellow);
  letter-spacing:.3em;
  text-transform:uppercase;
  margin-bottom:24px;
  display:inline-flex;align-items:center;gap:12px;
  text-shadow:0 0 10px rgba(255,214,0,.6);
  position:relative;
}
.featured-label::before{
  content:'';
  width:50px;height:1px;
  background:var(--yellow);
  box-shadow:0 0 8px var(--yellow);
}

.featured-text{
  position:relative;
  font-family:var(--ff-display);
  font-weight:700;
  font-size:clamp(28px,4vw,52px);
  line-height:1.15;
  letter-spacing:-.01em;
  margin-bottom:40px;
  color:var(--ice);
  text-shadow:0 0 20px rgba(224,247,255,.3);
  max-width:1100px;
}
.featured-text .accent{
  color:var(--magenta);
  text-shadow:0 0 20px var(--magenta-glow),0 0 40px var(--magenta-glow);
}

.featured-actions{
  position:relative;
  display:flex;gap:16px;flex-wrap:wrap;
}

/* ═══════════════════════════════════════════════════════════════════════
   SUBMIT SECTION
   ═══════════════════════════════════════════════════════════════════════ */
.submit{
  position:relative;z-index:1;
  padding:120px 40px;
  background:
    linear-gradient(180deg,transparent,rgba(255,0,110,.05)),
    var(--void-2);
  border-top:1px solid var(--magenta);
  border-bottom:1px solid var(--cyan);
  overflow:hidden;
}

.submit::before{
  content:'';
  position:absolute;inset:0;
  background-image:
    linear-gradient(var(--grid-line) 1px,transparent 1px),
    linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);
  background-size:50px 50px;
  opacity:.2;
  pointer-events:none;
}

.submit-inner{
  max-width:1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:80px;
  align-items:start;
  position:relative;
}

.submit-label{
  font-family:var(--ff-mono);
  font-size:11px;
  color:var(--lime);
  letter-spacing:.3em;
  text-transform:uppercase;
  margin-bottom:24px;
  text-shadow:0 0 10px var(--lime-glow);
}

.submit-title{
  font-family:var(--ff-display);
  font-weight:900;
  font-size:clamp(40px,5.5vw,76px);
  line-height:1;
  letter-spacing:.01em;
  text-transform:uppercase;
  color:var(--ice);
  margin-bottom:24px;
  text-shadow:0 0 30px var(--magenta-glow);
}
.submit-title .accent{
  color:var(--cyan);
  text-shadow:0 0 30px var(--cyan-glow);
}

.submit-lead{
  font-family:var(--ff-mono);
  font-size:14px;
  line-height:1.7;
  color:var(--ice-dim);
  margin-bottom:32px;
  max-width:460px;
  letter-spacing:.02em;
}

.submit-rules{
  display:flex;flex-direction:column;gap:14px;
  margin-top:32px;
  padding:24px;
  background:rgba(10,0,20,.4);
  border:1px solid var(--ice-soft);
}

.rule{
  display:flex;align-items:center;gap:12px;
  font-family:var(--ff-mono);
  font-size:12px;
  color:var(--ice-dim);
  letter-spacing:.05em;
  text-transform:uppercase;
}
.rule-mark{
  font-family:var(--ff-mono);
  font-size:14px;
  font-weight:700;
  width:24px;height:24px;
  display:flex;align-items:center;justify-content:center;
}
.rule-ok .rule-mark{color:var(--lime);text-shadow:0 0 8px var(--lime-glow)}
.rule-no .rule-mark{color:var(--magenta);text-shadow:0 0 8px var(--magenta-glow)}

.submit-form{display:flex;flex-direction:column;gap:24px}

.form-label{
  font-family:var(--ff-mono);
  font-size:10px;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:var(--cyan);
  margin-bottom:8px;
  display:block;
  text-shadow:0 0 8px var(--cyan-glow);
}

.form-textarea,.form-select{
  width:100%;
  background:rgba(10,0,20,.6);
  border:1px solid var(--ice-soft);
  color:var(--ice);
  font-family:var(--ff-body);
  font-size:16px;
  padding:18px 24px;
  outline:none;
  transition:all .3s var(--ease);
}
.form-textarea{resize:vertical;min-height:140px;font-family:var(--ff-body)}
.form-textarea:focus,.form-select:focus{
  border-color:var(--magenta);
  box-shadow:0 0 20px rgba(255,0,110,.2);
}
.form-textarea::placeholder{color:var(--ice-dim)}

.form-select{
  appearance:none;-webkit-appearance:none;
  cursor:pointer;
  font-family:var(--ff-mono);
  letter-spacing:.05em;
}
.form-select option{background:var(--deep);color:var(--ice)}

.form-select-wrap{position:relative}
.form-select-wrap::after{
  content:'▼';
  position:absolute;
  right:20px;top:50%;
  transform:translateY(-50%);
  color:var(--cyan);
  pointer-events:none;
  font-size:10px;
}

.char-count{
  font-family:var(--ff-mono);
  font-size:11px;
  color:var(--ice-dim);
  text-align:right;
  margin-top:8px;
  letter-spacing:.1em;
}
.char-count.warn{color:var(--yellow);text-shadow:0 0 8px rgba(255,214,0,.6)}

.submit-success{
  display:none;
  padding:20px 24px;
  background:rgba(204,255,0,.1);
  border:1px solid var(--lime);
  color:var(--lime);
  font-family:var(--ff-mono);
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.1em;
  margin-top:12px;
  box-shadow:0 0 20px rgba(204,255,0,.2);
}

/* ═══════════════════════════════════════════════════════════════════════
   THREAD / LOADOUT
   ═══════════════════════════════════════════════════════════════════════ */
.thread-fab{
  position:fixed;
  bottom:32px;right:32px;
  z-index:150;
  padding:14px 24px;
  font-family:var(--ff-mono);
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.2em;
  background:var(--magenta);
  color:var(--void);
  border:none;
  cursor:pointer;
  display:flex;align-items:center;gap:12px;
  clip-path:polygon(10px 0,100% 0,calc(100% - 10px) 100%,0 100%);
  box-shadow:0 0 30px var(--magenta-glow),0 8px 24px rgba(0,0,0,.5);
  transition:all .3s var(--ease);
}
.thread-fab:hover{
  background:var(--lime);
  box-shadow:0 0 40px var(--lime-glow),0 12px 32px rgba(0,0,0,.6);
  transform:translateY(-2px);
}
.thread-fab.hidden{display:none}

.fab-badge{
  background:var(--void);
  color:var(--magenta);
  padding:2px 8px;
  font-size:10px;
  font-weight:700;
}
.thread-fab:hover .fab-badge{color:var(--lime)}

.thread-panel{
  position:fixed;
  top:0;right:0;bottom:0;
  width:480px;max-width:92vw;
  background:
    linear-gradient(180deg,var(--deep),var(--void-2));
  border-left:1px solid var(--magenta);
  z-index:200;
  transform:translateX(100%);
  transition:transform .5s var(--ease-out);
  display:flex;flex-direction:column;
  box-shadow:-20px 0 60px rgba(0,0,0,.6),inset 0 0 40px rgba(255,0,110,.05);
}
.thread-panel.open{transform:translateX(0)}

.thread-head{
  padding:28px 32px;
  border-bottom:1px solid var(--magenta);
  display:flex;justify-content:space-between;align-items:start;gap:16px;
  background:rgba(10,0,20,.6);
}

.thread-head-label{
  font-family:var(--ff-mono);
  font-size:10px;
  color:var(--cyan);
  letter-spacing:.3em;
  text-transform:uppercase;
  margin-bottom:8px;
  text-shadow:0 0 8px var(--cyan-glow);
}

.thread-head-title{
  font-family:var(--ff-display);
  font-weight:900;
  font-size:28px;
  letter-spacing:.02em;
  text-transform:uppercase;
  color:var(--ice);
  text-shadow:0 0 15px var(--magenta-glow);
}

.thread-head-count{
  font-family:var(--ff-mono);
  font-size:11px;
  color:var(--lime);
  margin-top:6px;
  letter-spacing:.1em;
  text-shadow:0 0 8px var(--lime-glow);
}

.thread-close{
  width:40px;height:40px;
  border:1px solid var(--ice-soft);
  background:transparent;
  color:var(--ice);
  font-size:18px;
  cursor:pointer;
  transition:all .3s var(--ease);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.thread-close:hover{
  border-color:var(--magenta);
  color:var(--magenta);
  box-shadow:0 0 15px var(--magenta-glow);
}

.thread-body{
  flex:1;
  overflow-y:auto;
  padding:20px 32px 40px;
}

.thread-item{
  padding:16px 0;
  border-bottom:1px solid var(--ice-soft);
  display:grid;grid-template-columns:auto 1fr auto;gap:16px;
  align-items:start;
}
.thread-item:last-child{border-bottom:none}

.thread-item-num{
  font-family:var(--ff-mono);
  font-size:16px;
  font-weight:700;
  color:var(--lime);
  text-shadow:0 0 10px var(--lime-glow);
}

.thread-item-content{min-width:0}
.thread-item-cat{
  font-family:var(--ff-mono);
  font-size:9px;
  letter-spacing:.25em;
  text-transform:uppercase;
  margin-bottom:6px;
  opacity:.8;
}
.thread-item-text{
  font-family:var(--ff-body);
  font-size:14px;
  line-height:1.4;
  color:var(--ice);
}

.thread-item-del{
  background:transparent;
  border:none;
  color:var(--ice-dim);
  font-size:18px;
  cursor:pointer;
  padding:4px 8px;
  transition:all .2s var(--ease);
}
.thread-item-del:hover{color:var(--magenta);text-shadow:0 0 8px var(--magenta-glow)}

.thread-empty{
  padding:80px 32px;
  text-align:center;
  font-family:var(--ff-mono);
  font-size:13px;
  color:var(--ice-dim);
  letter-spacing:.1em;
  text-transform:uppercase;
  line-height:1.8;
}
.thread-empty::before{
  content:'⟡';
  display:block;
  font-size:48px;
  margin-bottom:20px;
  color:var(--cyan);
  text-shadow:0 0 20px var(--cyan-glow);
}

.thread-foot{
  padding:24px 32px;
  border-top:1px solid var(--magenta);
  display:flex;flex-direction:column;gap:10px;
  background:rgba(10,0,20,.8);
}

/* ═══════════════════════════════════════════════════════════════════════
   MODALS
   ═══════════════════════════════════════════════════════════════════════ */
.overlay{
  position:fixed;inset:0;
  background:rgba(10,0,20,.92);
  backdrop-filter:blur(8px);
  z-index:500;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  opacity:0;pointer-events:none;
  transition:opacity .3s var(--ease);
}
.overlay.open{opacity:1;pointer-events:all}

.modal{
  max-width:600px;width:100%;
  background:var(--deep);
  border:1px solid var(--cyan);
  padding:48px;
  position:relative;
  max-height:90vh;
  overflow-y:auto;
  transform:translateY(20px) scale(.98);
  transition:transform .4s var(--ease-out);
  box-shadow:0 0 40px rgba(0,240,255,.3),inset 0 0 60px rgba(0,240,255,.05);
  clip-path:polygon(20px 0,100% 0,100% calc(100% - 20px),calc(100% - 20px) 100%,0 100%,0 20px);
}
.overlay.open .modal{transform:translateY(0) scale(1)}
.modal-lg{max-width:720px}

.modal-close{
  position:absolute;top:20px;right:20px;
  width:40px;height:40px;
  border:1px solid var(--ice-soft);
  background:transparent;
  color:var(--ice);
  font-size:16px;
  cursor:pointer;
  transition:all .3s var(--ease);
  display:flex;align-items:center;justify-content:center;
}
.modal-close:hover{
  border-color:var(--magenta);
  color:var(--magenta);
  box-shadow:0 0 15px var(--magenta-glow);
}

.modal-label{
  font-family:var(--ff-mono);
  font-size:11px;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--lime);
  margin-bottom:16px;
  text-shadow:0 0 10px var(--lime-glow);
}

.modal-title{
  font-family:var(--ff-display);
  font-weight:900;
  font-size:36px;
  letter-spacing:.02em;
  text-transform:uppercase;
  margin-bottom:12px;
  color:var(--ice);
  text-shadow:0 0 20px var(--magenta-glow);
}

.modal-sub{
  font-family:var(--ff-mono);
  font-size:13px;
  color:var(--ice-dim);
  letter-spacing:.05em;
  margin-bottom:28px;
}

.modal-q{
  font-family:var(--ff-body);
  font-size:20px;
  font-weight:500;
  line-height:1.4;
  padding:24px;
  background:rgba(10,0,20,.6);
  border-left:3px solid var(--magenta);
  margin-bottom:28px;
  color:var(--ice);
  box-shadow:inset 0 0 20px rgba(255,0,110,.05);
}

.share-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
}

/* ─── Universal native share button (mobile) ────────────────────────── */
.share-universal-btn{
  display:none;
  width:100%;
  padding:20px 24px;
  background:var(--lime);
  color:var(--void);
  border:none;
  font-family:var(--ff-mono);
  font-size:13px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.2em;
  cursor:pointer;
  margin-bottom:16px;
  align-items:center;justify-content:center;gap:14px;
  clip-path:polygon(10px 0,100% 0,calc(100% - 10px) 100%,0 100%);
  box-shadow:0 0 30px var(--lime-glow);
  transition:all .3s var(--ease);
}
.share-universal-btn:hover{
  box-shadow:0 0 40px var(--lime-glow),0 0 80px var(--lime-glow);
  transform:translateY(-2px);
}

/* ─── Share guidance note ───────────────────────────────────────────── */
.share-note{
  margin-top:24px;
  padding:18px 22px;
  background:rgba(0,240,255,.05);
  border-left:2px solid var(--cyan);
  font-family:var(--ff-mono);
  font-size:11px;
  line-height:1.7;
  color:var(--ice-dim);
  letter-spacing:.02em;
}
.share-note strong{
  display:block;
  color:var(--lime);
  margin-bottom:10px;
  font-size:10px;
  letter-spacing:.25em;
  text-transform:uppercase;
  text-shadow:0 0 8px var(--lime-glow);
}
.share-note p{
  margin:4px 0;
}

.share-btn{
  padding:24px;
  border:1px solid var(--ice-soft);
  background:rgba(10,0,20,.4);
  cursor:pointer;
  text-align:left;
  transition:all .3s var(--ease);
  position:relative;overflow:hidden;
  /* Anchor-tag resets (buttons are styled neutrally already) */
  color:inherit;
  text-decoration:none;
  display:block;
  font:inherit;
}
.share-btn:hover{
  border-color:var(--cyan);
  box-shadow:0 0 20px var(--cyan-glow),inset 0 0 20px rgba(0,240,255,.05);
  transform:translateY(-2px);
}

.share-btn-icon{
  font-family:var(--ff-display);
  font-size:32px;
  color:var(--magenta);
  margin-bottom:14px;
  display:block;
  text-shadow:0 0 12px var(--magenta-glow);
}
.share-btn-name{
  font-family:var(--ff-mono);
  font-size:12px;
  font-weight:700;
  color:var(--ice);
  text-transform:uppercase;
  letter-spacing:.2em;
  display:block;
  margin-bottom:4px;
}
.share-btn-desc{
  font-family:var(--ff-mono);
  font-size:10px;
  color:var(--ice-dim);
  letter-spacing:.1em;
}

.tm-preview{
  background:rgba(10,0,20,.6);
  padding:24px;
  margin:20px 0;
  max-height:300px;
  overflow-y:auto;
  border:1px solid var(--ice-soft);
  font-family:var(--ff-mono);
  font-size:13px;
  line-height:1.6;
  color:var(--ice);
}
.tm-tweet{
  padding:14px 0;
  border-bottom:1px solid var(--ice-soft);
  white-space:pre-line;
}
.tm-tweet:last-child{border:none}
.tm-tweet-num{
  color:var(--lime);
  font-size:10px;
  letter-spacing:.2em;
  text-transform:uppercase;
  margin-bottom:6px;
  display:block;
  text-shadow:0 0 8px var(--lime-glow);
}

.tm-tips{
  margin-top:20px;
  padding:20px 24px;
  background:rgba(0,240,255,.05);
  border:1px solid var(--cyan);
  font-family:var(--ff-mono);
  font-size:12px;
  line-height:1.8;
  color:var(--ice-dim);
}
.tm-tips strong{
  color:var(--lime);
  display:block;
  margin-bottom:10px;
  font-size:10px;
  letter-spacing:.25em;
  text-transform:uppercase;
  text-shadow:0 0 8px var(--lime-glow);
}
.tm-tips ol{padding-left:24px;display:flex;flex-direction:column;gap:4px}

/* ═══════════════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════════════ */
.footer{
  position:relative;z-index:1;
  border-top:1px solid var(--magenta);
  padding:80px 40px 40px;
  background:var(--void);
}

.footer-main{
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:60px;
  max-width:1600px;margin:0 auto 60px;
}

.footer-brand{
  font-family:var(--ff-display);
  font-weight:900;
  font-size:clamp(48px,7vw,100px);
  letter-spacing:.05em;
  line-height:1;
  color:var(--ice);
  text-shadow:0 0 30px var(--magenta-glow),0 0 60px var(--magenta-glow);
}
.footer-brand .accent{
  color:var(--magenta);
  text-shadow:0 0 40px var(--magenta-glow);
}

.footer-tagline{
  font-family:var(--ff-mono);
  font-size:13px;
  color:var(--ice-dim);
  margin-top:20px;
  max-width:360px;
  letter-spacing:.05em;
  line-height:1.6;
}

.footer-col-title{
  font-family:var(--ff-mono);
  font-size:10px;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--cyan);
  margin-bottom:20px;
  text-shadow:0 0 8px var(--cyan-glow);
}

.footer-link{
  display:block;
  font-family:var(--ff-mono);
  font-size:13px;
  color:var(--ice);
  text-decoration:none;
  padding:6px 0;
  cursor:pointer;
  background:none;border:none;
  text-align:left;
  letter-spacing:.05em;
  transition:color .3s var(--ease);
}
.footer-link:hover{color:var(--magenta);text-shadow:0 0 8px var(--magenta-glow)}

.footer-bottom{
  border-top:1px solid var(--ice-soft);
  padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--ff-mono);
  font-size:10px;
  color:var(--ice-dim);
  letter-spacing:.2em;
  text-transform:uppercase;
  max-width:1600px;margin:0 auto;
}

/* ═══════════════════════════════════════════════════════════════════════
   TOAST
   ═══════════════════════════════════════════════════════════════════════ */
.toast{
  position:fixed;
  bottom:32px;left:50%;
  transform:translateX(-50%) translateY(100px);
  background:var(--void);
  border:1px solid var(--lime);
  color:var(--lime);
  padding:14px 28px;
  font-family:var(--ff-mono);
  font-size:12px;
  letter-spacing:.15em;
  text-transform:uppercase;
  z-index:9000;
  transition:transform .5s var(--ease-out);
  box-shadow:0 0 30px var(--lime-glow);
  pointer-events:none;
  clip-path:polygon(10px 0,100% 0,calc(100% - 10px) 100%,0 100%);
  max-width:90vw;text-align:center;
}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ═══════════════════════════════════════════════════════════════════════
   ANIMATIONS
   ═══════════════════════════════════════════════════════════════════════ */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}

.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ═══════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .submit-inner{grid-template-columns:1fr;gap:40px}
  .footer-main{grid-template-columns:1fr 1fr}
}

@media(max-width:768px){
  .nav{padding:14px 16px;grid-template-columns:1fr auto}
  .nav-left{display:none}
  .nav-link{display:none}
  .logo{font-size:20px}

  .hero{padding:100px 20px 60px}
  .hero-hud{gap:16px}
  .hud-stat{min-width:100px;padding:12px 16px}

  .arena-header{padding:0 20px 32px;grid-template-columns:1fr;gap:16px}
  .arena-meta{text-align:left}

  .controls{padding:0 20px 24px;grid-template-columns:1fr}
  .view-mode{display:none}

  .shelf-header{padding:0 20px 16px}
  .shelf-scroll{padding:20px 20px}

  .q-card{width:280px;min-height:360px}

  .featured{padding:0 20px}
  .featured-inner{padding:32px 24px}

  .submit{padding:80px 20px}

  .thread-panel{width:100%}
  .thread-fab{bottom:20px;right:20px}

  .modal{padding:32px 20px}
  .share-grid{grid-template-columns:1fr}

  .footer{padding:60px 20px 30px}
  .footer-main{grid-template-columns:1fr;gap:40px;margin-bottom:40px}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center}
}

@media(max-width:480px){
  .hero-cta .btn{width:100%;justify-content:center}
  .q-card{width:calc(85vw);max-width:300px}
}

/* ═══════════════════════════════════════════════════════════════════════
   NEW COMPONENTS — Cookie Banner / Create Banner / Nav CTA / Lang / Social shelf
   ═══════════════════════════════════════════════════════════════════════ */

/* ─── Nav CREATE button (always visible CTA) ────────────────────────────── */
.nav-btn-create{
  color:var(--lime);
  border-color:var(--lime);
  background:rgba(204,255,0,.08);
  box-shadow:0 0 20px rgba(204,255,0,.25);
}
.nav-btn-create:hover{
  background:var(--lime);
  color:var(--void);
  box-shadow:0 0 30px var(--lime-glow),0 0 60px var(--lime-glow);
}

/* ─── Nav language switcher ─────────────────────────────────────────────── */
.nav-lang{
  font-family:var(--ff-mono);
  font-size:11px;
  letter-spacing:.25em;
  color:var(--ice-dim);
  text-decoration:none;
  padding:10px 12px;
  border:1px solid var(--ice-soft);
  transition:all .3s var(--ease);
}
.nav-lang:hover{
  color:var(--cyan);
  border-color:var(--cyan);
  box-shadow:0 0 15px var(--cyan-glow);
}

/* ─── CRÉATION banner — replaces old submit section ─────────────────────── */
.create-banner{
  position:relative;z-index:1;
  padding:100px 40px;
  background:
    linear-gradient(135deg,rgba(204,255,0,.05) 0%,rgba(255,0,110,.03) 100%),
    var(--void-2);
  border-top:1px solid var(--lime);
  border-bottom:1px solid var(--lime);
  overflow:hidden;
  text-align:center;
}
.create-banner::before{
  content:'';
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(204,255,0,.12) 1px,transparent 1px),
    linear-gradient(90deg,rgba(204,255,0,.12) 1px,transparent 1px);
  background-size:50px 50px;
  opacity:.15;pointer-events:none;
}
.create-banner-inner{
  position:relative;
  max-width:800px;
  margin:0 auto;
}
.create-banner-label{
  font-family:var(--ff-mono);
  font-size:11px;
  color:var(--lime);
  letter-spacing:.3em;
  text-transform:uppercase;
  margin-bottom:24px;
  text-shadow:0 0 10px var(--lime-glow);
}
.create-banner-title{
  font-family:var(--ff-display);
  font-weight:900;
  font-size:clamp(36px,5vw,68px);
  line-height:1.05;
  letter-spacing:.01em;
  color:var(--ice);
  margin-bottom:28px;
  text-shadow:0 0 30px rgba(204,255,0,.3);
}
.create-banner-title .accent{
  color:var(--lime);
  text-shadow:0 0 30px var(--lime-glow);
}
.create-banner-lead{
  font-family:var(--ff-mono);
  font-size:14px;
  line-height:1.7;
  color:var(--ice-dim);
  max-width:600px;
  margin:0 auto 40px;
  letter-spacing:.02em;
}

/* ─── Cookie Banner (RGPD) ──────────────────────────────────────────────── */
.cookie-banner{
  position:fixed;
  bottom:-200px;left:0;right:0;
  z-index:9998;
  background:rgba(10,0,20,.98);
  backdrop-filter:blur(20px);
  border-top:1px solid var(--cyan);
  padding:20px 24px;
  box-shadow:0 -20px 60px rgba(0,240,255,.2);
  transition:bottom .5s var(--ease-out);
}
.cookie-banner.show{bottom:0}
.cookie-content{
  max-width:1200px;
  margin:0 auto;
  display:flex;
  gap:24px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
}
.cookie-text{flex:1;min-width:260px}
.cookie-text strong{
  display:block;
  color:var(--lime);
  font-family:var(--ff-mono);
  font-size:14px;
  margin-bottom:6px;
  letter-spacing:.05em;
}
.cookie-text p{
  font-family:var(--ff-body);
  font-size:13px;
  line-height:1.5;
  color:var(--ice-dim);
  margin:0;
}
.cookie-actions{
  display:flex;gap:12px;flex-shrink:0;
}
.cookie-btn{
  padding:12px 24px;
  font-family:var(--ff-mono);
  font-size:11px;
  font-weight:700;
  letter-spacing:.15em;
  text-transform:uppercase;
  cursor:pointer;
  border:1px solid;
  background:transparent;
  transition:all .3s var(--ease);
  clip-path:polygon(8px 0,100% 0,calc(100% - 8px) 100%,0 100%);
}
/* IMPORTANT: Refuse and Accept buttons have SAME visual weight (RGPD compliance) */
.cookie-btn-refuse{color:var(--ice);border-color:var(--ice-soft)}
.cookie-btn-refuse:hover{
  background:var(--ice-soft);
  border-color:var(--ice);
}
.cookie-btn-accept{color:var(--lime);border-color:var(--lime)}
.cookie-btn-accept:hover{
  background:var(--lime);
  color:var(--void);
  box-shadow:0 0 20px var(--lime-glow);
}

/* ─── Language suggestion banner ──────────────────────────────────────── */
.lang-suggest{
  position:fixed;
  top:80px;right:-350px;
  z-index:150;
  background:var(--void-2);
  border:1px solid var(--cyan);
  padding:14px 20px;
  font-family:var(--ff-mono);
  font-size:12px;
  color:var(--ice);
  display:flex;align-items:center;gap:14px;
  transition:right .5s var(--ease-out);
  box-shadow:0 0 20px rgba(0,240,255,.3);
  max-width:320px;
}
.lang-suggest.show{right:20px}
.lang-suggest a{
  color:var(--cyan);
  text-decoration:none;
  font-weight:700;
}
.lang-suggest a:hover{text-shadow:0 0 8px var(--cyan-glow)}
.lang-suggest button{
  background:none;border:none;
  color:var(--ice-dim);
  font-size:16px;
  cursor:pointer;
  padding:0 4px;
}
.lang-suggest button:hover{color:var(--magenta)}

/* ─── SOCIAL shelf (user-submitted) ───────────────────────────────────── */
.shelf[data-cat="SOCIAL"]{
  background:linear-gradient(90deg,transparent,rgba(0,255,163,.04) 20%,rgba(0,255,163,.04) 80%,transparent);
  border-top:1px solid rgba(0,255,163,.3);
  border-bottom:1px solid rgba(0,255,163,.3);
  padding:20px 0;margin-bottom:60px;position:relative;
}
.shelf[data-cat="SOCIAL"]::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,#00FFA3,transparent);
  box-shadow:0 0 10px #00FFA3;
}
.community-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:4px 12px;
  background:#00FFA3;color:var(--void);
  font-family:var(--ff-mono);
  font-size:10px;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  margin-left:16px;
  box-shadow:0 0 12px rgba(0,255,163,.6);
}

/* ─── Empty category hint ──────────────────────────────────────────────── */
.shelf-empty{
  padding:30px 40px;
  font-family:var(--ff-mono);
  font-size:13px;
  color:var(--ice-dim);
  letter-spacing:.1em;
  text-align:center;
  border:1px dashed var(--ice-soft);
  margin:0 40px;
}
.shelf-empty strong{color:var(--lime);display:block;margin-bottom:8px}

/* ─── Share counter on each card ───────────────────────────────────── */
.q-shares{
  font-family:var(--ff-mono);
  font-size:10px;
  color:var(--lime);
  letter-spacing:.1em;
  text-shadow:0 0 6px rgba(204,255,0,.4);
  padding:2px 8px;
  background:rgba(204,255,0,.08);
  border:1px solid rgba(204,255,0,.2);
}

/* ─── Dare button on each card ─────────────────────────────────────── */
.q-btn-dare{
  color:var(--magenta);
  border-color:var(--magenta);
  background:rgba(255,0,110,.08);
}
.q-btn-dare:hover{
  background:var(--magenta);
  color:var(--void);
  box-shadow:0 0 15px var(--magenta-glow);
  text-shadow:none;
}

/* ─── Random question button ───────────────────────────────────────── */
.btn-random{
  position:relative;
  animation:randomPulse 3s ease-in-out infinite;
}
@keyframes randomPulse{
  0%,100%{box-shadow:0 0 0 var(--lime-glow)}
  50%{box-shadow:0 0 30px var(--lime-glow),0 0 60px var(--lime-glow)}
}

/* ─── Onboarding tour ──────────────────────────────────────────────── */
.onboard-overlay{
  position:fixed;inset:0;
  background:rgba(10,0,20,.92);
  backdrop-filter:blur(12px);
  z-index:10000;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  opacity:0;pointer-events:none;
  transition:opacity .3s var(--ease);
}
.onboard-overlay.show{opacity:1;pointer-events:all}
.onboard-card{
  max-width:440px;width:100%;
  background:var(--deep);
  border:2px solid var(--lime);
  padding:40px 32px;
  text-align:center;
  box-shadow:0 0 50px var(--lime-glow),inset 0 0 40px rgba(204,255,0,.05);
  clip-path:polygon(16px 0,100% 0,100% calc(100% - 16px),calc(100% - 16px) 100%,0 100%,0 16px);
  transform:scale(.9);
  transition:transform .4s var(--ease-out);
}
.onboard-overlay.show .onboard-card{transform:scale(1)}
.onboard-step{
  font-family:var(--ff-mono);
  font-size:10px;color:var(--cyan);
  letter-spacing:.3em;margin-bottom:16px;
  text-shadow:0 0 8px var(--cyan-glow);
}
.onboard-title{
  font-family:var(--ff-display);
  font-weight:900;font-size:28px;
  color:var(--ice);
  margin-bottom:16px;
  text-shadow:0 0 20px rgba(204,255,0,.4);
}
.onboard-text{
  font-family:var(--ff-body);
  font-size:15px;line-height:1.6;
  color:var(--ice-dim);
  margin-bottom:24px;
}
.onboard-dots{
  display:flex;gap:10px;justify-content:center;margin-bottom:28px;
}
.onboard-dots span{
  width:10px;height:10px;border-radius:50%;
  background:rgba(204,255,0,.2);
  transition:all .3s var(--ease);
}
.onboard-dots span.active{
  background:var(--lime);
  box-shadow:0 0 10px var(--lime-glow);
}
.onboard-actions{
  display:flex;gap:12px;justify-content:center;
}
.onboard-skip{
  background:transparent;border:none;
  color:var(--ice-dim);
  font-family:var(--ff-mono);font-size:11px;
  letter-spacing:.2em;text-transform:uppercase;
  cursor:pointer;padding:14px 20px;
}
.onboard-skip:hover{color:var(--ice)}
.onboard-next{padding:14px 28px}

/* ─── Mobile vertical grid (override horizontal shelves on mobile) ─── */
@media(max-width:768px){
  .shelf-scroll{
    padding:16px 20px;
    overflow-x:visible;
    overflow-y:visible;
  }
  .shelf-row{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
    width:100%;
  }
  .q-card{
    width:100%;
    min-height:auto;
    padding:20px 16px;
  }
  .q-card-text{
    font-size:14px;
    line-height:1.35;
    padding-bottom:16px;
  }
  .q-card-actions{
    flex-direction:column;
    gap:6px;
  }
  .q-btn{
    font-size:9px;
    padding:7px 10px;
  }
  .shelf-count::after{
    content:'';
  }
  /* Remove "SCROLL →" hint on mobile since it's now a grid */
  .shelf-count{font-size:10px}
}
@media(max-width:480px){
  .shelf-row{grid-template-columns:1fr}
  .q-card{max-width:100%}
}

/* ─── Mobile cookie banner fixes ───────────────────────────────────────── */
@media(max-width:640px){
  .cookie-content{flex-direction:column;align-items:flex-start;gap:16px}
  .cookie-actions{width:100%;justify-content:stretch}
  .cookie-btn{flex:1;padding:12px 16px}
  .nav-lang{display:none}
  .nav-btn-create span{display:none}
  .create-banner{padding:60px 24px}
}

/* ─── Social notice in submit modal ────────────────────────────────────── */
.social-notice{
  margin:16px 0 24px;
  padding:16px 20px;
  background:rgba(0,255,163,.06);
  border-left:3px solid #00FFA3;
  font-family:'Share Tech Mono',monospace;
  font-size:12px;
  line-height:1.6;
  color:#D8E4F0;
}
.social-notice strong{
  display:block;
  color:#00FFA3;
  font-size:11px;
  letter-spacing:.2em;
  margin-bottom:8px;
  text-transform:uppercase;
}
.social-notice p{
  margin:4px 0;
  font-size:12px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   FAVORITES — ★ button on cards + "MES FAVORIS" top shelf
   ═══════════════════════════════════════════════════════════════════════════ */
.q-card{ position:relative; }
.q-fav{
  position:absolute;
  top:10px;
  right:10px;
  width:32px;
  height:32px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(10,0,20,.7);
  border:1px solid rgba(255,255,255,.12);
  color:#8FA4B8;
  font-size:18px;
  cursor:pointer;
  border-radius:4px;
  transition:all .15s ease;
  z-index:2;
  padding:0;
  line-height:1;
}
.q-fav:hover{
  border-color:#CCFF00;
  color:#CCFF00;
  box-shadow:0 0 10px rgba(204,255,0,.4);
}
.q-fav.active{
  color:#CCFF00;
  border-color:#CCFF00;
  background:rgba(204,255,0,.08);
  text-shadow:0 0 8px rgba(204,255,0,.6);
}
.q-fav:focus-visible{
  outline:2px solid #00F0FF;
  outline-offset:2px;
}
.q-card.is-fav{
  border-color:rgba(204,255,0,.25);
}

/* Favorites shelf banner — sits above all other shelves */
.shelf-title.cat-FAVORIS{
  color:#CCFF00;
  text-shadow:0 0 12px rgba(204,255,0,.5);
}
.fav-badge{
  display:inline-block;
  margin-left:10px;
  padding:2px 8px;
  background:rgba(204,255,0,.15);
  border:1px solid rgba(204,255,0,.4);
  color:#CCFF00;
  font-size:11px;
  font-family:monospace;
  letter-spacing:.15em;
  border-radius:2px;
}
#favorites-shelf:empty{
  display:none;
}
#favorites-shelf .shelf{
  border-top:1px solid rgba(204,255,0,.2);
  border-bottom:1px solid rgba(204,255,0,.2);
  padding-top:20px;
  padding-bottom:20px;
  margin-bottom:24px;
  background:linear-gradient(180deg, rgba(204,255,0,.03) 0%, transparent 100%);
}

/* ═══════════════════════════════════════════════════════════════════════════
   EXPORT / IMPORT — RGPD data portability buttons in thread panel
   ═══════════════════════════════════════════════════════════════════════════ */
.thread-data-actions{
  display:flex;
  gap:8px;
  padding:12px 16px 0;
  border-top:1px solid rgba(255,255,255,.06);
  margin-top:8px;
}
.thread-data-actions button{
  flex:1;
  background:transparent;
  border:1px solid rgba(255,255,255,.15);
  color:#8FA4B8;
  padding:8px;
  font-size:10px;
  letter-spacing:.15em;
  cursor:pointer;
  font-family:inherit;
  text-transform:uppercase;
  transition:all .15s ease;
}
.thread-data-actions button:hover{
  border-color:#00F0FF;
  color:#00F0FF;
}
.thread-data-actions input[type=file]{
  display:none;
}

/* ═══════════════════════════════════════════════════════════════════════════
   COOKIE BANNER — 3-state consent (Refuse / Essential / Accept all)
   ═══════════════════════════════════════════════════════════════════════════ */
.cookie-banner .cookie-btn-essential{
  background:rgba(0,240,255,.15);
  border:1px solid rgba(0,240,255,.4);
  color:#00F0FF;
}
/* ═══════════════════════════════════════════════════════════════════════════
   RANDOM PREVIEW — fallback for random question when card isn't in DOM
   ═══════════════════════════════════════════════════════════════════════════ */
.random-preview{
  position:fixed;
  inset:0;
  background:rgba(10,0,20,.85);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:50;
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease;
  padding:20px;
}
.random-preview.show{opacity:1;pointer-events:auto}
.random-preview-inner{
  max-width:640px;width:100%;
  background:#12002a;
  border:1px solid rgba(255,0,110,.4);
  box-shadow:0 0 60px rgba(255,0,110,.25);
  padding:32px 28px;
}
.random-preview-label{
  font:700 10px/1 'Share Tech Mono',monospace;
  color:#00F0FF;
  letter-spacing:.3em;
  margin-bottom:8px;
  text-shadow:0 0 8px rgba(0,240,255,.4);
}
.random-preview-cat{
  font:700 11px/1 'Share Tech Mono',monospace;
  color:#FF006E;
  letter-spacing:.2em;
  margin-bottom:20px;
}
.random-preview-text{
  font:700 22px/1.3 'Orbitron',sans-serif;
  color:#E0F7FF;
  margin:0 0 24px;
}
.random-preview-actions{display:flex;gap:10px;flex-wrap:wrap}
.random-preview-actions .btn{flex:1;min-width:120px;justify-content:center}

/* ═══════════════════════════════════════════════════════════════════════════
   COOKIE BANNER — hover tail
   ═══════════════════════════════════════════════════════════════════════════ */
.cookie-banner .cookie-btn-essential:hover{
  background:rgba(0,240,255,.25);
  border-color:#00F0FF;
}

/* ═══════════════════════════════════════════════════════════════════════════
   CHIP RAIL — category shortcuts, sticky sous la nav
   Mobile-first : overflow-x auto, scroll-snap, chip pill 36px.
   Active chip = glow pleine couleur + LED pulse + cursor blink terminal.
   ═══════════════════════════════════════════════════════════════════════════ */
.chip-rail{
  position:sticky;
  top:60px;
  z-index:40;
  background:linear-gradient(180deg,#0a0014 0%,rgba(10,0,20,.92) 100%);
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(255,0,110,.2);
  padding:10px 0;
  overflow:hidden;
  isolation:isolate;
}
.chip-rail-track{
  display:flex;
  gap:8px;
  overflow-x:auto;
  overflow-y:hidden;
  scroll-snap-type:x proximity;
  scroll-padding-left:20px;
  padding:4px 20px;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.chip-rail-track::-webkit-scrollbar{display:none}
.chip-rail-edge{
  position:absolute;
  top:0;bottom:0;
  width:24px;
  pointer-events:none;
  z-index:2;
}
.chip-rail-edge-l{left:0;background:linear-gradient(90deg,#0a0014 0%,transparent 100%)}
.chip-rail-edge-r{right:0;background:linear-gradient(-90deg,#0a0014 0%,transparent 100%)}

.chip{
  flex:0 0 auto;
  scroll-snap-align:start;
  display:inline-flex;
  align-items:center;
  gap:8px;
  height:36px;
  padding:0 14px 0 10px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  font:700 11px/1 'Share Tech Mono',monospace;
  letter-spacing:.12em;
  color:#8FA4B8;
  cursor:pointer;
  transition:all .2s ease;
  white-space:nowrap;
  position:relative;
  -webkit-appearance:none;
  appearance:none;
  /* Mobile: eliminate 300ms tap delay and iOS blue flash */
  touch-action:manipulation;
  text-decoration:none;
}
/* Tactile press feedback on touch devices */
@media (hover:none){
  .chip:active{
    transform:scale(.94);
    opacity:.75;
    transition:transform .08s ease,opacity .08s ease;
  }
}
.chip-led{
  width:6px;height:6px;
  border-radius:50%;
  background:currentColor;
  box-shadow:0 0 0 1px rgba(0,0,0,.25) inset, 0 0 4px currentColor;
  flex:0 0 auto;
}
.chip-name{flex:0 0 auto}
.chip-count{
  font-size:9px;
  opacity:.55;
  padding-left:8px;
  border-left:1px solid rgba(255,255,255,.12);
  margin-left:2px;
}
.chip:hover{
  border-color:currentColor;
  background:rgba(255,255,255,.06);
  transform:translateY(-1px);
}
.chip:focus-visible{
  outline:2px solid #00F0FF;
  outline-offset:2px;
}

/* Active state — pleine couleur, LED pulse, cursor terminal */
.chip.active{
  color:#E8F1FF;
  background:rgba(255,255,255,.08);
  border-color:currentColor;
  box-shadow:0 0 0 1px currentColor, 0 0 14px color-mix(in srgb, currentColor 45%, transparent);
}
.chip.active .chip-led{animation:chip-pulse 1.4s ease-in-out infinite}
.chip.active::after{
  content:'_';
  color:currentColor;
  margin-left:2px;
  animation:chip-cursor 1s steps(2) infinite;
  font-weight:900;
}
@keyframes chip-pulse{
  0%,100%{box-shadow:0 0 0 1px rgba(0,0,0,.25) inset, 0 0 4px currentColor}
  50%{box-shadow:0 0 0 1px rgba(0,0,0,.25) inset, 0 0 12px currentColor, 0 0 20px currentColor}
}
@keyframes chip-cursor{50%{opacity:0}}

/* Couleur de LED + bordure par catégorie (les classes cat-XXX existent déjà) */
/* Le chip hérite de color via la classe cat-XXX, pas besoin de réassigner */

/* Chip "TOUT" : cyan par défaut */
.chip.chip-all{color:#00F0FF}

/* Desktop : paddings un peu plus généreux */
@media (min-width:768px){
  .chip-rail{top:64px; padding:12px 0}
  .chip-rail-track{gap:10px; padding:4px 40px; scroll-snap-type:none}
  .chip{height:38px; font-size:12px}
}

/* ═══════════════════════════════════════════════════════════════════════════
   MOBILE DRAWER MENU — hamburger qui ouvre une liste complète de catégories
   ═══════════════════════════════════════════════════════════════════════════ */
.nav-burger{
  display:none;
  width:40px;height:40px;
  background:transparent;
  border:1px solid rgba(255,255,255,.15);
  padding:10px;
  cursor:pointer;
  flex-direction:column;
  gap:4px;
  justify-content:center;
}
.nav-burger span{
  display:block;width:100%;height:2px;
  background:#E8F1FF;
  transition:transform .2s ease;
}
@media (max-width:767px){
  .nav-burger{display:inline-flex}
}

.drawer{position:fixed; inset:0; z-index:90; display:none}
.drawer.open{display:block}
.drawer-backdrop{
  position:absolute; inset:0;
  background:rgba(10,0,20,.82);
  -webkit-backdrop-filter:blur(4px);
  backdrop-filter:blur(4px);
  animation:drawer-fade .25s ease;
}
.drawer-panel{
  position:absolute; top:0; right:0; bottom:0;
  width:min(88vw,420px);
  background:#0f0020;
  border-left:1px solid #FF006E;
  box-shadow:-20px 0 60px rgba(255,0,110,.25);
  padding:20px;
  overflow-y:auto;
  animation:drawer-slide .3s cubic-bezier(.2,.9,.3,1);
  -webkit-overflow-scrolling:touch;
}
@keyframes drawer-slide{from{transform:translateX(100%)}to{transform:translateX(0)}}
@keyframes drawer-fade{from{opacity:0}to{opacity:1}}

.drawer-head{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:24px;
}
.drawer-label{
  font:700 10px/1 'Share Tech Mono',monospace;
  color:#00F0FF;
  letter-spacing:.3em;
}
.drawer-close{
  background:transparent; border:0;
  color:#E8F1FF; font-size:28px;
  cursor:pointer; padding:0 10px; line-height:1;
}

.drawer-cats{
  display:flex;flex-direction:column;gap:2px;
  margin-bottom:28px;
}
.drawer-cat{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:14px 12px;
  background:transparent;
  touch-action:manipulation;
  border:0;
  border-left:3px solid currentColor;
  color:currentColor;
  text-align:left;
  cursor:pointer;
  font:700 13px/1 'Orbitron',sans-serif;
  letter-spacing:.08em;
  transition:background .15s ease;
  -webkit-appearance:none;
  appearance:none;
}
.drawer-cat:hover{
  background:color-mix(in srgb, currentColor 10%, transparent);
}
.drawer-cat .cat-count{
  font-family:'Share Tech Mono',monospace;
  font-size:11px; opacity:.6;
}

.drawer-actions{
  display:flex;flex-direction:column;gap:8px;
  padding-top:16px;
  border-top:1px dashed rgba(255,255,255,.1);
}
.drawer-actions a, .drawer-actions button{
  padding:12px 12px;
  background:transparent;
  border:1px solid rgba(255,255,255,.12);
  color:#8FA4B8;
  text-align:left;
  cursor:pointer;
  text-decoration:none;
  font:700 11px/1 'Share Tech Mono',monospace;
  letter-spacing:.15em;
}
.drawer-actions a:hover, .drawer-actions button:hover{
  border-color:#00F0FF;
  color:#00F0FF;
}

/* ═══════════════════════════════════════════════════════════════════════════
   HERO COMPACT MOBILE — hauteur maîtrisée pour que le ChipRail soit visible
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width:767px){
  .hero{
    min-height:auto;
    padding:80px 20px 32px;
  }
  .hero-eyebrow{font-size:11px; letter-spacing:.2em}
  .hero-title{font-size:clamp(28px,8vw,38px); line-height:1.08}
  .hero-sub{font-size:12px; margin:14px 0 8px}
  .hero-cta{flex-direction:column; gap:10px; margin-top:12px}
  .hero-cta .btn-lg{width:100%; padding:13px 14px; font-size:13px}
  .hero-cta .btn-cyan{display:none}  /* "créer" accessible via hamburger */
  .hero-hud{
    grid-template-columns:repeat(2,1fr);
    gap:6px 10px;
    margin-top:16px;
    padding:10px;
  }
  .hero-hud .hud-stat{padding:6px 6px}
  .hero-hud .hud-label{font-size:9px}
  .hero-hud .hud-value{font-size:20px}
}

/* Chevron "▼ EXPLORE" mobile only */
.hero-scroll-cue{
  display:none;
  position:absolute;
  bottom:14px;left:50%;
  transform:translateX(-50%);
  background:transparent; border:0;
  color:#00F0FF;
  font:700 10px/1 'Share Tech Mono',monospace;
  letter-spacing:.3em;
  cursor:pointer;
  padding:8px 12px;
  z-index:5;
}
@media (max-width:767px){
  .hero-scroll-cue{
    display:block;
    animation:hero-cue 2.4s ease-in-out 1s infinite;
  }
}
@keyframes hero-cue{
  0%,100%{transform:translate(-50%,0); opacity:.5}
  50%{transform:translate(-50%,6px); opacity:1}
}

/* ═══════════════════════════════════════════════════════════════════════════
   CATEGORY PAGE MODE
   Applied when body.cat-page (set by JS when ACTIVE_CATEGORY is detected).
   - Hero is swapped server-side by build-category-pages.mjs to .hero-category
   - On cat pages, we hide: .featured, .arena-header, .controls (search),
     .favorites-shelf (reserved for landing), .ticker.
   - Tone-down : smaller hero, no watermark, fewer particles, generous padding.
   ═══════════════════════════════════════════════════════════════════════════ */

/* Hide landing-only elements on category pages */
body.cat-page .featured,
body.cat-page .arena-header,
body.cat-page .controls,
body.cat-page #favorites-shelf,
body.cat-page .ticker,
body.cat-page .create-banner {
  display: none !important;
}

/* Premium hero-category : breathing room, restrained typography */
.hero-category {
  min-height: 55vh;
  padding: 120px 5vw 80px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.hero-category .grid-floor {
  opacity: 0.35;
}

.hero-category .particles {
  opacity: 0.5;
}

.hero-cat-back {
  position: absolute;
  top: 90px;
  left: 5vw;
  font-family: var(--ff-mono, 'Share Tech Mono', monospace);
  font-size: 12px;
  letter-spacing: 2px;
  color: var(--text-muted, #8FA4B8);
  text-decoration: none;
  text-transform: uppercase;
  padding: 6px 10px;
  border: 1px solid rgba(143, 164, 184, 0.2);
  transition: color 0.2s, border-color 0.2s, background 0.2s;
  z-index: 2;
}
.hero-cat-back:hover,
.hero-cat-back:focus {
  color: var(--cyan, #00F0FF);
  border-color: var(--cyan, #00F0FF);
  background: rgba(0, 240, 255, 0.06);
}

.hero-cat-kicker {
  font-family: var(--ff-mono, 'Share Tech Mono', monospace);
  font-size: 13px;
  letter-spacing: 4px;
  color: var(--text-muted, #8FA4B8);
  margin-bottom: 36px;
  position: relative;
  z-index: 2;
}
.hero-cat-kicker-count {
  color: var(--lime, #A0FF41);
  font-weight: 700;
}

.hero-cat-title {
  font-family: var(--ff-display, 'Orbitron', sans-serif);
  font-size: clamp(38px, 6.5vw, 82px);
  font-weight: 800;
  letter-spacing: -1px;
  line-height: 1.05;
  text-transform: uppercase;
  margin: 0 0 24px;
  position: relative;
  z-index: 2;
  max-width: 14ch;
  text-shadow: 0 0 40px currentColor;
  /* currentColor inherits the cat-XXXX color applied to this element */
}

.hero-cat-desc {
  max-width: 56ch;
  font-size: clamp(15px, 1.4vw, 18px);
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.75);
  margin: 0 0 44px;
  position: relative;
  z-index: 2;
}

.hero-cat-cta {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: center;
  position: relative;
  z-index: 2;
}
.hero-cat-cta .btn-ghost {
  background: transparent;
  border: 1px solid rgba(143, 164, 184, 0.35);
  color: var(--text-muted, #8FA4B8);
  font-family: var(--ff-mono, 'Share Tech Mono', monospace);
  letter-spacing: 2px;
  text-decoration: none;
  padding: 14px 22px;
  display: inline-flex;
  align-items: center;
  transition: color 0.2s, border-color 0.2s, background 0.2s;
}
.hero-cat-cta .btn-ghost:hover,
.hero-cat-cta .btn-ghost:focus {
  color: #fff;
  border-color: var(--cyan, #00F0FF);
  background: rgba(0, 240, 255, 0.05);
}

/* Mobile hero-category */
@media (max-width: 640px) {
  .hero-category {
    min-height: 46vh;
    padding: 100px 6vw 56px;
  }
  .hero-cat-back {
    top: 70px;
    left: 6vw;
    font-size: 10px;
  }
  .hero-cat-kicker {
    font-size: 11px;
    letter-spacing: 3px;
    margin-bottom: 24px;
  }
  .hero-cat-title {
    font-size: 40px;
    max-width: 16ch;
  }
  .hero-cat-desc {
    margin-bottom: 32px;
  }
  .hero-cat-cta {
    flex-direction: column;
    width: 100%;
    max-width: 320px;
  }
  .hero-cat-cta .btn-lg {
    width: 100%;
    justify-content: center;
  }
}

/* Cat page : reduce vertical space between nav and first shelf */
body.cat-page .arena {
  padding-top: 24px;
}

/* On cat pages, shelf-header shrinks (cat name already in hero) */
body.cat-page .shelf-title .idx {
  display: none;
}
body.cat-page .shelf-title {
  font-size: clamp(22px, 3vw, 32px);
}

/* ═══════════════════════════════════════════════════════════════════════════
   CATS-GRID : "Explore other categories" at bottom of cat pages
   ═══════════════════════════════════════════════════════════════════════════ */
.cats-grid {
  margin: 80px auto 100px;
  padding: 0 5vw;
  max-width: 1280px;
  position: relative;
}

.cats-grid-head {
  text-align: center;
  margin-bottom: 44px;
}
.cats-grid-head .section-label {
  font-family: var(--ff-mono, 'Share Tech Mono', monospace);
  font-size: 13px;
  letter-spacing: 5px;
  color: var(--text-muted, #8FA4B8);
}

.cats-grid-inner {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}

.cat-card {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 22px 20px 20px;
  min-height: 110px;
  background: rgba(20, 10, 30, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.08);
  touch-action: manipulation;
  text-decoration: none;
  color: #fff;
  transition: border-color 0.25s, background 0.25s, transform 0.25s;
  overflow: hidden;
}

.cat-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 3px; height: 100%;
  background: currentColor;
  opacity: 0.7;
  transition: opacity 0.25s, width 0.25s;
}

.cat-card:hover::before,
.cat-card:focus::before {
  width: 6px;
  opacity: 1;
}

.cat-card:hover,
.cat-card:focus {
  border-color: currentColor;
  background: rgba(30, 15, 45, 0.75);
  transform: translateY(-2px);
}

.cat-card-name {
  font-family: var(--ff-display, 'Orbitron', sans-serif);
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: currentColor;
  text-shadow: 0 0 12px currentColor;
}

.cat-card-count {
  font-family: var(--ff-mono, 'Share Tech Mono', monospace);
  font-size: 12px;
  letter-spacing: 2px;
  color: rgba(255, 255, 255, 0.55);
  margin-top: 6px;
  text-transform: uppercase;
}

.cat-card-arrow {
  position: absolute;
  top: 20px;
  right: 20px;
  font-family: var(--ff-mono, monospace);
  font-size: 18px;
  color: currentColor;
  opacity: 0.5;
  transition: transform 0.25s, opacity 0.25s;
}

.cat-card:hover .cat-card-arrow,
.cat-card:focus .cat-card-arrow {
  transform: translateX(4px);
  opacity: 1;
}

@media (max-width: 640px) {
  .cats-grid {
    margin: 56px auto 72px;
  }
  .cats-grid-inner {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
  .cat-card {
    padding: 18px 14px 14px;
    min-height: 92px;
  }
  .cat-card-name {
    font-size: 14px;
  }
  .cat-card-count {
    font-size: 10px;
  }
  .cat-card-arrow {
    top: 14px;
    right: 12px;
    font-size: 14px;
  }
}

/* Category accent color.
   Single source of truth : the `--cat-color` custom property is set inline
   on .hero-category and on each .cat-card by the build script / JS.
   .hero-cat-title inherits from its parent <section class="hero-category">. */
.hero-cat-title {
  color: var(--cat-color, #FF006E);
}
.cat-card {
  color: var(--cat-color, #FF006E);
}

