@import "https://fonts.googleapis.com/css2?family=Creepster&family=Inter:wght@400;500;600;700;800;900&display=swap";*{box-sizing:border-box;margin:0;padding:0}:root{--bg-abyss:#0a0a0f;--bg-dark:#0e0e16;--bg-card:#141420;--bg-surface:#1a1a2a;--bg-elevated:#1f1f32;--blood:#c41e3a;--blood-glow:#c41e3a66;--toxic:#39ff14;--toxic-dim:#2aaa10;--toxic-glow:#39ff144d;--alien-purple:#8b5cf6;--alien-glow:#8b5cf64d;--ember:#ff6b2b;--ember-glow:#ff6b2b4d;--ice-blue:#38bdf8;--warning-yellow:#fbbf24;--warning-glow:#fbbf244d;--infection-color:#7c3aed;--panic-color:#dc2626;--action-color:#2563eb;--defense-color:#16a34a;--obstacle-color:#d97706;--text:#e8e6f0;--text-dim:#7a7890;--text-blood:#ff4d6a;--text-toxic:#39ff14;--border-subtle:#ffffff0f;--border-glow:#8b5cf633;--border-radius:8px;--card-width:82px;--card-height:118px;--font-display:"Creepster", cursive;--font-body:"Inter", system-ui, -apple-system, sans-serif}body{font-family:var(--font-body);background:var(--bg-abyss);color:var(--text);-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased;min-height:100dvh;overflow-x:hidden}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#8b5cf64d;border-radius:4px}button{cursor:pointer;border-radius:var(--border-radius);font-size:13px;font-weight:700;font-family:var(--font-body);color:#fff;letter-spacing:.3px;border:none;padding:8px 16px;transition:all .2s;position:relative;overflow:hidden}button:after{content:"";pointer-events:none;background:linear-gradient(#ffffff14 0%,#0000 50%);position:absolute;inset:0}button:active:not(:disabled){transform:scale(.97)}button:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.5)}button.primary{box-shadow:0 2px 12px var(--blood-glow), inset 0 1px 0 #ffffff1a;background:linear-gradient(135deg,#c41e3a,#9b1830)}button.primary:active:not(:disabled){box-shadow:0 1px 6px var(--blood-glow)}button.secondary{background:var(--bg-elevated);border:1px solid var(--border-glow);box-shadow:0 2px 8px #0000004d}button.success{background:linear-gradient(135deg,#16a34a,#0d7a36);box-shadow:0 2px 12px #16a34a4d,inset 0 1px #ffffff1a}button.danger{background:linear-gradient(135deg,#dc2626,#a91d1d);box-shadow:0 2px 12px #dc26264d,inset 0 1px #ffffff1a}button.warning{color:#fff;background:linear-gradient(135deg,#d97706,#a85d04);box-shadow:0 2px 12px #d977064d,inset 0 1px #ffffff1a}input{background:var(--bg-card);border:1px solid var(--border-glow);border-radius:var(--border-radius);color:var(--text);font-size:15px;font-family:var(--font-body);outline:none;padding:12px 16px;transition:all .3s;box-shadow:inset 0 2px 4px #0000004d}input:focus{border-color:var(--blood);box-shadow:inset 0 2px 4px #0000004d, 0 0 12px var(--blood-glow)}input::placeholder{color:var(--text-dim)}.page{flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:20px;display:flex;position:relative;overflow:hidden}.page:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 20% 80%,#c41e3a0f 0%,#0000 50%),radial-gradient(at 80% 20%,#8b5cf60d 0%,#0000 50%),radial-gradient(#39ff1405 0%,#0000 40%);position:fixed;inset:0}.card-container{background:var(--bg-card);z-index:1;border:1px solid #8b5cf61a;border-radius:16px;width:100%;max-width:420px;padding:32px 28px;position:relative;box-shadow:0 0 40px #00000080,0 0 2px #8b5cf633,inset 0 1px #ffffff0a}.card-container:before{content:"";z-index:-1;background:linear-gradient(135deg,#0000 30%,#c41e3a26 50%,#0000 70%);border-radius:17px;animation:4s ease-in-out infinite border-shimmer;position:absolute;inset:-1px}@keyframes border-shimmer{0%,to{opacity:.3}50%{opacity:1}}h1{font-family:var(--font-display);letter-spacing:3px;margin-bottom:4px;font-size:2.4rem}h2{font-family:var(--font-display);letter-spacing:2px;margin-bottom:12px;font-size:1.6rem}.game-layout{background:url(/game-bg.png) 50%/cover no-repeat fixed;flex-direction:column;height:100dvh;display:flex;position:relative;overflow:hidden}.game-layout:before{content:"";z-index:0;pointer-events:none;background:#0a0a0f80;position:fixed;inset:0}.game-topbar{background:var(--bg-dark);border-bottom:1px solid var(--border-subtle);z-index:1;flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 14px;display:flex;position:relative}.topbar-item{color:var(--text-dim);letter-spacing:.5px;font-size:12px;font-weight:600}.topbar-phase{color:var(--warning-yellow);text-transform:uppercase;letter-spacing:.8px;text-shadow:0 0 12px var(--warning-glow);font-size:12px;font-weight:800;animation:2s ease-in-out infinite phase-pulse}@keyframes phase-pulse{0%,to{opacity:.9}50%{opacity:1;text-shadow:0 0 18px var(--warning-glow)}}.game-board{z-index:1;flex:1;min-height:0;position:relative;overflow:hidden}.panic-banner{background:linear-gradient(90deg, var(--bg-dark) 0%, #b41e32e6 20%, #b41e32e6 80%, var(--bg-dark) 100%);color:#fff;text-align:center;text-shadow:0 1px 4px #00000080;z-index:1;flex-wrap:wrap;flex-shrink:0;justify-content:center;align-items:center;gap:8px;padding:7px 14px;font-size:12px;animation:1s ease-out panic-flash;display:flex;position:relative}@keyframes panic-flash{0%{background-color:#ff3232cc}to{background-color:#0000}}.player-circle-container{width:100%;height:100%;position:relative}.player-seat{cursor:pointer;-webkit-tap-highlight-color:transparent;flex-direction:column;align-items:center;gap:2px;transition:transform .2s;display:flex;position:absolute;transform:translate(-50%,-50%)}.player-avatar{border:3px solid var(--text-dim);background:linear-gradient(135deg, var(--bg-surface) 0%, var(--bg-elevated) 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:17px;font-weight:800;transition:all .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 12px #00000080}.player-seat:not(.eliminated) .player-avatar:after{content:"";background:0 0;border-radius:50%;transition:all .3s;position:absolute;inset:-3px}.player-seat.current-turn .player-avatar{border-color:var(--warning-yellow);box-shadow:0 0 14px var(--warning-glow), 0 0 28px #fbbf2426;animation:2s ease-in-out infinite turn-glow}@keyframes turn-glow{0%,to{box-shadow:0 0 14px var(--warning-glow), 0 0 28px #fbbf2426}50%{box-shadow:0 0 20px var(--warning-glow), 0 0 40px #fbbf2440}}.player-seat.is-me .player-avatar{border-color:var(--toxic-dim);box-shadow:0 0 10px var(--toxic-glow)}.player-seat.is-me.current-turn .player-avatar{border-color:var(--warning-yellow);box-shadow:0 0 14px var(--warning-glow), 0 0 28px #fbbf2426}.player-seat.eliminated .player-avatar{opacity:.25;border-color:var(--blood);filter:grayscale(.8)}.player-seat.quarantined .player-avatar{border-color:var(--ember);border-style:dashed;animation:1.5s ease-in-out infinite quarantine-pulse}@keyframes quarantine-pulse{0%,to{box-shadow:0 0 8px var(--ember-glow)}50%{box-shadow:0 0 16px var(--ember-glow)}}.player-seat.disconnected .player-avatar{opacity:.3;filter:grayscale();border-color:#444}.player-seat.disconnected .player-name{opacity:.3}.player-name{text-align:center;text-overflow:ellipsis;white-space:nowrap;letter-spacing:.3px;text-shadow:0 1px 4px #000c;max-width:68px;font-size:10px;font-weight:700;overflow:hidden}.player-hand-count{color:var(--text-dim);font-size:9px;font-weight:600}.barred-door-marker{background:linear-gradient(135deg, var(--obstacle-color), #b86e00);z-index:5;border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;display:flex;position:absolute;transform:translate(-50%,-50%);box-shadow:0 0 8px #d9770666}.direction-indicator{color:var(--text-dim);pointer-events:none;z-index:1;opacity:.6;font-size:22px;position:absolute;top:50%;left:50%;transform:translate(-50%,-80%)}.deck-display{z-index:1;align-items:center;gap:10px;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.deck-pile{border-radius:6px;justify-content:center;align-items:center;width:44px;height:62px;font-size:15px;font-weight:800;display:flex;box-shadow:0 4px 12px #00000080}.deck-pile.draw{box-shadow:0 4px 12px #00000080, 0 0 8px var(--alien-glow);background:linear-gradient(135deg,#1a1a3a,#2a2a5a);border:2px solid #8b5cf666}.deck-pile.discard{background:linear-gradient(135deg,#1a1a1e,#2a2a30);border:2px solid #ffffff14}.game-card{width:var(--card-width);height:var(--card-height);cursor:pointer;text-align:center;-webkit-user-select:none;user-select:none;border:2px solid #ffffff14;border-radius:10px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;padding:8px 6px;font-size:10px;transition:transform .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 16px #00000080}.game-card:before{content:"";pointer-events:none;background:linear-gradient(#ffffff0f 0%,#0000 100%);border-radius:8px 8px 0 0;height:40%;position:absolute;top:0;left:0;right:0}.game-card:hover{z-index:10;transform:translateY(-8px)}.game-card.selected{border-color:var(--warning-yellow);box-shadow:0 0 16px var(--warning-glow), 0 0 32px #fbbf2426, 0 8px 24px #0006;transform:translateY(-12px)}.game-card.locked{border-color:#ffffff0a}.game-card.infection{background:linear-gradient(160deg,#2d1b4e 0%,#4c1d95 40%,#3b1280 100%);border-color:#7c3aed4d;box-shadow:0 4px 16px #4c1d954d}.game-card.action{background:linear-gradient(160deg,#0c2340 0%,#1e40af 40%,#1a3590 100%);border-color:#2563eb4d;box-shadow:0 4px 16px #1e40af4d}.game-card.defense{background:linear-gradient(160deg,#0a2e1a 0%,#15803d 40%,#0f6b32 100%);border-color:#16a34a4d;box-shadow:0 4px 16px #15803d4d}.game-card.obstacle{background:linear-gradient(160deg,#3a2500 0%,#b45309 40%,#92400e 100%);border-color:#d977064d;box-shadow:0 4px 16px #b453094d}.game-card.panic{background:linear-gradient(160deg,#3b0a0a 0%,#b91c1c 40%,#991b1b 100%);border-color:#dc26264d;box-shadow:0 4px 16px #b91c1c4d}.game-card .card-name{text-shadow:0 1px 3px #0009;letter-spacing:.3px;margin-bottom:4px;font-size:10px;font-weight:800;line-height:1.2}.game-card .card-desc{color:#ffffffb3;-webkit-line-clamp:4;-webkit-box-orient:vertical;font-size:7.5px;line-height:1.3;display:-webkit-box;overflow:hidden}.game-card .card-badge{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:8px;font-weight:800;display:flex;position:absolute;top:4px;right:4px}.hand-area{-webkit-overflow-scrolling:touch;scrollbar-width:none;z-index:1;background:0 0;flex-wrap:nowrap;flex-shrink:0;justify-content:center;gap:6px;padding:8px 10px;display:flex;position:relative;overflow-x:auto}.hand-area::-webkit-scrollbar{display:none}.action-panel{z-index:1;background:0 0;flex-wrap:wrap;flex-shrink:0;justify-content:center;align-items:center;gap:6px;min-height:38px;padding:6px 10px;display:flex;position:relative}.log-toggle{background:var(--bg-dark);border:none;border-top:1px solid var(--border-subtle);width:100%;color:var(--text-dim);text-align:center;cursor:pointer;letter-spacing:.5px;z-index:1;border-radius:0;flex-shrink:0;padding:7px;font-size:11px;font-weight:600;display:block;position:relative}.game-log-wrapper{z-index:1;flex-shrink:0;max-height:140px;position:relative;overflow:hidden}.game-log{background:var(--bg-card);max-height:140px;padding:6px 12px;font-size:11px;overflow-y:auto}.game-log .log-entry{border-bottom:1px solid var(--border-subtle);color:var(--text-dim);padding:4px 0;font-size:11px;line-height:1.4}.game-log .log-entry:last-child{color:var(--text);border-bottom:none;font-weight:500}.role-badge{letter-spacing:.5px;text-transform:uppercase;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:6px;padding:3px 10px;font-size:10px;font-weight:800;display:inline-block}.role-badge.human{color:var(--ice-blue);background:linear-gradient(135deg,#38bdf833,#38bdf81a);border:1px solid #38bdf84d}.role-badge.the_thing{color:var(--alien-purple);text-shadow:0 0 8px var(--alien-glow);background:linear-gradient(135deg,#8b5cf640,#8b5cf61a);border:1px solid #8b5cf666}.role-badge.infected{color:var(--text-blood);background:linear-gradient(135deg,#dc262640,#dc26261a);border:1px solid #dc26264d;animation:2s ease-in-out infinite infected-badge}@keyframes infected-badge{0%,to{border-color:#dc26264d}50%{border-color:#dc262699}}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100;background:#000c;justify-content:center;align-items:center;padding:16px;animation:.25s ease-out modal-in;display:flex;position:fixed;inset:0}@keyframes modal-in{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-card);border:1px solid var(--border-glow);border-radius:16px;width:100%;max-width:440px;max-height:80vh;padding:24px;overflow-y:auto;box-shadow:0 0 40px #0009,0 0 2px #8b5cf633}.timer-bar{background:linear-gradient(90deg, var(--blood), var(--ember));height:3px;box-shadow:0 0 6px var(--blood-glow);border-radius:2px;transition:width .1s linear}.player-list{padding:0;list-style:none}.player-list li{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:10px;align-items:center;gap:8px;margin:5px 0;padding:12px 14px;font-weight:500;transition:border-color .2s;display:flex}.player-list li:hover{border-color:var(--border-glow)}.player-list .host-badge{background:linear-gradient(135deg, var(--warning-yellow), #f59e0b);color:#000;letter-spacing:.5px;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:800}.results-player{background:var(--bg-surface);border-radius:var(--border-radius);align-items:center;gap:12px;margin:4px 0;padding:10px;display:flex}.results-player.winner{border:2px solid var(--defense-color)}.results-player.loser{opacity:.6}@media (width>=600px){:root{--card-width:100px;--card-height:142px}.game-card .card-name{font-size:12px}.game-card .card-desc{font-size:8.5px}.direction-indicator{font-size:28px}.deck-pile{width:52px;height:72px;font-size:17px}.player-avatar{width:72px;height:72px;font-size:19px}.player-name{max-width:80px;font-size:11px}.player-hand-count{font-size:10px}.hand-area{gap:8px;padding:12px 16px 10px}.action-panel{padding:8px 14px}.game-log{max-height:180px}.topbar-phase{font-size:13px}}@media (width>=900px){:root{--card-width:115px;--card-height:162px}.game-card .card-name{font-size:13px}.game-card .card-desc{-webkit-line-clamp:5;font-size:9px}.hand-area{gap:10px}.player-avatar{width:90px;height:90px;font-size:22px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes glitch{0%,to{transform:translate(0)}20%{transform:translate(-2px,1px)}40%{transform:translate(2px,-1px)}60%{transform:translate(-1px,-1px)}80%{transform:translate(1px,1px)}}
