/* Selbst-gehostete Display-/Body-Fonts (woff2, latin inkl. Umlaute) — offline-fähig, kein CDN. */
@font-face{font-family:'Cinzel';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/cinzel-600.woff2') format('woff2')}
@font-face{font-family:'Cinzel';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/fonts/cinzel-700.woff2') format('woff2')}
@font-face{font-family:'EB Garamond';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/ebgaramond-400.woff2') format('woff2')}
@font-face{font-family:'EB Garamond';font-style:italic;font-weight:400;font-display:swap;src:url('/assets/fonts/ebgaramond-400i.woff2') format('woff2')}
:root{
  --bg:#0c0e10; --bg2:#101417; --panel:#161b1f; --panel2:#1c2227;
  --gold:#c9a24b; --gold-soft:#e3c879; --gold-dim:#8c7434;
  --teal:#1f4e4a; --elli:#3bb3a6; --ink:#e9e3d4; --muted:#aaa395; --line:#2a3036;
  --red:#c0392b; --green:#2e8b57;
  --serif:'EB Garamond',Georgia,serif; --display:'Cinzel',Georgia,serif;
  --safe-b:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{background:var(--bg);color:var(--ink);font-family:var(--serif);font-size:18px;line-height:1.5;
  overscroll-behavior:none;-webkit-font-smoothing:antialiased;overflow-x:hidden}
#app{min-height:100%}
.boot{display:flex;align-items:center;justify-content:center;min-height:100dvh;color:transparent;
  background:url('/assets/logo/emblem.png') center/58px no-repeat;animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.45}50%{opacity:1}}

/* ---------- Layout primitives ---------- */
.screen{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;
  padding:max(20px,env(safe-area-inset-top)) 18px calc(20px + var(--safe-b));position:relative}
.screen.center{align-items:center;justify-content:center;text-align:center}
.bg{position:fixed;inset:0;z-index:-2;background-size:cover;background-position:center;}
.bg::after{content:'';position:absolute;inset:0;background:
  radial-gradient(125% 95% at 50% 32%, transparent 52%, rgba(8,9,11,.6) 100%),
  linear-gradient(180deg,rgba(8,9,11,.5),rgba(8,9,11,.9))}
/* Film-Grain (1920er-Anmutung) — leichtes Rauschen über allem, ohne Interaktion zu stören */
body::after{content:'';position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.045;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
/* Art-Déco-Eckwinkel für Panels/Karten */
.deco{position:relative}
.deco::before,.deco::after{content:'';position:absolute;width:15px;height:15px;border:1px solid var(--gold-dim);pointer-events:none;opacity:.8}
.deco::before{top:7px;left:7px;border-right:0;border-bottom:0}
.deco::after{bottom:7px;right:7px;border-left:0;border-top:0}
.bg-crime{background-image:url('/assets/backgrounds/crime-scene-library.jpg')}
.bg-foyer{background-image:url('/assets/backgrounds/lobby-foyer.jpg')}
.bg-duel{background-image:url('/assets/backgrounds/finale-duel.jpg')}

h1,h2,h3{font-family:var(--display);font-weight:600;margin:0;color:var(--gold-soft);letter-spacing:.06em}
.title{font-size:clamp(2rem,8.5vw,3rem);letter-spacing:.08em;text-shadow:0 2px 16px rgba(0,0,0,.85);
  line-height:1.05;overflow-wrap:break-word;max-width:100%}
.kicker{letter-spacing:.42em;text-transform:uppercase;font-size:.7rem;color:var(--muted);font-family:var(--display)}
.emblem{width:96px;height:96px;object-fit:contain;filter:drop-shadow(0 6px 20px rgba(0,0,0,.7))}
.lead{color:#cfc8b6;font-style:italic;max-width:34ch;margin:14px auto 0}
.muted{color:var(--muted)}
.tiny{font-size:.78rem}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;cursor:pointer;
  font-family:var(--display);letter-spacing:.08em;font-size:1rem;border-radius:12px;padding:15px 22px;
  border:1px solid var(--line);background:var(--panel2);color:var(--ink);transition:.18s;user-select:none;
  width:100%;text-transform:uppercase}
.btn:active{transform:translateY(1px) scale(.99)}
.btn-primary{background:linear-gradient(180deg,var(--gold-soft),var(--gold));color:#1a1407;border-color:var(--gold-soft);
  box-shadow:0 6px 22px rgba(201,162,75,.28);font-weight:700}
.btn-ghost{background:transparent}
.btn[disabled]{opacity:.4;pointer-events:none;filter:grayscale(.4)}
.btn-row{display:flex;gap:10px}
.bar{position:sticky;bottom:0;padding-top:12px;background:linear-gradient(0deg,var(--bg),transparent);margin-top:auto}

/* ---------- Cards / panels ---------- */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px;margin:10px 0;
  box-shadow:0 10px 30px rgba(0,0,0,.35)}
.divider{height:1px;background:linear-gradient(90deg,transparent,var(--gold-dim),transparent);margin:18px 0;opacity:.6}
.swatch{width:14px;height:14px;border-radius:50%;display:inline-block;border:1px solid rgba(255,255,255,.25);flex:0 0 auto}

/* ---------- Lobby roster ---------- */
.roster{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:8px 0}
.ritem{display:flex;align-items:center;gap:8px;padding:9px 11px;border:1px solid var(--line);border-radius:10px;
  background:var(--panel);font-size:.9rem}
.ritem.open{opacity:.5;font-style:italic}
.dot{width:8px;height:8px;border-radius:50%;background:#555;margin-left:auto;flex:0 0 auto}
.dot.on{background:var(--green);box-shadow:0 0 8px var(--green)}

/* ---------- Join / character draft ---------- */
.choices{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:440px}
.cgrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;width:100%;max-width:460px;margin:0 auto}
.cpick{position:relative;border:1px solid var(--line);border-radius:12px;overflow:hidden;cursor:pointer;background:var(--panel);
  aspect-ratio:3/4;transition:.18s}
.cpick img{width:100%;height:100%;object-fit:cover;display:block}
.cpick .cap{position:absolute;left:0;right:0;bottom:0;padding:6px 8px;font-family:var(--display);font-size:.72rem;
  letter-spacing:.05em;background:linear-gradient(0deg,rgba(0,0,0,.85),transparent)}
.cpick[data-on=true]{outline:2px solid var(--gold);outline-offset:-2px}
.cpick.taken{filter:grayscale(.9) brightness(.5);pointer-events:none}
.cpick.taken::after{content:'vergeben';position:absolute;inset:0;display:grid;place-items:center;
  font-family:var(--display);letter-spacing:.2em;font-size:.7rem;color:#bbb}
.toggle{display:flex;border:1px solid var(--line);border-radius:10px;overflow:hidden;max-width:240px;margin:0 auto}
.toggle button{flex:1;padding:11px;background:var(--panel);border:0;color:var(--muted);font-family:var(--display);
  letter-spacing:.1em;cursor:pointer}
.toggle button.on{background:var(--gold);color:#1a1407;font-weight:700}

/* ---------- Suspect view ---------- */
.shero{display:flex;gap:14px;align-items:center}
.shero img{width:84px;height:112px;object-fit:cover;border-radius:10px;border:1px solid var(--line);flex:0 0 auto}
.kwgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:6px}
.kw{perspective:1100px;aspect-ratio:3/4;cursor:pointer;border-radius:12px;transition:transform .16s;
  box-shadow:0 6px 18px rgba(0,0,0,.35)}
.kw:not(.locked):active{transform:translateY(1px) scale(.99)}
.kw .inner{position:relative;width:100%;height:100%;transition:transform .55s cubic-bezier(.4,.2,.2,1);
  -webkit-transform-style:preserve-3d;transform-style:preserve-3d}
.kw.flipped .inner{-webkit-transform:rotateY(180deg);transform:rotateY(180deg)}
.kw .face{position:absolute;inset:0;-webkit-backface-visibility:hidden;backface-visibility:hidden;
  border-radius:12px;overflow:hidden;border:1px solid var(--line)}
.kw .front{background:url('/assets/ui/card-back.jpg') center/cover;display:flex;align-items:flex-end}
.kw .front .lbl{width:100%;padding:8px;background:linear-gradient(0deg,rgba(0,0,0,.8),transparent);
  font-family:var(--display);font-size:.74rem;letter-spacing:.04em;text-align:center}
.kw .back{background:var(--panel2);transform:rotateY(180deg);padding:12px;overflow:auto;font-size:.84rem}
.kw .back .kwname{font-family:var(--display);color:var(--gold-soft);font-size:.72rem;letter-spacing:.1em;
  text-transform:uppercase;margin-bottom:6px}
.kw.locked{opacity:.45;filter:grayscale(.7);cursor:not-allowed}
.kw.locked .front .lbl::before{content:'🔒 '}
.unflip{font-size:.7rem;color:var(--gold-soft);text-align:center;margin-top:5px;text-decoration:underline;opacity:.8}

/* ---------- Elli dashboard ---------- */
.tabs{display:flex;gap:6px;margin:10px 0}
.tabs button{flex:1;padding:11px 6px;border:1px solid var(--line);border-radius:10px;background:var(--panel);
  color:var(--muted);font-family:var(--display);letter-spacing:.06em;font-size:.78rem;cursor:pointer;position:relative}
.tabs button.on{background:var(--panel2);color:var(--gold-soft);border-color:var(--gold-dim)}
.tabs .badge{position:absolute;top:-7px;right:-4px;background:var(--gold);color:#1a1407;border-radius:10px;
  font-size:.62rem;padding:1px 6px;font-family:var(--serif);font-weight:700}
.obj{display:flex;gap:10px;align-items:flex-start;padding:12px;border:1px solid var(--line);border-radius:11px;
  background:var(--panel);margin:8px 0}
.obj .kwtag{font-family:var(--display);color:var(--gold-soft);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase}
.clue{padding:12px 14px;border-left:3px solid var(--gold);border-radius:8px;background:var(--panel);margin:8px 0;
  animation:rise .4s ease}
.clue .ct{font-family:var(--display);color:var(--gold-soft);font-size:.92rem;letter-spacing:.04em}
.clue .cat{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.accuse-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.accuse-grid .ab{display:flex;align-items:center;gap:8px;padding:12px;border:1px solid var(--line);border-radius:10px;
  background:var(--panel);cursor:pointer;font-size:.86rem}
.accuse-grid .ab[data-on=true]{outline:2px solid var(--gold);outline-offset:-2px}

/* ---------- Finale chessboard ---------- */
.board{width:min(92vw,420px);aspect-ratio:1;display:grid;grid-template-columns:repeat(8,1fr);
  border:3px solid var(--gold-dim);border-radius:6px;overflow:hidden;margin:14px auto;box-shadow:0 12px 40px rgba(0,0,0,.6)}
.sq{display:flex;align-items:center;justify-content:center;font-size:min(8vw,38px);cursor:pointer;position:relative}
.sq.l{background:#c7b89a}.sq.d{background:#5b4a39}
.sq.sel{outline:3px solid var(--gold);outline-offset:-3px}
.sq.target::before{content:'';position:absolute;width:26%;height:26%;border-radius:50%;background:rgba(201,162,75,.65)}
.sq .pc{filter:drop-shadow(0 1px 1px rgba(0,0,0,.4))}
.sq .pc.w{color:#fff}.sq .pc.b{color:#111}

/* ---------- Toast ---------- */
.mute-btn{position:fixed;top:max(10px,env(safe-area-inset-top));right:10px;z-index:60;width:38px;height:38px;
  border-radius:50%;border:1px solid var(--line);background:rgba(20,24,27,.7);-webkit-backdrop-filter:blur(4px);
  backdrop-filter:blur(4px);color:var(--ink);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center}
.toast{position:fixed;left:50%;bottom:calc(24px + var(--safe-b));transform:translateX(-50%) translateY(20px);
  background:#000;border:1px solid var(--gold-dim);color:var(--ink);padding:11px 18px;border-radius:10px;
  font-size:.9rem;opacity:0;pointer-events:none;transition:.25s;z-index:50;max-width:90vw;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

.fade{animation:fade .5s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.row{display:flex;align-items:center;gap:8px}
.spacer{flex:1}
.center-col{display:flex;flex-direction:column;align-items:center}

/* ---------- Finale extras + Verbindungs-Overlay ---------- */
.sq.check{box-shadow:inset 0 0 0 3px var(--red)}
.board.mated{box-shadow:0 0 0 3px var(--gold),0 12px 50px rgba(201,162,75,.45);transition:box-shadow .4s}
/* Zuschauer-Brett: read-only Live-Spiegel auf jedem Gast-Handy */
.specboard{width:min(86vw,360px)}
.specboard .sq{cursor:default}
.specboard .pc{transition:none}
.connovl{position:fixed;inset:0;background:rgba(8,9,11,.82);backdrop-filter:blur(3px);display:none;
  align-items:center;justify-content:center;z-index:100}
.connovl.show{display:flex}
.connbox{background:var(--panel);border:1px solid var(--gold-dim);border-radius:14px;padding:22px 26px;
  display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--ink);font-family:var(--display);
  letter-spacing:.04em;max-width:80vw;text-align:center;font-size:.9rem}
.spinner{width:30px;height:30px;border:3px solid var(--line);border-top-color:var(--gold);border-radius:50%;
  animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- Briefing / Geschichte ---------- */
.bdots{display:flex;gap:7px;justify-content:center;padding:4px 0 2px}
.bdot{width:7px;height:7px;border-radius:50%;background:var(--line);transition:.25s}
.bdot.on{background:var(--gold);box-shadow:0 0 8px var(--gold)}
.beat{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  gap:2px;width:100%;animation:rise .45s ease}
.beat-img{max-width:92vw;max-height:46vh;width:auto;object-fit:contain;border-radius:14px;
  border:1px solid var(--line);box-shadow:0 16px 48px rgba(0,0,0,.6)}
.beat-title{font-family:var(--display);font-weight:600;font-size:clamp(1.6rem,7vw,2.4rem);letter-spacing:.05em;
  margin:4px 0 2px;color:var(--gold-soft)}
.beat-text{max-width:40ch;color:#cfc8b6;font-size:1.04rem;line-height:1.5;margin-top:8px}

/* ---------- Akte (Fall-Tab bei Elli) ---------- */
.akte-hero{width:100%;max-width:320px;display:block;margin:0 auto;border-radius:12px;border:1px solid var(--line);
  aspect-ratio:3/4;object-fit:cover;box-shadow:0 12px 36px rgba(0,0,0,.5)}
.akte-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-top:8px}
.akte-sus{border:1px solid var(--line);border-radius:9px;overflow:hidden;background:var(--panel)}
.akte-sus img{width:100%;aspect-ratio:3/4;object-fit:cover;display:block}
.akte-cap{padding:5px 6px;font-size:.68rem;font-family:var(--display);letter-spacing:.02em;text-align:center;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ---------- Anklage-Optionen (Motiv/Waffe) ---------- */
.opt-list{display:flex;flex-direction:column;gap:7px}
.opt{padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:var(--panel);cursor:pointer;
  font-size:.92rem;transition:.15s}
.opt:active{transform:scale(.99)}
.opt[data-on=true]{outline:2px solid var(--gold);outline-offset:-2px;color:var(--gold-soft);background:#1b1a14}

/* ---------- Epilog (Auflösung) ---------- */
.epi-list{display:flex;flex-direction:column;gap:8px}
.epi{display:flex;gap:10px;align-items:flex-start;background:var(--panel);border:1px solid var(--line);
  border-radius:10px;padding:8px 10px;animation:rise .4s ease}
.epi img{width:42px;height:54px;object-fit:cover;border-radius:6px;flex:0 0 auto}
.epi-name{font-family:var(--display);letter-spacing:.03em;font-size:.86rem;margin-bottom:2px}

/* ---------- Premium-Mikro-Interaktionen ---------- */
.btn-primary{position:relative;overflow:hidden}
.btn-primary::after{content:'';position:absolute;top:0;left:-60%;width:38%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.32),transparent);transform:skewX(-18deg);
  animation:sheen 5s ease-in-out infinite;pointer-events:none}
@keyframes sheen{0%,74%{left:-60%}88%{left:135%}100%{left:135%}}
.kwgrid>div{animation:rise .45s ease backwards}
.kwgrid>div:nth-child(2){animation-delay:.07s}
.kwgrid>div:nth-child(3){animation-delay:.14s}
.kwgrid>div:nth-child(4){animation-delay:.21s}
.cpick{animation:rise .4s ease backwards}
.cpick:nth-child(3n+2){animation-delay:.05s}
.cpick:nth-child(3n){animation-delay:.1s}
@media (prefers-reduced-motion:reduce){*{animation-duration:.001s!important;animation-iteration-count:1!important;transition-duration:.05s!important}}

/* ---------- Geführter Ermittlungs-Narrator (Elli) ---------- */
.guidebeat{display:flex;flex-direction:column;align-items:center;text-align:center;padding:6px 2px 12px;animation:rise .4s ease}
.leadchips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:18px;width:100%}
.leadchip{width:46px;height:58px;border-radius:8px;overflow:hidden;border:1px solid var(--line);padding:0;cursor:pointer;
  background:var(--panel);transition:transform .15s}
.leadchip:active{transform:scale(.94)}
.leadchip img{width:100%;height:100%;object-fit:cover;display:block}

/* ====================================================================
   Synchroner Reigen — geteilte Bühne, Chat-Bubbles, Regiepult (Elli)
   ==================================================================== */
.dialog{justify-content:space-between}
.stage{flex:1;display:flex;gap:14px;align-items:stretch;min-height:0;padding:6px 0 2px}
/* Scheinwerfer-Porträt links */
.stage-portrait{flex:0 0 38%;max-width:172px;display:flex;flex-direction:column;align-items:center;justify-content:center;
  position:relative;animation:spotIn .5s ease}
.stage-portrait::before{content:'';position:absolute;inset:-10% -14% -6% -14%;
  background:radial-gradient(60% 50% at 50% 38%,rgba(201,162,75,.22),transparent 72%);pointer-events:none}
.stage-portrait img{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:14px;border:2px solid var(--gold-dim);
  box-shadow:0 10px 34px rgba(0,0,0,.55),0 0 28px rgba(201,162,75,.18);position:relative}
.stage-name{margin-top:9px;font-family:var(--display);font-size:.92rem;letter-spacing:.05em;text-align:center;
  text-shadow:0 1px 6px rgba(0,0,0,.6)}
/* Chat-Bubbles rechts */
.stage-bubbles{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:flex-end;gap:9px;
  overflow-y:auto;padding:4px 2px 4px 2px;-webkit-overflow-scrolling:touch}
.bubble{position:relative;align-self:flex-start;max-width:100%;background:linear-gradient(180deg,#1f2530,#171c24);
  border:1px solid var(--line);border-radius:14px 14px 14px 4px;padding:11px 14px;font-size:1.05rem;line-height:1.42;
  color:#e9e4d6;box-shadow:0 4px 14px rgba(0,0,0,.35);animation:bubbleIn .32s ease backwards}
.bubble::before{content:'';position:absolute;left:-7px;bottom:0;width:12px;height:12px;background:#171c24;
  border-left:1px solid var(--line);border-bottom:1px solid var(--line);border-radius:0 0 0 4px;transform:skewY(-12deg)}
.bubble.cur{border-color:var(--gold-dim);background:linear-gradient(180deg,#2a2a1e,#211d12);color:#fff;
  box-shadow:0 6px 20px rgba(201,162,75,.22)}
.bubble.cur::before{background:#211d12;border-color:var(--gold-dim)}
/* Erzähler-/Auftritts-Bubbles (Narration + Überleitung): wärmer, kursiv, weniger „Chat" */
.bubble.narr{background:linear-gradient(180deg,#241f17,#1b1710);border-color:var(--gold-dim);color:#efe6d2;font-style:italic;
  border-radius:14px;align-self:stretch}
.bubble.narr::before{display:none}
/* Status-/Stichwort-Zeile */
.cue{text-align:center;font-family:var(--display);font-size:.82rem;letter-spacing:.04em;color:var(--muted);
  margin-bottom:10px}
.cue.me{color:var(--gold-soft);text-shadow:0 0 14px rgba(201,162,75,.4);animation:cuePulse 1.8s ease-in-out infinite}
/* Regiepult — Elli erteilt das Wort */
.floor-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin:4px 0 2px}
.floor{position:relative;border:1px solid var(--line);border-radius:12px;overflow:hidden;cursor:pointer;
  background:var(--panel);transition:transform .14s,box-shadow .2s;animation:rise .4s ease backwards}
.floor:active{transform:scale(.96)}
.floor img{width:100%;aspect-ratio:1/1;object-fit:cover;object-position:50% 22%;display:block}
.floor:not(.spent){box-shadow:0 0 0 1px var(--gold-dim) inset,0 6px 18px rgba(0,0,0,.3)}
.floor.spent{filter:grayscale(.7) brightness(.62)}
.floor.spent::after{content:'erzählt';position:absolute;top:6px;right:6px;font-family:var(--display);font-size:.56rem;
  letter-spacing:.12em;text-transform:uppercase;color:var(--muted);background:rgba(0,0,0,.55);padding:2px 6px;border-radius:6px}
.floor-cap{position:absolute;left:0;right:0;bottom:0;padding:5px 7px;font-family:var(--display);font-size:.66rem;
  letter-spacing:.01em;background:linear-gradient(0deg,rgba(8,9,11,.92),transparent);display:flex;align-items:center;gap:5px}
.floor:nth-child(3n+2){animation-delay:.04s}.floor:nth-child(3n){animation-delay:.08s}
.floor:nth-child(n+4){animation-delay:.1s}.floor:nth-child(n+7){animation-delay:.16s}
@keyframes spotIn{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}
@keyframes bubbleIn{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}
@keyframes cuePulse{0%,100%{opacity:.75}50%{opacity:1}}
/* Sehr schmale Geräte: Porträt etwas kleiner halten */
@media (max-width:360px){.stage-portrait{flex-basis:34%}.bubble{font-size:.98rem}}

/* Live-Besetzung im Briefing — passt sich den gewählten Geschlechtern an */
.beat-cast{justify-content:flex-start;padding-top:6px}
.castgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;width:100%;max-width:540px;margin:0 auto}
.casttile{position:relative;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--panel);
  box-shadow:0 4px 14px rgba(0,0,0,.3);animation:rise .4s ease backwards}
.casttile img{width:100%;aspect-ratio:1/1;object-fit:cover;object-position:50% 20%;display:block}
.casttile.open{filter:grayscale(.65) brightness(.55)}
.casttile.open::after{content:'frei';position:absolute;top:5px;right:5px;font-family:var(--display);font-size:.52rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--muted);background:rgba(0,0,0,.55);padding:1px 5px;border-radius:5px}
.castcap{position:absolute;left:0;right:0;bottom:0;padding:5px 6px 4px;
  background:linear-gradient(0deg,rgba(8,9,11,.95),rgba(8,9,11,.55) 60%,transparent);
  font-family:var(--display);line-height:1.12}
.castcap b{display:block;font-size:.66rem;letter-spacing:.05em}
.castcap span{color:#cfc8b6;font-size:.58rem;letter-spacing:.02em}
.casttile:nth-child(3n+2){animation-delay:.04s}.casttile:nth-child(3n){animation-delay:.08s}
.casttile:nth-child(n+4){animation-delay:.1s}.casttile:nth-child(n+7){animation-delay:.15s}.casttile:nth-child(n+10){animation-delay:.2s}
@media (min-width:600px){.castgrid{grid-template-columns:repeat(4,1fr);max-width:640px}}

/* ====================================================================
   Ellis Dialog-Rad, Beweis-Reveal, freies Verhör, Lobby-Steckbrief
   ==================================================================== */
/* Dialog-Rad (Elli) — Aktionen OBEN, Bild/Bühne darunter */
.wheelscreen{justify-content:flex-start}
.whead{display:flex;align-items:center;gap:8px;margin-bottom:2px}
.wheel{display:flex;flex-direction:column;gap:10px;margin:2px 0}
.wcard{position:relative;text-align:left;width:100%;cursor:pointer;color:var(--ink);
  border:1px solid var(--line);border-radius:14px;padding:13px 15px 11px;
  background:linear-gradient(180deg,#1b2027,#13171b);box-shadow:0 6px 20px rgba(0,0,0,.34);
  transition:transform .14s,box-shadow .2s,border-color .2s;animation:rise .4s ease backwards}
.wcard:nth-child(2){animation-delay:.06s}.wcard:nth-child(3){animation-delay:.12s}
.wcard:active{transform:scale(.985)}
.wcard:hover,.wcard:focus-visible{border-color:var(--gold-dim);box-shadow:0 8px 26px rgba(201,162,75,.18);outline:none}
.wcard-line{font-family:var(--serif);font-size:1.04rem;line-height:1.4;color:#efe7d4}
.wcard-to{display:flex;align-items:center;gap:7px;margin-top:10px;font-family:var(--display);font-size:.68rem;
  letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.wcard-to img{width:22px;height:22px;border-radius:50%;object-fit:cover;object-position:50% 16%}
.wcard-read{margin-top:6px;font-family:var(--display);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-soft);opacity:.8}
.wheel-extra{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.wheel-extra .weak{flex:1;min-width:130px;flex-direction:column;gap:1px;padding:11px;font-size:.82rem;text-transform:none;letter-spacing:.02em}
.wheel-extra .sub{font-family:var(--serif);font-size:.64rem;letter-spacing:0;color:var(--muted);text-transform:none}
.wheel-extra .hintbtn{flex:0 0 auto;min-width:0;color:var(--gold-soft);border-color:var(--gold-dim)}

/* Elli-Bubble: rechtsbündig, eigene Seite (Teal) */
.bubble.elli{align-self:flex-end;border-radius:14px 14px 4px 14px;
  background:linear-gradient(180deg,#16302d,#0f211f);border-color:var(--teal);color:#eaf3ef}
.bubble.elli::before{left:auto;right:-7px;border-left:0;border-right:1px solid var(--teal);
  border-bottom:1px solid var(--teal);border-radius:0 0 4px 0;transform:skewY(12deg);background:#0f211f}
.bubble.elli.cur{border-color:var(--elli);background:linear-gradient(180deg,#1c3a35,#123029);color:#fff;box-shadow:0 6px 20px rgba(59,179,166,.22)}
.bubble.elli.cur::before{background:#123029;border-color:var(--elli)}
.stage-portrait img{transition:opacity .35s ease}

/* Beweis-Reveal — Kartendreh (synchron) */
.reveal-screen{justify-content:flex-start}
.reveal{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;animation:rise .4s ease}
.cluebanner{margin:0 0 6px;text-align:center;font-family:var(--display);font-size:.8rem;letter-spacing:.03em;
  color:#1a1407;background:linear-gradient(180deg,var(--gold-soft),var(--gold));border-radius:10px;padding:9px 12px;
  box-shadow:0 6px 22px rgba(201,162,75,.3);animation:bannerIn .5s ease}
.cluebanner b{font-weight:700}
@keyframes bannerIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
.kw.evidence{width:min(62vw,220px);aspect-ratio:3/4;perspective:1100px;cursor:pointer}
.kw.evidence .inner{position:relative;width:100%;height:100%;transition:transform .6s cubic-bezier(.2,.7,.2,1);transform-style:preserve-3d}
.kw.evidence.flipped .inner{transform:rotateY(180deg)}
.kw.evidence .face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:13px;
  border:1px solid var(--gold-dim);background-size:cover;background-position:center;overflow:hidden;box-shadow:0 14px 38px rgba(0,0,0,.55)}
.kw.evidence .back{transform:rotateY(180deg);display:flex;flex-direction:column;justify-content:flex-end}
.kw.evidence .ev-title{font-family:var(--display);color:var(--gold-soft);font-size:.92rem;letter-spacing:.03em;
  padding:26px 12px 0;background:linear-gradient(0deg,rgba(8,9,11,.95),rgba(8,9,11,.55) 70%,transparent)}
.kw.evidence .ev-text{font-size:.74rem;color:#e6dfce;line-height:1.34;padding:6px 12px 12px;background:rgba(8,9,11,.95)}
/* Legendärer Pull — Strahlenkranz, Glühen, Funken, dramatischer Dreh */
.reveal-stage{position:relative;display:flex;align-items:center;justify-content:center;width:100%;min-height:46vh}
.reveal-stage.lit{animation:revShake .5s ease}
.reveal-stage:not(.lit) .kw.evidence{animation:cardFloat 3.2s ease-in-out infinite}
.rays{position:absolute;left:50%;top:50%;width:360px;height:360px;transform:translate(-50%,-50%);pointer-events:none;opacity:0;z-index:1;
  background:repeating-conic-gradient(from 0deg, rgba(227,200,121,0) 0 6deg, rgba(227,200,121,.18) 6deg 8deg);
  -webkit-mask:radial-gradient(circle, transparent 86px, #000 92px, #000 172px, transparent 178px);
  mask:radial-gradient(circle, transparent 86px, #000 92px, #000 172px, transparent 178px)}
.reveal-stage.lit .rays{animation:raysIn .5s ease forwards, raysSpin 16s linear infinite}
.glow{position:absolute;left:50%;top:50%;width:320px;height:320px;transform:translate(-50%,-50%) scale(.4);pointer-events:none;opacity:0;z-index:1;
  background:radial-gradient(circle, rgba(201,162,75,.55), rgba(201,162,75,.10) 45%, transparent 70%)}
.reveal-stage.lit .glow{animation:glowBurst 1.1s ease forwards}
.kw.evidence{position:relative;z-index:2}
.reveal-stage.lit .kw.evidence .inner{animation:legFlip .95s cubic-bezier(.2,.85,.2,1) forwards}
.reveal-stage.lit .kw.evidence .face{box-shadow:0 14px 38px rgba(0,0,0,.55),0 0 28px rgba(201,162,75,.55)}
.front-sheen{position:absolute;inset:0;background:linear-gradient(110deg,transparent 36%,rgba(255,247,214,.5) 50%,transparent 64%);transform:translateX(-130%)}
.reveal-stage:not(.lit) .front-sheen{animation:sheenSweep 3.4s ease-in-out infinite}
.sparks{position:absolute;left:50%;top:50%;width:0;height:0;pointer-events:none;z-index:3}
.spark{position:absolute;left:-3px;top:-3px;width:6px;height:6px;border-radius:50%;background:var(--gold-soft);opacity:0;box-shadow:0 0 8px var(--gold-soft)}
.reveal-stage.lit .spark{animation:sparkFly 1s ease-out forwards;animation-delay:var(--d,0s)}
@keyframes raysIn{to{opacity:.9}}
@keyframes raysSpin{to{transform:translate(-50%,-50%) rotate(360deg)}}
@keyframes glowBurst{0%{opacity:0;transform:translate(-50%,-50%) scale(.4)}45%{opacity:.95;transform:translate(-50%,-50%) scale(1.12)}100%{opacity:.5;transform:translate(-50%,-50%) scale(1)}}
@keyframes legFlip{0%{transform:rotateY(0) scale(1)}55%{transform:rotateY(360deg) scale(1.16)}80%{transform:rotateY(520deg) scale(1.02)}100%{transform:rotateY(540deg) scale(1.05)}}
@keyframes revShake{0%,100%{transform:translateX(0)}15%{transform:translateX(-5px)}30%{transform:translateX(5px)}45%{transform:translateX(-3px)}60%{transform:translateX(3px)}80%{transform:translateX(-1px)}}
@keyframes cardFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@keyframes sheenSweep{0%,100%{transform:translateX(-130%)}28%,72%{transform:translateX(130%)}}
@keyframes sparkFly{0%{opacity:0;transform:rotate(var(--a)) translateY(0) scale(.4)}25%{opacity:1}100%{opacity:0;transform:rotate(var(--a)) translateY(-165px) scale(1)}}
@media (prefers-reduced-motion:reduce){.reveal-stage.lit .kw.evidence .inner{animation:none;transform:rotateY(180deg)}.rays,.glow,.spark,.front-sheen{display:none}}

/* Freies Verhör — Stichwort-Wolke */
.cloud{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.chip{border:1px solid var(--line);border-radius:999px;background:var(--panel);color:#d9d2c2;font-family:var(--serif);
  font-size:.88rem;padding:8px 14px;cursor:pointer;transition:.15s}
.chip:active{transform:scale(.96)}
.chip[data-on=true]{outline:2px solid var(--gold);outline-offset:-2px;background:#1b1a14;color:var(--gold-soft)}
/* Freies Verhör — Figuren-Porträts ("an den Tisch treten") */
.vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.vtile{position:relative;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--panel);cursor:pointer;
  padding:0;transition:transform .14s,box-shadow .2s,border-color .2s;animation:rise .4s ease backwards}
.vtile img{width:100%;aspect-ratio:1/1;object-fit:cover;object-position:50% 18%;display:block}
.vtile:active{transform:scale(.96)}
.vtile[data-on=true]{outline:2px solid var(--gold);outline-offset:-2px;box-shadow:0 0 0 1px var(--gold) inset,0 6px 18px rgba(201,162,75,.28)}
.vtile:nth-child(3n+2){animation-delay:.04s}.vtile:nth-child(3n){animation-delay:.08s}
.vcap{position:absolute;left:0;right:0;bottom:0;padding:5px 6px;font-family:var(--display);font-size:.62rem;letter-spacing:.03em;
  text-align:left;background:linear-gradient(0deg,rgba(8,9,11,.95),transparent);display:flex;align-items:center;gap:5px}

/* ====================================================================
   ART-DÉCO-CHROME — Restyle der Basis-Komponenten (Buttons, Titel, Panels)
   ==================================================================== */
/* Messing-Buttons mit Gold-Doppellinie + Bevel; eckiger (Déco) */
.btn{border-radius:7px;letter-spacing:.16em;border:1px solid var(--gold-dim);
  background:linear-gradient(180deg,#1b2127,#11161b);
  box-shadow:inset 0 1px 0 rgba(227,200,121,.10), inset 0 0 0 1px rgba(0,0,0,.35), 0 5px 16px rgba(0,0,0,.42)}
.btn::before{content:'';position:absolute;inset:3px;border:1px solid rgba(201,162,75,.22);border-radius:4px;pointer-events:none}
.btn{position:relative}
.btn-primary{background:linear-gradient(180deg,#ecd692 0%,var(--gold) 50%,#9a7c33 100%);color:#241803;
  border-color:var(--gold-soft);text-shadow:0 1px 0 rgba(255,255,255,.28);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.55), inset 0 -3px 7px rgba(120,90,20,.45), 0 7px 24px rgba(201,162,75,.32)}
.btn-primary::before{border-color:rgba(40,24,3,.35)}
.btn-ghost{background:linear-gradient(180deg,rgba(38,46,52,.45),rgba(16,21,26,.5));color:var(--gold-soft)}
.btn:hover,.btn:focus-visible{border-color:var(--gold-soft);outline:none;
  box-shadow:inset 0 1px 0 rgba(227,200,121,.18), 0 0 0 1px rgba(201,162,75,.28), 0 7px 22px rgba(201,162,75,.24)}
.btn-primary:hover{filter:brightness(1.06)}
.btn:active{transform:translateY(1px)}
.btn[disabled]::before{opacity:.3}

/* Emblem-Sunburst + Titel-Ornamente (Startscreen) */
.emblem{background:radial-gradient(circle at 50% 45%, rgba(201,162,75,.16), transparent 68%)}
.screen.center .kicker{position:relative;display:inline-block}
.screen.center .kicker::before,.screen.center .kicker::after{content:'';position:absolute;top:50%;width:24px;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-dim))}
.screen.center .kicker::before{right:100%;margin-right:9px;transform:scaleX(-1)}
.screen.center .kicker::after{left:100%;margin-left:9px}
.title{position:relative}
.screen.center .title::after{content:'◆';display:block;margin:12px auto 0;color:var(--gold-dim);font-size:.7rem;letter-spacing:1.2em;
  text-indent:1.2em;text-shadow:0 0 0 var(--gold-dim)}

/* Panels: feine Gold-Inlay-Linie oben (Déco) */
.panel{position:relative}
.panel::after{content:'';position:absolute;left:12px;right:12px;top:0;height:1px;opacity:.45;
  background:linear-gradient(90deg,transparent,var(--gold-dim),transparent)}
.panel.deco::after{display:none}

/* m/w-Toggle in Gold */
.toggle{border-color:var(--gold-dim)}
.toggle button.on{background:linear-gradient(180deg,var(--gold-soft),var(--gold));color:#241803;font-weight:700}

/* Divider mit Mittel-Raute */
.divider{position:relative;overflow:visible}
.divider::after{content:'◆';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  color:var(--gold-dim);font-size:.6rem;background:var(--bg);padding:0 8px}

/* Lobby-Steckbrief */
.steckbrief .sb-head{display:flex;gap:12px;align-items:center}
.steckbrief .sb-head img{width:66px;height:88px;object-fit:cover;border-radius:9px;border:1px solid var(--line);flex:0 0 auto}
.sb-story{font-style:italic;color:#cfc8b6;margin:10px 0 0;font-size:.92rem;line-height:1.45}
.eck{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:5px}
.eck li{position:relative;padding-left:16px;font-size:.86rem;color:#ddd5c4}
.eck li::before{content:'◆';position:absolute;left:0;color:var(--gold-dim);font-size:.7rem;top:3px}
.secret{margin-top:12px;border-top:1px solid var(--gold-dim);padding-top:10px;background:#191512;border-radius:0 0 10px 10px}

/* ====================================================================
   PREMIUM-NOIR — Ellis Dialog-Rad (Home) mit Animationen
   ==================================================================== */
.wheelscreen{justify-content:flex-start}
.wheelscreen .whead{position:relative;padding:2px 2px 9px;margin-bottom:9px;border-bottom:1px solid var(--line)}
.wheelscreen .whead::after{content:'';position:absolute;left:0;right:0;bottom:-1px;height:1px;background:linear-gradient(90deg,var(--gold),transparent)}
.wheelscreen .whead .kicker{color:var(--gold-soft)}
/* sanftes Scheinwerfer-Glühen hinter dem Rad */
.wheelscreen::before{content:'';position:fixed;left:50%;top:22%;width:92vw;max-width:540px;height:330px;transform:translateX(-50%);
  background:radial-gradient(circle, rgba(201,162,75,.11), transparent 70%);pointer-events:none;z-index:-1;animation:spotBreath 6s ease-in-out infinite}
@keyframes spotBreath{0%,100%{opacity:.55}50%{opacity:1}}
.wheel{perspective:1200px;gap:11px}
.wcard{border-radius:12px;border-color:var(--gold-dim);padding:13px 15px 11px 18px;overflow:hidden;
  background:linear-gradient(180deg,#1c222a 0%,#12161b 100%);
  box-shadow:0 8px 24px rgba(0,0,0,.42), inset 0 1px 0 rgba(227,200,121,.07);
  animation:dealIn .52s cubic-bezier(.2,.8,.2,1) backwards}
.wcard::before{content:'';position:absolute;left:0;top:10px;bottom:10px;width:3px;border-radius:3px;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold-dim));opacity:.85}
.wcard::after{content:'';position:absolute;right:9px;top:9px;width:13px;height:13px;
  border-top:1px solid var(--gold-dim);border-right:1px solid var(--gold-dim);opacity:.5;pointer-events:none}
.wcard:nth-child(1){animation-delay:.02s}.wcard:nth-child(2){animation-delay:.1s}.wcard:nth-child(3){animation-delay:.18s}
.wcard:hover,.wcard:focus-visible{transform:translateY(-2px);border-color:var(--gold-soft);outline:none;
  box-shadow:0 12px 30px rgba(201,162,75,.22), inset 0 1px 0 rgba(227,200,121,.12)}
.wcard:hover .wcard-read{color:var(--gold-soft);opacity:1}
.wcard:active{transform:translateY(0) scale(.99)}
.wcard-line{font-size:1.06rem}
.wcard-to img{box-shadow:0 0 0 1px var(--gold-dim)}
.wcard-read{transition:.2s}
@keyframes dealIn{from{opacity:0;transform:translateY(26px) rotateX(12deg)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.wcard{animation:none}.wheelscreen::before{animation:none}}

/* Große Bild-Buttons: Akte / Hinweise / Anklage */
.navcards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.navcard{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;color:var(--ink);
  border:1px solid var(--gold-dim);border-radius:13px;overflow:hidden;background:linear-gradient(180deg,#1a2027,#11161b);
  padding:0 0 9px;transition:transform .14s,box-shadow .2s,border-color .2s}
.navcard img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;border-bottom:1px solid var(--gold-dim)}
.nc-label{font-family:var(--display);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-soft);padding:0 4px;text-align:center}
.navcard:hover,.navcard:focus-visible{transform:translateY(-2px);border-color:var(--gold-soft);box-shadow:0 10px 26px rgba(201,162,75,.22);outline:none}
.navcard:active{transform:scale(.98)}
.navcard[disabled]{opacity:.42;pointer-events:none;filter:grayscale(.5)}
.navcard.ready{border-color:var(--gold-soft);box-shadow:0 0 0 1px var(--gold-soft) inset,0 8px 24px rgba(201,162,75,.3)}
.nc-badge{position:absolute;top:6px;right:6px;min-width:21px;height:21px;border-radius:11px;padding:0 5px;display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:.66rem;color:#241803;background:linear-gradient(180deg,var(--gold-soft),var(--gold));box-shadow:0 2px 8px rgba(0,0,0,.45)}

/* Spürsinn — großer zentrierter Hinweis */
.spurovl{position:fixed;inset:0;z-index:70;display:none;align-items:center;justify-content:center;padding:24px;
  background:rgba(8,9,11,.72);backdrop-filter:blur(3px);animation:fadeIn .2s ease}
.spurovl.show{display:flex}
.spurbox{position:relative;max-width:440px;width:100%;text-align:center;background:linear-gradient(180deg,#1c2128,#13171b);
  border:1px solid var(--gold-dim);border-radius:16px;padding:30px 26px 24px;
  box-shadow:0 20px 60px rgba(0,0,0,.6),0 0 44px rgba(201,162,75,.16);animation:rise .35s ease}
.spurbox::before,.spurbox::after{content:'';position:absolute;width:18px;height:18px;border:1px solid var(--gold-dim)}
.spurbox::before{top:10px;left:10px;border-right:0;border-bottom:0}
.spurbox::after{bottom:10px;right:10px;border-left:0;border-top:0}
.spur-ic{font-size:2.6rem;line-height:1;margin-bottom:6px;filter:drop-shadow(0 0 14px rgba(227,200,121,.5));animation:spurGlow 2s ease-in-out infinite}
.spur-txt{font-family:var(--serif);font-size:1.18rem;line-height:1.5;color:#efe7d4;margin:12px 0 20px}
.spurbox .btn{max-width:220px;margin:0 auto}
@keyframes spurGlow{0%,100%{transform:scale(1);opacity:.92}50%{transform:scale(1.09);opacity:1}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
