*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f1419;--surface: #1a2332;--surface2: #243044;--border: #2d3f56;--text: #e8edf4;--text-muted: #8899aa;--primary: #3b82f6;--primary-hover: #2563eb;--police: #3b82f6;--thief: #ef4444;--success: #22c55e;--warning: #f59e0b;--radius: 12px;--shadow: 0 4px 24px rgba(0, 0, 0, .4)}body{font-family:Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.6}#app{max-width:900px;margin:0 auto;padding:24px 16px}.screen{display:none;animation:fadeIn .3s ease}.screen.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.hero{text-align:center;padding:40px 0 32px}.hero-icons{font-size:48px;margin-bottom:12px}.hero h1{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,var(--police),#60a5fa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{color:var(--text-muted);margin-top:8px;font-size:1.1rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:16px;box-shadow:var(--shadow)}.card h3{margin-bottom:16px;font-size:1.1rem}.card label{display:block;margin-bottom:6px;color:var(--text-muted);font-size:.875rem}input[type=text],textarea{width:100%;padding:12px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:1rem;font-family:inherit;transition:border-color .2s}input[type=text]:focus,textarea:focus{outline:none;border-color:var(--primary)}textarea{resize:vertical;min-height:120px;line-height:1.8}.char-count{text-align:right;font-size:.8rem;color:var(--text-muted);margin:4px 0 12px}.btn{padding:10px 20px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}.btn-primary:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border);margin-top:12px;width:100%}.btn-ghost:hover{color:var(--text);border-color:var(--text-muted)}.btn-lg{width:100%;padding:14px;font-size:1.1rem;margin-top:16px}.btn-group{display:flex;gap:12px;margin-top:16px}.btn-group .btn{flex:1}.join-panel{display:flex;gap:8px;margin-top:12px}.join-panel input{flex:1;text-transform:uppercase;letter-spacing:4px;text-align:center;font-weight:700}.hidden{display:none!important}.rules-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px}.rules-card h3{margin-bottom:12px;color:var(--warning)}.rules-card ul{padding-left:20px;color:var(--text-muted)}.rules-card li{margin-bottom:6px}.rules-card strong{color:var(--text)}.lobby-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:8px}.room-info{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.room-info strong{color:var(--warning);font-size:1.3rem;letter-spacing:3px}.lan-info{font-size:.8rem;color:var(--success)}.lobby-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 700px){.lobby-grid{grid-template-columns:1fr}}.player-list{list-style:none}.player-list li{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--surface2);border-radius:8px;margin-bottom:8px}.player-avatar{font-size:1.4rem}.player-name{flex:1;font-weight:600}.player-tag{font-size:.75rem;padding:2px 8px;border-radius:99px;font-weight:600}.tag-host{background:#f59e0b33;color:var(--warning)}.tag-police{background:#3b82f633;color:var(--police)}.tag-thief{background:#ef444433;color:var(--thief)}.tag-caught{background:#89a3;color:var(--text-muted)}.tag-escaped{background:#22c55e33;color:var(--success)}.role-select-section{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.role-select-section label{display:block;margin-bottom:8px;color:var(--text-muted);font-size:.875rem}.role-select-btns{display:flex;gap:10px}.btn-role{flex:1;padding:12px;border:2px solid var(--border);background:var(--surface2);color:var(--text)}.btn-role-police.selected{border-color:var(--police);background:#3b82f626;color:var(--police)}.btn-role-thief.selected{border-color:var(--thief);background:#ef444426;color:var(--thief)}.role-hint{margin-top:10px;font-size:.85rem;color:var(--text-muted)}.role-counts{margin-top:6px;font-size:.85rem;color:var(--warning)}.host-badge{font-size:.7rem;background:#f59e0b33;color:var(--warning);padding:2px 8px;border-radius:99px;font-weight:400}.slider-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}.slider-row input[type=range]{flex:1;accent-color:var(--primary)}#headstart-value{font-weight:700;color:var(--thief);min-width:40px}#btn-save-settings{width:100%}#settings-card.readonly textarea,#settings-card.readonly input[type=range]{opacity:.6;pointer-events:none}#settings-card.readonly #btn-save-settings{display:none}.game-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.role-badge{font-size:1.2rem;font-weight:700;padding:8px 16px;border-radius:99px}.role-police{background:#3b82f633;color:var(--police)}.role-thief{background:#ef444433;color:var(--thief)}.game-stats{display:flex;gap:20px;color:var(--text-muted)}.game-stats strong{color:var(--text)}.race-track{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px;overflow:hidden}.track-bg{position:relative;height:160px;background:linear-gradient(180deg,#1e3a2f,#1a2332);border-radius:8px;overflow:hidden}.track-line{position:absolute;top:50%;left:0;right:40px;height:3px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.3) 0px,rgba(255,255,255,.3) 20px,transparent 20px,transparent 40px);transform:translateY(-50%)}.finish-line{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:1.5rem}.track-runner{position:absolute;top:50%;transform:translate(-50%,-50%);transition:left .3s ease;display:flex;flex-direction:column;align-items:center;z-index:2}.runner-icon{font-size:1.8rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.runner-name{font-size:.65rem;color:var(--text-muted);white-space:nowrap;margin-top:2px}.thief-runner{z-index:3}.thief-runner.caught{opacity:.45;filter:grayscale(.8)}.thief-runner.escaped .runner-icon{filter:drop-shadow(0 0 6px rgba(34,197,94,.6))}.police-runner{z-index:2}.police-runner .runner-icon{font-size:1.4rem}.typing-area{margin-bottom:16px}.typing-unified{position:relative;background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);padding:20px 24px;min-height:120px;cursor:text;transition:border-color .2s}.typing-unified:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f626}.typing-unified.spectator{cursor:default;opacity:.85}.typing-unified.spectator:focus-within{border-color:var(--border);box-shadow:none}.text-display{font-size:1.25rem;line-height:2;letter-spacing:.5px;word-break:break-word;white-space:pre-wrap;pointer-events:none;-webkit-user-select:none;user-select:none}.char{transition:color .1s,background .1s}.char.correct{color:var(--success)}.char.incorrect{color:var(--thief);background:#ef44441f;border-radius:2px}.char.current{background:var(--primary);color:#fff;border-radius:2px;animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.55}}.char.pending{color:var(--text-muted)}.typing-input-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;padding:20px 24px;border:none;outline:none;resize:none;overflow:hidden;background:transparent;color:transparent;caret-color:transparent;font-size:1.25rem;line-height:2;letter-spacing:.5px;font-family:inherit}.typing-input-overlay:disabled{cursor:not-allowed}.spectator-banner{background:#ef444426;border:1px solid rgba(239,68,68,.4);border-radius:var(--radius);padding:14px 20px;margin-bottom:16px;text-align:center;font-weight:600;color:var(--thief)}.spectator-banner.escaped-mode{background:#22c55e26;border-color:#22c55e66;color:var(--success)}.players-progress{display:flex;flex-direction:column;gap:8px}.progress-row{display:flex;align-items:center;gap:10px}.progress-label{width:80px;font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.progress-bar-bg{flex:1;height:8px;background:var(--surface2);border-radius:99px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:99px;transition:width .3s ease}.fill-police{background:var(--police)}.fill-thief{background:var(--thief)}.fill-thief.caught{background:var(--text-muted)}.fill-thief.escaped{background:var(--success)}.progress-pct{width:40px;text-align:right;font-size:.8rem;color:var(--text-muted)}.result-card{text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:48px 32px;box-shadow:var(--shadow);margin-top:60px}.result-icon{font-size:64px;margin-bottom:16px}.result-card h2{font-size:2rem;margin-bottom:8px}#result-message{color:var(--text-muted);font-size:1.1rem;margin-bottom:24px}.result-stats{display:flex;justify-content:center;gap:24px;margin-bottom:32px;flex-wrap:wrap}.stat-item{background:var(--surface2);padding:12px 20px;border-radius:8px}.stat-item .label{font-size:.8rem;color:var(--text-muted)}.stat-item .value{font-size:1.3rem;font-weight:700}.result-card .btn-group{justify-content:center}.result-card .btn-group .btn{min-width:140px}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--thief);color:#fff;padding:12px 24px;border-radius:8px;font-weight:600;z-index:1000;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}
