*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-dark: #0a0e17;--bg-card: #111827;--bg-card-hover: #1a2235;--border: #1e2a3d;--text: #e2e8f0;--text-dim: #64748b;--accent: #ef4444;--accent-glow: rgba(239, 68, 68, .3);--blue: #3b82f6;--blue-glow: rgba(59, 130, 246, .3);--green: #22c55e;--yellow: #eab308;--purple: #a855f7;--font: "Segoe UI", system-ui, -apple-system, sans-serif;--font-mono: "Fira Code", "SF Mono", "Consolas", monospace;--sidebar-width: 240px}html,body,#root{height:100%;overflow:hidden}body{font-family:var(--font);background:var(--bg-dark);color:var(--text);-webkit-font-smoothing:antialiased}.app{height:100vh;display:flex;flex-direction:column}.screen-transition{animation:screenIn .35s cubic-bezier(.22,1,.36,1);height:100%;width:100%}@keyframes screenIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.splash-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:var(--bg-dark);display:flex;flex-direction:column;align-items:center;justify-content:center;animation:fadeIn .3s ease}.splash-logo{font-size:72px;margin-bottom:12px;animation:splashBounce 2s ease-in-out infinite;filter:drop-shadow(0 0 20px rgba(239,68,68,.3))}.splash-title{font-size:36px;font-weight:900;letter-spacing:6px;color:var(--text);text-transform:uppercase;margin-bottom:8px;text-shadow:0 0 40px var(--accent-glow);animation:titleGlow 3s ease-in-out infinite}.splash-sub{color:var(--text-dim);font-size:14px;margin-bottom:20px}.splash-dots{display:flex;gap:8px}.splash-dots span{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:dotPulse 1.4s ease-in-out infinite}.splash-dots span:nth-child(2){animation-delay:.2s}.splash-dots span:nth-child(3){animation-delay:.4s}@keyframes splashBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes titleGlow{0%,to{text-shadow:0 0 40px var(--accent-glow)}50%{text-shadow:0 0 60px var(--accent-glow),0 0 80px rgba(239,68,68,.15)}}@keyframes dotPulse{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.game-loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#0a0e17f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease}.game-loading-card{text-align:center;padding:40px}.game-loading-icon{font-size:56px;margin-bottom:16px;animation:splashBounce 2s ease-in-out infinite}.game-loading-card h2{color:var(--text);font-size:22px;margin-bottom:20px}.loading-steps{display:flex;flex-direction:column;gap:12px;text-align:left;margin:0 auto 24px;max-width:260px}.loading-step{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text-dim);transition:color .4s}.loading-step.active{color:var(--text)}.loading-step-dot{width:10px;height:10px;border-radius:50%;background:var(--border);flex-shrink:0;transition:all .4s}.loading-step.active .loading-step-dot{background:var(--accent);box-shadow:0 0 8px var(--accent-glow);animation:dotPulse 1.4s ease-in-out infinite}.loading-step.done .loading-step-dot{background:var(--green)}.loading-step.done{color:var(--green)}.loading-step:nth-child(1){animation:stepReveal .3s ease forwards}.loading-step:nth-child(2){animation:stepReveal .3s ease 1.5s forwards;opacity:.4}.loading-step:nth-child(3){animation:stepReveal .3s ease 3s forwards;opacity:.4}.loading-step:nth-child(4){animation:stepReveal .3s ease 4.5s forwards;opacity:.4}@keyframes stepReveal{to{opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.home-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 20px;background:radial-gradient(ellipse at 20% 50%,rgba(239,68,68,.08) 0%,transparent 60%),radial-gradient(ellipse at 80% 50%,rgba(59,130,246,.06) 0%,transparent 60%),var(--bg-dark);position:relative;overflow:hidden}.home-screen:before{content:"";position:absolute;top:-50%;right:-50%;bottom:-50%;left:-50%;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:60px 60px;animation:gridDrift 20s linear infinite;pointer-events:none}@keyframes gridDrift{0%{transform:translate(0) rotate(0)}to{transform:translate(60px,60px) rotate(1deg)}}.home-container{width:100%;max-width:900px}.home-container-narrow{max-width:440px}.home-header{text-align:center;margin-bottom:32px;animation:fadeIn .5s ease}.home-title{font-size:48px;font-weight:800;letter-spacing:6px;color:#fff;text-shadow:0 0 40px var(--accent-glow);animation:titleGlow 3s ease-in-out infinite}.title-icon{display:block;font-size:56px;margin-bottom:8px;animation:splashBounce 3s ease-in-out infinite;filter:drop-shadow(0 0 15px var(--accent-glow))}.home-subtitle{color:var(--text-dim);font-size:15px;margin-top:8px;letter-spacing:1px;animation:taglineFade .6s ease}@keyframes taglineFade{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.tab-buttons{display:flex;gap:4px;background:var(--bg-card);border-radius:8px;padding:4px;margin-bottom:20px;max-width:400px;margin-left:auto;margin-right:auto}.tab-btn{flex:1;padding:10px;border:none;border-radius:6px;background:transparent;color:var(--text-dim);font-size:14px;font-weight:600;cursor:pointer;transition:all .25s ease;font-family:var(--font)}.tab-btn:hover:not(.active){background:#ffffff0d;color:var(--text)}.tab-btn.active{background:var(--accent);color:#fff;box-shadow:0 0 12px var(--accent-glow)}.home-form{display:flex;flex-direction:column;gap:16px;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.create-layout{display:grid;grid-template-columns:1.3fr 1fr;gap:28px;align-items:start}.create-left,.create-right{display:flex;flex-direction:column;gap:16px}.join-layout{display:flex;flex-direction:column;gap:16px;max-width:400px;margin:0 auto}.input-group{display:flex;flex-direction:column;gap:6px}.input-group label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim)}.input-group input{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:12px 14px;font-size:16px;color:var(--text);font-family:var(--font);outline:none;transition:border-color .2s}.input-group input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.code-input{font-family:var(--font-mono)!important;font-size:24px!important;text-align:center;letter-spacing:8px}.option-cards{display:flex;gap:8px}.option-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 10px;background:var(--bg-card);border:2px solid var(--border);border-radius:10px;color:var(--text);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;font-family:var(--font)}.option-card:hover{background:var(--bg-card-hover);border-color:#2a3a52}.option-card.selected{border-color:var(--accent);background:#ef44441a}.option-emoji{font-size:24px}.btn-primary{padding:14px 24px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s cubic-bezier(.22,1,.36,1);font-family:var(--font);text-transform:uppercase;letter-spacing:1px;position:relative;overflow:hidden}.btn-primary:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 60%);opacity:0;transition:opacity .2s}.btn-primary:hover:not(:disabled):after{opacity:1}.btn-primary:hover:not(:disabled){background:#dc2626;box-shadow:0 0 20px var(--accent-glow);transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:scale(.96) translateY(0)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{padding:10px 20px;background:transparent;color:var(--text-dim);border:1px solid var(--border);border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s cubic-bezier(.22,1,.36,1);font-family:var(--font)}.btn-secondary:hover{background:var(--bg-card);color:var(--text);border-color:var(--text-dim);transform:translateY(-1px)}.btn-secondary:active{transform:scale(.96) translateY(0)}.error-msg{background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:10px 14px;font-size:14px;color:#fca5a5}.lobby-screen{min-height:100vh;display:flex;align-items:flex-start;justify-content:center;background:var(--bg-dark);padding:20px;overflow-y:auto}.lobby-container{width:100%;max-width:740px;padding:0 20px;animation:fadeIn .4s ease}.lobby-container-wide{max-width:1100px}.lobby-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.lobby-header h2{font-size:28px;font-weight:700}.lobby-code-display{display:flex;align-items:center;gap:8px}.code-label{font-size:12px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px}.code-value{font-family:var(--font-mono);font-size:22px;font-weight:700;color:var(--accent);letter-spacing:3px}.lobby-body{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}.lobby-body-3col{grid-template-columns:1.2fr 1fr 1fr}.lobby-col-map,.lobby-col-center,.lobby-col-left,.lobby-col-right{display:flex;flex-direction:column;gap:16px;overflow-y:auto;max-height:85vh;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.lobby-col-map::-webkit-scrollbar{width:6px}.lobby-col-map::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.lobby-map-info{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:16px;font-size:14px;color:var(--text);line-height:1.6}.lobby-map-info.dim{color:var(--text-dim);font-style:italic}.lobby-settings{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:16px}.setting-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.setting-row+.setting-row{border-top:1px solid var(--border);padding-top:8px;margin-top:4px}.setting-label{color:var(--text-dim);font-size:14px}.setting-value{font-weight:600;font-size:14px}.lobby-players h3{font-size:14px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);margin-bottom:12px}.player-list{display:flex;flex-direction:column;gap:6px}.player-item{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;font-size:15px;animation:playerJoin .35s cubic-bezier(.22,1,.36,1);transition:all .2s ease}.player-item.is-me{border-color:var(--blue);background:#3b82f614}.player-item.empty{opacity:.3;animation:none}.player-icon{font-size:20px}.player-name{font-weight:500}.me-tag{color:var(--blue);font-size:12px;margin-left:6px}.lobby-actions{display:flex;flex-direction:column;gap:10px}.btn-start{width:100%}.waiting-msg{text-align:center;padding:14px;color:var(--text-dim);font-size:15px}.lobby-hint{text-align:center;font-size:13px;color:var(--text-dim)}.lobby-hint strong{color:var(--accent);font-family:var(--font-mono);letter-spacing:2px}.role-label{display:block;font-size:13px;color:#9ca3af;margin-bottom:8px}.role-buttons{display:flex;gap:8px;flex-wrap:wrap}.role-btn{padding:8px 14px;border-radius:8px;border:2px solid #374151;background:#1e1e28cc;color:#d1d5db;font-size:14px;cursor:pointer;transition:all .2s}.role-btn:hover{border-color:#6b7280}.role-btn.active.fugitive{border-color:#ef4444;background:#ef444426;color:#fca5a5}.role-btn.active.hunter{border-color:#3b82f6;background:#3b82f626;color:#93c5fd}.role-btn.active.random{border-color:#a855f7;background:#a855f726;color:#c4b5fd}.btn-ready{padding:10px 28px;border-radius:10px;border:2px solid #374151;background:#1e1e28cc;color:#9ca3af;font-size:16px;cursor:pointer;transition:all .2s;width:100%}.btn-ready:hover{border-color:#22c55e}.btn-ready.is-ready{border-color:#22c55e;background:#22c55e26;color:#86efac}.player-role-badge{margin-left:auto;font-size:12px;color:#9ca3af;white-space:nowrap}.player-ready-badge{font-size:16px;width:24px;text-align:center;transition:transform .2s}.player-ready-badge.ready{animation:readyPulse 2s ease-in-out infinite}.lobby-link{color:#60a5fa;cursor:pointer;word-break:break-all;text-decoration:underline;text-decoration-style:dotted}.lobby-link:hover{color:#93c5fd}.lobby-link:active{color:#22c55e}.lobby-header-right{display:flex;align-items:center;gap:12px}.lobby-public-toggle{background:#ffffff0f;border:1px solid rgba(255,255,255,.15);color:var(--text-dim);padding:4px 10px;border-radius:6px;font-size:12px;cursor:pointer;white-space:nowrap}.lobby-public-toggle:hover{background:#ffffff1a}.lobby-public-toggle.active{background:#22c55e26;border-color:#22c55e66;color:#22c55e}.lobby-public-badge{font-size:12px;color:#22c55e;white-space:nowrap}.tab-buttons-3 .tab-btn{flex:1;font-size:13px}.tab-buttons-4 .tab-btn{flex:1;font-size:12px;padding:8px 6px}.lobby-browser{display:flex;flex-direction:column;gap:8px;max-height:320px;overflow-y:auto}.browse-empty{text-align:center;padding:24px 12px;color:var(--text-dim);font-size:14px}.browse-lobby{display:flex;align-items:center;justify-content:space-between;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:10px 14px;gap:12px;transition:all .2s cubic-bezier(.22,1,.36,1);animation:slideUp .3s ease backwards}.browse-lobby:nth-child(1){animation-delay:0s}.browse-lobby:nth-child(2){animation-delay:.05s}.browse-lobby:nth-child(3){animation-delay:.1s}.browse-lobby:nth-child(4){animation-delay:.15s}.browse-lobby:nth-child(5){animation-delay:.2s}.browse-lobby:hover{background:#ffffff12;border-color:#ffffff26;transform:translateY(-1px);box-shadow:0 4px 12px #0003}.browse-lobby-info{flex:1;min-width:0}.browse-lobby-host{font-size:14px;font-weight:600;color:var(--text-main);display:flex;align-items:center;gap:8px}.browse-lobby-code{font-family:var(--font-mono);font-size:11px;color:var(--text-dim);background:#ffffff0f;padding:1px 5px;border-radius:3px;font-weight:400}.browse-lobby-meta{display:flex;gap:10px;font-size:12px;color:var(--text-dim);margin-top:3px}.btn-browse-join{background:var(--accent);color:#fff;border:none;padding:6px 14px;border-radius:6px;font-size:13px;cursor:pointer;white-space:nowrap;font-weight:600}.btn-browse-join:hover:not(:disabled){filter:brightness(1.15)}.btn-browse-join:disabled{opacity:.4;cursor:not-allowed}.browse-hint{text-align:center;font-size:11px;color:var(--text-dim);opacity:.6;padding-top:4px}.gs-panel{margin-top:12px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;overflow:visible}.gs-panel-head{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;font-size:13px;font-weight:600;color:var(--text-dim);border-bottom:1px solid rgba(255,255,255,.06)}.gs-reset-all{background:none;border:none;color:#f97316;font-size:11px;cursor:pointer;padding:2px 6px;border-radius:4px}.gs-reset-all:hover{background:#f9731626}.gs-group{border-bottom:1px solid rgba(255,255,255,.04)}.gs-group:last-child{border-bottom:none}.gs-group-toggle{width:100%;display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:none;border:none;color:var(--text-main);font-size:13px;cursor:pointer;text-align:left}.gs-group-toggle:hover{background:#ffffff0a}.gs-chevron{color:var(--text-dim);font-size:11px}.gs-dot{color:#f97316;margin-left:4px;font-size:10px}.gs-group-body{padding:6px 12px 12px}.gs-slider{margin-bottom:8px}.gs-slider:last-child{margin-bottom:0}.gs-slider-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}.gs-slider-label{font-size:12px;color:var(--text-dim)}.gs-slider-val{font-size:12px;color:var(--text-main);font-family:var(--font-mono);display:flex;align-items:center;gap:4px}.gs-slider-val.changed{color:#f97316;font-weight:600}.gs-reset-btn{background:none;border:none;color:#f97316;font-size:13px;cursor:pointer;padding:0 2px;line-height:1}.gs-reset-btn:hover{color:#fb923c}.gs-range{width:100%;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff1f;border-radius:2px;outline:none;cursor:pointer}.gs-range::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--bg-dark)}.gs-range::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--bg-dark)}.gs-summary{margin-top:12px;background:#f9731614;border:1px solid rgba(249,115,22,.2);border-radius:8px;padding:8px 12px}.gs-summary-title{font-size:12px;font-weight:600;color:#f97316;margin-bottom:6px}.gs-summary-row{display:flex;justify-content:space-between;font-size:12px;color:var(--text-dim);padding:2px 0}.game-screen{height:100vh;display:flex;position:relative;overflow:hidden}.sidebar{width:var(--sidebar-width);flex-shrink:0;background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:10;overflow-y:auto}.sidebar-right{border-right:none;border-left:1px solid var(--border)}.sidebar-section{padding:14px 16px;border-bottom:1px solid var(--border)}.sidebar-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);margin-bottom:8px}.sidebar-role{font-size:16px;font-weight:700}.fugitive-counter{font-size:12px;color:#9ca3af;margin-top:2px}.ticket-grid{display:flex;gap:10px;flex-wrap:wrap}.ticket-item{font-size:14px;font-weight:600;white-space:nowrap}.transport-buttons{display:flex;gap:6px}.transport-btn{width:44px;height:44px;border-radius:10px;border:2px solid var(--border);background:#111827d9;font-size:20px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.transport-btn:hover:not(:disabled){border-color:#4a5568;background:#1e2a3de6}.transport-btn:disabled{opacity:.3;cursor:not-allowed}.transport-btn.bus.active{border-color:var(--green);background:#22c55e26;box-shadow:0 0 12px #22c55e4d}.transport-btn.taxi.active{border-color:var(--yellow);background:#eab30826;box-shadow:0 0 12px #eab3084d}.transport-btn.ubahn.active{border-color:var(--purple);background:#a855f726;box-shadow:0 0 12px #a855f74d}.transport-btn.polizei.active{border-color:var(--blue);background:#3b82f626;box-shadow:0 0 12px #3b82f64d}.transport-btn.barricade.active{border-color:#ef4444;background:#ef444426;box-shadow:0 0 12px #ef44444d}.footprint-legend{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-dim)}.footprint-legend-item{display:flex;align-items:center;gap:6px}.footprint-legend-item.dim{color:var(--text-dim);font-size:11px}.fp-dot{width:8px;height:8px;border-radius:50%}.fp-dot.walk{background:#9ca3af}.fp-dot.run{background:#f97316}.fp-dot.bus{background:#22c55e}.fp-dot.taxi{background:#eab308}.move-hint{font-size:11px;color:var(--text-dim);line-height:1.6}.sidebar-controls{margin-top:auto}.clue-title{color:var(--purple)!important}.clue-list{display:flex;flex-direction:column;gap:2px}.clue-entry{font-size:13px;font-weight:500;padding:3px 0;display:flex;align-items:center;gap:6px}.clue-time{font-size:11px;color:var(--text-dim);margin-left:auto}.sidebar-chat{flex:1;display:flex;flex-direction:column;min-height:200px}.sidebar-chat .chat-panel{position:static;width:100%;max-height:none;flex:1;border:none;border-radius:0;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;display:flex;flex-direction:column}.sidebar-chat .chat-messages{flex:1;min-height:0;max-height:none}.game-center{flex:1;position:relative;overflow:hidden}.game-map{height:100%;width:100%;z-index:1}.emoji-icon{background:none!important;border:none!important;pointer-events:none!important}.emoji-icon.interactive{pointer-events:auto!important;cursor:pointer}.fp-arrow-icon{background:none!important;border:none!important;pointer-events:none!important}.leaflet-tooltip{background:#0f141ee6!important;border:1px solid #1e2a3d!important;color:#e2e8f0!important;font-family:var(--font)!important;font-size:12px!important;padding:4px 8px!important;border-radius:4px!important}.leaflet-tooltip-top:before{border-top-color:#0f141ee6!important}.leaflet-tooltip-bottom:before{border-bottom-color:#0f141ee6!important}.leaflet-tooltip-left:before{border-left-color:#0f141ee6!important}.leaflet-tooltip-right:before{border-right-color:#0f141ee6!important}.hud-top{position:absolute;top:0;left:0;right:0;display:flex;justify-content:center;align-items:center;gap:24px;padding:12px 20px;background:linear-gradient(to bottom,rgba(10,14,23,.9),transparent);z-index:1000;pointer-events:none}.headstart-timer{font-size:13px;color:var(--yellow);font-weight:600;text-transform:uppercase;letter-spacing:1px;animation:pulse 1s ease infinite}.main-timer{font-family:var(--font-mono);font-size:32px;font-weight:700;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5)}.hud-mode{font-size:14px;padding:6px 14px;background:#111827d9;border-radius:20px;border:1px solid var(--border);color:var(--text-dim);pointer-events:auto}.hud-sound-toggle{font-size:16px;padding:4px 10px;background:#111827d9;border-radius:20px;border:1px solid var(--border);color:var(--text-dim);cursor:pointer;pointer-events:auto;transition:all .2s}.hud-sound-toggle:hover{border-color:#4a5568}.stamina-bar-container{position:absolute;top:56px;left:50%;transform:translate(-50%);width:200px;height:6px;background:#0009;border-radius:3px;z-index:1001;overflow:hidden;border:1px solid rgba(255,255,255,.15)}.stamina-bar-fill{height:100%;background:#22c55e;border-radius:3px;transition:width .1s linear}.stamina-bar-fill.low{background:#f97316}.stamina-bar-fill.critical{background:#ef4444}.transport-clue-flash,.transport-error{position:absolute;top:70px;left:50%;transform:translate(-50%);z-index:1000;padding:10px 24px;border-radius:8px;font-weight:700;font-size:16px;animation:flashIn .3s ease}.transport-clue-flash{background:#a855f7e6;color:#fff;box-shadow:0 0 30px #a855f766;top:110px}.transport-error{background:#ef4444d9;color:#fff;font-size:14px;font-weight:600;top:110px}.cell-ping-warning{position:absolute;top:140px;left:50%;transform:translate(-50%);z-index:1000;background:#f59e0be6;color:#000;font-weight:700;font-size:14px;padding:8px 20px;border-radius:8px;white-space:nowrap;box-shadow:0 0 30px #f59e0b80;animation:cellPingPulse 1s ease-in-out infinite}@keyframes cellPingPulse{0%,to{opacity:1;transform:translate(-50%) scale(1)}50%{opacity:.7;transform:translate(-50%) scale(1.03)}}@keyframes flashIn{0%{opacity:0;transform:translate(-50%) scale(.8)}to{opacity:1;transform:translate(-50%) scale(1)}}.transport-mode-active{position:absolute;top:70px;left:50%;transform:translate(-50%);z-index:1000;display:flex;align-items:center;gap:10px;padding:10px 20px;border-radius:10px;background:#111827f2;border:1px solid var(--purple);color:#fff;font-size:14px;font-weight:600;box-shadow:0 4px 20px #0006;animation:flashIn .2s ease;white-space:nowrap}.transport-cancel{background:#ef44444d;border:none;color:#fca5a5;width:24px;height:24px;border-radius:50%;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.transport-cancel:hover{background:#ef444499}.ubahn-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1500;background:#0a0e17b3;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .3s ease}.ubahn-card{text-align:center;padding:32px 48px;background:var(--bg-card);border:1px solid var(--purple);border-radius:16px;box-shadow:0 0 40px #a855f733;font-size:48px}.ubahn-text{font-size:18px;font-weight:600;margin-top:12px;color:var(--text)}.ubahn-spinner{width:32px;height:32px;margin:16px auto 0;border:3px solid var(--border);border-top-color:var(--purple);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.caught-flash{position:absolute;top:70px;left:50%;transform:translate(-50%);padding:10px 24px;border-radius:10px;background:#ef4444e6;color:#fff;font-size:16px;font-weight:700;z-index:1001;animation:flashSlideIn .4s cubic-bezier(.22,1,.36,1)}@keyframes flashSlideIn{0%{transform:translate(-50%) translateY(-20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.caught-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1502;display:flex;align-items:center;justify-content:center;background:#00000080;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .3s ease}.caught-card{text-align:center;padding:32px 48px;background:#140a0af2;border:2px solid #ef4444;border-radius:20px;box-shadow:0 0 60px #ef44444d;animation:caughtPop .4s cubic-bezier(.34,1.56,.64,1)}.caught-icon{font-size:56px;margin-bottom:8px;animation:caughtShake .5s ease}.catch-vignette{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1500;pointer-events:none;background:radial-gradient(ellipse at center,transparent 40%,rgba(239,68,68,.4) 100%);animation:vignetteFlash 1.5s ease-out forwards}@keyframes vignetteFlash{0%{opacity:0}15%{opacity:1}to{opacity:0}}.game-screen.shake{animation:screenShake .4s ease}@keyframes screenShake{0%,to{transform:translate(0)}10%{transform:translate(-4px,2px)}20%{transform:translate(4px,-2px)}30%{transform:translate(-3px,-3px)}40%{transform:translate(3px,3px)}50%{transform:translate(-2px,1px)}60%{transform:translate(2px,-1px)}70%{transform:translate(-1px,2px)}80%{transform:translate(1px,-1px)}}.caught-text{font-size:28px;font-weight:900;color:#fca5a5;letter-spacing:2px}@keyframes caughtPop{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}@keyframes caughtShake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.chat-panel{display:flex;flex-direction:column;background:#111827f2;border:1px solid var(--border);border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid var(--border);font-weight:600;font-size:14px}.chat-close{background:none;border:none;color:var(--text-dim);font-size:16px;cursor:pointer;padding:2px 6px}.chat-messages{flex:1;min-height:120px;max-height:280px;overflow-y:auto;padding:10px 14px}.chat-empty{color:var(--text-dim);font-size:13px;text-align:center;padding:20px 0}.chat-msg{margin-bottom:6px;font-size:13px;line-height:1.4}.chat-author{color:var(--blue);font-weight:600;margin-right:6px}.chat-text{color:var(--text)}.chat-input{display:flex;gap:6px;padding:8px;border-top:1px solid var(--border)}.chat-input input{flex:1;background:var(--bg-dark);border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:13px;color:var(--text);outline:none;font-family:var(--font)}.chat-input input:focus{border-color:var(--blue)}.chat-input button{background:var(--blue);border:none;border-radius:6px;color:#fff;padding:8px 12px;font-size:14px;cursor:pointer;font-weight:700}.game-over-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0e17d9;z-index:2000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.game-over-card{text-align:center;padding:32px 48px;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;box-shadow:0 0 80px #0009;animation:goSlideUp .5s cubic-bezier(.34,1.56,.64,1);max-width:400px;width:90%;position:relative;overflow:hidden}.game-over-card.victory{border-color:#22c55e4d;box-shadow:0 0 80px #22c55e26}.game-over-card.defeat{border-color:#ef444433}@keyframes goSlideUp{0%{transform:translateY(40px) scale(.9);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.go-result{margin-bottom:20px}.go-icon{font-size:56px;margin-bottom:8px}.go-result.victory .go-icon{animation:victoryBounce .6s ease}.go-result.defeat .go-icon{animation:defeatShake .5s ease}.go-result h2{font-size:32px;color:var(--text)}.go-result.victory h2{color:var(--green);text-shadow:0 0 30px rgba(34,197,94,.3)}.go-result.defeat h2{color:var(--accent)}.go-detail{margin-bottom:24px}.go-winner{font-size:16px;color:var(--text);font-weight:600;margin-bottom:4px}.go-reason{font-size:14px;color:var(--text-dim)}.go-buttons{display:flex;flex-direction:column;gap:10px;align-items:center}.go-buttons .btn-primary,.go-buttons .btn-replay{min-width:200px}@keyframes victoryBounce{0%{transform:scale(0)}50%{transform:scale(1.3)}to{transform:scale(1)}}@keyframes defeatShake{0%,to{transform:rotate(0)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}.confetti-container{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:1}.confetti-piece{position:absolute;top:-20px;width:10px;height:10px;opacity:.9;border-radius:2px;animation:confettiFall linear forwards}@keyframes confettiFall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(500px) rotate(720deg);opacity:0}}.game-toast{position:absolute;top:70px;left:50%;z-index:1500;transform:translate(-50%);pointer-events:none;display:flex;flex-direction:column;gap:6px;align-items:center}.toast-item{padding:8px 18px;border-radius:8px;font-size:13px;font-weight:600;white-space:nowrap;box-shadow:0 4px 20px #0006;animation:toastIn .3s cubic-bezier(.22,1,.36,1),toastOut .3s ease 2.7s forwards}.toast-item.info{background:#3b82f6e6;color:#fff}.toast-item.warn{background:#eab308e6;color:#000}.toast-item.danger{background:#ef4444e6;color:#fff}.toast-item.success{background:#22c55ee6;color:#fff}@keyframes toastIn{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes toastOut{0%{opacity:1}to{opacity:0;transform:translateY(-10px)}}.headstart-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1500;display:flex;align-items:center;justify-content:center;background:#00000080;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);pointer-events:none;animation:fadeIn .3s ease}.headstart-countdown{text-align:center}.headstart-num{font-size:120px;font-weight:900;color:#fff;text-shadow:0 0 60px rgba(255,255,255,.4),0 0 120px rgba(239,68,68,.2);animation:countPop 1s cubic-bezier(.22,1,.36,1) infinite;line-height:1}.headstart-num.go-text{font-size:80px;color:var(--green);text-shadow:0 0 60px rgba(34,197,94,.5);animation:goFlash .6s ease}.headstart-label{font-size:20px;font-weight:700;color:#fffc;text-shadow:0 2px 8px rgba(0,0,0,.5);margin-top:12px;letter-spacing:2px;text-transform:uppercase}.headstart-role-hint{font-size:14px;color:#ffffff80;margin-top:8px}@keyframes countPop{0%{transform:scale(1.3);opacity:0}15%{transform:scale(1);opacity:1}85%{transform:scale(1);opacity:1}to{transform:scale(.8);opacity:0}}@keyframes goFlash{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2);opacity:1}to{transform:scale(1);opacity:1}}.tutorial-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;background:#0a0e17d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease}.tutorial-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;max-width:420px;width:90%;max-height:80vh;overflow-y:auto;animation:goSlideUp .3s ease}.tutorial-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border);font-size:18px;font-weight:700}.tutorial-close{background:none;border:none;color:var(--text-dim);font-size:20px;cursor:pointer;padding:4px 8px;border-radius:6px}.tutorial-close:hover{background:#ffffff1a}.tutorial-body{padding:16px 20px}.tutorial-section{margin-bottom:16px}.tutorial-section:last-child{margin-bottom:0}.tutorial-section h3{font-size:15px;color:var(--text);margin-bottom:4px}.tutorial-section p{font-size:13px;color:var(--text-dim);line-height:1.5}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#2a3a52}.witness-response{position:absolute;top:80px;left:50%;transform:translate(-50%);z-index:1500;background:#0f141ef2;border:1px solid #eab308;border-radius:12px;padding:12px 16px;min-width:240px;max-width:320px;box-shadow:0 4px 20px #eab30833;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.witness-response-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.witness-emoji{font-size:24px}.witness-name{font-weight:700;font-size:14px;color:#eab308;flex:1}.witness-close{background:none;border:none;color:var(--text-dim);font-size:14px;cursor:pointer;padding:2px 6px}.witness-message{font-size:14px;color:var(--text);font-style:italic;line-height:1.5;padding:6px 0;border-top:1px solid rgba(234,179,8,.2)}.witness-direction{font-size:13px;color:#22c55e;margin-top:4px;font-weight:600}.witness-icon{background:none!important;border:none!important;pointer-events:auto!important}.witness-icon div{cursor:pointer;transition:transform .15s ease}.witness-icon div:hover{transform:scale(1.15)}.map-picker{margin:8px 0}.map-search{display:flex;gap:6px;margin-bottom:8px}.map-search-input{flex:1;padding:8px 12px;border-radius:8px;border:1px solid #374151;background:#14141ecc;color:#e5e7eb;font-size:14px}.map-search-btn{padding:8px 12px;border-radius:8px;border:1px solid #374151;background:#1e1e28cc;color:#e5e7eb;cursor:pointer;font-size:16px}.map-search-btn:hover{border-color:#6b7280}.map-presets-container{margin-bottom:8px}.map-country-tabs{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px}.map-country-tab{padding:4px 10px;border-radius:6px;border:1px solid var(--border);background:var(--bg-dark);color:var(--text-dim);font-size:12px;cursor:pointer;transition:all .15s;font-family:var(--font)}.map-country-tab:hover{border-color:#4a5568}.map-country-tab.active{border-color:var(--blue);background:#3b82f626;color:var(--text)}.map-presets{display:flex;flex-wrap:wrap;gap:6px}.map-preset-hint{font-size:11px;color:var(--text-dim);margin-top:4px}.map-preset-btn{padding:5px 10px;border-radius:6px;border:1px solid #374151;background:#14141ecc;color:#9ca3af;cursor:pointer;font-size:12px;transition:all .2s}.map-preset-btn:hover{border-color:#6b7280;color:#e5e7eb}.map-preset-btn.active{border-color:#3b82f6;background:#3b82f626;color:#93c5fd}.map-picker-container{border-radius:12px;overflow:hidden;border:1px solid #374151}.picker-map{height:380px;width:100%;background:#1a1a2e}.radius-control{margin-top:10px}.radius-control label{display:block;font-size:13px;color:#9ca3af;margin-bottom:4px}.radius-slider{width:100%;accent-color:#3b82f6}.radius-labels{display:flex;justify-content:space-between;font-size:11px;color:#6b7280}.map-picker-hint{text-align:center;color:#6b7280;font-size:13px;margin-top:8px}.osrm-badge{margin-top:8px;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;text-align:center}.osrm-badge.covered{background:#22c55e1f;color:#4ade80;border:1px solid rgba(34,197,94,.25)}.osrm-badge.uncovered{background:#eab3081f;color:#facc15;border:1px solid rgba(234,179,8,.25)}.replay-screen{height:100vh;display:flex;flex-direction:column;background:var(--bg-dark)}.replay-loading{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-dim);font-size:16px}.replay-map-container{flex:1;position:relative}.replay-map-container .game-map{height:100%;width:100%}.replay-controls{background:var(--bg-card);border-top:1px solid var(--border);padding:12px 20px;display:flex;flex-direction:column;gap:8px}.replay-controls-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.replay-btn{width:40px;height:40px;border-radius:8px;border:1px solid var(--border);background:var(--bg-dark);color:var(--text);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:var(--font)}.replay-btn:hover{border-color:#4a5568;background:var(--bg-card-hover)}.replay-btn.active{border-color:var(--blue);background:#3b82f626}.replay-btn.play{width:48px;height:48px;font-size:20px;border-color:var(--accent)}.replay-btn.play:hover{background:#ef444426}.replay-sep{width:1px;height:28px;background:var(--border);margin:0 4px}.replay-follow-select{background:var(--bg-dark);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:6px 10px;font-size:13px;font-family:var(--font);cursor:pointer;outline:none;max-width:160px}.replay-follow-select:hover{border-color:#4a5568}.replay-time{font-family:var(--font-mono);font-size:14px;color:var(--text);margin-left:auto;padding:0 8px;white-space:nowrap}.replay-timeline{position:relative;padding:8px 0 16px}.replay-slider{width:100%;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border);border-radius:3px;outline:none;cursor:pointer;position:relative;z-index:2}.replay-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:var(--accent);border-radius:50%;cursor:pointer;border:2px solid white}.replay-slider::-moz-range-thumb{width:16px;height:16px;background:var(--accent);border-radius:50%;cursor:pointer;border:2px solid white}.replay-event-dots{position:absolute;top:4px;left:0;right:0;height:16px;pointer-events:none;z-index:1}.replay-edot{position:absolute;width:8px;height:8px;border-radius:50%;top:50%;transform:translate(-50%,-50%);pointer-events:auto;cursor:pointer;transition:transform .15s;box-shadow:0 0 4px #00000080}.replay-edot:hover{transform:translate(-50%,-50%) scale(1.8);z-index:10}.replay-events{display:flex;flex-wrap:wrap;gap:6px;min-height:20px}.replay-event-item{font-size:12px;color:var(--text-dim);white-space:nowrap;background:var(--bg-dark);padding:2px 8px;border-radius:4px;transition:background .15s}.replay-event-item:hover{background:var(--bg-card-hover)}.replay-evt{color:var(--text-dim);font-family:var(--font-mono);font-size:11px}.replay-state-tag{font-size:10px;color:var(--text-dim)}.rp-stats-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px}.rp-stats-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;max-width:500px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.rp-stats-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border);font-size:16px;font-weight:700;color:var(--text)}.rp-stats-close{background:none;border:none;color:var(--text-dim);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:6px}.rp-stats-close:hover{background:var(--bg-dark)}.rp-stats-body{padding:12px 20px;display:flex;flex-direction:column;gap:10px}.rp-stat-player{padding:10px 14px;border-radius:10px;border:1px solid var(--border);background:var(--bg-dark)}.rp-stat-player.fugitive{border-left:3px solid #ef4444}.rp-stat-player.hunter{border-left:3px solid #3b82f6}.rp-stat-player.operator{border-left:3px solid #60a5fa}.rp-stat-name{font-weight:600;font-size:14px;color:var(--text);margin-bottom:6px}.rp-stat-chips{display:flex;flex-wrap:wrap;gap:6px}.rp-chip{font-size:12px;padding:3px 8px;border-radius:6px;background:#ffffff0f;color:var(--text-dim)}.rp-chip.caught{background:#ef444426;color:#f87171;font-weight:600}.rp-stats-footer{padding:12px 20px;border-top:1px solid var(--border);font-size:12px;color:var(--text-dim);text-align:center}.btn-replay{margin-top:8px}.game-over-card .btn-replay{min-width:200px}.toast-container{position:fixed;top:16px;left:50%;transform:translate(-50%);z-index:10000;display:flex;flex-direction:column;gap:8px;pointer-events:none;max-width:400px;width:calc(100% - 32px)}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:10px;font-size:13px;font-weight:600;color:#fff;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 8px 32px #0006;pointer-events:auto;cursor:pointer;animation:toastIn .35s cubic-bezier(.22,1,.36,1),toastOut .3s ease 3.6s forwards}.toast-error{background:#ef4444e6}.toast-success{background:#22c55ee6}.toast-info{background:#3b82f6e6}.toast-icon{font-size:16px;flex-shrink:0}.toast-msg{flex:1}@keyframes toastIn{0%{opacity:0;transform:translateY(-16px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}.option-card,.lobby-card,.replay-card{transition:all .25s cubic-bezier(.22,1,.36,1)!important}.option-card:hover,.lobby-card:hover,.replay-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.lobby-player{animation:playerJoin .3s cubic-bezier(.22,1,.36,1)}@keyframes playerJoin{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.ready-badge-ready{animation:readyPulse 2s ease-in-out infinite}@keyframes readyPulse{0%,to{box-shadow:0 0 #22c55e66}50%{box-shadow:0 0 0 6px #22c55e00}}.settings-group-body{animation:settingsExpand .25s ease}@keyframes settingsExpand{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}input:focus,select:focus{outline:none;border-color:var(--accent)!important;box-shadow:0 0 0 3px var(--accent-glow)!important;transition:all .2s ease}@keyframes ticketUse{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.ticket-used{animation:ticketUse .3s ease}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.loading-shimmer{background:linear-gradient(90deg,transparent 30%,rgba(255,255,255,.05) 50%,transparent 70%);background-size:200% 100%;animation:shimmer 1.5s ease infinite}.connection-badge{position:fixed;bottom:12px;right:12px;z-index:1000;display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:11px;font-weight:600;background:#111827cc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);opacity:.6;transition:opacity .3s}.connection-badge:hover{opacity:1}.connection-dot{width:8px;height:8px;border-radius:50%}.connection-dot.online{background:var(--green);box-shadow:0 0 6px #22c55e80}.connection-dot.offline{background:var(--accent);animation:dotPulse 1s ease-in-out infinite}.op-sidebar{width:var(--sidebar-width)}.op-timeline-section{flex:1;min-height:0;display:flex;flex-direction:column}.op-timeline{flex:1;overflow-y:auto;min-height:80px;max-height:250px}.btn-operator{width:100%;padding:10px 14px;border-radius:8px;border:2px solid var(--border);background:#111827d9;color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.btn-operator:hover:not(:disabled){border-color:#4a5568}.btn-operator:disabled{opacity:.4;cursor:not-allowed}.btn-operator.active.heli{border-color:#60a5fa;background:#60a5fa26;color:#93c5fd}.op-marker-btns{display:flex;gap:6px}.btn-op-marker{width:40px;height:40px;border-radius:8px;border:2px solid var(--border);background:#111827d9;font-size:18px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-op-marker:hover{border-color:#4a5568}.btn-op-marker.active{border-color:#a855f7;background:#a855f726}.heli-icon{font-size:28px;text-align:center;animation:heliSpin 2s linear infinite;filter:drop-shadow(0 0 8px rgba(96,165,250,.6))}@keyframes heliSpin{0%,to{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}.heli-warning{position:absolute;top:140px;left:50%;transform:translate(-50%);z-index:1000;background:#60a5fae6;color:#000;font-weight:700;font-size:14px;padding:8px 20px;border-radius:8px;white-space:nowrap;box-shadow:0 0 30px #60a5fa80;animation:cellPingPulse 1.5s ease-in-out infinite}.zone-warning{position:absolute;top:180px;left:50%;transform:translate(-50%);z-index:1000;background:#ef4444e6;color:#fff;font-weight:700;font-size:14px;padding:8px 20px;border-radius:8px;white-space:nowrap;box-shadow:0 0 30px #ef444480;animation:cellPingPulse 1s ease-in-out infinite}.zone-indicator{position:absolute;bottom:60px;right:16px;z-index:1000;background:#ef4444b3;color:#fff;font-size:11px;font-weight:600;padding:4px 10px;border-radius:6px;pointer-events:none}.mission-progress{position:absolute;top:60px;right:16px;z-index:1000;background:#111827d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(234,179,8,.4);color:#eab308;font-size:14px;font-weight:700;padding:8px 14px;border-radius:10px;display:flex;align-items:center;gap:10px}.mission-dots{display:flex;gap:5px}.mission-dot{width:10px;height:10px;border-radius:50%;background:#eab30833;border:2px solid rgba(234,179,8,.4);transition:all .3s}.mission-dot.done{background:#eab308;border-color:#eab308;box-shadow:0 0 8px #eab30880;animation:missionDotPop .4s cubic-bezier(.22,1,.36,1)}@keyframes missionDotPop{0%{transform:scale(.5)}50%{transform:scale(1.4)}to{transform:scale(1)}}.checkpoint-flash{position:absolute;top:100px;left:50%;transform:translate(-50%);z-index:1000;background:#eab308e6;color:#000;font-weight:700;font-size:15px;padding:10px 24px;border-radius:10px;white-space:nowrap;box-shadow:0 0 30px #eab30866;animation:checkpointFlashIn .4s cubic-bezier(.22,1,.36,1)}@keyframes checkpointFlashIn{0%{opacity:0;transform:translate(-50%) scale(.8) translateY(-10px)}to{opacity:1;transform:translate(-50%) scale(1) translateY(0)}}.role-btn.operator.active{background:#60a5fa33;border-color:#60a5fa}.mobile-hud{display:none}@media (max-width: 768px){:root{--sidebar-width: 0px}.game-screen{position:fixed;top:0;left:0;right:0;bottom:0;overflow:hidden}.home-screen{padding:16px;min-height:100vh;min-height:100dvh;overflow-y:auto;align-items:flex-start;padding-top:max(20px,env(safe-area-inset-top))}.home-container,.home-container-narrow{max-width:100%;padding:20px 16px}.home-title{font-size:28px}.lobby-screen{overflow-y:auto;min-height:100dvh}.lobby-container,.lobby-container-wide{max-width:100%;padding:16px}.lobby-body,.lobby-body-3col{grid-template-columns:1fr;gap:12px}.lobby-col-map,.lobby-col-center,.lobby-col-left,.lobby-col-right{max-height:none;overflow-y:visible}.picker-map{height:200px}.lobby-header{flex-wrap:wrap;gap:8px}.lobby-header-right{flex-wrap:wrap;gap:6px}.sidebar{display:none!important}.game-screen{flex-direction:column}.game-center{flex:1}.main-timer{font-size:22px}.hud-top{padding:8px 12px;gap:12px}.hud-mode{font-size:12px;padding:4px 10px}.headstart-timer{font-size:11px}.stamina-bar-container{width:160px;top:44px}.transport-mode-active{font-size:12px;padding:8px 14px;top:60px}.transport-clue-flash,.transport-error{top:80px;font-size:13px;padding:8px 16px}.cell-ping-warning{top:100px;font-size:12px;padding:6px 14px}.caught-flash{top:60px;font-size:14px}.game-over-card{padding:24px;margin:0 16px}.game-over-card h2{font-size:20px}.mobile-hud{display:flex;flex-direction:column;position:absolute;bottom:0;left:0;right:0;z-index:1100;padding:6px 8px max(6px,env(safe-area-inset-bottom));background:linear-gradient(to top,rgba(10,14,23,.95) 70%,transparent);pointer-events:none}.mobile-hud>*{pointer-events:auto}.m-hud-tickets{display:flex;justify-content:center;gap:12px;font-size:13px;font-weight:600;color:var(--text-main);margin-bottom:4px}.m-ticket{white-space:nowrap}.m-hud-actions{display:flex;gap:6px;justify-content:center;align-items:center}.m-hud-spacer{flex:1}.m-btn{width:44px;height:44px;border-radius:12px;border:2px solid var(--border);background:#111827e6;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.m-btn:disabled{opacity:.3}.m-btn.bus.active{border-color:var(--green);background:#22c55e33}.m-btn.taxi.active{border-color:var(--yellow);background:#eab30833}.m-btn.ubahn.active{border-color:var(--purple);background:#a855f733}.m-btn.polizei.active{border-color:var(--blue);background:#3b82f633}.m-btn.barricade.active{border-color:#ef4444;background:#ef444433}.m-btn.clue{font-size:14px;width:auto;padding:0 10px}.m-btn.clue.active{border-color:var(--purple);background:#a855f733}.m-btn.chat{font-size:14px;width:auto;padding:0 10px}.m-btn.chat.active{border-color:var(--blue);background:#3b82f633}.m-hud-hint{text-align:center;font-size:10px;color:var(--text-dim);margin-top:3px;opacity:.7}.m-drawer{position:absolute;bottom:100%;left:8px;right:8px;background:#111827f7;border:1px solid var(--border);border-radius:12px 12px 0 0;padding:10px 14px;max-height:220px;overflow-y:auto;animation:mDrawerSlide .2s ease}.m-drawer-chat{padding:0;max-height:280px}.m-drawer-chat .chat-panel{position:static;border:none;border-radius:0;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;max-height:none}.m-drawer-chat .chat-messages{max-height:180px}.m-drawer-title{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:600;color:var(--text-dim);margin-bottom:8px}.m-drawer-close{background:none;border:none;color:var(--text-dim);font-size:16px;cursor:pointer;padding:2px 6px}@keyframes mDrawerSlide{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.leaflet-container{touch-action:pan-x pan-y}.leaflet-control-zoom{display:none}}
