/* ============================================================
   transitions-dev — bloc :root universel (collé une seule fois)
   ============================================================ */
:root {
  /* Number pop-in */
  --digit-dur: 500ms;
  --digit-distance: 8px;
  --digit-stagger: 70ms;
  --digit-blur: 2px;
  --digit-ease: cubic-bezier(0.34, 1.45, 0.64, 1);
  --digit-dir-x: 0;
  --digit-dir-y: 1;
  /* Tabs sliding */
  --tabs-dur: 200ms;
  --tabs-ease: cubic-bezier(0.22, 1, 0.36, 1);
  --tabs-text-muted: rgba(255, 255, 255, 0.55);
  --tabs-text-active: #0a0a0a;
  --tabs-bar-bg: #11150f;
  --tabs-pill-bg: #39ff14;
  /* Shimmer text */
  --shimmer-dur: 2000ms;
  --shimmer-base: #5a5a5a;
  --shimmer-highlight: #39ff14;
  --shimmer-band: 400%;
  --shimmer-ease: linear;
  /* Texts reveal */
  --stagger-dur: 600ms;
  --stagger-distance: 12px;
  --stagger-stagger: 40ms;
  --stagger-blur: 3px;
  --stagger-ease: cubic-bezier(0.22, 1, 0.36, 1);

  /* palette MLG */
  --bg: #07080a;
  --panel: #0e1411;
  --panel-2: #121a14;
  --neon: #39ff14;
  --cyan: #00e5ff;
  --pink: #ff2e97;
  --gold: #ffd000;
  --red: #ff2b2b;
  --txt: #e8ffe1;
  --muted: #8a9a82;
}

/* ============================================================
   base
   ============================================================ */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg);
  color: var(--txt);
  font-family: "Russo One", "Arial Black", system-ui, sans-serif;
  min-height: 100vh;
  overflow-x: hidden;
  background-image:
    radial-gradient(circle at 20% 0%, rgba(57,255,20,.08), transparent 45%),
    radial-gradient(circle at 80% 100%, rgba(0,229,255,.08), transparent 45%);
}
h1, h2 { margin: 0; }
.muted { color: var(--muted); font-weight: 400; font-size: .7em; }

/* ============================================================
   ambiance MLG (couches plein écran)
   ============================================================ */
#rgb-overlay {
  position: fixed; inset: 0; z-index: 0; pointer-events: none; opacity: 0;
  background: linear-gradient(120deg,#ff0000,#ff7f00,#ffff00,#00ff00,#00ffff,#0000ff,#8b00ff,#ff0000);
  background-size: 400% 400%;
  mix-blend-mode: overlay;
  transition: opacity .4s ease;
}
body.mlg #rgb-overlay { opacity: .55; animation: rgbshift 6s linear infinite; }
@keyframes rgbshift { 0%{background-position:0% 50%} 100%{background-position:400% 50%} }

#rain-layer { position: fixed; inset: 0; z-index: 1; pointer-events: none; overflow: hidden; }
.drop {
  position: absolute; top: -10vh; font-size: 2rem;
  animation: fall linear forwards;
  will-change: transform;
}
@keyframes fall {
  to { transform: translateY(115vh) rotate(540deg); }
}

#hitmarker-layer { position: fixed; inset: 0; z-index: 9998; pointer-events: none; }
.hitmarker {
  position: absolute; width: 34px; height: 34px; transform: translate(-50%,-50%) scale(.4);
  opacity: 0; color: #fff; font-weight: 900; font-size: 34px; line-height: 34px;
  text-shadow: 0 0 4px #000;
  animation: hit .35s ease-out forwards;
}
@keyframes hit {
  0% { opacity: 1; transform: translate(-50%,-50%) scale(1.4) rotate(0deg); }
  100%{ opacity: 0; transform: translate(-50%,-50%) scale(.7) rotate(20deg); }
}

#illuminati {
  position: fixed; bottom: 6vh; right: 6vw; z-index: 2; pointer-events: none;
  font-size: 6rem; color: rgba(255,255,255,.06); opacity: 0;
  transition: opacity .5s ease;
}
body.mlg #illuminati { opacity: 1; animation: spin 9s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

body.mlg.shake { animation: shake .25s linear infinite; }
@keyframes shake {
  0%,100%{transform:translate(0,0)} 25%{transform:translate(-4px,3px)}
  50%{transform:translate(3px,-3px)} 75%{transform:translate(-3px,-2px)}
}

/* ============================================================
   hero
   ============================================================ */
.hero { position: relative; z-index: 3; text-align: center; padding: 48px 16px 24px; }
.hero-glasses { font-size: 3rem; animation: glasses-drop 1.2s cubic-bezier(.34,1.56,.64,1) both; }
@keyframes glasses-drop {
  0% { transform: translateY(-120px) rotate(-25deg); opacity: 0; }
  70%{ transform: translateY(8px) rotate(6deg); opacity: 1; }
  100%{ transform: translateY(0) rotate(0); }
}
.hero h1 {
  font-family: "Press Start 2P", monospace;
  font-size: clamp(1.1rem, 4.5vw, 3rem);
  letter-spacing: 2px; margin: 10px 0;
  color: var(--neon);
  text-shadow: 0 0 8px var(--neon), 0 0 24px rgba(57,255,20,.5);
}
.hero-sub { font-size: clamp(.75rem,2.2vw,1.1rem); letter-spacing: 3px; margin: 6px 0 18px; }

/* glitch */
.glitch { position: relative; }
.glitch::before, .glitch::after {
  content: attr(data-text); position: absolute; left: 0; top: 0; width: 100%;
  overflow: hidden;
}
.glitch::before { color: var(--cyan); animation: glx 3s infinite linear alternate-reverse; clip-path: inset(0 0 60% 0); }
.glitch::after  { color: var(--pink); animation: glx 2.4s infinite linear alternate-reverse; clip-path: inset(55% 0 0 0); }
@keyframes glx { 0%{transform:translate(0)} 20%{transform:translate(-2px,1px)} 40%{transform:translate(2px,-1px)} 60%{transform:translate(-1px,0)} 100%{transform:translate(1px,1px)} }

.mlg-btn {
  font-family: "Press Start 2P", monospace; font-size: .7rem;
  background: linear-gradient(90deg,var(--neon),var(--cyan));
  color: #061008; border: 0; border-radius: 8px; padding: 12px 18px; cursor: pointer;
  box-shadow: 0 0 0 2px #000, 0 6px 0 #0a3b08; transition: transform .1s ease, box-shadow .1s ease;
}
.mlg-btn:active { transform: translateY(4px); box-shadow: 0 0 0 2px #000, 0 2px 0 #0a3b08; }
body.mlg .mlg-btn::after { content: " ON"; }

/* ============================================================
   transitions-dev — Shimmer text (verbatim)
   ============================================================ */
.t-shimmer {
  background: linear-gradient(90deg, var(--shimmer-base) 25%, var(--shimmer-highlight) 50%, var(--shimmer-base) 75%);
  background-size: var(--shimmer-band) 100%;
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  animation: t-shimmer var(--shimmer-dur) var(--shimmer-ease) infinite;
}
@keyframes t-shimmer { 0% { background-position: 100% 0; } 100% { background-position: -100% 0; } }
@media (prefers-reduced-motion: reduce) { .t-shimmer { animation: none; color: var(--shimmer-highlight); } }

/* ============================================================
   transitions-dev — Number pop-in (verbatim)
   ============================================================ */
@keyframes t-digit-pop-in {
  0% {
    transform: translate(calc(var(--digit-distance) * var(--digit-dir-x)), calc(var(--digit-distance) * var(--digit-dir-y)));
    opacity: 0; filter: blur(var(--digit-blur));
  }
  100% { transform: translate(0, 0); opacity: 1; filter: blur(0); }
}
.t-digit-group { display: inline-flex; align-items: baseline; }
.t-digit { display: inline-block; will-change: transform, opacity, filter; }
.t-digit-group.is-animating .t-digit { animation: t-digit-pop-in var(--digit-dur) var(--digit-ease) both; }
.t-digit-group.is-animating .t-digit[data-stagger="1"] { animation-delay: var(--digit-stagger); }
.t-digit-group.is-animating .t-digit[data-stagger="2"] { animation-delay: calc(var(--digit-stagger) * 2); }
@media (prefers-reduced-motion: reduce) { .t-digit-group .t-digit { animation: none !important; } }

/* ============================================================
   transitions-dev — Tabs sliding (verbatim)
   ============================================================ */
.t-tabs {
  position: relative; display: inline-flex; align-items: center; gap: 3px;
  padding: 3px; border-radius: 48px; background: var(--tabs-bar-bg);
  border: 1px solid rgba(57,255,20,.25);
}
.t-tab {
  position: relative; appearance: none; border: 0; background: transparent;
  height: 34px; padding: 4px 18px; color: var(--tabs-text-muted); cursor: pointer;
  border-radius: 48px; z-index: 1; font-family: "Russo One", sans-serif; letter-spacing: 1px;
  transition: color var(--tabs-dur) var(--tabs-ease);
}
.t-tab:not([aria-selected="true"]):hover, .t-tab[aria-selected="true"] { color: var(--tabs-text-active); }
.t-tabs-pill {
  position: absolute; top: 3px; left: 0; height: 34px; width: 0;
  background: var(--tabs-pill-bg); border-radius: 48px; transform: translateX(0);
  transition: transform var(--tabs-dur) var(--tabs-ease), width var(--tabs-dur) var(--tabs-ease);
  will-change: transform, width; z-index: 0; pointer-events: none;
  box-shadow: 0 0 12px var(--neon);
}
@media (prefers-reduced-motion: reduce) { .t-tabs-pill, .t-tab { transition: none !important; } }

/* ============================================================
   layout
   ============================================================ */
.wrap { position: relative; z-index: 3; max-width: 1180px; margin: 0 auto; padding: 8px 16px 40px; }
#account-tabs { display: inline-flex; margin: 22px 0 8px; }

.kpis { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; margin-bottom: 8px; }
.grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px; }
.span-2 { grid-column: span 2; }

.card {
  background: linear-gradient(180deg,var(--panel),var(--panel-2));
  border: 1px solid rgba(57,255,20,.18);
  border-radius: 14px; padding: 16px;
  box-shadow: 0 0 0 1px rgba(0,0,0,.5), 0 10px 30px rgba(0,0,0,.5), inset 0 0 30px rgba(57,255,20,.04);
}
.card-title { font-size: 1rem; letter-spacing: 1px; margin-bottom: 12px; color: var(--txt); }

.kpi { display: flex; flex-direction: column; gap: 6px; align-items: flex-start; }
.kpi-label { font-size: .72rem; color: var(--muted); letter-spacing: 1px; }
.kpi-value { font-family: "Press Start 2P", monospace; font-size: clamp(.95rem,2.4vw,1.5rem); color: var(--neon); text-shadow: 0 0 10px rgba(57,255,20,.5); }
.kpi-sub { font-size: .8rem; }
.pos { color: var(--neon); } .neg { color: var(--red); }

.chart-card .chart-box { position: relative; height: 280px; }
.span-2.chart-card .chart-box { height: 320px; }

/* table */
.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; font-size: .9rem; }
th, td { padding: 10px 12px; text-align: left; border-bottom: 1px solid rgba(255,255,255,.06); white-space: nowrap; }
th { color: var(--muted); font-size: .72rem; letter-spacing: 1px; text-transform: uppercase; }
td.num, th.num { text-align: right; font-variant-numeric: tabular-nums; }
tbody tr { transition: background .15s ease; cursor: crosshair; }
tbody tr:hover { background: rgba(57,255,20,.06); }
.badge { display: inline-block; padding: 2px 8px; border-radius: 6px; font-size: .7rem; }
.badge.pea { background: rgba(57,255,20,.15); color: var(--neon); }
.badge.cto { background: rgba(0,229,255,.15); color: var(--cyan); }

.updated { text-align: right; color: var(--muted); font-size: .8rem; margin-top: 14px; }

/* footer */
.footer { position: relative; z-index: 3; text-align: center; padding: 30px 16px 60px; color: var(--muted); }
.footer strong { color: var(--gold); }
.rekt { font-family: "Press Start 2P", monospace; color: var(--red); text-shadow: 0 0 8px var(--red); }
.tiny { font-size: .72rem; margin-top: 8px; }

/* contrôles (filtres) */
.controls { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; margin: 22px 0 6px; }
#range-tabs .t-tab { padding: 4px 12px; }

/* news éco */
.news-list { display: flex; flex-direction: column; gap: 2px; max-height: 320px; overflow-y: auto; }
.news-item { display: block; padding: 10px 8px; border-bottom: 1px solid rgba(255,255,255,.06); color: var(--txt); text-decoration: none; transition: background .15s ease; }
.news-item:hover { background: rgba(0,229,255,.07); }
.news-item .news-src { color: var(--cyan); font-size: .68rem; letter-spacing: 1px; text-transform: uppercase; }
.news-item .news-title { display: block; font-size: .9rem; margin-top: 3px; }
.news-item .news-date { color: var(--muted); font-size: .7rem; }

/* ============================================================
   responsive — mobile / tablette (iOS + Android)
   ============================================================ */
/* zones sûres iPhone (encoche) */
body { padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left); }

/* tablette */
@media (max-width: 1024px) {
  .wrap { padding: 8px 14px 40px; }
  .chart-card .chart-box { height: 260px; }
  .span-2.chart-card .chart-box { height: 300px; }
}

/* mobile */
@media (max-width: 768px) {
  .hero { padding: 28px 12px 16px; }
  .kpis { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .grid { grid-template-columns: 1fr; gap: 12px; }
  .span-2 { grid-column: span 1; }
  .card { padding: 13px; border-radius: 12px; }
  .card-title { font-size: .92rem; }
  .chart-card .chart-box, .span-2.chart-card .chart-box { height: 240px; }
  /* doughnuts : légende dessous plutôt qu'à droite (gérée aussi en JS) */
  .kpi-value { font-size: 1rem; }
  .updated { text-align: center; }
  /* barres d'onglets scrollables horizontalement si trop larges */
  .controls { gap: 8px; }
  .t-tabs { max-width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
  .t-tabs::-webkit-scrollbar { display: none; }
  /* tables : police compacte + scroll horizontal fluide */
  table { font-size: .82rem; }
  th, td { padding: 8px 9px; }
  .table-wrap { -webkit-overflow-scrolling: touch; }
}

/* petits mobiles */
@media (max-width: 420px) {
  .hero h1 { font-size: 1rem; }
  .kpis { grid-template-columns: 1fr 1fr; }
  .kpi-label { font-size: .65rem; }
  .mlg-btn { font-size: .6rem; padding: 10px 12px; }
}

/* confort tactile : pas de hover collant, cibles plus grandes */
@media (hover: none) {
  .t-tab { min-height: 38px; }
  tbody tr { cursor: default; }
}
