:root{
  --bg:#0c1018; --bg2:#121826; --panel:#161d2e; --panel2:#1d2740;
  --line:#26314d; --txt:#e7ecf5; --mut:#8a97b5; --acc:#3da9fc;
  --fire:#ff5a3c; --police:#2f7bff; --ems:#1fb574; --warn:#ffb000; --bad:#ff3b5c;
  --ok:#34d27b; --shadow:0 8px 30px rgba(0,0,0,.45);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{background:var(--bg);color:var(--txt);font-family:"Segoe UI",system-ui,Roboto,Arial,sans-serif;-webkit-font-smoothing:antialiased}
a{color:var(--acc);text-decoration:none}a:hover{text-decoration:underline}
button{font-family:inherit;cursor:pointer}
.mono{font-variant-numeric:tabular-nums}
.ok{color:var(--ok)}.bad{color:var(--bad)}.low{color:var(--bad)}

/* ---------- LANDING ---------- */
.wrap{max-width:1040px;margin:0 auto;padding:0 20px}
.hero{min-height:78vh;display:flex;flex-direction:column;justify-content:center;text-align:center;border-bottom:1px solid var(--line);
  background:radial-gradient(1200px 500px at 70% -10%,rgba(61,169,252,.18),transparent),radial-gradient(900px 500px at 10% 110%,rgba(255,90,60,.14),transparent),var(--bg)}
.badge{display:inline-block;border:1px solid var(--line);background:var(--panel);color:var(--mut);padding:5px 14px;border-radius:999px;font-size:13px;margin-bottom:22px;letter-spacing:.04em}
.hero h1{font-size:clamp(34px,6vw,62px);line-height:1.04;margin:0 0 14px;letter-spacing:-.02em}
.hero h1 b{color:var(--fire)}
.hero p{font-size:clamp(16px,2.4vw,21px);color:var(--mut);max-width:660px;margin:0 auto 30px}
.cta{display:inline-flex;gap:12px;align-items:center;justify-content:center;flex-wrap:wrap}
.btn{display:inline-block;border:0;border-radius:12px;padding:15px 30px;font-size:17px;font-weight:600;background:var(--fire);color:#fff;box-shadow:var(--shadow);transition:transform .08s,filter .15s}
.btn:hover{filter:brightness(1.08);text-decoration:none}.btn:active{transform:translateY(1px)}
.btn.ghost{background:var(--panel);border:1px solid var(--line);color:var(--txt)}
.btn.full{width:100%;margin-top:6px}.btn.sm{padding:11px 16px;font-size:14px}
.btn:disabled{opacity:.6;cursor:default}
.stats{display:flex;gap:30px;justify-content:center;flex-wrap:wrap;margin-top:34px;color:var(--mut)}
.stats b{display:block;font-size:30px;color:var(--txt);font-weight:700}
section.block{padding:60px 0;border-bottom:1px solid var(--line)}
section.block h2{font-size:clamp(24px,4vw,34px);margin:0 0 28px;text-align:center}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:24px}
.card h3{margin:.2em 0 .4em;font-size:19px}.card p{margin:0;color:var(--mut);font-size:15px;line-height:1.5}
.ic{font-size:30px}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:s}
.steps .card{position:relative;padding-top:40px}
.steps .card::before{counter-increment:s;content:counter(s);position:absolute;top:16px;left:16px;width:30px;height:30px;border-radius:50%;background:var(--fire);color:#fff;display:grid;place-items:center;font-weight:700}
.lead-list{max-width:560px;margin:24px auto 0}.lead-list li{margin:8px 0;color:var(--mut)}
footer{padding:40px 0;color:var(--mut);font-size:14px;text-align:center}
@media(max-width:760px){.grid3,.steps{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.grid3,.steps{grid-template-columns:1fr}}

/* ---------- HRA ---------- */
.game body{overflow:hidden}
#map{position:fixed;inset:0;background:#e8eef3;z-index:0}
.leaflet-container{background:#e8eef3;font:inherit}

/* topbar */
.topbar{position:fixed;top:0;left:0;right:0;height:54px;z-index:600;display:flex;align-items:center;gap:14px;padding:0 14px;
  background:rgba(15,20,32,.96);border-bottom:1px solid var(--line);backdrop-filter:blur(6px)}
.brand{font-weight:800;font-size:18px}
.pill{display:inline-block;padding:4px 10px;border-radius:999px;font-size:13px;font-weight:700;color:#fff;margin-right:3px}
.pill.F{background:var(--fire)}.pill.P{background:var(--police)}.pill.Z{background:var(--ems)}
.metric{display:flex;flex-direction:column;line-height:1.05}
.metric.wide{max-width:200px}
.metric .k{font-size:10px;color:var(--mut);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.metric .v{font-size:17px;font-weight:700}
.metric .v.sm{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.spacer{flex:1}
.tbtn{background:var(--panel2);border:1px solid var(--line);color:var(--txt);border-radius:9px;padding:8px 14px;font-weight:600;font-size:14px}
.tbtn:hover{filter:brightness(1.15)}.tbtn.xs{padding:3px 9px;font-size:12px}

/* panel */
.panel{position:fixed;z-index:500;background:rgba(18,24,38,.97);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);backdrop-filter:blur(8px)}
#calls{top:64px;left:12px;width:300px;max-height:calc(100vh - 80px);display:flex;flex-direction:column;overflow:hidden}
#calls h2,#dispatch h2{margin:0;padding:10px 14px;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--mut);border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
#callList{overflow:auto;padding:8px;display:flex;flex-direction:column;gap:7px;flex:1}

/* výzvy */
.call{border:1px solid var(--line);border-left:4px solid var(--mut);border-radius:10px;padding:9px 11px;background:var(--panel);cursor:pointer;transition:.12s}
.call:hover{border-color:var(--acc)}.call.sel{outline:2px solid var(--acc);border-left-color:var(--acc)}
.call.sev1{border-left-color:var(--warn)}.call.sev2{border-left-color:var(--fire)}.call.sev3{border-left-color:var(--bad)}
.call.mci{background:rgba(255,59,92,.07);border-color:rgba(255,59,92,.35)}
.call .t{font-weight:700;font-size:13.5px;display:flex;justify-content:space-between;gap:6px}
.call .t .tm{color:var(--mut);font-size:11.5px;font-weight:600;white-space:nowrap;display:flex;align-items:center;gap:5px}
.call-warn{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--bad);color:#fff;font-size:10px;font-weight:900;flex:none}
.call .m{font-size:11.5px;color:var(--mut);margin-top:3px}
.call .m2{font-size:11px;color:var(--mut);margin-top:2px;opacity:.8}
.call .bar{height:4px;border-radius:3px;background:var(--line);margin-top:7px;overflow:hidden}
.call .bar i{display:block;height:100%;background:var(--bad);transition:width .3s linear}
.call .bar.w i{background:var(--ok)}
.tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:6px}
.tag{font-size:11px;font-weight:700;padding:2px 6px;border-radius:6px;background:var(--panel2);border:1px solid var(--line)}
.tag.F{color:var(--fire)}.tag.P{color:#7aa6ff}.tag.Z{color:var(--ems)}
.tag.done{opacity:.4;text-decoration:line-through}
.tag.ho{color:var(--warn);border-color:rgba(255,176,0,.3)}
.tag.ho.done{color:var(--ok)}
.tag.mci{color:var(--bad);border-color:rgba(255,59,92,.4);font-size:10px}

/* DISPATCH — zobrazuje se VEDLE sloupce volání */
#dispatch{top:64px;left:324px;width:350px;max-height:calc(100vh - 80px);display:none;flex-direction:column}
#dispatch.open{display:flex}
#dispInfo{padding:10px 14px;border-bottom:1px solid var(--line);flex-shrink:0}
.di-h{font-weight:800;font-size:15px;line-height:1.3}
.di-mci{display:inline-block;background:var(--bad);color:#fff;font-size:11px;font-weight:800;padding:2px 8px;border-radius:6px;margin:4px 0}
.di-m{font-size:12px;color:var(--mut);margin-top:3px}
.di-m.ph{color:var(--acc);margin-top:6px;font-weight:600}
.di-pac{font-size:12.5px;margin-top:5px;background:rgba(31,181,116,.08);border:1px solid rgba(31,181,116,.2);border-radius:8px;padding:5px 9px}
.di-req{margin-top:7px;font-size:12px;color:var(--mut);display:flex;gap:4px;flex-wrap:wrap;align-items:center}
.di-ho{font-size:12px;margin-top:5px;color:var(--warn)}
.di-ho.urgent{font-weight:800;color:var(--bad);background:rgba(255,59,92,.1);border:1px solid rgba(255,59,92,.3);border-radius:7px;padding:4px 8px}
.src-disp{color:var(--mut);font-size:12px;margin-top:3px}
.src-disp b{color:var(--acc)}
.call .src{font-size:10.5px;color:var(--acc);margin-top:2px;opacity:.85}
#transPanel{flex-shrink:0}
.trans-panel{padding:10px 14px;border-bottom:1px solid var(--line);background:rgba(61,169,252,.05)}
.trans-hdr{font-weight:800;font-size:14px;margin-bottom:5px}
.trans-pat{font-size:12px;color:var(--mut);margin-bottom:3px}
.trans-spec{font-size:12px;color:var(--warn);font-weight:700;margin-bottom:5px}
.trans-timer{font-size:11px;color:var(--bad);margin-bottom:7px;font-variant-numeric:tabular-nums}
.trans-opts{display:flex;flex-direction:column;gap:5px}
.trans-btn{background:var(--panel2);border:1px solid var(--line);color:var(--txt);border-radius:9px;padding:8px 11px;font-size:12.5px;display:flex;justify-content:space-between;align-items:center;gap:8px;text-align:left}
.trans-btn:hover{border-color:var(--acc);background:var(--panel)}
.trans-btn.pref{border-color:var(--warn);color:var(--warn)}
.trans-btn.pref:hover{background:rgba(255,176,0,.1)}
.trans-btn .td{font-size:11px;color:var(--mut);white-space:nowrap}
#unitList{overflow:auto;padding:8px;display:flex;flex-direction:column;gap:5px;flex:1;min-height:60px}
.unit{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:10px;padding:8px 10px;background:var(--panel);cursor:pointer;transition:.1s;user-select:none}
.unit:hover{border-color:var(--acc);background:var(--panel2)}
.unit.sel{outline:2px solid var(--acc);background:rgba(61,169,252,.12)}
.unit.dis{opacity:.45;cursor:default}.unit.dis:hover{border-color:var(--line);background:var(--panel)}
.unit .dot{width:10px;height:10px;border-radius:50%;flex:none}
.unit .dot.F{background:var(--fire)}.unit .dot.P{background:var(--police)}.unit .dot.Z{background:var(--ems)}
.unit .dot.avail-ok{background:var(--ok)}.unit .dot.avail-bad{background:var(--bad)}
.mezi-hdr{font-size:11px;font-weight:700;color:var(--mut);text-transform:uppercase;letter-spacing:.05em;padding:8px 0 4px;border-top:1px solid var(--line);margin-top:6px}
.unit .nm{flex:1;font-size:13px;font-weight:600;line-height:1.25}
.unit .nm .sub{font-size:11px;color:var(--mut);font-weight:400}
.unit .nm i.fld{color:var(--warn);font-style:normal;font-size:11px}
.unit .nm .sub .spz{font-family:monospace;letter-spacing:.03em;color:var(--acc);font-size:10.5px}
.unit .eta{font-size:12px;color:var(--acc);font-variant-numeric:tabular-nums;white-space:nowrap;text-align:right}
.unit .eta.busy{color:var(--mut)}.unit .eta.on{color:var(--ok)}
.unit .chk{width:18px;text-align:center;color:var(--acc);font-weight:800}
.empty{padding:14px;color:var(--mut);text-align:center;font-size:13px}
#moreRow .morerow{padding:6px 12px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:8px;flex-shrink:0}
.lnk{background:none;border:none;color:var(--acc);font-size:12px;padding:0;cursor:pointer;font-weight:600}
.lnk:hover{text-decoration:underline}.lnk.on{color:var(--ok)}
.heli-btn{color:#9b6ef3}.heli-btn.on{color:var(--ok)}
.dispatch-foot{padding:8px;border-top:1px solid var(--line);flex-shrink:0}
.dispatch-foot .btn{width:100%;padding:12px;font-size:15px;border-radius:10px}

/* LEGENDA — stavy vozidel a typy markerů */
.legend{position:fixed;right:12px;bottom:12px;z-index:500;background:rgba(18,24,38,.95);border:1px solid var(--line);border-radius:10px;padding:9px 14px;font-size:11.5px;color:var(--mut);display:flex;flex-direction:column;gap:5px;min-width:170px}
.legend .lrow{display:flex;align-items:center;gap:7px}
.legend .ltit{font-size:10px;text-transform:uppercase;letter-spacing:.06em;opacity:.6;margin-top:3px;margin-bottom:1px}
/* miniatury vozidel v legendě */
.legend .vi{width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.6);display:inline-flex;align-items:center;justify-content:center;font-size:6px;flex:none}
.legend .vi.prep{background:#7a4500;border-color:#ffb000;border-style:dashed}
.legend .vi.enr{background:#cc1a00;border-color:#ff4422;box-shadow:0 0 4px rgba(255,60,0,.8)}
.legend .vi.scn{background:#fff;border-color:var(--ok);border-width:2.5px}
.legend .vi.trn{background:#2a80c4;border-color:#7bc8ff}
.legend .vi.ret{background:#444;border-color:#666;opacity:.6}
.legend .vi.pat{background:#1a5c3a;border-color:var(--ok)}
.legend .vi.bsy{background:#6b1a1a;border-color:var(--bad);opacity:.8}
/* miniatura diamantu événementy v legendě */
.legend .di{width:12px;height:12px;transform:rotate(45deg);border-radius:2px;display:inline-block;flex:none;border:1.5px solid rgba(255,255,255,.7)}
.legend .di.ev{background:var(--fire)}
.legend .di.fo{background:#4a5568;opacity:.7}

/* Štítky vozidel — jen při zoom >= 14 */
body:not(.zoom-lbl) .veh-lbl,
body:not(.zoom-lbl) .inc-lbl{display:none!important}
.veh-lbl{background:rgba(15,20,32,.88)!important;color:#e7ecf5!important;border:1px solid rgba(255,255,255,.18)!important;border-radius:5px!important;padding:3px 7px!important;font-size:11px!important;font-weight:600!important;white-space:nowrap!important;box-shadow:0 1px 4px rgba(0,0,0,.5)!important;line-height:1.4!important}
.veh-lbl::before{display:none!important}

/* Filtr speciálních složek */
.flt-bar{display:flex;gap:5px;margin:4px 0 6px;flex-wrap:wrap}
.flt-btn{background:var(--panel2);border:1px solid var(--line);color:var(--mut);border-radius:7px;padding:4px 9px;font-size:11.5px;cursor:pointer;transition:.12s}
.flt-btn.on{background:rgba(122,166,255,.15);border-color:var(--acc);color:var(--acc);font-weight:700}
/* Posily */
.di-reinf{font-size:12px;margin-top:7px;background:rgba(255,176,0,.06);border:1px solid rgba(255,176,0,.25);border-radius:7px;padding:6px 9px;display:flex;gap:5px;flex-wrap:wrap;align-items:center}
.lnk.ri{font-size:12px;background:var(--panel2);border:1px solid var(--line);border-radius:7px;padding:3px 8px;color:var(--txt)}
.lnk.ri:hover{border-color:var(--warn);color:var(--warn);text-decoration:none}
/* Seznam složek na místě */
.di-units{margin-top:7px;border-top:1px solid var(--line);padding-top:6px;display:flex;flex-direction:column;gap:3px}
.di-ul{font-size:11.5px;display:flex;gap:5px;flex-wrap:wrap;align-items:baseline}
.diu-hdr{font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
.diu-hdr.ok{color:var(--ok)}.diu-hdr.warn{color:var(--warn)}.diu-hdr.bad{color:var(--bad)}
.diu{background:var(--panel2);border:1px solid var(--line);border-radius:5px;padding:1px 5px;font-size:11px}
.diu.bad{color:var(--bad);border-color:rgba(255,59,92,.3)}
/* Štítky událostí na mapě */
.inc-lbl{background:rgba(10,14,26,.92)!important;border:1px solid rgba(255,255,255,.2)!important;border-radius:6px!important;padding:3px 7px!important;font-size:11px!important;white-space:nowrap!important;box-shadow:0 2px 6px rgba(0,0,0,.6)!important;pointer-events:none!important}
.inc-lbl::before{display:none!important}
.inc-lbl-in{display:flex;gap:5px;align-items:center;flex-wrap:nowrap}

/* MARKERY ZÁKLADEN — bílé pozadí, barevný rámeček + počet dostupných vozidel */
.mk{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-size:13px;border:3px solid;box-shadow:0 2px 7px rgba(0,0,0,.65);background:#fff;position:relative}
.mk.F{border-color:var(--fire)}.mk.P{border-color:var(--police)}.mk.Z{border-color:var(--ems)}
.mk.heli{border-color:#9b6ef3}
/* nemocnice — pouze symbol, bez pozadí */
.mk.hosp{width:22px;height:22px;border:none;background:transparent;font-size:16px;box-shadow:none;opacity:.9;border-radius:0;filter:drop-shadow(0 1px 3px rgba(0,0,0,.7))}
.mk-cnt{position:absolute;bottom:-6px;right:-6px;min-width:16px;height:16px;border-radius:8px;background:var(--ok);color:#000;font-size:9px;font-weight:800;display:grid;place-items:center;padding:0 3px;border:1.5px solid #fff;line-height:1}
.mk-cnt.low{background:var(--warn)}
.mk-cnt.empty{background:var(--bad);color:#fff}

/* VOZIDLA — kruhy, odlišeny stavem */
.veh{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:11px;border:2px solid rgba(255,255,255,.65);box-shadow:0 1px 6px rgba(0,0,0,.5)}
.veh.F{background:var(--fire)}.veh.P{background:var(--police)}.veh.Z{background:var(--ems)}
/* příprava k výjezdu — oranžová přerušovaná */
.veh.prep{background:#7a4500!important;border-color:#ffb000!important;border-style:dashed!important;animation:vprep 1.2s ease-in-out infinite}
@keyframes vprep{0%,100%{opacity:.7}50%{opacity:1}}
/* jede k zásahu — ČERVENÉ pozadí */
.veh.enr{background:#cc1a00!important;border-color:#ff4422!important;box-shadow:0 0 8px rgba(255,59,60,.7)}
/* na místě zásahu — bílé pozadí, zelený okraj */
.veh.scn{background:#fff!important;border-color:var(--ok)!important;border-width:3px!important;color:#111;box-shadow:0 0 8px rgba(52,210,123,.6)}
/* transport pacienta — modrá */
.veh.trn{background:#1e6fa8!important;border-color:#7bc8ff!important;box-shadow:0 0 6px rgba(61,169,252,.5)}
/* návrat na základnu — poloprůhledné přerušované */
.veh.ret{opacity:.55;border-style:dashed}
/* hlídka — volné zelené */
.veh.pat{background:#1a5c3a!important;border-color:var(--ok)!important;box-shadow:0 0 5px rgba(52,210,123,.5)}
/* busy hlídka — ČERNÉ pozadí */
.veh.bsy{background:#111!important;border-color:#444!important;opacity:.75}

/* MÍSTA UDÁLOSTI — DIAMANT (rotovaný čtverec) — ODLIŠNÉ od vehiclů i základen! */
.incpin{display:inline-flex;align-items:center;justify-content:center;filter:drop-shadow(0 3px 7px rgba(0,0,0,.6))}
.incpin .incdot{width:28px;height:28px;border-radius:5px;transform:rotate(45deg);display:flex;align-items:center;justify-content:center;border:2px solid rgba(255,255,255,.85)}
.incpin .inic{transform:rotate(-45deg);font-size:13px;line-height:1;display:block;pointer-events:none}
.incpin.sev1 .incdot{background:var(--warn)}
.incpin.sev2 .incdot{background:var(--fire)}
.incpin.sev3 .incdot{background:var(--bad)}
.incpin.sev3{animation:incglow 1.3s ease-in-out infinite}
.incpin.mci .incdot{width:36px;height:36px;font-size:17px;border-width:3px}
.incpin.mci.sev3{animation:incglow .7s ease-in-out infinite}
.incpin.foreign .incdot{background:#4a5568;border-color:#718096;opacity:.8}
@keyframes incglow{0%,100%{filter:drop-shadow(0 3px 8px rgba(255,59,92,.9))}50%{filter:drop-shadow(0 3px 20px rgba(255,59,92,.1))}}

/* overlays */
.overlay{position:fixed;inset:0;z-index:800;display:grid;place-items:center;background:radial-gradient(900px 500px at 50% 0%,rgba(255,90,60,.12),transparent),rgba(8,11,18,.94);backdrop-filter:blur(4px)}
.dialog{width:min(560px,93vw);background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:28px;box-shadow:var(--shadow);max-height:94vh;overflow:auto}
.dialog h1{margin:0 0 6px;font-size:25px}.dialog h1 span{color:var(--fire)}
.dialog p.sub{margin:0 0 22px;color:var(--mut)}
.field{margin-bottom:15px}
.field>label{display:block;font-size:13px;color:var(--mut);margin-bottom:7px}
.field.row{display:flex;align-items:center;gap:9px}.field.row label{margin:0}
.field.row input{width:18px;height:18px;accent-color:var(--acc)}
.field select,.field input[type=text],.field #nickIn{width:100%;background:var(--bg2);border:1px solid var(--line);color:var(--txt);border-radius:10px;padding:12px;font-size:15px}
#nickIn{width:100%;background:var(--bg2);border:1px solid var(--line);color:var(--txt);border-radius:10px;padding:12px;font-size:15px}
.hint{font-size:12px;color:var(--acc);margin-top:6px}
.note{color:var(--mut);font-size:12.5px;margin:16px 0 0;line-height:1.5}
.seg{display:flex;gap:8px}.seg button{flex:1;background:var(--bg2);border:1px solid var(--line);color:var(--txt);border-radius:10px;padding:11px;font-weight:600}
.seg.big button{padding:14px 8px;font-size:15px}
.seg button.on{background:var(--fire);border-color:var(--fire);color:#fff}
.go-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:18px 0}
.go-stats .s{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:14px}
.go-stats .s b{display:block;font-size:26px}.go-stats .s span{font-size:12px;color:var(--mut)}
.lb{width:100%;border-collapse:collapse;margin-top:8px;font-size:14px}
.lb th,.lb td{text-align:left;padding:7px 8px;border-bottom:1px solid var(--line)}
.lb th{color:var(--mut);font-size:12px;text-transform:uppercase}
.lb td.r{text-align:right;font-variant-numeric:tabular-nums}.lb td.rg{color:var(--mut);font-size:12px}
.toast{position:fixed;top:62px;left:50%;transform:translateX(-50%);z-index:700;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:10px 18px;box-shadow:var(--shadow);opacity:0;transition:opacity .25s;pointer-events:none;font-weight:600;max-width:90vw;text-align:center;white-space:nowrap}
.toast.show{opacity:1}.toast.good{border-color:var(--ok)}.toast.bad{border-color:var(--bad)}

/* ---- NOVÁ VOLÁNÍ — pulzující zvýraznění ---- */
.call.fresh{background:rgba(255,176,0,.07)!important;border-left-color:var(--warn)!important;animation:callflash 1.6s ease-in-out infinite}
.call.fresh.sev3{background:rgba(255,59,92,.1)!important;border-left-color:var(--bad)!important;animation:callflash-urg .9s ease-in-out infinite}
.call.fresh.mci{background:rgba(255,59,92,.13)!important;animation:callflash-urg .7s ease-in-out infinite}
@keyframes callflash{0%,100%{box-shadow:0 0 0 0 rgba(255,176,0,0)}60%{box-shadow:0 0 0 4px rgba(255,176,0,.25)}}
@keyframes callflash-urg{0%,100%{box-shadow:0 0 0 0 rgba(255,59,92,0)}50%{box-shadow:0 0 0 5px rgba(255,59,92,.35)}}

/* ---- NASTAVENÍ ---- */
#settingsPanel{position:fixed;top:58px;right:12px;z-index:700;width:300px;max-height:calc(100vh - 75px);overflow:auto;
  background:rgba(18,24,38,.98);border:1px solid var(--line);border-radius:14px;padding:14px;box-shadow:var(--shadow)}
.sett-row{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid rgba(38,49,77,.5);font-size:13px}
.sett-row:last-child{border-bottom:0}
.sett-row label{color:var(--txt);font-weight:600}
.sett-row.small{font-size:11.5px;color:var(--mut);padding:3px 0;border-bottom:0}
.sett-row.small b{color:var(--txt)}
.sett-hint{font-size:11px;color:var(--mut)}
.sett-sep{height:1px;background:var(--line);margin:8px 0}
.sett-toggle{position:relative;display:inline-block;width:40px;height:22px;flex:none}
.sett-toggle input{opacity:0;width:0;height:0}
.sett-toggle span{position:absolute;inset:0;background:var(--panel2);border:1px solid var(--line);border-radius:11px;transition:.2s;cursor:pointer}
.sett-toggle span::before{content:'';position:absolute;left:3px;top:3px;width:14px;height:14px;background:var(--mut);border-radius:50%;transition:.2s}
.sett-toggle input:checked+span{background:var(--ok);border-color:var(--ok)}
.sett-toggle input:checked+span::before{transform:translateX(18px);background:#fff}
.sett-row input[type=range]{width:110px;accent-color:var(--acc)}

/* ═══════════════ RESPONZIVITA ═══════════════ */

/* Tablet landscape + malý desktop (901–1200px) */
@media(max-width:1200px){
  #calls{width:270px}
  #dispatch{left:282px;width:320px}
}

/* Tablet portrait (601–900px) */
@media(max-width:900px){
  .topbar{gap:8px;padding:0 10px}
  .metric{gap:1px}
  .metric .v{font-size:15px}
  #calls{width:240px;left:8px}
  #dispatch{left:252px;width:calc(100vw - 264px);max-height:calc(100vh - 80px)}
  .legend{padding:6px 10px;font-size:10.5px;min-width:140px}
}

/* Telefon — výchozí landscape orientace (481–700px) */
@media(max-width:700px){
  /* Topbar — kompaktní */
  .topbar{gap:6px;padding:0 8px;height:50px}
  .brand{font-size:16px}
  .metric .v{font-size:14px}
  .metric .k{font-size:9px}
  .tbtn{padding:6px 10px;font-size:13px}
  .m-hide{display:none!important}

  /* Volání — plovoucí panel, pevně vlevo nahoře */
  #calls{
    top:58px;left:0;right:0;width:100%;border-radius:0;
    max-height:38vh;border-left:none;border-right:none;border-top:none;
    border-radius:0 0 14px 14px;
  }
  #calls.collapsed #callList{display:none}
  #calls.collapsed{max-height:none}
  #callsToggle{margin-left:auto}

  /* Výjezd — bottom sheet */
  #dispatch{
    top:auto;bottom:0;left:0;right:0;width:100%;
    border-radius:18px 18px 0 0;max-height:70vh;
    border-bottom:none;border-left:none;border-right:none;
  }
  #dispatch h2{padding:12px 14px 10px}
  #unitList{max-height:35vh}

  /* Nastavení — bottom sheet */
  #settingsPanel{right:0;left:0;width:100%;border-radius:14px 14px 0 0;top:auto;bottom:0;max-height:80vh}

  /* Legenda — skryta na mobilu */
  .legend{display:none}

  /* Větší touch targety */
  .unit{padding:10px 12px;min-height:52px}
  .call{padding:10px 12px}
  .trans-btn{padding:10px 12px;min-height:44px}
  .flt-btn{padding:6px 12px;font-size:12px}
  .lnk{font-size:13px;padding:4px 2px}
  #moreRow .morerow{gap:12px;padding:8px 12px}

  /* Toast výše aby nepřekrýval panel */
  .toast{top:56px}
}

/* Telefon — portrait orientace (≤ 480px) */
@media(max-width:480px){
  .topbar{gap:5px;padding:0 6px}
  .brand{display:none}
  #hudSvc{order:-1}
  #calls{max-height:42vh}
  #dispatch{max-height:75vh}
  #unitList{max-height:40vh}
  .metric .v{font-size:13px}

  /* Dispatch panel — užší padding */
  #dispInfo{padding:8px 10px}
  .di-h{font-size:14px}
  #unitList{padding:6px}
  .dispatch-foot{padding:6px}
  .dispatch-foot .btn{padding:10px;font-size:14px}

  /* Výzvy — menší */
  .call{padding:8px 10px}
  .call .t{font-size:12.5px}
  .call .m,.call .m2{font-size:10.5px}
  .tags{gap:3px}
  .tag{font-size:10px;padding:2px 5px}
}

/* Zajistit aby mapa byla vždy dotykova */
#map{touch-action:manipulation}

/* Pull handle pro bottom sheety */
@media(max-width:700px){
  #dispatch::before,#calls::before{
    content:'';display:block;width:40px;height:4px;background:rgba(255,255,255,.18);
    border-radius:2px;margin:8px auto 0;
  }
}
