:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color:#333;background-color:#fafafa}body{margin:0;min-width:320px;min-height:100vh}button{font-family:inherit}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Open Sans,sans-serif;background:#fafafa;color:#333;min-height:100vh}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:#fff;padding:2rem;border-radius:12px;display:flex;flex-direction:column;gap:1rem;min-width:300px}.modal input{padding:.75rem;border:2px solid #ddd;border-radius:8px;font-size:1rem}.modal button{padding:.75rem;border:none;border-radius:8px;background:#1976d2;color:#fff;font-size:1rem;cursor:pointer}.modal button:disabled{opacity:.5}.landing{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.landing h1{font-size:2.5rem;color:#1976d2}.create-btn{padding:1rem 2rem;font-size:1.2rem;border:none;border-radius:12px;background:#1976d2;color:#fff;cursor:pointer;transition:transform .1s}.create-btn:hover{transform:scale(1.05)}.change-name-btn{padding:.5rem 1rem;border:1px solid #999;border-radius:8px;background:transparent;cursor:pointer}.lobby{max-width:800px;margin:2rem auto;padding:1rem}.lobby h2{text-align:center;margin-bottom:1rem}.invite-link{display:flex;gap:.5rem;margin-bottom:1.5rem}.invite-link input{flex:1;padding:.5rem;border:1px solid #ddd;border-radius:8px;font-size:.9rem}.invite-link button{padding:.5rem 1rem;border:none;border-radius:8px;background:#1976d2;color:#fff;cursor:pointer}.teams-container{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.team-panel{border:3px solid;border-radius:12px;padding:1rem}.team-panel h3{text-align:center;margin-bottom:.75rem}.team-players{min-height:60px;margin-bottom:.75rem}.team-player{display:flex;justify-content:space-between;padding:.25rem 0}.team-player.offline{opacity:.4}.role-badge{font-size:1.1rem}.join-btn{width:100%;padding:.6rem;border:none;border-radius:8px;color:#fff;font-size:1rem;cursor:pointer}.role-buttons{display:flex;gap:.5rem}.role-buttons button{flex:1;padding:.5rem;border:1px solid #999;border-radius:8px;background:#fff;cursor:pointer}.role-buttons button:hover{background:#f0f0f0}.lobby-players{margin-bottom:1rem}.player-chip{display:inline-block;padding:.25rem .75rem;margin:.25rem;background:#e0e0e0;border-radius:16px;font-size:.9rem}.start-btn{display:block;width:100%;padding:1rem;border:none;border-radius:12px;background:#4caf50;color:#fff;font-size:1.2rem;cursor:pointer}.start-btn:hover{background:#43a047}.error-banner{background:#ffebee;color:#c62828;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;cursor:pointer;text-align:center}.game-wrapper{display:flex;justify-content:center}.game-page{padding:0 1rem;margin:1rem auto;max-width:900px}.game-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.score{font-size:1.5rem;font-weight:700}.score-red{color:#d32f2f}.score-blue{color:#1976d2}.turn-indicator{font-size:1.1rem;font-weight:600}.spy-badge{background:#333;color:#ffd600;padding:.3rem .75rem;border-radius:16px;font-size:.85rem;font-weight:600}.clue-display{text-align:center;margin-bottom:1rem;font-size:1.3rem}.clue-word{font-weight:700;text-transform:uppercase;margin-right:.5rem}.clue-number{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;background:#333;color:#fff;font-weight:700;margin-right:.5rem}.guesses-left{color:#666;font-size:.9rem}.clue-input{display:flex;gap:.5rem;margin-bottom:1rem;justify-content:center}.clue-input input{padding:.6rem;border:2px solid #ddd;border-radius:8px;font-size:1rem;width:200px}.clue-input select{padding:.6rem;border:2px solid #ddd;border-radius:8px;font-size:1rem}.clue-input button{padding:.6rem 1rem;border:none;border-radius:8px;background:#4caf50;color:#fff;cursor:pointer}.clue-input button:disabled{opacity:.5}.clue-history-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.clue-history{background:#fff;border:1px solid #e2e2e2;border-radius:12px;width:250px;padding:1rem}.clue-history h3{font-size:1rem;margin-bottom:.75rem}.clue-history-red h3{color:#d32f2f}.clue-history-blue h3{color:#1976d2}.clue-history-empty{color:#777;font-size:.95rem}.clue-history-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.clue-history-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;border-radius:8px;background:#f6f6f6}.clue-history-word{font-size:.75rem;font-weight:600;text-transform:uppercase}.clue-history-number{min-width:2rem;text-align:center;color:000;font-weight:700}.board{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:1rem}.card{aspect-ratio:1.4;display:flex;align-items:center;justify-content:center;border:2px solid #ddd;border-radius:10px;font-size:.85rem;font-weight:600;text-transform:uppercase;cursor:pointer;transition:transform .1s,box-shadow .1s;padding:4px;text-align:center;word-break:break-word}.card:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.card:disabled{cursor:default}.card.revealed{border-color:transparent;opacity:.85}.card.hinted{border-style:dashed}.end-guessing-btn{display:block;margin:0 auto 1rem;padding:.75rem 2rem;border:2px solid #ff9800;border-radius:8px;background:#fff;color:#ff9800;font-size:1rem;font-weight:600;cursor:pointer}.end-guessing-btn:hover{background:#fff3e0}.game-over-banner{text-align:center;padding:1.5rem;border:3px solid;border-radius:12px;margin-bottom:1rem;background:#fff}.game-over-banner button{margin-top:1rem;padding:.75rem 2rem;border:none;border-radius:8px;background:#1976d2;color:#fff;font-size:1rem;cursor:pointer}.game-players{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1rem}.game-team h4{margin-bottom:.5rem}.red-team h4{color:#d32f2f}.blue-team h4{color:#1976d2}.player-tag{display:inline-block;padding:.2rem .5rem;margin:.15rem;background:#f0f0f0;border-radius:12px;font-size:.85rem}.player-tag.offline{opacity:.4}.join-team-modal{text-align:center}.join-team-options{display:flex;gap:1rem}.join-team-btn{flex:1;padding:1.5rem 1rem;border:3px solid;border-radius:12px;background:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.5rem;transition:transform .1s}.join-team-btn:hover{transform:scale(1.05)}.join-team-red{border-color:#d32f2f;color:#d32f2f}.join-team-blue{border-color:#1976d2;color:#1976d2}.join-team-name{font-size:1.2rem;font-weight:700}.join-team-count{font-size:.85rem;opacity:.7}.loading{text-align:center;padding:3rem;font-size:1.2rem;color:#999}@media(max-width:768px){.clue-history-grid,.game-players,.teams-container{grid-template-columns:1fr}}
