/* ======================================================================
   VAULT RUSH — echter 3D-Heist-Korridor (CSS-3D, Kamera-Dolly durch Türen)
   Figur läuft von vorne in die Tiefe; bei richtig dollyt die Kamera hinter
   ihr durch den wachsenden Türrahmen in einen neuen Raum.
   ====================================================================== */

:root {
  --text: #eaf0ff; --text-dim: #93a0c8; --text-faint: #5e6a95;
  --gold: #ffc83d; --green: #2dff9e; --red: #ff3b5c;
  --tap: 0.12s ease;

  /* Zonen-Palette (von JS gesetzt) */
  --bgTop: #0a1622; --bgBottom: #0e2436;
  --wall: #12283a; --wallAccent: #1f4a66;
  --floor: #0c1c2a; --floorLine: #2fe6ff;
  --accent: #2fe6ff; --accent2: #e8f6ff;
  --doorBody: #16344a; --doorFrame: #2a5e7e; --doorGlow: #5cf2ff;

  --thief-body: #0a0d16;

  /* 3D-Geometrie (live tunebar) */
  --persp: 720px; --poY: 40%;
  --roomW: 1000px; --roomH: 600px; --depth: 1900px;
  --doorZ: -700px; --doorX: 250px;
  --heroX: 0px; --heroY: 196px; --heroZ: -150px; --heroScale: 1;
  --cam: 0px; --camX: 0px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
  background: #04060d;
  color: var(--text);
  font-family: "Segoe UI", system-ui, -apple-system, Roboto, sans-serif;
  overflow: hidden;
  -webkit-text-size-adjust: 100%;
}
.hidden { display: none !important; }
.muted { color: var(--text-dim); font-weight: 500; font-size: 0.8em; }

.game { position: fixed; inset: 0; overflow: hidden; }

/* ================================ Stage =============================== */

.stage {
  position: absolute;
  inset: 0;
  overflow: hidden;
  background:
    radial-gradient(62% 52% at 50% 44%, color-mix(in srgb, var(--accent) 20%, transparent), transparent 72%),
    radial-gradient(120% 90% at 50% 38%, var(--bgTop) 0%, var(--bgBottom) 70%, #03040a 100%);
  perspective: var(--persp);
  perspective-origin: 50% var(--poY);
  transition: background 0.6s ease;
}

.cam {
  position: absolute;
  inset: 0;
  transform-style: preserve-3d;
  transform: translateZ(var(--cam)) translateX(var(--camX));
  transition: transform 0.85s cubic-bezier(0.5, 0, 0.3, 1);
  pointer-events: none; /* nur die Türen sind klickbar (Korridorflächen dürfen Klicks NICHT abfangen) */
}
.world { position: absolute; inset: 0; transform-style: preserve-3d; pointer-events: none; }

/* Korridor-Flächen */
.face { position: absolute; left: 50%; top: 50%; pointer-events: none; }
.f-floor {
  width: var(--roomW); height: var(--depth);
  margin-left: calc(var(--roomW) / -2); margin-top: calc(var(--depth) / -2);
  transform: translateY(calc(var(--roomH) / 2)) translateZ(calc(var(--depth) / -2)) rotateX(90deg);
  /* Glatter, dunkler Spiegelboden mit Lichtpool unter den Türen – KEINE Gitterlinien (verzerren bei Bewegung). */
  background:
    radial-gradient(50% 42% at 50% 15%, color-mix(in srgb, var(--accent) 30%, transparent), transparent 72%),
    linear-gradient(0deg, color-mix(in srgb, var(--floor) 88%, var(--accent) 12%) 0%, #04060c 70%);
  box-shadow: inset 0 0 220px rgba(0, 0, 0, 0.65);
}
/* Boden, Wände, Decke und Rückwand entfernt – man sieht NUR die Türen im Void. */
.f-floor, .f-ceil, .f-wall, .f-back { display: none; }

.f-back {
  width: var(--roomW); height: var(--roomH);
  margin-left: calc(var(--roomW) / -2); margin-top: calc(var(--roomH) / -2);
  transform: translateZ(calc(var(--depth) * -1));
  background: linear-gradient(180deg, color-mix(in srgb, var(--wall) 70%, #000), #03040a);
  overflow: hidden;
}
.back-glow {
  position: absolute; inset: 0;
  background:
    radial-gradient(50% 55% at 50% 48%, color-mix(in srgb, var(--accent) 36%, transparent), transparent 72%),
    radial-gradient(90% 70% at 50% 100%, color-mix(in srgb, var(--accent2) 16%, transparent), transparent 70%);
  animation: backPulse 5s ease-in-out infinite;
}
@keyframes backPulse { 0%, 100% { opacity: 0.8; } 50% { opacity: 1; } }
/* Tiefen-Dunst am Fluchtpunkt */
.vanish-fog {
  position: absolute; left: 50%; top: 42%;
  width: 40%; height: 40%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--accent) 22%, transparent), transparent 70%);
  filter: blur(20px);
  pointer-events: none;
}
.back-decor { position: absolute; inset: 0; }

/* ============================== Partikel ============================== */
.fx { position: absolute; inset: 0; pointer-events: none; z-index: 6; }

/* =========================== Türen (3D-Plane) ========================= */

.door3d {
  position: absolute; left: 50%; top: 50%;
  width: 246px; height: 384px;
  margin-left: -123px; margin-top: -192px;
  transform-style: preserve-3d;
  cursor: pointer;
  pointer-events: auto; /* trotz pointer-events:none am Korridor anklickbar */
  transition: filter 0.25s ease, opacity 0.3s ease;
  -webkit-tap-highlight-color: transparent;
}
.door-a { transform: translateX(calc(var(--doorX) * -1)) translateZ(var(--doorZ)); }
.door-b { transform: translateX(var(--doorX)) translateZ(var(--doorZ)); }
.door3d > * { position: absolute; }

.d-aura {
  inset: -30px;
  border-radius: 30px;
  background: radial-gradient(58% 60% at 50% 46%, color-mix(in srgb, var(--doorGlow) 58%, transparent), transparent 72%);
  opacity: 0.7; filter: blur(3px);
}
.d-frame {
  inset: 0;
  border-radius: 22px 22px 12px 12px;
  background:
    linear-gradient(160deg, color-mix(in srgb, var(--doorFrame) 150%, #fff 24%) 0%, var(--doorFrame) 30%, color-mix(in srgb, var(--doorFrame) 38%, #000) 100%);
  box-shadow:
    0 0 50px color-mix(in srgb, var(--doorGlow) 70%, transparent),
    0 20px 44px rgba(0, 0, 0, 0.55),
    inset 0 3px 5px color-mix(in srgb, #fff 42%, transparent),
    inset 0 -6px 12px rgba(0, 0, 0, 0.6),
    inset 0 0 0 3px color-mix(in srgb, var(--doorGlow) 60%, transparent),
    inset 0 0 30px color-mix(in srgb, var(--doorGlow) 32%, transparent);
}
/* Eckbolzen für den Tresor-Look */
.d-frame::before, .d-frame::after {
  content: ""; position: absolute; width: 11px; height: 11px; border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #fff, color-mix(in srgb, var(--doorFrame) 60%, #000));
  box-shadow: 0 0 4px rgba(0, 0, 0, 0.6);
}
.d-frame::before { top: 12px; left: 12px; box-shadow: 212px 0 0 -1px color-mix(in srgb, var(--doorFrame) 70%, #fff 10%), 0 0 4px rgba(0,0,0,.6); }
.d-frame::after { bottom: 12px; left: 12px; box-shadow: 212px 0 0 -1px color-mix(in srgb, var(--doorFrame) 70%, #fff 10%), 0 0 4px rgba(0,0,0,.6); }
/* Runde, versenkte Stahl-Tresorluke (clean) */
.d-portal {
  left: 50%; top: 50%; width: 82%; aspect-ratio: 1; transform: translate(-50%, -50%);
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 34%, #353f63 0%, #1d2440 48%, #0d1124 100%);
  box-shadow:
    inset 0 0 0 4px color-mix(in srgb, var(--doorGlow) 50%, #000),
    inset 0 8px 16px rgba(255, 255, 255, 0.07),
    inset 0 0 44px rgba(0, 0, 0, 0.82),
    0 0 26px color-mix(in srgb, var(--doorGlow) 38%, transparent);
}
.d-leaf {
  top: 7%; bottom: 7%; width: 43%;
  background: linear-gradient(180deg, color-mix(in srgb, var(--doorBody) 130%, #fff 8%), var(--doorBody));
  box-shadow: inset 0 0 30px rgba(0, 0, 0, 0.6), inset 0 2px 0 color-mix(in srgb, var(--doorGlow) 30%, transparent);
  transition: transform 0.5s cubic-bezier(0.7, 0, 0.2, 1);
  z-index: 3;
}
.d-leaf-l { left: 7%; border-radius: 7px 2px 2px 5px; }
.d-leaf-r { right: 7%; border-radius: 2px 7px 5px 2px; }
.d-iris {
  left: 7%; right: 7%; height: 43%;
  background: linear-gradient(180deg, color-mix(in srgb, var(--doorBody) 130%, #fff 8%), var(--doorBody));
  box-shadow: inset 0 0 26px rgba(0, 0, 0, 0.6);
  transition: transform 0.5s cubic-bezier(0.7, 0, 0.2, 1);
  z-index: 3;
}
.di-1 { top: 7%; border-radius: 7px 7px 0 0; }
.di-2 { bottom: 7%; border-radius: 0 0 7px 7px; }
.d-bar {
  bottom: 7%; width: 14%; height: 86%; top: 7%;
  background: linear-gradient(180deg, color-mix(in srgb, var(--doorFrame) 130%, #fff 8%), var(--doorBody));
  border-radius: 6px;
  box-shadow: 0 0 8px color-mix(in srgb, var(--doorGlow) 40%, transparent);
  transition: transform 0.5s cubic-bezier(0.6, 0, 0.2, 1);
  z-index: 3;
}
.b1 { left: 16%; } .b2 { left: 43%; } .b3 { right: 16%; }
/* === Tresor-Speichenrad (dreht sich) — kräftiges Messing für klare Sichtbarkeit === */
/* === Clean Tresor-Ziffernblatt (dezent rotierend, keine Speichen/Zahnräder) === */
.d-wheel {
  left: 50%; top: 50%; width: 58%; aspect-ratio: 1;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: radial-gradient(circle, #0b0f20 0 40%, transparent 41% 100%);
  box-shadow:
    inset 0 0 0 2px color-mix(in srgb, var(--doorGlow) 70%, transparent),
    inset 0 0 22px rgba(0, 0, 0, 0.7);
  z-index: 4;
}
/* rotierender Ziffernblatt-Ring (feine Ticks) */
.d-wheel::before {
  content: ""; position: absolute; inset: 12%; border-radius: 50%;
  background: repeating-conic-gradient(from 0deg, color-mix(in srgb, var(--doorGlow) 88%, #fff 12%) 0 1.4deg, transparent 1.4deg 11.25deg);
  -webkit-mask: radial-gradient(circle, transparent 0 74%, #000 76% 95%, transparent 97%);
          mask: radial-gradient(circle, transparent 0 74%, #000 76% 95%, transparent 97%);
}
.door3d.ready .d-wheel::before { animation: wheelSpin 11s linear infinite; }
.door3d.opening .d-wheel::before { animation: wheelSpin 0.55s linear infinite; }
@keyframes wheelSpin { to { transform: rotate(360deg); } }
/* 6 Bolzen am Lukenrand */
.d-wheel::after {
  content: ""; position: absolute; inset: -17%; border-radius: 50%;
  background:
    radial-gradient(circle at 50% 3%, #cdd6ec 0 2.6px, transparent 3.2px),
    radial-gradient(circle at 91.5% 27%, #cdd6ec 0 2.6px, transparent 3.2px),
    radial-gradient(circle at 91.5% 73%, #cdd6ec 0 2.6px, transparent 3.2px),
    radial-gradient(circle at 50% 97%, #cdd6ec 0 2.6px, transparent 3.2px),
    radial-gradient(circle at 8.5% 73%, #cdd6ec 0 2.6px, transparent 3.2px),
    radial-gradient(circle at 8.5% 27%, #cdd6ec 0 2.6px, transparent 3.2px);
  filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.6));
}
/* Tresor-Mechanik-Reste ausblenden (altes Konzept) */
.door3d .d-leaf, .door3d .d-iris, .door3d .d-bar, .door3d .d-seam, .door3d .d-gear { display: none !important; }
.d-seam {
  left: 50%; top: 9%; bottom: 9%; width: 3px;
  transform: translateX(-50%);
  background: linear-gradient(180deg, transparent, var(--doorGlow), transparent);
  box-shadow: 0 0 10px var(--doorGlow);
  z-index: 4;
  animation: seamPulse 2.4s ease-in-out infinite;
}
@keyframes seamPulse { 0%, 100% { opacity: 0.5; } 50% { opacity: 1; } }
.d-tag {
  left: 0; right: 0; top: -34px;
  text-align: center;
  font-size: 1.4rem; font-weight: 900;
  color: var(--doorGlow);
  text-shadow: 0 0 12px var(--doorGlow);
  z-index: 5;
}
/* Multiplikator-Badge mittig auf der Tür (ersetzt das alte "Eingang A/B") */
.d-label {
  display: flex; align-items: center; justify-content: center;
  left: 50%; top: 50%; transform: translate(-50%, -50%);
  padding: 5px 15px; border-radius: 999px;
  font-size: 1.95rem; font-weight: 900; letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
  color: #ffe9a8;
  background: transparent;
  text-shadow: 0 0 20px var(--gold), 0 0 10px rgba(255, 200, 61, 0.9), 0 2px 5px #000;
  z-index: 6; pointer-events: none; white-space: nowrap;
}
.door3d.ready .d-label { animation: rewardBreath 1.6s ease-in-out infinite; }
@keyframes rewardBreath { 0%, 100% { transform: translate(-50%, -50%) scale(1); } 50% { transform: translate(-50%, -50%) scale(1.05); } }
/* Gewinn: der gewählte (richtige) Multiplikator springt groß & golden hervor */
.d-label.won {
  color: #fff6cf; font-size: 2.4rem;
  text-shadow: 0 0 28px #ffd24a, 0 0 12px #fff, 0 2px 6px rgba(0, 0, 0, 0.6);
  animation: rewardPop 0.5s cubic-bezier(0.2, 1.5, 0.4, 1) both;
}
@keyframes rewardPop { 0% { transform: translate(-50%, -50%) scale(0.4); opacity: 0; } 60% { transform: translate(-50%, -50%) scale(1.28); opacity: 1; } 100% { transform: translate(-50%, -50%) scale(1.14); } }

/* Tür-Typen: zeigen jeweils andere Mechanik */
.door3d .d-leaf, .door3d .d-iris, .door3d .d-bar { display: none; }
.d-wheel { display: block; } /* Tresorrad immer sichtbar */
.door3d.t-slide .d-leaf { display: block; }
.door3d.t-iris  .d-iris { display: block; }
.door3d.t-bars  .d-bar { display: block; }
.door3d.t-vault .d-leaf { display: block; }
.door3d.t-hex   .d-leaf { display: block; }
.door3d.t-hex .d-leaf-l { clip-path: polygon(0 12%, 100% 0, 100% 100%, 0 88%); }
.door3d.t-hex .d-leaf-r { clip-path: polygon(0 0, 100% 12%, 100% 88%, 0 100%); }
.door3d.t-vault .d-leaf { width: 46%; top: 5%; bottom: 5%; }
.door3d.t-vault .d-leaf-l { left: 4%; border-radius: 7px; } .door3d.t-vault .d-leaf-r { right: 4%; border-radius: 7px; }

/* Tür-Zustände */
.door3d.ready { animation: doorBob 1.6s ease-in-out infinite; }
.door-b.ready { animation-delay: 0.45s; }
@keyframes doorBob { 0%, 100% { filter: brightness(1); } 50% { filter: brightness(1.22) drop-shadow(0 0 16px var(--doorGlow)); } }
.door3d.ready .d-aura { animation: readyAura 1.5s ease-in-out infinite; }
.door-b.ready .d-aura { animation-delay: 0.45s; }
@keyframes readyAura { 0%, 100% { opacity: 0.5; transform: scale(1); } 50% { opacity: 0.95; transform: scale(1.13); } }
/* Eingabe im Übergang gepuffert – sofortiges Feedback, fühlt sich nie "tot" an */
.door3d.queued { filter: brightness(1.35) drop-shadow(0 0 22px var(--accent)); }
.door3d.queued .d-frame { box-shadow: 0 0 30px var(--accent), inset 0 0 0 3px var(--accent); }
.door3d.queued .d-label { color: #fff; text-shadow: 0 0 18px var(--accent), 0 2px 5px rgba(0, 0, 0, 0.7); }
@media (hover: hover) { .door3d:hover { filter: brightness(1.2) drop-shadow(0 0 18px var(--doorGlow)); } }
.door3d.dim { opacity: 0.3; filter: brightness(0.6); }
.door3d.chosen { filter: brightness(1.18) drop-shadow(0 0 30px var(--green)); transition: filter 0.45s ease; }
.door3d.chosen .d-frame { box-shadow: 0 0 46px 8px color-mix(in srgb, var(--green) 55%, transparent), inset 0 0 34px color-mix(in srgb, var(--green) 30%, transparent); transition: box-shadow 0.45s ease; }
/* Weicher Lichtschein der richtigen Tür beim Gewinn (kein harter Rahmen) */
.door3d.won-burst { animation: doorWinBurst 1s ease both; }
.door3d.won-burst .d-frame { box-shadow: 0 0 90px 22px color-mix(in srgb, var(--green) 50%, transparent), inset 0 0 56px color-mix(in srgb, var(--green) 42%, transparent); transition: box-shadow 0.45s ease; }
@keyframes doorWinBurst { 0% { filter: brightness(1); } 30% { filter: brightness(1.9) drop-shadow(0 0 52px color-mix(in srgb, #fff 80%, transparent)); } 100% { filter: brightness(1.22); } }

.door3d.opening.t-slide .d-leaf-l, .door3d.opening.t-vault .d-leaf-l { transform: translateX(-112%); }
.door3d.opening.t-slide .d-leaf-r, .door3d.opening.t-vault .d-leaf-r { transform: translateX(112%); }
.door3d.opening.t-hex .d-leaf-l { transform: translateX(-112%); }
.door3d.opening.t-hex .d-leaf-r { transform: translateX(112%); }
.door3d.opening.t-iris .di-1 { transform: translateY(-115%); }
.door3d.opening.t-iris .di-2 { transform: translateY(115%); }
.door3d.opening.t-bars .d-bar { transform: translateY(-128%); }
.door3d.opening.t-vault .d-wheel { transform: translate(-50%, -50%) rotate(230deg); opacity: 0.4; }
.door3d.opening .d-portal { filter: brightness(2.4); }

.door3d.wrong .d-frame { box-shadow: 0 0 44px 8px var(--red), inset 0 0 0 3px var(--red); }
.door3d.wrong .d-portal { background: radial-gradient(circle, color-mix(in srgb, var(--red) 80%, #200), #200 70%); }
.door3d.wrong { animation: doorWrong 0.4s ease; }
@keyframes doorWrong { 40% { transform: translateX(calc(var(--doorX) * -1)) translateZ(var(--doorZ)) scale(1.06); } }
.door-b.wrong { animation: doorWrongB 0.4s ease; }
@keyframes doorWrongB { 40% { transform: translateX(var(--doorX)) translateZ(var(--doorZ)) scale(1.06); } }

/* ===================== Maskottchen (glänzend, Rücken) ================= */

.hero {
  position: absolute; left: 50%; top: 50%;
  width: 150px; height: 250px;
  margin-left: -75px; margin-top: -125px;
  transform-style: preserve-3d;
  transform: translateX(var(--heroX)) translateY(var(--heroY)) translateZ(var(--heroZ)) scale(var(--heroScale));
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.5, 1), opacity 0.25s ease;
}
.hero-shadow {
  position: absolute; left: 50%; bottom: 30px;
  width: 76px; height: 16px; margin-left: -38px;
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--accent) 45%, rgba(0, 0, 0, 0.5)), transparent 70%);
  filter: blur(2px);
  animation: orbShadow 2.6s ease-in-out infinite;
}
@keyframes orbShadow { 0%, 100% { transform: scale(1); opacity: 0.6; } 50% { transform: scale(0.78); opacity: 0.4; } }
/* ===== Heist-Wisp: schwebender Energie-Orb (ersetzt die laufende Figur) ===== */
.orb {
  position: absolute; left: 50%; top: 46%; width: 64px; height: 64px; margin: -32px 0 0 -32px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 42%, #fff 0%, color-mix(in srgb, var(--accent) 92%, #fff) 26%, var(--accent) 55%, color-mix(in srgb, var(--accent) 40%, transparent) 80%, transparent 100%);
  box-shadow: 0 0 26px 6px color-mix(in srgb, var(--accent) 70%, transparent), 0 0 60px 16px color-mix(in srgb, var(--accent) 35%, transparent);
  animation: orbFloat 2.6s ease-in-out infinite;
}
.orb-core {
  position: absolute; left: 50%; top: 44%; width: 22px; height: 22px; margin: -11px 0 0 -11px; border-radius: 50%;
  background: radial-gradient(circle, #fff 0%, #fff 55%, transparent 75%);
  animation: orbCore 1.4s ease-in-out infinite;
}
.orb-spark { position: absolute; left: 50%; top: 50%; width: 5px; height: 5px; margin: -2.5px; border-radius: 50%; background: #fff; box-shadow: 0 0 6px var(--accent); opacity: 0; }
.orb-spark.s1 { animation: spark1 2.2s ease-in-out infinite; }
.orb-spark.s2 { animation: spark2 2.8s ease-in-out infinite; }
.orb-spark.s3 { animation: spark3 2.5s ease-in-out infinite; }
.orb-trail {
  position: absolute; left: 50%; top: 48%; width: 30px; height: 90px; margin-left: -15px;
  border-radius: 50%; transform-origin: 50% 0%;
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 55%, transparent), transparent 72%);
  filter: blur(7px); opacity: 0.45; transition: opacity 0.3s ease, height 0.3s ease;
}
@keyframes orbFloat { 0%, 100% { transform: translateY(0) scale(1); } 50% { transform: translateY(-7px) scale(1.04); } }
@keyframes orbCore { 0%, 100% { transform: scale(1); opacity: 0.9; } 50% { transform: scale(1.25); opacity: 1; } }
@keyframes spark1 { 0%, 100% { transform: translate(0, 0); opacity: 0; } 50% { transform: translate(17px, -13px); opacity: 0.9; } }
@keyframes spark2 { 0%, 100% { transform: translate(0, 0); opacity: 0; } 50% { transform: translate(-15px, -8px); opacity: 0.8; } }
@keyframes spark3 { 0%, 100% { transform: translate(0, 0); opacity: 0; } 45% { transform: translate(11px, 14px); opacity: 0.7; } }
/* Bewegung (Gehen/Laufen): schnellerer Puls, leichter Stretch, hellerer/längerer Schweif */
.hero.walk .orb, .hero.run .orb { animation: orbRun 0.5s ease-in-out infinite; }
.hero.walk .orb-trail, .hero.run .orb-trail { opacity: 0.9; height: 130px; }
@keyframes orbRun { 0%, 100% { transform: translateY(0) scale(1.05, 0.95); } 50% { transform: translateY(-5px) scale(0.95, 1.12); } }

/* Erwischt: rot werden, flackern, kollabieren */
.hero.caught .orb {
  background: radial-gradient(circle at 50% 42%, #fff 0%, #ff7a8c 30%, var(--red) 60%, transparent 100%);
  box-shadow: 0 0 30px 8px color-mix(in srgb, var(--red) 75%, transparent);
  animation: orbCaught 0.5s ease forwards;
}
.hero.caught .orb-core { animation: heroShiver 0.1s linear 6; }
.hero.caught .orb-trail { opacity: 0; }
@keyframes orbCaught { 0% { transform: scale(1); } 18% { transform: scale(1.18); } 100% { transform: scale(0.28); opacity: 0.2; } }
@keyframes heroShiver { 0%, 100% { transform: translateX(0); } 25% { transform: translateX(-3px); } 75% { transform: translateX(3px); } }

/* Gewinn/Cashout: goldener Flare-Burst */
.hero.cheer .orb {
  background: radial-gradient(circle at 50% 42%, #fff 0%, #ffe9a8 28%, #ffc83d 58%, transparent 100%);
  box-shadow: 0 0 42px 12px rgba(255, 200, 61, 0.7), 0 0 95px 30px rgba(255, 200, 61, 0.35);
  animation: orbFlare 0.65s ease;
}
@keyframes orbFlare { 0% { transform: scale(1); } 35% { transform: scale(1.55); } 100% { transform: scale(1.12); } }

/* =============================== Overlays ============================= */
.scr { position: absolute; inset: 0; pointer-events: none; }
.scanlines { z-index: 7; background-image: repeating-linear-gradient(0deg, color-mix(in srgb, var(--accent) 6%, transparent) 0 1px, transparent 1px 4px); opacity: 0.3; }
.vignette { z-index: 8; background: radial-gradient(120% 100% at 50% 42%, transparent 38%, rgba(2, 3, 8, 0.82) 100%); }

/* Großer goldener Gewinn-Multiplikator mitten auf dem Bildschirm */
.win-mult { z-index: 14; display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity 0.4s ease; }
.win-mult::before { content: ""; position: absolute; left: 5%; top: 18%; width: 90%; height: 64%; background: radial-gradient(circle at 50% 50%, rgba(255, 210, 80, 0.34), transparent 68%); opacity: 0; }
.win-mult span {
  font-size: calc(clamp(3rem, 16vw, 9rem) * var(--win-scale, 1)); font-weight: 900; line-height: 1;
  font-variant-numeric: tabular-nums; letter-spacing: -0.02em; color: #ffe7a0;
  text-shadow: 0 0 46px #ffd24a, 0 0 20px #fff7df, 0 6px 20px rgba(0, 0, 0, 0.6);
  transform: scale(0.2);
}
.win-mult.show { opacity: 1; }
.win-mult.show::before { animation: winGlow 1s ease both; }
.win-mult.show span { animation: winMultPop 0.6s cubic-bezier(0.22, 0.61, 0.36, 1) both, winMultFloat 3s ease-in-out 0.6s 1; }
@keyframes winGlow { 0% { opacity: 0; transform: scale(0.8); } 45% { opacity: 1; transform: scale(1.03); } 100% { opacity: 0.85; transform: scale(1); } }
@keyframes winMultPop { 0% { transform: scale(0.78); opacity: 0; } 70% { opacity: 1; } 100% { transform: scale(1.06); opacity: 1; } }
@keyframes winMultFloat { 0%, 100% { transform: scale(1.06) translateY(0); } 50% { transform: scale(1.08) translateY(-6px); } }
.win-mult::after { content: ""; position: absolute; left: 50%; top: 46%; width: 40px; height: 40px; transform: translate(-50%, -50%); border-radius: 50%; border: 2px solid rgba(255, 222, 130, 0.4); opacity: 0; }
.win-mult.show::after { animation: winShock 1.1s ease-out both; }
@keyframes winShock { 0% { opacity: 0.45; width: 40px; height: 40px; } 100% { opacity: 0; width: 520px; height: 520px; } }

/* Start-Prämie (im Einsatz-Panel, damit der erste Multiplikator gross sichtbar ist) */
.bet-prize { text-align: center; font-size: 1.15rem; font-weight: 900; color: #ffe9a8; font-variant-numeric: tabular-nums; text-shadow: 0 0 14px color-mix(in srgb, var(--gold) 60%, transparent); }
.bet-prize::before { content: "First door · "; color: var(--text-dim); font-weight: 600; font-size: 0.8rem; text-shadow: none; }

/* Live-Gewinne anderer Spieler (rechts) */
.live-wins { position: absolute; top: 92px; right: 10px; width: 190px; z-index: 9; pointer-events: none; }
.lw-title { display: flex; align-items: center; gap: 6px; font-size: 0.64rem; font-weight: 800; letter-spacing: 0.09em; text-transform: uppercase; color: var(--text-dim); margin-bottom: 7px; }
.lw-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--green); box-shadow: 0 0 8px var(--green); animation: lwPulse 1.4s ease-in-out infinite; }
@keyframes lwPulse { 0%, 100% { opacity: 0.45; } 50% { opacity: 1; } }
.lw-list { display: flex; flex-direction: column; gap: 6px; }
.lw-row { display: flex; align-items: center; gap: 8px; background: rgba(12, 18, 38, 0.66); border: 1px solid rgba(120, 140, 200, 0.18); border-radius: 10px; padding: 6px 9px; animation: lwIn 0.4s ease; }
.lw-av { font-size: 1.05rem; flex: none; }
.lw-mid { display: flex; flex-direction: column; min-width: 0; flex: 1; }
.lw-name { font-size: 0.72rem; font-weight: 700; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lw-mult { font-size: 0.6rem; color: var(--text-dim); }
.lw-amt { font-size: 0.73rem; font-weight: 800; color: var(--gold); white-space: nowrap; flex: none; }
.lw-row.me { border-color: color-mix(in srgb, var(--gold) 55%, transparent); background: rgba(40, 32, 8, 0.6); }
@keyframes lwIn { from { opacity: 0; transform: translateX(16px); } to { opacity: 1; transform: none; } }
@media (max-width: 860px) { .live-wins { display: none; } }

.alarm { z-index: 9; display: none; background: radial-gradient(circle at 16% 0%, rgba(255, 45, 75, 0.6), transparent 44%), radial-gradient(circle at 84% 0%, rgba(255, 45, 75, 0.6), transparent 44%); opacity: 0; }
.stage.alarm-on .alarm { display: block; animation: alarmStrobe 0.26s steps(1) 4; }
@keyframes alarmStrobe { 0%, 100% { opacity: 0; } 50% { opacity: 1; } }
.stage.shake { animation: shake 0.5s ease; }
@keyframes shake { 0%, 100% { transform: translate(0, 0); } 20% { transform: translate(-8px, 4px); } 40% { transform: translate(8px, -3px); } 60% { transform: translate(-5px, 2px); } 80% { transform: translate(5px, -1px); } }
.stage.lost-grade { filter: grayscale(0.45) brightness(0.62); transition: filter 0.3s ease; }

.spot-cone { z-index: 8; display: none; background: radial-gradient(ellipse 160px 280px at 50% 64%, rgba(255, 255, 255, 0.3), transparent 70%); opacity: 0; }
.stage.spot .spot-cone { display: block; opacity: 1; }

.god-rays {
  z-index: 7; display: none;
  background: conic-gradient(from 0deg at 50% 42%,
    transparent 0 6%, color-mix(in srgb, var(--gold) 32%, transparent) 6% 9%, transparent 9% 18%,
    color-mix(in srgb, var(--gold) 24%, transparent) 18% 21%, transparent 21% 31%,
    color-mix(in srgb, var(--gold) 32%, transparent) 31% 34%, transparent 34% 47%,
    color-mix(in srgb, var(--gold) 24%, transparent) 47% 50%, transparent 50% 64%,
    color-mix(in srgb, var(--gold) 32%, transparent) 64% 67%, transparent 67% 82%,
    color-mix(in srgb, var(--gold) 24%, transparent) 82% 85%, transparent 85% 100%);
  opacity: 0;
}
.stage.jackpot .god-rays { display: block; animation: godRays 2.4s ease; }
@keyframes godRays { 0% { opacity: 0; transform: scale(0.6) rotate(0); } 30% { opacity: calc(var(--win-glow, 1) * 0.85); } 100% { opacity: calc(var(--win-glow, 1) * 0.2); transform: scale(1.7) rotate(40deg); } }

.vault-burst { z-index: 9; display: none; background: radial-gradient(circle at 50% 44%, rgba(255, 245, 214, 0.95), rgba(255, 200, 61, 0) 55%); opacity: 0; }
.stage.jackpot .vault-burst { display: block; animation: vaultBurst 1.3s ease; }
@keyframes vaultBurst { 0% { opacity: 0; transform: scale(0.3); } 28% { opacity: var(--win-glow, 1); transform: scale(1.2); } 100% { opacity: 0; transform: scale(1.7); } }

.flash { z-index: 10; display: none; background: radial-gradient(circle at var(--flash-x, 50%) var(--flash-y, 44%), color-mix(in srgb, var(--accent) 35%, #fff) 0%, color-mix(in srgb, var(--accent) 75%, #fff) 45%, color-mix(in srgb, var(--accent) 30%, transparent) 80%, transparent 100%); opacity: 0; }
.stage.flash-on .flash { display: block; animation: flashWipe 0.55s ease-out; }
@keyframes flashWipe { 0% { opacity: 0; } 30% { opacity: 0.92; } 100% { opacity: 0; } }

.coin-layer { position: absolute; inset: 0; z-index: 10; pointer-events: none; overflow: hidden; }
.coin { position: absolute; top: -6%; font-size: calc(1.5rem * var(--coin-scale, 1)); animation: coinFall var(--cd, 1.1s) cubic-bezier(0.3, 0.1, 0.6, 1) forwards; }
@keyframes coinFall { 0% { transform: translateY(0) rotate(0); opacity: 1; } 85% { opacity: 1; } 100% { transform: translateY(112vh) translateX(var(--cx, 0)) rotate(var(--cr, 360deg)); opacity: 0; } }

.escape-portal { position: absolute; right: 4%; bottom: 26%; width: 120px; height: 120px; z-index: 5; opacity: 0; transform: translateX(40px); transition: opacity 0.3s ease, transform 0.3s ease; }
.escape-portal.show { opacity: 1; transform: translateX(0); }
.portal-glow { position: absolute; inset: 0; border-radius: 50%; background: radial-gradient(circle, color-mix(in srgb, var(--gold) 70%, transparent), transparent 70%); animation: portalPulse 1.4s ease-in-out infinite; }
@keyframes portalPulse { 0%, 100% { transform: scale(0.92); opacity: 0.7; } 50% { transform: scale(1.05); opacity: 1; } }
.portal-icon { position: absolute; inset: 0; display: grid; place-items: center; font-size: 3rem; }

/* ================================ HUD ================================= */
.hud-top { position: absolute; top: 0; left: 0; right: 0; z-index: 20; display: flex; align-items: center; gap: 10px; padding: 10px 12px; padding-top: max(10px, env(safe-area-inset-top)); }
.icon-btn { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 11px; border: 1px solid color-mix(in srgb, var(--accent) 35%, #2a3354); background: rgba(6, 10, 22, 0.78); color: var(--text); font-size: 1rem; cursor: pointer; transition: var(--tap); }
.icon-btn:active { transform: scale(0.93); }
.menu-toggle { position: relative; }
.burger, .burger::before, .burger::after { content: ""; position: absolute; width: 18px; height: 2px; border-radius: 2px; background: var(--accent); box-shadow: 0 0 8px var(--accent); transition: 0.25s; }
.burger::before { transform: translateY(-6px); } .burger::after { transform: translateY(6px); }
.brand { display: flex; align-items: center; gap: 7px; flex: 1; min-width: 0; }
.brand-mark { font-size: 1.15rem; filter: drop-shadow(0 0 6px rgba(255, 200, 61, 0.5)); }
.brand-name { font-size: 1rem; font-weight: 900; letter-spacing: 0.05em; }
.brand-name span { color: var(--gold); }
.balance-chip { display: flex; flex-direction: column; align-items: flex-end; padding: 5px 12px; border-radius: 11px; border: 1px solid color-mix(in srgb, var(--gold) 35%, #2a3354); background: rgba(6, 10, 22, 0.78); }
.balance-label { font-size: 0.54rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--text-faint); }
.balance-value { font-size: 1rem; font-weight: 800; font-variant-numeric: tabular-nums; color: var(--gold); }
.balance-value.bump { animation: bump 0.5s ease; }
@keyframes bump { 0% { transform: scale(1); } 35% { transform: scale(1.22); color: var(--green); } 100% { transform: scale(1); } }

.hud-stats { position: absolute; top: calc(58px + env(safe-area-inset-top)); left: 0; right: 0; z-index: 19; display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 0 12px; pointer-events: none; }
.stat-chips { display: flex; gap: 6px; }
.chip-stat { display: flex; flex-direction: column; align-items: center; min-width: 62px; padding: 4px 8px; border-radius: 10px; background: rgba(6, 10, 22, 0.66); border: 1px solid #283154; }
.cs-label { font-size: 0.5rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-faint); }
.cs-value { font-size: 0.86rem; font-weight: 800; font-variant-numeric: tabular-nums; }
.cs-mult { border-color: color-mix(in srgb, var(--gold) 55%, transparent); } .cs-mult .cs-value { color: var(--gold); }
.cs-value.pop { animation: pop 0.5s ease; }
@keyframes pop { 0% { transform: scale(1); } 40% { transform: scale(1.4); } 100% { transform: scale(1); } }
.zone-pips { display: flex; gap: 4px; }
.pip { width: 16px; height: 5px; border-radius: 3px; background: #1a2344; border: 1px solid #283154; transition: 0.3s; }
.pip.done { background: linear-gradient(90deg, var(--green), #14b878); border-color: var(--green); box-shadow: 0 0 7px rgba(45, 255, 158, 0.4); }
.pip.current { background: var(--gold); border-color: var(--gold); box-shadow: 0 0 9px rgba(255, 200, 61, 0.6); animation: pipPulse 1.2s ease-in-out infinite; }
.pip.failed { background: var(--red); border-color: var(--red); }
@keyframes pipPulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.45; } }

.hud-bottom { position: absolute; left: 0; right: 0; bottom: 0; z-index: 20; padding: 12px 14px; padding-bottom: max(14px, env(safe-area-inset-bottom)); display: flex; flex-direction: column; gap: 10px; background: linear-gradient(180deg, transparent, rgba(3, 5, 11, 0.9) 42%); }
.result-banner { border-radius: 12px; padding: 9px 12px; text-align: center; font-weight: 800; font-size: 0.9rem; animation: slideUp 0.3s ease; }
@keyframes slideUp { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }
.result-banner.win { background: rgba(45, 255, 158, 0.14); border: 1px solid var(--green); color: var(--green); }
.result-banner.lose { background: linear-gradient(90deg, #3a0010, #1a0008); border: 1px solid var(--red); color: var(--red); }
.result-banner.cashout { background: linear-gradient(90deg, #1a1405, #2e2208); border: 1px solid var(--gold); color: var(--gold); }
.result-banner.jackpot { background: linear-gradient(90deg, #2e2208, #4a3608); border: 1px solid #fff6d6; color: var(--gold); font-size: 1rem; }

.bet-panel { display: flex; flex-direction: column; gap: 9px; }
.bet-row { display: flex; gap: 8px; }
.bet-step { width: 52px; min-height: 52px; font-size: 1.5rem; font-weight: 800; color: var(--text); background: rgba(20, 26, 50, 0.92); border: 1px solid #283154; border-radius: 12px; cursor: pointer; transition: var(--tap); }
.bet-step:active { transform: scale(0.92); }
.bet-field { flex: 1; min-width: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; background: rgba(20, 26, 50, 0.92); border: 1px solid #283154; border-radius: 12px; }
.bet-cap { font-size: 0.56rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-faint); margin-top: 5px; }
#betInput { width: 100%; text-align: center; font-size: 1.4rem; font-weight: 800; color: var(--text); background: none; border: none; padding: 0 0 5px; appearance: textfield; -moz-appearance: textfield; }
#betInput::-webkit-outer-spin-button, #betInput::-webkit-inner-spin-button { -webkit-appearance: none; }
#betInput:focus { outline: none; }
.bet-chips { display: flex; gap: 7px; }
.chip { flex: 1; min-height: 34px; font-size: 0.8rem; font-weight: 800; color: var(--text-dim); background: rgba(20, 26, 50, 0.92); border: 1px solid #283154; border-radius: 999px; cursor: pointer; transition: var(--tap); }
.chip:active { transform: scale(0.95); } .chip:hover { color: var(--accent); border-color: var(--accent); }
.btn { width: 100%; min-height: 54px; border: none; border-radius: 13px; font-size: 1.04rem; font-weight: 900; letter-spacing: 0.02em; cursor: pointer; transition: transform var(--tap), filter 0.15s, opacity 0.15s; }
.btn:active:not(:disabled) { transform: scale(0.97); }
.btn:disabled { opacity: 0.45; cursor: not-allowed; }
.btn-start { background: linear-gradient(135deg, var(--gold), #ff9f1c); color: #251a00; box-shadow: 0 6px 22px rgba(255, 200, 61, 0.35); }
.btn-start:hover:not(:disabled) { filter: brightness(1.08); }
.play-panel { display: flex; flex-direction: column; gap: 8px; align-items: center; }
.pick-hint { font-size: 0.82rem; font-weight: 700; color: var(--accent); text-shadow: 0 0 10px color-mix(in srgb, var(--accent) 50%, transparent); animation: hintPulse 1.6s ease-in-out infinite; }
.pick-hint.live { font-size: 0.92rem; color: #fff; text-shadow: 0 0 14px var(--accent), 0 0 6px var(--accent); animation: hintPulse 1s ease-in-out infinite; }
@keyframes hintPulse { 0%, 100% { opacity: 0.6; } 50% { opacity: 1; } }
.btn-cashout { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1px; background: linear-gradient(135deg, var(--green), #14b878); color: #03240f; box-shadow: 0 5px 20px rgba(45, 255, 158, 0.4); }
.btn-cashout:hover:not(:disabled) { filter: brightness(1.08); }
.btn-cashout.confirm { animation: cashConfirm 0.16s ease; }
@keyframes cashConfirm { 50% { transform: scale(1.06); } }
.cash-top { font-size: 0.74rem; font-weight: 800; }
.cash-value { font-size: 1rem; font-weight: 900; font-variant-numeric: tabular-nums; }
.form-error { color: var(--red); font-size: 0.8rem; text-align: center; }

/* =============================== Drawer =============================== */
.drawer-backdrop { position: fixed; inset: 0; z-index: 40; background: rgba(2, 4, 10, 0.6); }
.drawer { position: fixed; top: 0; left: 0; z-index: 50; width: min(86vw, 360px); height: 100%; padding: 16px 16px 26px; padding-top: max(16px, env(safe-area-inset-top)); overflow-y: auto; background: linear-gradient(180deg, #0e1428, #060a14); border-right: 1px solid #2f3e74; box-shadow: 18px 0 50px rgba(0, 0, 0, 0.6); transform: translateX(-104%); transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1); }
.drawer.open { transform: translateX(0); }
.drawer-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.drawer-title { font-size: 1.05rem; font-weight: 800; }
.drawer-profile { display: flex; gap: 14px; align-items: center; padding: 14px; border-radius: 10px; border: 1px solid #243056; background: #131a33; margin-bottom: 12px; }
.avatar-btn { position: relative; width: 62px; height: 62px; flex: none; border-radius: 50%; border: 2px solid var(--accent); background: radial-gradient(circle at 50% 35%, #1a2344, #05070f); cursor: pointer; display: grid; place-items: center; box-shadow: 0 0 16px color-mix(in srgb, var(--accent) 40%, transparent); }
.avatar-btn:active { transform: scale(0.94); }
.avatar-glyph { font-size: 2rem; }
.avatar-edit { position: absolute; right: -2px; bottom: -2px; width: 22px; height: 22px; border-radius: 50%; background: #ff3da6; color: #fff; font-size: 0.7rem; display: grid; place-items: center; border: 2px solid #0e1428; }
.profile-fields { flex: 1; min-width: 0; }
.field-label { display: block; font-size: 0.6rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-faint); margin-bottom: 5px; }
.name-row { display: flex; gap: 6px; }
#nameInput { flex: 1; min-width: 0; height: 38px; padding: 0 10px; border-radius: 9px; border: 1px solid #243056; background: #05070f; color: var(--text); font-size: 0.9rem; }
#nameInput:focus { outline: 2px solid var(--accent); border-color: transparent; }
.profile-hint { font-size: 0.68rem; margin-top: 6px; min-height: 0.9rem; color: var(--green); }
.profile-hint.err { color: var(--red); }
.btn-mini { height: 38px; padding: 0 12px; border-radius: 9px; border: 1px solid var(--accent); background: color-mix(in srgb, var(--accent) 14%, transparent); color: var(--accent); font-weight: 800; font-size: 0.82rem; cursor: pointer; white-space: nowrap; }
.btn-mini:active { transform: scale(0.95); }
.avatar-picker { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; padding: 12px; margin-bottom: 12px; border-radius: 10px; border: 1px solid #243056; background: #131a33; }
.avatar-opt { aspect-ratio: 1; border-radius: 12px; border: 1px solid #243056; background: #05070f; font-size: 1.5rem; cursor: pointer; display: grid; place-items: center; transition: var(--tap); }
.avatar-opt:hover { border-color: var(--accent); }
.avatar-opt.active { border-color: var(--gold); box-shadow: 0 0 12px rgba(255, 200, 61, 0.4); background: rgba(255, 200, 61, 0.1); }
.drawer-section { display: flex; flex-direction: column; gap: 8px; padding: 12px 0; border-top: 1px solid #243056; }
.toggle-row { display: flex; align-items: center; justify-content: space-between; padding: 4px 2px; }
.toggle-text { font-size: 0.92rem; font-weight: 600; }
.switch { position: relative; width: 52px; height: 30px; border-radius: 999px; border: 1px solid #243056; background: #05070f; cursor: pointer; transition: 0.2s; }
.switch-knob { position: absolute; top: 3px; left: 3px; width: 22px; height: 22px; border-radius: 50%; background: var(--text-faint); transition: 0.22s cubic-bezier(0.4, 0, 0.2, 1); }
.switch[aria-checked="true"] { background: linear-gradient(90deg, #14b878, var(--green)); border-color: var(--green); box-shadow: 0 0 12px rgba(45, 255, 158, 0.4); }
.switch[aria-checked="true"] .switch-knob { left: 27px; background: #04240f; }
.drawer-link { text-align: left; padding: 13px 14px; border-radius: 10px; border: 1px solid #243056; background: #131a33; color: var(--text); font-size: 0.92rem; font-weight: 600; cursor: pointer; transition: var(--tap); }
.drawer-link:hover { border-color: var(--accent); background: #1a2344; }
.drawer-link:active { transform: scale(0.98); }
.drawer-foot { margin-top: 16px; text-align: center; font-size: 0.66rem; line-height: 1.6; color: var(--text-faint); }

/* =============================== Modal =============================== */
.modal-backdrop { position: fixed; inset: 0; z-index: 60; display: grid; place-items: end center; background: rgba(2, 4, 10, 0.66); }
@media (min-width: 560px) { .modal-backdrop { place-items: center; } }
.modal { width: min(100%, 520px); max-height: 84vh; display: flex; flex-direction: column; background: linear-gradient(180deg, #0e1428, #060a14); border: 1px solid #2f3e74; border-radius: 18px 18px 0 0; box-shadow: 0 -10px 50px rgba(0, 0, 0, 0.6); animation: sheetUp 0.28s cubic-bezier(0.4, 0, 0.2, 1); }
@media (min-width: 560px) { .modal { border-radius: 18px; } }
@keyframes sheetUp { from { transform: translateY(40px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.modal-head { display: flex; align-items: center; justify-content: space-between; padding: 14px 16px; border-bottom: 1px solid #243056; }
.modal-title { font-size: 1.02rem; font-weight: 800; }
.modal-body { padding: 16px; overflow-y: auto; }
.modal-body h4 { font-size: 0.9rem; margin: 14px 0 6px; color: var(--accent); }
.modal-body h4:first-child { margin-top: 0; }
.modal-body p, .modal-body li { font-size: 0.85rem; line-height: 1.55; color: var(--text-dim); }
.modal-body ul, .modal-body ol { padding-left: 20px; display: flex; flex-direction: column; gap: 4px; }
.modal-body b { color: var(--text); }
.info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin: 4px 0; }
.info-cell { background: #131a33; border: 1px solid #243056; border-radius: 10px; padding: 10px; }
.info-cell .k { display: block; font-size: 0.62rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-faint); }
.info-cell .v { font-size: 1.05rem; font-weight: 800; color: var(--text); }
.row-item { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 10px; background: #131a33; border: 1px solid #243056; border-radius: 10px; padding: 9px 11px; margin-bottom: 7px; }
.ri-badge { font-size: 0.58rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.04em; border-radius: 999px; padding: 3px 8px; white-space: nowrap; }
.ri-badge.cashed_out, .ri-badge.auto_cashed_out { background: rgba(45, 255, 158, 0.14); color: var(--green); border: 1px solid var(--green); }
.ri-badge.lost { background: rgba(255, 59, 92, 0.14); color: var(--red); border: 1px solid var(--red); }
.ri-info { font-size: 0.76rem; color: var(--text-dim); line-height: 1.4; min-width: 0; }
.ri-info b { color: var(--text); }
.ri-net { font-weight: 900; font-variant-numeric: tabular-nums; text-align: right; white-space: nowrap; font-size: 0.84rem; }
.ri-net.pos { color: var(--green); } .ri-net.neg { color: var(--red); }
.lb-row { display: grid; grid-template-columns: 30px 30px 1fr auto; align-items: center; gap: 9px; background: #131a33; border: 1px solid #243056; border-radius: 10px; padding: 7px 11px; margin-bottom: 6px; }
.lb-row.me { border-color: var(--accent); box-shadow: 0 0 12px color-mix(in srgb, var(--accent) 20%, transparent); }
.lb-rank { font-weight: 900; font-size: 0.82rem; color: var(--text-faint); text-align: center; }
.lb-av { font-size: 1.25rem; text-align: center; }
.lb-name { font-size: 0.84rem; font-weight: 700; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lb-sub { font-size: 0.62rem; color: var(--text-faint); }
.lb-mult { font-size: 0.84rem; font-weight: 800; color: var(--gold); font-variant-numeric: tabular-nums; text-align: right; }
.lb-amount { font-size: 0.62rem; color: var(--green); font-variant-numeric: tabular-nums; text-align: right; }

/* ===================== Back-Wall-Decor (Signaturen) =================== */
.back-decor > * { position: absolute; }
.d-sign { left: 50%; top: 30%; transform: translateX(-50%); font-size: 1.1rem; font-weight: 900; letter-spacing: 0.4em; color: var(--accent); text-shadow: 0 0 16px var(--accent); opacity: 0.85; }
.bd-strip { left: 10%; right: 10%; height: 3px; background: linear-gradient(90deg, transparent, var(--accent), transparent); box-shadow: 0 0 8px var(--accent); opacity: 0.7; }
.bd-rack { width: 12%; top: 24%; bottom: 18%; background: repeating-linear-gradient(0deg, color-mix(in srgb, var(--accent) 60%, transparent) 0 2px, transparent 2px 8px), #050810; border: 1px solid var(--wallAccent); opacity: 0.8; }
.bd-mon { width: 9%; height: 12%; background: color-mix(in srgb, var(--accent) 22%, #050810); border: 1px solid var(--accent); box-shadow: 0 0 8px color-mix(in srgb, var(--accent) 40%, transparent); }
.bd-ring { left: 50%; top: 50%; width: 46%; aspect-ratio: 1; transform: translate(-50%, -50%); border-radius: 50%; border: 5px solid color-mix(in srgb, var(--accent) 60%, #000); box-shadow: 0 0 30px color-mix(in srgb, var(--accent) 50%, transparent), inset 0 0 24px rgba(0, 0, 0, 0.6); opacity: 0.65; }
.bd-bars { bottom: 16%; width: 11%; height: 20%; background: repeating-linear-gradient(0deg, var(--accent) 0 4px, color-mix(in srgb, var(--accent) 45%, #000) 4px 10px); opacity: 0.7; }

/* ===================== Phase 1: Game-Feel + Hooks ===================== */

/* Guthaben +/- Floater (grün hoch / rot runter) */
.balance-chip { position: relative; overflow: visible; }
.bal-delta { position: absolute; right: 10px; top: 4px; font-size: 0.8rem; font-weight: 900; font-variant-numeric: tabular-nums; pointer-events: none; text-shadow: 0 1px 3px rgba(0, 0, 0, 0.6); animation: balFloat 1.05s ease-out forwards; z-index: 30; }
.bal-delta.pos { color: var(--green); }
.bal-delta.neg { color: var(--red); }
@keyframes balFloat { 0% { opacity: 0; transform: translateY(6px) scale(0.9); } 25% { opacity: 1; transform: translateY(0) scale(1.08); } 100% { opacity: 0; transform: translateY(-24px) scale(1); } }

/* Farb-/Prefix-Eskalation an Schwellen (die GRÖSSE wächst kontinuierlich pro Stufe via --win-scale) */
.win-mult[data-tier="big"] span { color: #fff3c4; text-shadow: 0 0 56px #ffd24a, 0 0 26px #fff, 0 6px 20px rgba(0, 0, 0, 0.6); }
.win-mult[data-tier="mega"] span, .win-mult[data-tier="ultra"] span { color: #fff; text-shadow: 0 0 80px #ff9a3d, 0 0 38px #fff, 0 0 18px #ffd24a, 0 6px 22px rgba(0, 0, 0, 0.6); }
.win-mult[data-tier="mega"] span::before, .win-mult[data-tier="ultra"] span::before { content: "MEGA "; font-size: 0.3em; color: #ff9a3d; vertical-align: 0.5em; letter-spacing: 0.13em; text-shadow: 0 0 16px #ff9a3d; }

/* Win-Punch (kurzer Zoom) – getrennt vom harten Lose-Shake */
/* Eskalierender Gewinn-Schüttel-Punch — Stärke via --shake-mag (je höher der Multiplikator, desto krasser) */
.stage.win-shake { animation: winShake var(--shake-dur, 0.45s) cubic-bezier(0.36, 0.07, 0.19, 0.97) both; }
@keyframes winShake {
  0% { transform: scale(1) translate(0, 0); }
  10% { transform: scale(1.04) translate(calc(var(--shake-mag, 6px) * -1), calc(var(--shake-mag, 6px) * 0.5)); }
  25% { transform: scale(1.03) translate(var(--shake-mag, 6px), calc(var(--shake-mag, 6px) * -0.6)); }
  40% { transform: scale(1.02) translate(calc(var(--shake-mag, 6px) * -0.8), var(--shake-mag, 6px)); }
  55% { transform: translate(calc(var(--shake-mag, 6px) * 0.7), calc(var(--shake-mag, 6px) * -0.4)); }
  70% { transform: translate(calc(var(--shake-mag, 6px) * -0.5), calc(var(--shake-mag, 6px) * 0.3)); }
  85% { transform: translate(calc(var(--shake-mag, 6px) * 0.3), 0); }
  100% { transform: scale(1) translate(0, 0); }
}

/* Gold-Burst bei JEDEM Gewinn — Stärke (Opazität) wächst pro Stufe via --win-glow.
   God-Rays kommen ab mittlerer Stufe dazu und skalieren ebenfalls mit --win-glow. */
.stage.winfx .vault-burst { display: block; animation: vaultBurst 1.1s ease; }
.stage.winfx[data-win-tier="3"] .god-rays,
.stage.winfx[data-win-tier="4"] .god-rays,
.stage.winfx[data-win-tier="5"] .god-rays { display: block; animation: godRays 1.9s ease; }

/* Cashout-Button scharf -> pulsiert (Risk/Reward sichtbar) */
.btn-cashout.armed { animation: cashPulse 1.3s ease-in-out infinite; }
@keyframes cashPulse { 0%, 100% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--green) 50%, transparent); } 50% { box-shadow: 0 0 20px 3px color-mix(in srgb, var(--green) 45%, transparent); } }

/* Glut-Puls (wird von der Multi-Chip-Intensität genutzt) */
@keyframes badgePulse { 0%, 100% { box-shadow: 0 0 0 0 transparent; } 50% { box-shadow: 0 0 14px 2px color-mix(in srgb, var(--gold) 50%, transparent); } }

/* Multi-Chip Intensität nach Höhe */
.chip-stat.cs-mult[data-heat="2"] .cs-value { text-shadow: 0 0 10px color-mix(in srgb, var(--gold) 60%, transparent); }
.chip-stat.cs-mult[data-heat="3"] .cs-value { text-shadow: 0 0 16px color-mix(in srgb, var(--gold) 75%, transparent); }
.chip-stat.cs-mult[data-heat="4"] .cs-value { text-shadow: 0 0 22px var(--gold); animation: badgePulse 0.7s ease-in-out infinite; }

/* Near-Miss: die richtige Tür wird golden enthüllt */
.door3d.was-right { filter: brightness(1.3) drop-shadow(0 0 26px var(--gold)) !important; opacity: 1 !important; animation: wasRight 0.5s ease; }
.door3d.was-right .d-frame { box-shadow: 0 0 44px 8px var(--gold), inset 0 0 0 3px var(--gold) !important; }
.door3d.was-right .d-portal { background: radial-gradient(circle at 50% 56%, #fff 0%, var(--gold) 36%, #1a1206 82%) !important; }
@keyframes wasRight { 0% { transform: scale(0.96); } 60% { transform: scale(1.05); } 100% { transform: none; } }

/* Tür A kühl / B warm – Wahl sofort lesbar (Hue nur auf Rahmen/Aura/Naht, nicht Portal) */
.door-a.tint-a .d-frame, .door-a.tint-a .d-aura, .door-a.tint-a .d-seam { filter: hue-rotate(-26deg); }
.door-b.tint-b .d-frame, .door-b.tint-b .d-aura, .door-b.tint-b .d-seam { filter: hue-rotate(30deg) saturate(1.1); }

/* Atmender Energiekern im Ready-Zustand */
.door3d.ready .d-portal { animation: portalBreathe 3.2s ease-in-out infinite; }
.door-b.ready .d-portal { animation-delay: 1.6s; }
@keyframes portalBreathe { 0%, 100% { filter: brightness(1); } 50% { filter: brightness(1.45); } }

/* ===================== Phase 2: Meta (EP/Rang, Rekorde, Toast) ===================== */
.toast { position: absolute; left: 50%; top: 64px; transform: translateX(-50%); z-index: 20; display: flex; flex-direction: column; gap: 6px; align-items: center; pointer-events: none; width: max-content; max-width: 92%; }
.toast-item { font-size: 0.82rem; font-weight: 800; color: var(--text); background: rgba(12, 18, 38, 0.92); border: 1px solid var(--border); border-radius: 999px; padding: 7px 16px; box-shadow: 0 6px 20px rgba(0, 0, 0, 0.4); animation: toastIn 0.35s cubic-bezier(0.2, 1.4, 0.4, 1); }
.toast-item.out { animation: toastOut 0.45s ease forwards; }
.toast-item.rank { border-color: var(--accent); color: #fff; box-shadow: 0 0 18px color-mix(in srgb, var(--accent) 45%, transparent); }
.toast-item.record { border-color: var(--gold); color: #ffe9a8; box-shadow: 0 0 20px color-mix(in srgb, var(--gold) 50%, transparent); }
.toast-item.daily { border-color: var(--green); color: #d6ffe9; }
@keyframes toastIn { from { opacity: 0; transform: translateY(-10px) scale(0.9); } to { opacity: 1; transform: none; } }
@keyframes toastOut { to { opacity: 0; transform: translateY(-12px); } }

.rank-box { gap: 8px; }
.rank-head { display: flex; align-items: baseline; justify-content: space-between; }
.rank-name { font-size: 0.95rem; font-weight: 900; color: var(--gold); }
.rank-xp { font-size: 0.68rem; color: var(--text-dim); font-variant-numeric: tabular-nums; }
.rank-bar { height: 8px; border-radius: 999px; background: #1b2344; overflow: hidden; }
.rank-fill { display: block; height: 100%; width: 0; border-radius: 999px; background: linear-gradient(90deg, var(--accent), var(--gold)); transition: width 0.5s ease; }
.rec-row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.rec { background: #131a33; border: 1px solid var(--border); border-radius: 9px; padding: 7px 9px; display: flex; flex-direction: column; gap: 2px; }
.rec-k { font-size: 0.58rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-faint); }
.rec-v { font-size: 0.85rem; font-weight: 800; color: var(--text); font-variant-numeric: tabular-nums; }
.rank-note { font-size: 0.6rem; color: var(--text-faint); line-height: 1.4; }

/* ============================ Reduced Motion ========================== */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.08s !important; }
}
@media (max-height: 560px) { .hud-stats .stat-chips { display: none; } }

/* ===================== Demo / Compliance / Responsible Gaming ===================== */

/* DEMO-Badge im Header */
.demo-badge { align-self: center; margin-left: 8px; padding: 3px 9px; border-radius: 999px; font-size: 0.6rem; font-weight: 900; letter-spacing: 0.14em; color: #ffd24a; background: rgba(255, 200, 61, 0.12); border: 1px solid color-mix(in srgb, var(--gold) 55%, transparent); text-shadow: 0 0 10px rgba(255, 200, 61, 0.5); white-space: nowrap; }

/* Branded Splash + 18+ Age-Gate */
.splash { position: fixed; inset: 0; z-index: 9000; display: grid; place-items: center; padding: 20px; overflow-y: auto;
  background: radial-gradient(80% 70% at 50% 36%, #0b1430 0%, #05070f 72%), #05070f;
  transition: opacity 0.55s ease, transform 0.55s ease; }
.splash.gone { opacity: 0; transform: scale(1.04); pointer-events: none; }
.splash-inner { width: min(440px, 100%); text-align: center; padding: 16px 0; }
.splash-brand { font-size: 2.2rem; font-weight: 900; letter-spacing: 0.02em; display: inline-flex; align-items: center; gap: 10px; }
.splash-brand .brand-name { color: var(--text); }
.splash-brand .brand-name span { color: var(--gold); }
.splash-brand .brand-mark { filter: drop-shadow(0 0 14px rgba(255, 200, 61, 0.5)); }
.splash-tag { margin-top: 6px; color: var(--text-dim); font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; font-size: 0.72rem; }
.splash-load { margin: 26px auto 0; width: 200px; height: 5px; border-radius: 999px; background: rgba(255, 255, 255, 0.08); overflow: hidden; }
.splash-bar { display: block; height: 100%; width: 40%; border-radius: 999px; background: linear-gradient(90deg, var(--accent), var(--gold)); animation: splashBar 1.05s ease-in-out infinite; }
@keyframes splashBar { 0% { transform: translateX(-120%); } 100% { transform: translateX(360%); } }
.age-gate { margin-top: 18px; background: linear-gradient(180deg, #0e1428, #070b16); border: 1px solid #2f3e74; border-radius: 16px; padding: 22px 20px; box-shadow: 0 20px 60px rgba(0, 0, 0, 0.6); }
.ag-icon { font-size: 2.4rem; line-height: 1; }
.ag-title { margin: 8px 0 6px; font-size: 1.25rem; color: var(--text); }
.ag-text { font-size: 0.9rem; line-height: 1.5; color: var(--text-dim); }
.ag-text a { color: var(--accent); }
.ag-actions { display: flex; flex-direction: column; gap: 10px; margin: 16px 0 12px; }
.ag-help { font-size: 0.74rem; color: var(--text-faint); }
.ag-help a { color: var(--text-dim); }

/* Modals immer über dem Splash */
.modal-backdrop { z-index: 9500; }

/* Sekundär-Button */
.btn-ghost { background: rgba(255, 255, 255, 0.06); color: var(--text-dim); border: 1px solid #2c3866; }
.btn-ghost:hover:not(:disabled) { filter: brightness(1.2); }

/* RG-Link Akzent */
.drawer-link.rg { color: #ffd24a; }

/* Spec-Sheet & RG-Modal */
.spec-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin: 4px 0 10px; }
.spec-formula { margin: 2px 0 10px; }
.modal-body h4 { margin: 14px 0 6px; font-size: 0.95rem; color: var(--text); }
.modal-body code { background: rgba(255, 255, 255, 0.08); padding: 1px 5px; border-radius: 5px; font-size: 0.85em; }
.rg-break-row { display: flex; gap: 8px; margin: 4px 0 10px; }
.rg-limit-row { display: flex; gap: 10px; margin: 4px 0 10px; }
.rg-limit-row .field-label { flex: 1; }
.rg-limit-row input { width: 100%; height: 40px; border-radius: 9px; border: 1px solid #2c3866; background: #0c1224; color: var(--text); padding: 0 10px; font-size: 0.95rem; margin-top: 4px; }
.end-actions { display: flex; gap: 10px; margin-top: 14px; }
.end-actions .btn { flex: 1; }
