:root{--bg: #11161d;--bg-2: #18202a;--card: #1d2733;--line: #2c3a4a;--text: #e8eef4;--muted: #8da0b3;--accent: #4ade80;--red: #e25d51;--blue: #5689e5;--gold: #ffe44d}*{box-sizing:border-box}html,body{margin:0;height:100%}body{background:var(--bg);color:var(--text);font-family:system-ui,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.45}#app,.screen{height:100%}.hidden{display:none!important}.muted{color:var(--muted)}h1,h2,h3{margin:0 0 8px}button{font:inherit;color:var(--text);background:var(--line);border:1px solid transparent;border-radius:8px;padding:8px 14px;cursor:pointer;transition:filter .1s,transform .05s}button:hover{filter:brightness(1.15)}button:active{transform:translateY(1px)}button:disabled{opacity:.45;cursor:default}button.primary{background:var(--accent);color:#07240f;font-weight:700}button.ghost{background:transparent;border-color:var(--line)}button.small{padding:5px 10px;font-size:13px}button.big{padding:12px 28px;font-size:17px}input{font:inherit;color:var(--text);background:var(--bg-2);border:1px solid var(--line);border-radius:8px;padding:8px 10px;outline:none}input:focus{border-color:var(--accent)}.row{display:flex;align-items:center}.row.gap{gap:8px}.row.spread{justify-content:space-between}.row.end{justify-content:flex-end}.flex-spacer{flex:1}.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px}#screen-home{display:grid;place-items:center;overflow-y:auto}.home-wrap{width:min(560px,92vw);display:flex;flex-direction:column;gap:14px;padding:32px 0}.logo{font-size:56px;letter-spacing:-2px;text-align:center;margin:0}.logo span{color:var(--accent)}.tagline{text-align:center;color:var(--muted);margin:-6px 0 8px}.field-label{display:block;font-size:13px;color:var(--muted);margin-bottom:4px}#nick{width:100%;margin-bottom:10px}#btn-create{flex:1}#join-code{width:90px;text-transform:uppercase;text-align:center;letter-spacing:2px}#room-list{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:6px}#room-list li{display:flex;align-items:center;gap:10px;background:var(--bg-2);border-radius:8px;padding:8px 12px}#room-list .r-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}#room-list .r-meta{color:var(--muted);font-size:13px}.badge{font-size:11px;text-transform:uppercase;letter-spacing:1px;padding:2px 8px;border-radius:99px;background:var(--line)}.badge.live{background:#3b2710;color:var(--gold)}.hint{text-align:center;font-size:13px}#conn-status{text-align:center;font-size:13px;min-height:1.2em}#screen-lobby{overflow-y:auto}.lobby-wrap{width:min(980px,94vw);margin:0 auto;padding:24px 0 40px;display:flex;flex-direction:column;gap:16px}.lobby-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.lobby-head h2{margin:0}.code-chip{background:var(--bg-2);border:1px dashed var(--muted);font-family:ui-monospace,Consolas,monospace;letter-spacing:3px;padding:5px 12px}.teams{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.team-col{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:8px;min-height:150px}.team-col.red h3{color:var(--red)}.team-col.blue h3{color:var(--blue)}.team-col.spec h3{color:var(--muted)}.team-col ul{list-style:none;margin:0;padding:0;flex:1;display:flex;flex-direction:column;gap:5px}.member-chip{display:flex;align-items:center;gap:8px;background:var(--bg-2);border-radius:7px;padding:5px 9px;font-size:14px}.member-chip .dot{width:11px;height:11px;border-radius:50%;flex:none}.member-chip.me{outline:1px solid var(--accent)}.char-title{margin:4px 0 0}#char-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}.char-card{background:var(--card);border:2px solid var(--line);border-radius:12px;padding:12px;cursor:pointer;display:flex;flex-direction:column;gap:6px}.char-card:hover{border-color:var(--muted)}.char-card.selected{border-color:var(--accent)}.char-card .char-head{display:flex;align-items:baseline;gap:8px}.char-card .char-name{font-weight:700;font-size:16px}.char-card .char-role{font-size:12px;color:var(--muted)}.char-card .char-desc{font-size:12.5px;color:var(--muted);min-height:2.4em}.statbar{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted)}.statbar .label{width:44px}.statbar .track{flex:1;height:5px;background:var(--bg-2);border-radius:3px;overflow:hidden}.statbar .fill{height:100%;border-radius:3px}.char-skill{font-size:12.5px;border-top:1px solid var(--line);padding-top:6px}.char-skill b{color:var(--gold)}.lobby-bottom{display:grid;grid-template-columns:1fr 240px;gap:12px;align-items:stretch}.chat{display:flex;flex-direction:column;padding:10px}#chat-log{list-style:none;margin:0 0 8px;padding:0;flex:1;overflow-y:auto;max-height:160px;min-height:100px;font-size:13.5px;display:flex;flex-direction:column;gap:3px}#chat-log .sys{color:var(--muted);font-style:italic}#chat-log .who{font-weight:700;color:var(--accent)}#chat-form input{width:100%}.start-box{display:flex;flex-direction:column;align-items:stretch;justify-content:center;gap:8px;text-align:center}#screen-game{position:relative;overflow:hidden}#game-canvas{position:absolute;inset:0;width:100%;height:100%;display:block}#hud{position:absolute;inset:0;pointer-events:none}#hud button,#hud form{pointer-events:auto}#hud-top{position:absolute;top:10px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:16px;background:#0d1218d1;border:1px solid var(--line);border-radius:12px;padding:6px 22px;font-size:24px;font-weight:800}#hud-top .score.red{color:var(--red)}#hud-top .score.blue{color:var(--blue)}#hud-clock{font-size:17px;font-weight:600;color:var(--muted);min-width:52px;text-align:center}#hud-golden{position:absolute;top:62px;left:50%;transform:translate(-50%);color:var(--gold);font-weight:700;text-shadow:0 0 12px rgba(255,228,77,.5)}#hud-banner{position:absolute;top:38%;left:0;right:0;text-align:center;font-size:64px;font-weight:900;letter-spacing:2px;text-shadow:0 4px 24px rgba(0,0,0,.6);animation:pop .3s ease-out}@keyframes pop{0%{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}#hud-skill{position:absolute;right:14px;bottom:14px;display:flex;align-items:center;gap:10px;background:#0d1218d1;border:1px solid var(--line);border-radius:10px;padding:8px 12px}#hud-skill-key{font-family:ui-monospace,Consolas,monospace;background:var(--line);border-radius:6px;padding:2px 8px;font-weight:700}#hud-skill-bar{width:90px;height:8px;background:var(--bg-2);border-radius:4px;overflow:hidden}#hud-skill-cd{height:100%;width:100%;background:var(--accent);border-radius:4px}#hud-skill.ready #hud-skill-name{color:var(--accent)}#hud-chatlog{position:absolute;left:14px;bottom:56px;display:flex;flex-direction:column;gap:3px;font-size:13.5px;max-width:40vw}#hud-chatlog div{background:#0d1218b8;border-radius:7px;padding:3px 9px;animation:fadeout 8s forwards}#hud-chatlog .who{font-weight:700;color:var(--accent)}#hud-chatlog .sys{color:var(--muted);font-style:italic}@keyframes fadeout{0%,80%{opacity:1}to{opacity:0}}#hud-chat-form{position:absolute;left:14px;bottom:14px;width:min(360px,50vw)}#hud-chat-form input{width:100%;background:#0d1218e6}#hud-spectate{position:absolute;bottom:14px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;background:#0d1218d1;border:1px solid var(--line);border-radius:10px;padding:8px 14px}#hud-spectate .red-btn{background:var(--red);font-weight:700}#hud-spectate .blue-btn{background:var(--blue);font-weight:700}#hud-buttons{position:absolute;top:12px;right:12px;display:flex;gap:8px}#hud-hint{position:absolute;bottom:14px;left:50%;transform:translate(-50%);color:var(--muted);font-size:12.5px;background:#0d121899;padding:3px 12px;border-radius:99px;animation:fadeout 9s forwards;pointer-events:none}dialog{background:var(--card);color:var(--text);border:1px solid var(--line);border-radius:14px;padding:22px;width:min(380px,92vw)}dialog::backdrop{background:#0000008c}#create-form{display:flex;flex-direction:column;gap:12px}#create-form label{display:flex;align-items:center;gap:8px;justify-content:space-between;font-size:14px}#create-form label .muted{font-size:11.5px}#create-form input[type=number]{width:70px}#create-form #cr-name{flex:1}#create-form .check{justify-content:flex-start}#toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(80px);background:var(--card);border:1px solid var(--line);border-radius:10px;padding:10px 18px;opacity:0;transition:transform .25s,opacity .25s;z-index:50;pointer-events:none}#toast.show{transform:translate(-50%) translateY(0);opacity:1}@media(max-width:760px){.teams,.lobby-bottom{grid-template-columns:1fr}#hud-banner{font-size:40px}}
