:root{
  --bg:#0e1116; --bg2:#161c25; --panel:#1b2330; --line:#2a3543;
  --txt:#e8edf4; --muted:#8c9bb0; --red:#e23b3b; --green:#27c081;
  --gold:#f5c451; --silver:#cdd6e0; --bronze:#cd7f4a; --accent:#4f9dff;
  --radius:16px; --shadow:0 10px 30px rgba(0,0,0,.45);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{
  font-family:"Segoe UI",system-ui,-apple-system,Roboto,sans-serif;
  background:radial-gradient(120% 120% at 50% -20%,#1a2330 0%,var(--bg) 55%);
  color:var(--txt);overflow:hidden;user-select:none;-webkit-user-select:none;
}
.hidden{display:none !important}
.screen{height:100vh;height:100dvh;width:100vw}
.dot{display:inline-block;width:.6em;height:.6em;border-radius:50%;vertical-align:middle;margin:0 .35em}
.dot.red{background:var(--red)}.dot.green{background:var(--green)}.accent{color:var(--red)}

/* ============ SETUP ============ */
#setup{display:flex;align-items:center;justify-content:center;padding:min(4vh,32px)}
.setup-card{width:min(1100px,96vw);background:var(--bg2);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:clamp(20px,3.2vh,40px) clamp(24px,4vw,56px)}
.logo{font-size:clamp(28px,5.2vh,46px);font-weight:800;letter-spacing:.5px;text-align:center}
.subtitle{text-align:center;color:var(--muted);margin:.5em 0 1.4em;font-size:clamp(13px,2vh,17px)}
.setup-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(18px,3vw,40px)}
.block-label{display:block;color:var(--muted);font-size:14px;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;font-weight:700}
.setup-block{margin-bottom:18px}
.name-list{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.name-row{display:flex;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:6px 10px}
.name-row .num{width:26px;height:26px;flex:0 0 26px;border-radius:50%;background:#28323f;color:var(--muted);font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center}
.name-row input{flex:1;background:transparent;border:none;color:var(--txt);font-size:18px;padding:8px 2px;outline:none;min-width:0}
.name-row input::placeholder{color:#5c6b80}
.preset-row{display:flex;gap:10px;margin-bottom:10px}
.preset{flex:1;padding:14px 0;border-radius:12px;border:1px solid var(--line);background:var(--panel);color:var(--txt);font-size:20px;font-weight:700;cursor:pointer}
.preset.active{background:var(--red);border-color:var(--red);color:#fff}
.custom-target{width:100%;background:var(--panel);border:1px solid var(--line);border-radius:12px;color:var(--txt);font-size:18px;padding:12px 14px;outline:none}
.custom-target::placeholder{color:#5c6b80}
.switch{display:flex;align-items:center;gap:12px;cursor:pointer;font-size:15px;color:var(--txt)}
.switch input{display:none}
.switch-track{width:50px;height:28px;border-radius:20px;background:#34404f;position:relative;flex:0 0 50px;transition:background .15s}
.switch-thumb{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;transition:left .15s}
.switch input:checked + .switch-track{background:var(--green)}
.switch input:checked + .switch-track .switch-thumb{left:25px}
.primary-btn{display:block;width:100%;margin-top:26px;padding:18px;border:none;border-radius:14px;background:linear-gradient(180deg,#2e8f5f,#1f7a4f);color:#fff;font-size:22px;font-weight:800;letter-spacing:.5px;cursor:pointer;box-shadow:0 6px 18px rgba(31,122,79,.4)}
.primary-btn:active{transform:translateY(1px)}

/* ============ GAME shell ============ */
#game{display:flex;flex-direction:column;position:relative}
#game.shake{animation:shake .42s cubic-bezier(.36,.07,.19,.97)}
@keyframes shake{10%,90%{transform:translateX(-2px)}20%,80%{transform:translateX(4px)}30%,50%,70%{transform:translateX(-8px)}40%,60%{transform:translateX(8px)}}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:var(--bg2);border-bottom:1px solid var(--line);flex:0 0 auto;z-index:5}
.topbar-left{display:flex;align-items:center;gap:14px}
.brand{font-weight:800;font-size:17px}
.meta{color:var(--muted);font-size:13px;background:var(--panel);padding:4px 12px;border-radius:20px;border:1px solid var(--line)}
.topbar-right{display:flex;gap:10px}
.ghost-btn{background:var(--panel);border:1px solid var(--line);color:var(--txt);padding:9px 16px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer}
.ghost-btn:active{transform:translateY(1px)}
.ghost-btn:disabled{opacity:.45}

.booster{position:absolute;top:52px;left:50%;transform:translateX(-50%);z-index:25;background:linear-gradient(180deg,#7a4cff,#5b2fd6);color:#fff;padding:10px 22px;border-radius:14px;font-size:18px;box-shadow:var(--shadow);animation:boost 1s ease-in-out infinite alternate}
@keyframes boost{from{box-shadow:0 0 0 0 rgba(123,76,255,.55)}to{box-shadow:0 0 0 12px rgba(123,76,255,0)}}
.toast{position:absolute;top:60px;left:50%;transform:translateX(-50%);z-index:30;padding:14px 26px;border-radius:14px;font-size:20px;font-weight:800;box-shadow:var(--shadow);max-width:80vw;text-align:center;animation:pop .25s ease}
.toast.elim{background:linear-gradient(180deg,#e23b3b,#b51f1f);color:#fff}
.toast.bust{background:#3a4452;color:#fff;border:1px solid var(--line)}
.toast.fun{background:linear-gradient(180deg,#f5a623,#e07c00);color:#1a1206}
.toast.info{background:#26313e;color:#cfe0f5;border:1px solid var(--line);font-size:16px}
@keyframes pop{from{transform:translateX(-50%) scale(.85);opacity:0}to{transform:translateX(-50%) scale(1);opacity:1}}

/* confetti */
.confetti{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:40}
.confetti i{position:absolute;top:-12px;width:9px;height:14px;border-radius:2px;animation:fall linear forwards}
@keyframes fall{to{transform:translateY(105vh) rotate(720deg);opacity:.9}}

/* ============ board: pad + side ============ */
.board2{flex:1;display:grid;grid-template-columns:1fr 372px;gap:14px;padding:14px;min-height:0}
.padwrap{display:flex;flex-direction:column;gap:12px;min-height:0}
.mult-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;flex:0 0 auto}
.mult{padding:14px 0;border-radius:14px;border:2px solid var(--line);background:var(--panel);color:var(--txt);font-size:clamp(17px,2.6vh,22px);font-weight:800;cursor:pointer;letter-spacing:.5px;transition:transform .05s}
.mult:active{transform:translateY(1px)}
.mult[data-m="1"].active{background:#33414f;border-color:#5a6c80;color:#fff}
.mult[data-m="2"].active{background:#1d6fb8;border-color:#3a9be0;color:#fff}
.mult[data-m="3"].active{background:#9a2bbf;border-color:#c45ce0;color:#fff}

.numpad{flex:1;display:grid;grid-template-columns:repeat(5,1fr);grid-auto-rows:1fr;gap:10px;min-height:0}
.num{border:1px solid var(--line);background:var(--panel);color:var(--txt);border-radius:14px;font-size:clamp(22px,4.4vh,34px);font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .05s,background .08s}
.num:active{transform:translateY(1px) scale(.97);background:#2b3645}
.numpad .num[data-armed="2"]{box-shadow:inset 0 0 0 3px rgba(58,155,224,.6)}
.numpad .num[data-armed="3"]{box-shadow:inset 0 0 0 3px rgba(196,92,224,.6)}

/* Sonder-Buttons: größer als zuvor, aber kleiner als Zahlen */
.special-row{display:grid;grid-template-columns:1fr 1fr 1fr 1.15fr;gap:10px;flex:0 0 auto;height:clamp(76px,12vh,104px)}
.special-row .num{flex-direction:column;line-height:1.05;font-size:clamp(16px,2.5vh,21px)}
.special-row .num small{font-size:.62em;color:var(--muted);font-weight:700}
.special{background:#202a36}
.special.miss small{color:#ff9b9b}
.next{background:linear-gradient(180deg,#2e8f5f,#1f7a4f);border-color:#1f7a4f;color:#fff;font-size:clamp(16px,2.5vh,21px)}

/* ---- side ---- */
.side{display:flex;flex-direction:column;gap:12px;min-height:0}
.active-banner{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:14px 16px;flex:0 0 auto}
.active-label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:1px;font-weight:700}
.active-name{display:block;font-size:clamp(22px,3.4vh,30px);font-weight:800;color:var(--green);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.active-need{display:block;color:var(--muted);font-size:14px;font-weight:600;margin-top:2px}
.finish-box{display:flex;align-items:center;gap:10px;margin-top:10px;background:#10161e;border:1px solid var(--line);border-radius:12px;padding:8px 12px}
.finish-label{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--accent);font-weight:800}
.finish-darts{font-size:clamp(18px,3vh,26px);font-weight:800;letter-spacing:.5px}
.finish-darts .seg{color:var(--gold)}
.visit-darts{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px;min-height:30px}
.dchip{background:#10161e;border:1px solid var(--line);border-radius:10px;padding:4px 9px;font-size:14px;font-weight:700}

/* auto-scroll Kartenliste */
.scorelist{flex:1;overflow:hidden;display:flex;flex-direction:column;gap:9px;padding-right:2px}
.prow{display:flex;align-items:center;gap:12px;background:var(--panel);border:2px solid var(--line);border-radius:14px;padding:10px 13px;flex:0 0 auto;transition:border-color .15s,box-shadow .15s}
.prow.active{border-color:var(--green);box-shadow:0 0 0 2px rgba(39,192,129,.25)}
.prow.bump{animation:bump .35s ease}
@keyframes bump{0%{transform:scale(1)}40%{transform:scale(1.04)}100%{transform:scale(1)}}
.prow.flash-elim{animation:flashRed .7s ease}
@keyframes flashRed{0%{border-color:var(--red);box-shadow:0 0 0 4px rgba(226,59,59,.6)}100%{}}
.medal{font-size:24px;width:30px;text-align:center;flex:0 0 30px}
.medal.empty{color:#3a4654;font-size:15px;font-weight:800}
.pinfo{flex:1;min-width:0}
.pname{font-size:18px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pdiff{font-size:12.5px;font-weight:700;color:var(--muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pdiff.lead{color:var(--green)}
.pfinish{font-size:12px;color:var(--accent);font-weight:700;margin-top:1px}
.pscore-wrap{text-align:right;flex:0 0 auto}
.pscore{font-size:32px;font-weight:800;line-height:1}
.prow.active .pscore{color:var(--green)}
.pneed{font-size:11px;color:var(--muted);font-weight:700;margin-top:2px}

/* ============ WIN ============ */
.overlay{position:fixed;inset:0;z-index:50;background:rgba(8,11,15,.85);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.win-card{background:var(--bg2);border:1px solid var(--line);border-radius:24px;padding:40px 56px;text-align:center;box-shadow:var(--shadow);animation:pop .3s ease}
.trophy{font-size:80px;line-height:1;animation:bump .6s ease}
.win-label{color:var(--muted);text-transform:uppercase;letter-spacing:3px;font-weight:700;margin-top:8px}
.win-name{font-size:clamp(38px,8vh,72px);font-weight:800;color:var(--gold);margin:6px 0 26px}
.win-actions{display:flex;flex-direction:column;gap:12px}
.win-actions .primary-btn{margin-top:0}

@media (orientation:portrait){
  .board2{grid-template-columns:1fr;grid-template-rows:auto 1fr}
  .side{order:-1}.scorelist{max-height:24vh}.numpad{min-height:280px}
}
