/* ── CRT — retro sci-fi terminal viewport ───────────────────────────────────*/

.lcd-statusbar {
  position: relative;
  z-index: 4;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-height: var(--statusbar-h);
  padding: 5px 12px 6px;
  font-family: var(--font-hud);
  font-size: var(--type-small);
  font-weight: 500;
  color: var(--green-muted);
  background: linear-gradient(180deg, #0a1510 0%, #020604 100%);
  border-bottom: 2px solid color-mix(in srgb, var(--rose) 18%, #000);
  box-shadow:
    inset 0 1px 0 rgba(100, 200, 120, 0.1),
    inset 0 -1px 0 rgba(0, 0, 0, 0.6),
    inset 0 0 20px rgba(255, 124, 255, 0.03);
}

.lcd-statusbar__form {
  display: flex;
  align-items: center;
  gap: 6px;
  flex: 1 1 0;
  min-width: 0;
  margin: 0;
  text-transform: none;
  letter-spacing: normal;
}

.lcd-statusbar__prompt {
  color: var(--green-dim);
  flex-shrink: 0;
  cursor: pointer;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

.lcd-statusbar__suffix {
  flex-shrink: 0;
  color: var(--green-muted);
  letter-spacing: 0.02em;
  margin-right: -2px;
}

.lcd-statusbar__input {
  flex: 1 1 0;
  min-width: 80px;
  margin: 0;
  padding: 2px 0 1px;
  border: none;
  border-bottom: 1px solid rgba(57, 255, 20, 0.2);
  border-radius: 0;
  background: transparent;
  color: var(--green);
  font-family: var(--font-hud);
  font-size: var(--type-small);
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: none;
  caret-color: var(--green);
  outline: none;
}

.lcd-statusbar__input::placeholder {
  color: var(--green-dim);
  opacity: 0.75;
}

.lcd-statusbar__input:focus {
  border-bottom-color: color-mix(in srgb, var(--green) 55%, transparent);
  text-shadow: 0 0 8px color-mix(in srgb, var(--green) 35%, transparent);
}

.lcd-statusbar__input--error {
  border-bottom-color: var(--red);
  color: #ff8888;
}

.lcd-statusbar__title {
  flex: 0 1 auto;
  max-width: min(42vw, 520px);
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--green-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.lcd-statusbar__sync {
  flex-shrink: 0;
  font-size: 0.92em;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--green);
  text-shadow: var(--green-glow);
}

@media (max-width: 560px) {
  .lcd-statusbar {
    flex-wrap: wrap;
    row-gap: 6px;
    padding-bottom: 8px;
  }
  .lcd-statusbar__form {
    flex: 1 1 100%;
    order: 1;
  }
  .lcd-statusbar__title {
    order: 2;
    flex: 1 1 auto;
    max-width: 100%;
    font-size: var(--type-caption);
    letter-spacing: 0.08em;
  }
  .lcd-statusbar__sync {
    order: 3;
  }
}

#matrix-bg {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  opacity: 0.36;
  pointer-events: none;
  display: block;
}

/* Bruit + flicker (même famille que 404 — réutilisé par .crt-vfx-noise dans 404.html) */
.crt-vfx-noise {
  pointer-events: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  opacity: 0.07;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation: crt-vfx-noise-flicker 3.2s steps(2) infinite;
}

@media (prefers-reduced-motion: reduce) {
  .crt-vfx-noise {
    animation: none;
    opacity: 0.055;
  }
}

@keyframes crt-vfx-noise-flicker {
  0%, 95%, 100% { opacity: 0.06; }
  96% { opacity: 0.11; }
}

.dashboard-header, .dashboard-grid, .ticker-zone, .levelup-overlay, .scanlines, .crt-glass {
  position: relative;
  z-index: 1;
}

.dashboard-grid {
  z-index: 2;
}

@media (min-width: 1400px) {
  .lcd-statusbar {
    font-size: var(--type-body);
    min-height: clamp(52px, 5.2dvh, 68px);
    padding: 8px 18px 9px;
  }

  .lcd-statusbar__input {
    font-size: var(--type-body);
  }

  .dashboard-header {
    gap: 14px 18px;
  }

  .header-menu {
    font-size: var(--type-nav);
    gap: 4px 18px;
  }

  .header-layout-btn {
    font-size: var(--type-nav);
  }
}

/* ── Châssis LCD — bezel 404 (rose + phosphore) + grille rétro ─────────────── */
.crt-stage.crt-stage--80s {
  border-radius: 6px;
  border: 3px solid var(--bezel);
  box-shadow:
    inset 0 0 0 1px var(--bezel-highlight),
    inset 0 0 100px rgba(0, 35, 18, 0.45),
    inset 2px 2px 0 rgba(255, 255, 255, 0.04),
    inset -3px -3px 0 rgba(0, 0, 0, 0.5),
    0 0 0 1px color-mix(in srgb, var(--rose) 28%, transparent),
    0 12px 48px rgba(0, 0, 0, 0.75);
  background:
    radial-gradient(ellipse 90% 60% at 50% 40%, rgba(255, 124, 255, 0.06) 0%, transparent 55%),
    radial-gradient(ellipse 80% 50% at 50% 50%, rgba(57, 255, 20, 0.04) 0%, transparent 60%),
    repeating-linear-gradient(90deg, transparent 0, transparent 7px, rgba(0, 50, 28, 0.04) 7px, rgba(0, 50, 28, 0.04) 8px),
    repeating-linear-gradient(0deg, transparent 0, transparent 7px, rgba(0, 50, 28, 0.04) 7px, rgba(0, 50, 28, 0.04) 8px),
    #010402;
}

/* Flicker CRT — rare intensity dips like a tired tube */
@media (prefers-reduced-motion: no-preference) {
  .crt { animation: flicker 60s linear infinite; }
}
@keyframes flicker {
  0%,100%{opacity:1} 92%{opacity:1} 92.5%{opacity:.97} 93%{opacity:1} 97%{opacity:1} 97.3%{opacity:.95} 97.6%{opacity:1}
}

@media (prefers-reduced-motion: no-preference) {
  .crt .crt-stage {
    filter: contrast(1.04) saturate(1.07);
  }
}

/* Scanlines — même pitch que la page 404 + vignette rose / vert */
.scanlines {
  pointer-events: none;
  position: absolute;
  inset: 0;
  z-index: 6;
  background:
    repeating-linear-gradient(0deg,
      rgba(0, 0, 0, 0),
      rgba(0, 0, 0, 0) 1px,
      rgba(0, 0, 0, 0.22) 1px,
      rgba(0, 0, 0, 0.22) 2px),
    radial-gradient(120% 95% at 50% 45%, rgba(0, 0, 0, 0) 48%, rgba(255, 124, 255, 0.05) 72%, rgba(0, 25, 14, 0.42) 100%);
  mix-blend-mode: multiply;
  opacity: 0.62;
}

@media (prefers-contrast: more) {
  .scanlines {
    opacity: 0.42;
    mix-blend-mode: multiply;
  }
}

/* ── Logo glitch (même palette / rythme que le « 404 » de la page erreur) ────*/
.logo.glitch {
  position: relative;
  display: inline-block;
  color: var(--green);
  text-shadow:
    0 0 8px color-mix(in srgb, var(--green) 55%, transparent),
    0 0 10px color-mix(in srgb, var(--rose) 38%, transparent);
  animation: logo-glitch-main 4s infinite step-end;
}
@supports ((-webkit-background-clip: text) or (background-clip: text)) {
  .logo.glitch {
    background: linear-gradient(180deg, var(--rose) 0 50%, var(--green) 50% 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    text-shadow: none;
  }
}
.logo.glitch::before,
.logo.glitch::after {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  overflow: hidden;
}
.logo.glitch::before {
  color: var(--rose);
  text-shadow: var(--rose-glow);
  animation: logo-glitch-rose 3.2s infinite step-end;
  clip-path: polygon(0 0, 100% 0, 100% 42%, 0 42%);
  opacity: 0.92;
}
.logo.glitch::after {
  color: var(--green);
  text-shadow: var(--green-glow);
  animation: logo-glitch-cyan 2.8s infinite step-end;
  clip-path: polygon(0 58%, 100% 58%, 100% 100%, 0 100%);
  opacity: 0.85;
}
@keyframes logo-glitch-main {
  0%, 91%, 100% { transform: translate(0); filter: none; }
  92% { transform: translate(2px, -1px); }
  93% { transform: translate(-3px, 1px); }
  94% { transform: translate(0); }
}
@keyframes logo-glitch-rose {
  0%, 88%, 100% { transform: translate(0); }
  89% { transform: translate(-5px, 1px); }
  90% { transform: translate(4px, -2px); }
  91% { transform: translate(-2px, 0); }
}
@keyframes logo-glitch-cyan {
  0%, 90%, 100% { transform: translate(0); }
  91% { transform: translate(3px, 2px); }
  92% { transform: translate(-4px, -1px); }
}

@media (prefers-reduced-motion: reduce) {
  .logo.glitch,
  .logo.glitch::before,
  .logo.glitch::after {
    animation: none !important;
  }
  .logo.glitch::before,
  .logo.glitch::after {
    opacity: 0;
  }
}

/* ── Header — barre de session type menu DOS / GEM ───────────────────────────*/
.dashboard-header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 10px 14px;
  flex-shrink: 0;
  min-height: var(--header-h);
  padding: 8px clamp(14px, 2vw, 22px) 10px;
  border-bottom: 2px solid color-mix(in srgb, var(--rose) 14%, #0a1810);
  background:
    linear-gradient(180deg, #0a1810 0%, #030806 48%, #020403 100%);
  width: 100%;
  box-sizing: border-box;
  box-shadow:
    inset 0 1px 0 rgba(120, 220, 140, 0.12),
    inset 0 -2px 0 rgba(0, 0, 0, 0.65),
    0 0 28px rgba(255, 124, 255, 0.045);
}

.header-left {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  min-width: 0;
  flex: 0 1 auto;
  max-width: min(100%, 480px);
}

/* Zone centrale : horloge isolée pour éviter tout chevauchement avec la barre d’outils */
.header-center {
  flex: 1 1 260px;
  min-width: 0;
  max-width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}

/* Météo + connexion + outils : regroupés, poussés à droite sur la même ligne quand il y a la place */
.header-right {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 8px 12px;
  flex: 0 1 auto;
  min-width: 0;
  margin-left: auto;
}
.header-brand {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 8px;
}

.header-menu {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 2px 14px;
  font-family: var(--font-pixel);
  font-size: var(--text-pixel-sm);
  letter-spacing: 0.06em;
  color: color-mix(in srgb, var(--green) 55%, var(--dim));
  padding-top: 2px;
  user-select: none;
}
.header-menu__item {
  display: inline-flex;
  align-items: center;
  padding: 2px 0;
  line-height: 1.2;
  border-bottom: 1px solid transparent;
}
.header-menu__item:hover {
  color: var(--green);
  border-bottom-color: color-mix(in srgb, var(--green) 40%, transparent);
}

/* Logo CRT 13" — plus grand et lisible */
.logo {
  font-family: var(--font-pixel);
  font-size: var(--type-pixel-md);
  color: var(--green);
  text-shadow: var(--green-glow);
  letter-spacing: 2px;
}
.version { font-family:var(--font-mono); font-size: var(--type-body); letter-spacing: 0.5px; }

/* Actions header (Tout replier / Tout déplier / Mise en page / Showcase)
   alignées sur le style menu FILE VIEW SESSION LINK HELP */
.header-layout-btn {
  appearance: none;
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  font-family: var(--font-pixel);
  font-size: var(--text-pixel-sm);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 2px 0;
  min-height: 0;
  margin: 0;
  cursor: pointer;
  border: none;
  border-bottom: 1px solid transparent;
  background: transparent;
  color: color-mix(in srgb, var(--green) 55%, var(--dim));
  text-decoration: none;
  line-height: 1.2;
  transition: color 0.15s, border-color 0.15s;
}
.header-layout-btn:hover {
  color: var(--green);
  border-bottom-color: color-mix(in srgb, var(--green) 40%, transparent);
}
.header-layout-btn:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
  border-bottom-color: color-mix(in srgb, var(--green) 55%, transparent);
}

/* Étroit : empiler marque → horloge → outils/météo sans chevauchement */
@media (max-width: 720px) {
  .dashboard-header {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }
  .header-left {
    max-width: 100%;
  }
  .header-center {
    flex: 0 1 auto;
    width: 100%;
    order: 0;
  }
  .header-right {
    margin-left: 0;
    width: 100%;
    justify-content: center;
    border-top: 1px solid color-mix(in srgb, var(--green) 12%, #0a1810);
    padding-top: 10px;
  }
  .header-weather {
    max-width: 100%;
    flex: 1 1 auto;
    min-width: 0;
    justify-content: center;
  }
}

/* Horloge — HUD tabular */
.clock {
  font-family: var(--font-hud);
  font-weight: 500;
  font-size: var(--type-display);
  color: var(--green);
  text-shadow: var(--green-glow);
  letter-spacing: 0.08em;
  font-variant-numeric: tabular-nums;
}

.clock.clock--triple {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  width: 100%;
  max-width: min(96vw, 920px);
  gap: clamp(4px, 0.6vw, 8px);
  line-height: 1.2;
  box-sizing: border-box;
}

/* Horloge dans .header-center : largeur bornée, plus de flex-grow sur l’élément (évitait le recouvrement des boutons) */
.dashboard-header .header-center .clock.clock--triple {
  flex: 0 1 auto;
  width: 100%;
  max-width: min(100%, 880px);
  margin-inline: 0;
}

/* Date : pleine largeur au-dessus des 3 colonnes */
.clock.clock--triple .clock__date {
  display: block;
  width: 100%;
  box-sizing: border-box;
  font-family: var(--font-hud);
  font-size: 0.42em;
  font-weight: 500;
  letter-spacing: 0.14em;
  color: color-mix(in srgb, var(--green) 88%, #fff);
  text-shadow: var(--green-glow);
  white-space: nowrap;
  text-align: center;
}

/* Grille 1×5 : heure locale, +5, heure+5, +15, heure+15 */
.clock__grid {
  display: grid;
  grid-template-columns: auto auto auto auto auto;
  column-gap: clamp(6px, 1.4vw, 14px);
  width: 100%;
  align-items: baseline;
  justify-content: center;
  justify-items: center;
}

.clock__sep {
  font-size: 0.42em;
  font-family: var(--font-mono);
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.06em;
  color: color-mix(in srgb, var(--green) 72%, #889988);
  text-shadow: 0 0 8px color-mix(in srgb, var(--green) 35%, transparent);
}

.clock__cell--time {
  font-size: 0.92em;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  line-height: 1;
}

.clock__cell--t5,
.clock__cell--t15 {
  color: color-mix(in srgb, var(--green) 72%, #889988);
  text-shadow: 0 0 8px color-mix(in srgb, var(--green) 35%, transparent);
}

.clock__cell--t0 {
  font-weight: 500;
  color: color-mix(in srgb, var(--green) 96%, #fff);
  text-shadow: var(--green-glow);
}

.header-weather {
  font-family: var(--font-mono);
  font-size: var(--type-body);
  color: color-mix(in srgb, var(--green) 78%, #fff);
  border: 1px solid color-mix(in srgb, var(--green) 28%, #0a120c);
  background: linear-gradient(180deg, rgba(8, 20, 12, 0.85), rgba(2, 8, 4, 0.92));
  padding: 4px 8px;
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  max-width: min(42vw, 560px);
}

.header-weather__link {
  color: color-mix(in srgb, var(--blue) 80%, #fff);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.header-weather__link:hover {
  color: color-mix(in srgb, var(--blue) 92%, #fff);
}

.header-right .db-meter {
  order: 2;
  width: 100%;
  max-width: min(42vw, 560px);
  padding-top: 2px;
}

.header-right .db-meter__eq {
  gap: 2px;
}

.header-right .db-meter__band-track {
  height: 34px;
}

.header-right .db-meter__band-value,
.header-right .db-meter__band-label {
  display: none;
}

.header-right .db-meter__readouts {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  font-size: var(--type-small);
}

/* Statut connexion */
.conn-status { display:flex; align-items:center; gap:8px; font-family:var(--font-mono); font-size: var(--type-h3); }
.conn-dot    { width:12px; height:12px; border-radius:50%; display:inline-block; }
.conn-online  .conn-dot   { background:var(--green); box-shadow:var(--green-glow); }
.conn-online  .conn-label { color:var(--green); text-shadow:var(--green-glow); }
.conn-offline .conn-dot   { background:var(--red); animation:blink 1s step-end infinite; }
.conn-offline .conn-label { color:var(--red); }

/* ── Level-up overlay ────────────────────────────────────────────────────────*/
.levelup-overlay {
  position:absolute; inset:0; z-index:1000;
  display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,.75);
  animation:levelup-fade 3s ease-out forwards;
}
@keyframes levelup-fade { 0%{opacity:0} 15%{opacity:1} 75%{opacity:1} 100%{opacity:0;pointer-events:none} }
.levelup-box { text-align:center; border:2px solid var(--rose); padding:24px 40px; background:var(--panel-bg); box-shadow:0 0 40px var(--rose); }
.levelup-text  { font-family:var(--font-pixel); font-size:var(--type-h2); color:var(--rose); text-shadow:var(--rose-glow); animation:blink .4s step-end infinite; }
.levelup-level { font-family:var(--font-mono);  font-size:var(--type-h1); color:var(--rose); margin-top:10px; }

/* ── Double ticker — ancré en bas du stage (flux flex) ───────────────────────*/
.ticker-zone {
  position: relative;
  flex-shrink: 0;
  width: 100%;
  z-index: 3;
  border-top: 2px solid #0a1810;
  background: linear-gradient(180deg, rgba(0, 10, 5, 0.98), rgba(0, 2, 1, 0.99));
  box-shadow:
    inset 0 2px 0 rgba(60, 140, 80, 0.08),
    inset 0 -1px 0 rgba(0, 0, 0, 0.5);
}
.ticker-bar {
  display:flex; align-items:center; gap:7px;
  padding: 0 clamp(12px, 2vw, 18px);
  min-height: 34px;
  overflow: hidden;
}
.ticker-bar--top    { background:linear-gradient(180deg, rgba(0,0,0,.95), rgba(0,0,0,.85)); border-bottom:1px solid #0d0d0d; }
.ticker-bar--bottom { background:linear-gradient(180deg, rgba(0,0,0,.86), rgba(0,0,0,.72)); }

.ticker-prefix { font-family:var(--font-mono); font-size:var(--type-h3); color:var(--green); flex-shrink:0; }
.ticker-track  { overflow:hidden; flex:1; }

/* Polices ticker plus grandes pour CRT */
.ticker-content { 
  font-family: var(--font-mono);
  font-size: var(--type-h3);
  color: var(--green);
  white-space: nowrap; display:inline-block;
  animation: ticker-scroll 35s linear infinite;
}
.ticker-content--reverse {
  font-size: var(--type-h4);
  animation: ticker-scroll-reverse 22s linear infinite;
}

@keyframes ticker-scroll         { 0%{transform:translateX(100%)} 100%{transform:translateX(-100%)} }
@keyframes ticker-scroll-reverse { 0%{transform:translateX(-100%)} 100%{transform:translateX(100%)} }
.ticker-content .alert-text { color:var(--red); }

/* ══════════════════════════════════════════════════════════════════════════════
   GLITCH OVERLAY — animation plein écran au déclenchement de règle
   ══════════════════════════════════════════════════════════════════════════════ */

#glitch-overlay {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: rgba(0, 0, 0, 0.92);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.08s steps(1);
  overflow: hidden;
}

/* ── Mode de base : shake léger rouge ─────────────────────────────────────── */
#glitch-overlay.go-active {
  opacity: 1;
  pointer-events: all;
  cursor: pointer;
  animation: go-shake 0.07s steps(1) infinite;
}

/* ── go-basic : flash rouge, shake normal (défaut règle déclenchée) ─────── */
#glitch-overlay.go-active.go-basic {
  background: rgba(40, 0, 0, 0.93);
  animation: go-shake 0.07s steps(1) infinite;
}
#glitch-overlay.go-active.go-basic .go-scanlines {
  background: repeating-linear-gradient(
    0deg, transparent, transparent 3px,
    rgba(255,0,0,0.08) 3px, rgba(255,0,0,0.08) 4px
  );
}
#glitch-overlay.go-active.go-basic .go-label { color: #ff2020; }

/* ── go-scan-pulse : scanlines vertes intenses, fond vert phosphore ──────── */
#glitch-overlay.go-active.go-scan-pulse {
  background: rgba(0, 10, 0, 0.96);
  animation: go-shake-slow 0.15s steps(1) infinite;
}
#glitch-overlay.go-active.go-scan-pulse .go-scanlines {
  background: repeating-linear-gradient(
    0deg,
    color-mix(in srgb, var(--green) 22%, transparent) 0px,
    color-mix(in srgb, var(--green) 22%, transparent) 2px,
    transparent 2px, transparent 5px
  );
  animation: go-scan-pulse 0.06s steps(2) infinite;
}
#glitch-overlay.go-active.go-scan-pulse .go-label { color: var(--green); text-shadow: 0 0 20px var(--green), 0 0 50px color-mix(in srgb, var(--green) 50%, transparent); }
#glitch-overlay.go-active.go-scan-pulse .go-rule-name {
  color: var(--green);
  text-shadow: 0 0 20px var(--green), -3px 0 var(--blue), 3px 0 var(--green);
}
#glitch-overlay.go-active.go-scan-pulse #glitch-noise-canvas { opacity: 0.2; filter: hue-rotate(120deg); }

/* ── go-chromatic : aberration chromatique RGB forte, fond violet ────────── */
#glitch-overlay.go-active.go-chromatic {
  background: rgba(10, 0, 20, 0.94);
  animation: go-shake 0.05s steps(1) infinite;
  filter: contrast(1.3);
}
#glitch-overlay.go-active.go-chromatic .go-content {
  filter: saturate(2.5) hue-rotate(15deg);
}
#glitch-overlay.go-active.go-chromatic .go-rule-name {
  text-shadow:
    0 0 30px #ffffff,
    -8px 0 #ff2020cc,
     8px 0 #00cfffcc,
     0  -4px #ff6fffcc,
     0   4px color-mix(in srgb, var(--green) 50%, transparent);
  animation: go-text-glitch 0.08s steps(1) infinite;
}
#glitch-overlay.go-active.go-chromatic .go-label { color: #a855f7; text-shadow: 0 0 20px #a855f7, 0 0 50px #a855f780; }
#glitch-overlay.go-active.go-chromatic #glitch-noise-canvas {
  opacity: 0.7; mix-blend-mode: color-dodge; filter: hue-rotate(270deg) saturate(3);
}
#glitch-overlay.go-active.go-chromatic .go-scanlines { display: none; }

/* ── go-random : chaos total, rotation hue rapide, secousse extrême ──────── */
#glitch-overlay.go-active.go-random {
  animation: go-shake-violent 0.04s steps(1) infinite;
  background: rgba(0, 0, 0, 0.88);
}
#glitch-overlay.go-active.go-random .go-content {
  animation: go-hue-spin 0.3s steps(6) infinite;
}
#glitch-overlay.go-active.go-random .go-scanlines {
  animation: go-scan-pulse 0.04s steps(4) infinite;
  background: repeating-linear-gradient(
    0deg, rgba(255,0,0,0.1) 0px, transparent 1px,
    rgba(0,200,255,0.1) 2px, transparent 3px
  );
}
#glitch-overlay.go-active.go-random #glitch-noise-canvas { opacity: 0.85; filter: saturate(4) hue-rotate(0deg); animation: noise-hue 0.2s linear infinite; }
#glitch-overlay.go-active.go-random .go-label { animation: go-label-blink 0.1s steps(1) infinite; }

/* ── go-heavy : distorsion maximale, inversion, fond flash blanc/rouge ───── */
#glitch-overlay.go-active.go-heavy {
  animation: go-shake-extreme 0.03s steps(1) infinite;
  background: rgba(0,0,0,0.9);
}
#glitch-overlay.go-active.go-heavy .go-content {
  animation: go-invert-pulse 0.12s steps(1) infinite;
}
#glitch-overlay.go-active.go-heavy .go-rule-name {
  animation: go-text-glitch 0.05s steps(1) infinite;
  font-size: var(--type-display);
}
#glitch-overlay.go-active.go-heavy .go-scanlines {
  background: repeating-linear-gradient(
    0deg,
    rgba(255,255,255,0.15) 0px, rgba(255,255,255,0.15) 1px,
    rgba(255,0,0,0.12) 1px, rgba(255,0,0,0.12) 2px,
    transparent 2px, transparent 4px
  );
  animation: go-scan-pulse 0.03s steps(3) infinite;
}
#glitch-overlay.go-active.go-heavy #glitch-noise-canvas { opacity: 0.9; mix-blend-mode: hard-light; }

/* ── Keyframes shake ───────────────────────────────────────────────────────── */
@keyframes go-shake {
  0%   { transform: translate(0, 0) skewX(0deg); }
  15%  { transform: translate(-4px, 1px) skewX(-1.5deg); }
  30%  { transform: translate(4px, -2px) skewX(1deg); }
  50%  { transform: translate(-2px, 3px) skewX(0.5deg); }
  65%  { transform: translate(3px, -1px) skewX(-0.8deg); }
  80%  { transform: translate(-1px, 2px) skewX(1.2deg); }
  100% { transform: translate(0, 0) skewX(0deg); }
}
@keyframes go-shake-slow {
  0%   { transform: translate(0,0) skewX(0deg); }
  30%  { transform: translate(-2px,1px) skewX(-0.5deg); }
  70%  { transform: translate(2px,-1px) skewX(0.5deg); }
  100% { transform: translate(0,0) skewX(0deg); }
}
@keyframes go-shake-violent {
  0%   { transform: translate(0,0) skewX(0) scaleX(1); }
  10%  { transform: translate(-8px, 3px) skewX(-3deg) scaleX(0.98); }
  20%  { transform: translate(10px,-4px) skewX(4deg) scaleX(1.02); }
  30%  { transform: translate(-6px, 5px) skewX(-2deg); }
  50%  { transform: translate(6px,-2px) skewX(2.5deg); }
  75%  { transform: translate(-4px, 4px) skewX(-1.5deg); }
  100% { transform: translate(0,0) skewX(0); }
}
@keyframes go-shake-extreme {
  0%   { transform: translate(0,0) skewX(0) skewY(0); }
  10%  { transform: translate(-14px,6px) skewX(-5deg) skewY(1deg); }
  20%  { transform: translate(16px,-8px) skewX(6deg) skewY(-1.5deg); }
  35%  { transform: translate(-10px,10px) skewX(-4deg); }
  50%  { transform: translate(12px,-6px) skewX(5deg) skewY(0.5deg); }
  65%  { transform: translate(-8px,8px) skewX(-3deg); }
  80%  { transform: translate(10px,-4px) skewX(4deg); }
  100% { transform: translate(0,0) skewX(0); }
}

/* ── Keyframes scanlines ───────────────────────────────────────────────────── */
@keyframes go-scan-pulse {
  0%   { opacity: 0.3; transform: translateY(0); }
  50%  { opacity: 1;   transform: translateY(2px); }
  100% { opacity: 0.4; transform: translateY(0); }
}

/* ── Keyframes couleur chaos ───────────────────────────────────────────────── */
@keyframes go-hue-spin {
  0%   { filter: hue-rotate(0deg)   saturate(2); }
  16%  { filter: hue-rotate(60deg)  saturate(3) brightness(1.5); }
  33%  { filter: hue-rotate(120deg) saturate(2); }
  50%  { filter: hue-rotate(180deg) saturate(4) brightness(0.8); }
  66%  { filter: hue-rotate(240deg) saturate(2); }
  83%  { filter: hue-rotate(300deg) saturate(3) brightness(1.3); }
  100% { filter: hue-rotate(360deg) saturate(2); }
}
@keyframes noise-hue {
  0%   { filter: saturate(4) hue-rotate(0deg); }
  100% { filter: saturate(4) hue-rotate(360deg); }
}
@keyframes go-invert-pulse {
  0%,40% { filter: none; }
  41%    { filter: invert(1) hue-rotate(180deg); }
  48%    { filter: none; }
  55%    { filter: invert(0.7) sepia(1) saturate(3); }
  62%    { filter: none; }
}

/* Canvas bruit TV */
#glitch-noise-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0.55;
  mix-blend-mode: screen;
}

/* Scanlines overlay sur la glitch */
.go-scanlines {
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    transparent, transparent 2px,
    rgba(0,0,0,0.4) 2px, rgba(0,0,0,0.4) 4px
  );
  pointer-events: none;
}

/* Barres de distorsion horizontales */
.go-bars { position: absolute; inset: 0; pointer-events: none; }
.go-bar  {
  position: absolute;
  left: 0; right: 0;
  animation: go-bar-jitter steps(1) infinite;
  transform-origin: left center;
}
@keyframes go-bar-jitter {
  0%   { transform: translateX(0) scaleX(1); }
  33%  { transform: translateX(20px) scaleX(0.85); }
  66%  { transform: translateX(-15px) scaleX(1.1); }
  100% { transform: translateX(0) scaleX(1); }
}

/* Contenu central */
.go-content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 32px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
}

.go-label {
  font-family: 'Press Start 2P', monospace;
  font-size: var(--type-pixel-sm);
  color: #ff2020;
  letter-spacing: 4px;
  text-shadow: 0 0 20px #ff2020, 0 0 40px #ff202080;
  animation: go-label-blink 0.25s steps(1) infinite;
}
@keyframes go-label-blink {
  0%, 74% { opacity: 1; }
  75%, 100% { opacity: 0.7; }
}

.go-rule-name {
  font-family: 'Press Start 2P', monospace;
  /* Overlay « héros » : un cran au-dessus du h1 sémantique (pixel très carré) */
  font-size: var(--type-display);
  color: #fff;
  position: relative;
  text-shadow:
    0 0 30px #ffffff,
    -4px 0 #ff2020,
     4px 0 #00cfff;
  animation: go-text-glitch 0.13s steps(1) infinite;
  max-width: 700px;
  word-break: break-word;
}

.go-rule-name::before,
.go-rule-name::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  font-size: inherit;
  font-family: inherit;
}

.go-rule-name::before {
  color: #ff2020;
  animation: go-glitch-r 0.18s steps(1) infinite;
  clip-path: polygon(0 20%, 100% 20%, 100% 45%, 0 45%);
  transform: translateX(-5px);
}

.go-rule-name::after {
  color: #00cfff;
  animation: go-glitch-l 0.22s steps(1) infinite;
  clip-path: polygon(0 55%, 100% 55%, 100% 78%, 0 78%);
  transform: translateX(5px);
}

@keyframes go-text-glitch {
  0%,80%  { transform: skewX(0deg) translateX(0); }
  81%     { transform: skewX(-5deg) translateX(-6px); }
  84%     { transform: skewX(3deg) translateX(4px); }
  87%     { transform: skewX(0deg) translateX(0); }
  90%     { transform: skewX(8deg) translateX(8px); }
  95%     { transform: skewX(-2deg) translateX(-3px); }
  100%    { transform: skewX(0deg) translateX(0); }
}

@keyframes go-glitch-r {
  0%,60%  { clip-path: polygon(0 20%, 100% 20%, 100% 45%, 0 45%); transform: translateX(-5px); }
  61%     { clip-path: polygon(0 5%,  100% 5%,  100% 25%, 0 25%); transform: translateX(-12px); }
  72%     { clip-path: polygon(0 70%, 100% 70%, 100% 85%, 0 85%); transform: translateX(8px); }
  85%     { clip-path: polygon(0 40%, 100% 40%, 100% 55%, 0 55%); transform: translateX(-3px); }
  100%    { clip-path: polygon(0 20%, 100% 20%, 100% 45%, 0 45%); transform: translateX(-5px); }
}

@keyframes go-glitch-l {
  0%,50%  { clip-path: polygon(0 55%, 100% 55%, 100% 78%, 0 78%); transform: translateX(5px); }
  51%     { clip-path: polygon(0 30%, 100% 30%, 100% 50%, 0 50%); transform: translateX(15px); }
  65%     { clip-path: polygon(0 80%, 100% 80%, 100% 95%, 0 95%); transform: translateX(-6px); }
  80%     { clip-path: polygon(0 10%, 100% 10%, 100% 28%, 0 28%); transform: translateX(9px); }
  100%    { clip-path: polygon(0 55%, 100% 55%, 100% 78%, 0 78%); transform: translateX(5px); }
}

.go-detail {
  font-family: 'VT323', monospace;
  font-size: var(--type-h3);
  color: #ffb000;
  text-shadow: 0 0 10px #ffb000;
  letter-spacing: 2px;
}

.go-osc {
  font-family: 'VT323', monospace;
  font-size: var(--type-h3);
  color: #ff6fff;
  text-shadow: 0 0 8px #ff6fff;
  letter-spacing: 1px;
}

.go-hint {
  font-family: 'VT323', monospace;
  font-size: var(--type-body);
  color: #333;
  animation: go-hint-pulse 1.5s ease-in-out infinite;
  margin-top: 8px;
}
@keyframes go-hint-pulse {
  0%,100% { color: #333; }
  50%     { color: #666; }
}

/* ── Typography normalization (dashboard home) ─────────────────────────────── */
body.crt .lcd-statusbar,
body.crt .lcd-statusbar__input,
body.crt .header-weather,
body.crt .header-right .db-meter__readouts,
body.crt .version,
body.crt .conn-status,
body.crt .ticker-content--reverse {
  font-size: var(--dash-type-m);
}

body.crt .header-menu,
body.crt .header-layout-btn,
body.crt .db-meter__title,
body.crt .go-label {
  font-size: var(--dash-type-s);
}

body.crt .clock,
body.crt .ticker-content {
  font-size: var(--type-display);
}

/* ── Mobile phone portrait (≤640px) — CRT décoratif masqué, header compact ── */
@media (max-width: 640px) {
  /* Overlays position:absolute dont l'étendue est imprévisible sans hauteur fixe */
  #matrix-bg     { display: none; }
  .crt-vfx-noise { display: none; }
  .scanlines     { display: none; }

  /* Analyseur dB 24 bandes trop large pour portrait téléphone */
  #db-meter { display: none; }

  /* Header plus compact */
  .dashboard-header {
    gap: 6px 8px;
    min-height: auto;
  }

  /* Ticker compact */
  .ticker-bar {
    min-height: 24px;
  }
  .ticker-content {
    font-size: var(--type-h4);
  }
  .ticker-content--reverse {
    font-size: var(--type-body);
  }
}

