*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0D1117;--surface: #161B22;--surface-2: #1C2128;--border: #30363D;--primary: #7C3AED;--primary-hover: #6D28D9;--primary-light: #A78BFA;--gold: #F59E0B;--gold-hover: #D97706;--gold-light: #FDE68A;--text: #F0F6FC;--text-muted: #8B949E;--text-subtle: #6E7681;--success: #3FB950;--danger: #F85149;--card-bg: #FFFFFF;--card-text: #0D1117;--radius: 12px;--radius-sm: 8px;--shadow: 0 4px 24px rgba(0, 0, 0, .4);--shadow-card: 0 2px 12px rgba(0, 0, 0, .3)}html,body,#root{height:100%;width:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100dvh}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.text-center{text-align:center}.w-full{width:100%}.relative{position:relative}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;border:none;cursor:pointer;transition:background .15s,transform .1s,opacity .15s;text-decoration:none;white-space:nowrap;letter-spacing:.01em}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-gold{background:var(--gold);color:#0d1117}.btn-gold:hover:not(:disabled){background:var(--gold-hover)}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text);border-color:var(--text-subtle)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#d63031}.btn-lg{padding:.875rem 1.75rem;font-size:1rem}.btn-sm{padding:.4rem .875rem;font-size:.8rem}.input{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.95rem;padding:.625rem .875rem;width:100%;transition:border-color .15s,box-shadow .15s;outline:none}.input::placeholder{color:var(--text-subtle)}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #7c3aed40}.input-lg{font-size:1.1rem;padding:.75rem 1rem;letter-spacing:.1em;font-weight:700;text-transform:uppercase}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.play-card{background:var(--card-bg);color:var(--card-text);border-radius:10px;padding:.875rem .75rem;min-height:120px;width:90px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;font-size:.8rem;font-weight:600;line-height:1.3;cursor:pointer;-webkit-user-select:none;user-select:none;border:2px solid transparent;box-shadow:var(--shadow-card);transition:transform .15s,box-shadow .15s,border-color .15s;flex-shrink:0}.play-card:hover{transform:translateY(-6px);box-shadow:0 8px 24px #0006}.play-card.selected{border-color:var(--primary);transform:translateY(-10px);box-shadow:0 8px 24px #7c3aed80}.play-card.played{opacity:.6;cursor:default;transform:none}.play-card.played:hover{transform:none}.play-card.adjective{background:#1a0f00;color:var(--gold-light);border-color:var(--gold);min-height:110px;width:110px;font-size:.9rem;cursor:default}.play-card.adjective:hover{transform:none}.play-card.face-down{background:var(--primary);border-color:var(--primary-light);cursor:default}.play-card.face-down:hover{transform:none}.play-card.winner-candidate{border-color:var(--gold);cursor:pointer}.play-card.winner-candidate:hover{transform:translateY(-8px);box-shadow:0 8px 24px #f59e0b66;border-color:var(--gold-hover)}.page{min-height:100dvh;padding:1rem;display:flex;flex-direction:column}.page-center{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1rem}.room-code{font-size:2.5rem;font-weight:800;letter-spacing:.15em;color:var(--primary-light);font-family:Courier New,monospace;cursor:pointer;padding:.5rem 1rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);transition:background .15s;text-align:center}.room-code:hover{background:var(--surface)}.player-chip{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border)}.player-chip .avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0;background:var(--primary);color:#fff}.player-chip.is-judge .avatar{background:var(--gold);color:#0d1117}.player-chip.is-you{border-color:var(--primary)}.score-badge{background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:.2rem .6rem;font-size:.8rem;font-weight:700;color:var(--text-muted)}.alert{padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.875rem}.alert-error{background:#f8514926;border:1px solid rgba(248,81,73,.4);color:#ff7b7b}.alert-info{background:#7c3aed26;border:1px solid rgba(124,58,237,.4);color:var(--primary-light)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;width:100%;max-width:400px;box-shadow:var(--shadow)}.game-page{min-height:100dvh;display:grid;grid-template-rows:auto 1fr auto;overflow:hidden}.game-header{background:var(--surface);border-bottom:1px solid var(--border);padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.game-table{overflow-y:auto;padding:1rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.player-hand{background:var(--surface);border-top:1px solid var(--border);padding:1rem;overflow-x:auto}.hand-cards{display:flex;gap:.75rem;overflow-x:auto;padding-bottom:.25rem;justify-content:center;flex-wrap:nowrap;min-width:min-content}.plays-area{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;padding:.5rem}.play-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}.play-argument{font-size:.7rem;color:var(--text-muted);max-width:90px;text-align:center;font-style:italic;line-height:1.3;word-break:break-word}.play-player-name{font-size:.7rem;color:var(--text-subtle);max-width:90px;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-bar{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.625rem 1rem;font-size:.875rem;color:var(--text-muted);text-align:center}.argument-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;width:100%;max-width:400px}.score-row{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border)}.score-row.winner{border-color:var(--gold);background:#f59e0b1a}.score-row .rank{font-weight:800;color:var(--text-muted);min-width:1.5rem;text-align:center}.score-row.winner .rank{color:var(--gold)}.score-bar{flex:1;height:6px;background:var(--surface);border-radius:999px;overflow:hidden}.score-bar-fill{height:100%;background:var(--primary);border-radius:999px;transition:width .5s ease}.score-row.winner .score-bar-fill{background:var(--gold)}.label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .25s ease forwards}@media (max-width: 480px){.play-card{width:76px;min-height:104px;font-size:.72rem;padding:.625rem .5rem}.play-card.adjective{width:96px;min-height:96px}.room-code{font-size:2rem}.modal{padding:1.5rem}}
