:root{
    --bg:#07111f;
    --panel:#0f1f35;
    --panel2:#142844;
    --text:#f8fafc;
    --muted:#a8b3c7;
    --danger:#ef4444;
    --good:#22c55e;
    --warn:#f59e0b;
}
*{box-sizing:border-box}
body{margin:0;background:radial-gradient(circle at top,#1b3558,#07111f 60%);color:var(--text);font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;min-height:100vh;overflow-x:hidden}
.screen{display:none;min-height:100vh}.screen.active{display:block}.eyebrow{text-transform:uppercase;letter-spacing:.14em;color:#93c5fd;font-weight:800;font-size:.8rem}.start-card{min-height:100vh;display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:center;max-width:1200px;margin:0 auto;padding:60px}.start-card h1{font-size:clamp(56px,8vw,120px);line-height:.9;margin:18px 0;font-weight:1000;text-transform:uppercase}.start-card h1 span{color:#fb7185}.start-card p{font-size:24px;color:#cbd5e1;max-width:720px}.start-actions{display:grid;gap:18px}.btn-lg{min-height:64px;font-weight:900}.tv-frame{width:100vw;height:100vh;aspect-ratio:16/9;display:grid;grid-template-columns:minmax(0,1fr) 370px;gap:18px;padding:18px;background:linear-gradient(135deg,#0c1a2c,#12233b)}.tv-board-wrap{min-width:0;background:#081426;border:3px solid #28476f;border-radius:24px;padding:16px;box-shadow:0 20px 60px rgba(0,0,0,.45)}.board-title-row{height:80px;display:flex;justify-content:space-between;align-items:center;gap:16px}.board-title-row h2{margin:0;font-weight:1000;font-size:38px}.turn-banner{min-width:310px;text-align:center;padding:14px 18px;border-radius:18px;background:#334155;color:#fff;font-size:24px;font-weight:1000;box-shadow:inset 0 0 0 3px rgba(255,255,255,.12)}.game-board{height:calc(100vh - 132px);display:grid;grid-template-columns:repeat(20,1fr);grid-template-rows:repeat(10,1fr);gap:5px}.tile{position:relative;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:min(4.2vw,58px);font-weight:1000;box-shadow:inset 0 -5px 0 rgba(0,0,0,.22),0 4px 12px rgba(0,0,0,.18);overflow:hidden}.tile::after{content:attr(data-coord);position:absolute;left:5px;top:3px;font-size:10px;color:rgba(255,255,255,.45)}.tile.forest{background:linear-gradient(#1f7a46,#14532d)}.tile.yard{background:linear-gradient(#46b950,#15803d)}.tile.house,.tile.room{background:linear-gradient(#b77937,#7c3f1d)}.tile.wall{background:linear-gradient(#64748b,#334155)}.tile.start_car{background:linear-gradient(#fde047,#f59e0b)}.tile.finish_car{background:linear-gradient(#86efac,#16a34a)}.tile.door{background:linear-gradient(#a16207,#713f12)}.tile.trap{background:linear-gradient(#78350f,#451a03)}.tile.noise{background:linear-gradient(#f97316,#9a3412)}.tile.dark{background:linear-gradient(#111827,#020617)}.tile.hidden{filter:brightness(.35) saturate(.55)}.tile.hidden .tile-emoji{opacity:.32}.card-token{position:absolute;right:6px;top:6px;width:38px;height:48px;border-radius:9px;background:linear-gradient(135deg,#facc15,#f97316);display:flex;align-items:center;justify-content:center;font-size:28px;border:3px solid rgba(255,255,255,.75);box-shadow:0 6px 10px rgba(0,0,0,.35);z-index:2}.item-stack{position:absolute;right:4px;bottom:4px;background:#0f172a;border:2px solid rgba(255,255,255,.65);border-radius:10px;padding:2px 6px;font-size:22px;z-index:4}.unit-token,.zombie-token{position:absolute;width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:1000;border:4px solid white;box-shadow:0 8px 18px rgba(0,0,0,.45);z-index:8}.unit-token{bottom:5px;left:5px}.unit-token .num{font-size:22px;margin-left:1px;text-shadow:0 2px 3px #000}.zombie-token{top:5px;left:5px;background:#14532d}.zombie-token.small-offset{left:48px}.tile.danger-pulse{animation:pulseDanger 1.2s infinite}@keyframes pulseDanger{50%{box-shadow:0 0 0 6px rgba(239,68,68,.5),0 0 35px rgba(239,68,68,.8)}}.tv-hud{display:grid;grid-template-rows:auto auto auto 1fr;gap:14px;min-width:0}.hud-panel{background:linear-gradient(180deg,var(--panel),#0b1728);border:2px solid #274464;border-radius:22px;padding:14px;box-shadow:0 16px 40px rgba(0,0,0,.28)}.hud-title{font-size:14px;text-transform:uppercase;letter-spacing:.12em;color:#93c5fd;font-weight:1000;margin-bottom:8px}.big-status{font-size:30px;font-weight:1000}.phase-status{font-size:17px;color:#dbeafe}.hud-buttons{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}.players-hud{display:grid;gap:8px}.player-row{display:grid;grid-template-columns:42px 1fr auto;gap:8px;align-items:center;border-radius:14px;background:rgba(255,255,255,.06);padding:8px}.player-row .emoji{font-size:30px}.player-row .name{font-size:18px;font-weight:900}.player-row .meta{font-size:13px;color:#cbd5e1}.score{font-size:22px;font-weight:1000}.log-list{display:grid;gap:7px;overflow:auto}.log-item{font-size:15px;background:rgba(255,255,255,.06);border-radius:12px;padding:8px;color:#e2e8f0}.log-time{color:#93c5fd;font-weight:900;margin-right:6px}.roulette{position:relative;display:flex;flex-direction:column;align-items:center}.roulette-pointer{font-size:28px;color:#fde047;margin-bottom:-8px;z-index:3}.roulette-wheel{width:210px;height:210px;border-radius:50%;border:8px solid #e2e8f0;background:conic-gradient(#ef4444 0 45deg,#f59e0b 45deg 90deg,#22c55e 90deg 135deg,#3b82f6 135deg 180deg,#a855f7 180deg 225deg,#ef4444 225deg 270deg,#14b8a6 270deg 315deg,#f97316 315deg 360deg);position:relative;box-shadow:inset 0 0 0 8px rgba(0,0,0,.25),0 12px 30px rgba(0,0,0,.35);transition:transform 1.2s cubic-bezier(.16,.82,.22,1)}.roulette-wheel.spin{transform:rotate(1080deg)}.roulette-wheel span{position:absolute;left:50%;top:50%;font-size:28px;font-weight:1000;text-shadow:0 2px 4px #000}.roulette-wheel span:nth-child(1){transform:rotate(22deg) translate(72px) rotate(-22deg)}.roulette-wheel span:nth-child(2){transform:rotate(67deg) translate(72px) rotate(-67deg)}.roulette-wheel span:nth-child(3){transform:rotate(112deg) translate(72px) rotate(-112deg)}.roulette-wheel span:nth-child(4){transform:rotate(157deg) translate(72px) rotate(-157deg)}.roulette-wheel span:nth-child(5){transform:rotate(202deg) translate(72px) rotate(-202deg)}.roulette-wheel span:nth-child(6){transform:rotate(247deg) translate(72px) rotate(-247deg)}.roulette-wheel span:nth-child(7){transform:rotate(292deg) translate(72px) rotate(-292deg)}.roulette-wheel span:nth-child(8){transform:rotate(337deg) translate(72px) rotate(-337deg)}.roulette-result{font-size:30px;font-weight:1000;margin-top:8px;min-height:44px}.join-wrap{min-height:100vh;max-width:960px;margin:0 auto;padding:42px 18px;text-align:center}.join-wrap h2{font-size:52px;font-weight:1000}.join-teams{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:26px}.join-team{border:3px solid rgba(255,255,255,.25);border-radius:24px;padding:28px;background:rgba(255,255,255,.08)}.join-team .emoji{font-size:68px}.join-team h3{font-weight:1000}.join-team .btn{min-height:58px;font-weight:900}.phone-shell{min-height:100vh;padding:12px;background:#08111f}.phone-header{display:flex;justify-content:space-between;gap:10px;align-items:center;background:var(--panel);border-radius:18px;padding:12px}.phone-team{font-size:20px;font-weight:1000}.phone-turn{color:#cbd5e1}.selected-unit-card{margin-top:10px;background:linear-gradient(135deg,#172554,#0f172a);border:2px solid #334155;border-radius:20px;padding:14px;min-height:92px}.selected-unit-card .unit-name{font-size:24px;font-weight:1000}.badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.badge-game{font-size:13px;background:#334155;border-radius:999px;padding:5px 8px}.phone-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:12px 0}.tab{border:0;border-radius:14px;padding:14px 8px;background:#1e293b;color:#cbd5e1;font-weight:1000}.tab.active{background:#2563eb;color:#fff}.tab-panel{display:none}.tab-panel.active{display:block}.action-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.btn-xl{min-height:66px;font-size:17px;font-weight:1000}.dpad{margin:16px auto 10px;width:220px;display:grid;grid-template-columns:repeat(3,70px);grid-template-rows:repeat(3,62px);gap:5px;justify-content:center}.dpad button{font-size:30px;font-weight:1000}.dpad button:nth-child(1){grid-column:2;grid-row:1}.dpad button:nth-child(2){grid-column:1;grid-row:2}.dpad .center{grid-column:2;grid-row:2}.dpad button:nth-child(4){grid-column:3;grid-row:2}.dpad button:nth-child(5){grid-column:2;grid-row:3}.inventory-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}.inventory-actions .btn{min-height:56px;font-weight:900}.units-list{display:grid;gap:10px}.unit-card{background:#0f1f35;border:2px solid #334155;border-radius:18px;padding:12px}.unit-card.active{border-color:#60a5fa}.unit-card .top{display:flex;justify-content:space-between;gap:10px}.unit-card .name{font-size:20px;font-weight:1000}.phone-log{max-height:70vh}.zombie-button{background:#14532d!important;color:white!important}@media(max-width:900px){.start-card{grid-template-columns:1fr;padding:24px}.join-teams{grid-template-columns:1fr}.tv-frame{grid-template-columns:1fr;height:auto;min-height:100vh}.tv-hud{grid-template-rows:auto}.game-board{height:70vh}.tile{border-radius:8px}.unit-token,.zombie-token{width:42px;height:42px;font-size:22px}.card-token{width:30px;height:38px;font-size:20px}}
