:root{
  --bg:#313539;
  --gold:#d8cba9;
  --gold-stroke:#b9ab84;
  --ok:#1c8f4d;
  --bad:#a32121;
  --text:#f4f6f8;
  --muted:#cfd5da;
  --panel:#2b2f33;
  --panel-2:#3c4248;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial}
a{color:inherit}

/* Layout */
.kw-page{max-width:1200px;margin:18px auto;padding:0 14px}
.kw-bar{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:12px;text-align:center}
.kw-title{margin:0;font-size:1.6rem;letter-spacing:.02em}
.kw-status{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;align-items:center}
.pill{background:var(--panel-2);border:1px solid #4a5056;border-radius:999px;padding:.35rem .7rem;font-weight:700}

.kw-main{display:grid;grid-template-columns: 280px 1fr;gap:16px}
@media (max-width:900px){ .kw-main{grid-template-columns: 1fr} }

.kw-aside{background:var(--panel);border:1px solid #3b3f44;border-radius:14px;padding:12px}
.aside-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.aside-title{margin:.2rem 0 .6rem;font-size:1.05rem}
.hint-btn{border:1px solid #556;background:var(--panel-2);color:#fff;border-radius:50%;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;font-weight:800;cursor:pointer}
.kw-tip{display:none;background:#1f2326;border:1px solid #3b3f44;border-radius:10px;padding:.6rem .7rem;margin:.4rem 0 .6rem;font-size:.95rem;line-height:1.35}
.kw-tip[aria-hidden="false"]{display:block}

/* Chips list with icons */
.kw-list{display:flex;flex-wrap:wrap;gap:6px}
.kw-list .chip{display:inline-flex;align-items:center;gap:6px;background:var(--panel-2);border:1px dashed #555;border-radius:10px;padding:.28rem .5rem;color:var(--muted);font-size:.92rem}
.kw-list .chip svg{width:16px;height:16px;opacity:.95}
.kw-list .chip.jackpot{background:#4a2020;border-color:#ff8686;color:#ffd9d9;font-weight:700}
.kw-list .chip.found-dud{opacity:.35;text-decoration:line-through}
.kw-list .chip.found-win{filter:contrast(1.1)}
.kw-list .chip.flash-bad{background:#6f1c1c;color:#fff;border-color:#bb4444;animation:chipFlash .55s ease}
@keyframes chipFlash{0%{filter:brightness(1.25)}100%{filter:brightness(1)}}

/* Stage frame */
.kw-stage{}
.kw-frame{position:relative;border-radius:14px;overflow:hidden;background:#1f2326;
  border:3px solid var(--gold); box-shadow:0 14px 36px rgba(0,0,0,.35), inset 0 0 0 1px var(--gold-stroke);}
.kw-frame::before, .kw-frame::after{
  content:""; position:absolute; inset:6px; border:1px solid rgba(216,203,169,.35); border-radius:10px; pointer-events:none;
}
.kw-frame .img{display:block;width:100%;height:auto}
.kw-overlay{position:absolute;inset:0;pointer-events:none}
.kw-hot{position:absolute;transform:translate(-50%,-50%);width:2.4%;aspect-ratio:1;border:none;background:transparent;padding:0;cursor:pointer;pointer-events:auto;z-index:5;outline-offset:4px}
.kw-overlay.block .kw-hot{pointer-events:none}
.kw-hot svg{width:100%;height:100%;opacity:.85;mix-blend-mode:multiply;filter:contrast(1.1) sepia(25%) saturate(115%);transition:.15s transform ease,.15s opacity ease}
.kw-hot:hover svg{transform:scale(1.15);opacity:1}
.kw-hot.found svg{opacity:.25;filter:grayscale(100%) brightness(.9)}
.kw-hot.win svg{opacity:1;filter:none;transform:scale(1.25)}

/* Kontext-Stempel für "Niete" */
.kw-stamp{position:absolute;left:0;top:0;transform:translate(-50%,-100%) rotate(-10deg);
  background:var(--bad);color:#fff;font-weight:900;border-radius:8px;padding:.35rem .6rem;white-space:nowrap;
  box-shadow:0 8px 22px rgba(0,0,0,.4);opacity:0;pointer-events:none;
  transition:opacity .18s ease, transform .25s cubic-bezier(.2,.7,.2,1);z-index:90}
.kw-stamp.show{opacity:1;transform:translate(-50%,-115%) rotate(-10deg)}
/* Alternative Positionierung: Stempel unterhalb des Hotspots */
.kw-stamp.below{transform:translate(-50%,10%) rotate(3deg)}
.kw-stamp.below.show{transform:translate(-50%,5%) rotate(3deg)}

/* Buttons */
.btn{appearance:none;display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
  padding:.6rem .95rem;border-radius:999px;border:0;text-decoration:none;font-weight:800;cursor:pointer;
  transition:transform .06s ease, filter .12s ease; outline-offset:3px}
.btn:active{transform:translateY(1px)}
.btn-primary{background:#17a36b;color:#062c1e}
.btn-ghost{background:var(--panel-2);color:#dfe6ec;border:1px solid #556}
.btn:hover{filter:brightness(1.05)}
.link{text-decoration:underline}
.textlink{background:none;border:none;color:#cfe6ff;text-decoration:underline;cursor:pointer}

/* Music toggle – mehr Luft um die Wellen */
.music-toggle{position:relative; gap:.35rem;}
.music-toggle .label{margin-right:.35rem}
.music-toggle .waves{display:flex;position:relative;top:0;transform:none;width:.75rem;height:.9rem;
  align-items:flex-end;gap:2px;margin:0 .35rem}
.music-toggle .waves i{display:block;width:2px;height:.35rem;background:#95f3c5;opacity:.6;animation:wave 1.1s infinite ease-in-out}
.music-toggle .waves i:nth-child(2){animation-delay:.15s}
.music-toggle .waves i:nth-child(3){animation-delay:.3s}
.music-toggle[aria-pressed="true"]{background:#17a36b;color:#062c1e}
@keyframes wave{0%,100%{height:.25rem;opacity:.6}50%{height:.9rem;opacity:1}}
@media (prefers-reduced-motion: reduce){ .music-toggle .waves i{animation:none} }

/* Badge/Toast */
.kw-badge{position:fixed;top:14px;left:50%;transform:translateX(-50%);padding:.55rem 1rem;border-radius:999px;color:#fff;font-weight:800;letter-spacing:.02em;box-shadow:0 10px 30px rgba(0,0,0,.25);z-index:120;opacity:0;transition:opacity .2s, transform .2s}
.kw-badge.show{opacity:1;transform:translateX(-50%) translateY(4px)}
.bad{background:var(--bad)} .good{background:var(--ok)}
.kw-toast{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);background:#111;color:#fff;padding:.6rem 1rem;border-radius:12px;box-shadow:0 10px 30px rgba(0,0,0,.4);z-index:110;opacity:0;pointer-events:none;transition:opacity .2s ease}
.kw-toast.show{opacity:1}

/* Endcard */
.kw-endbox{position:absolute;left:50%;bottom:12px;transform:translateX(-50%);background:#1f2326cc;border:1px solid #3a3f44;border-radius:14px;padding:12px 14px;display:none;z-index:180;backdrop-filter:saturate(120%) blur(2px);max-width:min(92vw,1000px)}
.kw-endbox.show{display:block}
.kw-endbox h3{margin:.2rem 0 .4rem;font-size:1.15rem}
.kw-endbox .row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;justify-content:center;margin-bottom:.35rem}
.kw-endbox .info{font-size:.95rem;opacity:.95;line-height:1.35}
.kw-dim{position:absolute;inset:0;background:rgba(0,0,0,.12);opacity:0;transition:opacity .2s;z-index:100;pointer-events:none}
.kw-dim.show{opacity:1}

/* Modals */
.kw-modal{position:fixed;inset:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;padding:1rem;z-index:200}
.kw-modal[aria-hidden="false"]{display:flex}
.kw-dialog{background:var(--panel);border:1px solid #444;border-radius:16px;padding:1.2rem;max-width:min(760px,92vw);box-shadow:0 18px 40px rgba(0,0,0,.5);text-align:center}
/* Größeres Dialog-Layout nur für das Intro-Modal */
.modal-intro .kw-dialog{max-width:min(1100px,96vw)}
.kw-dialog h2{margin:.2rem 0 .6rem;font-size:1.5rem}
.kw-dialog img{max-width:160px;height:auto;margin:.2rem auto .6rem;display:block}
.kw-dialog .code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,'Liberation Mono','Courier New',monospace;background:#111;color:#fff;padding:.6rem .8rem;border-radius:10px;font-size:1.2rem;letter-spacing:.06em;text-align:center;margin-top:.4rem}
.kw-actions{display:flex;gap:.5rem;justify-content:center;margin-top:.8rem;flex-wrap:wrap}
.small{opacity:.75;font-size:.9rem;margin-top:.6rem}
.muted{opacity:.8;font-size:.95rem}

/* Intro centered look – größerer Banner */
.intro-centered .intro-panel{
  max-width:1000px;
  margin:0 auto;
  text-align:center;
}
@media (max-width:1080px){
  .intro-centered .intro-panel{ max-width:96vw; }
}
.intro-hero{
  display:block;
  width:100%;
  height:auto;
  border-radius:14px;
  margin:0 auto .6rem;
  box-shadow:0 16px 40px rgba(0,0,0,.35);
}
.intro-title{margin:.3rem 0 .2rem;font-size:1.65rem}
.intro-teaser{margin:0 0 .5rem}
.meta{display:flex;gap:.4rem;justify-content:center;flex-wrap:wrap;margin:.5rem 0}
.meta-badge{background:#42392e;border:1px solid #6a5c49;color:#f9e7c9;border-radius:999px;padding:.3rem .6rem;font-weight:700}

/* Intro: Panels */
.modal-intro .intro-panel.hide{display:none}
.modal-intro .terms-panel{display:none;max-height:60vh;overflow:auto;text-align:left}
.modal-intro .terms-panel.show{display:block}

/* Teilnahmebedingungen – bessere Struktur */
.terms-panel h2{
  font-size:1.4rem;
  margin:0 0 .6rem;
  text-align:center;
}
.terms-panel .t-block{ margin:.6rem 0 1rem; }
.terms-panel h3{
  font-size:1.05rem;
  margin:.2rem 0 .35rem;
  color:var(--muted);
  letter-spacing:.02em;
}
.terms-panel p{ margin:.2rem 0 .4rem; line-height:1.45; }
.terms-panel ul{
  margin:.2rem 0 .6rem .9rem;
  padding-left:.9rem;
  list-style:disc;
}
.terms-panel li{ margin:.15rem 0; }
.terms-panel a{ text-decoration:underline; }

/* SVG tint */
.kw-hot svg{ fill:var(--gold); stroke:var(--gold-stroke); stroke-width:3px; }

@media (max-width:640px){ .kw-hot{width:3.2%} }

/* Admin panel */
.kw-admin{ position:fixed; right:14px; bottom:14px; z-index:300; }
.kw-admin .panel{
  background:#222; border:1px solid #444; border-radius:12px; padding:.6rem;
  display:flex; gap:.4rem; flex-wrap:wrap;
}
.kw-admin .panel .btn{ padding:.45rem .7rem; font-weight:700; }

/* Larger invisible hit area for hotspots */
.kw-hit{position:absolute;transform:translate(-50%,-50%);width:clamp(40px,6vw,52px);height:clamp(40px,6vw,52px);background:transparent;border:0;padding:0;margin:0;pointer-events:auto;z-index:4;}

/* Tiny intro trigger button (help) */
.intro-trigger{position:absolute;top:8px;right:8px;background:var(--panel-2);border:1px solid #4a5056;border-radius:999px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-weight:700;cursor:pointer;opacity:.85}
.intro-trigger:hover{opacity:1}

