@import url(https://fonts.googleapis.com/css2?family=Jersey+10&display=swap);.app{display:flex;flex-direction:column;min-height:100vh}.loading{height:100vh;justify-content:center}.app-header,.loading{align-items:center;display:flex}.app-header{border-bottom:1px dashed var(--text-secondary);color:var(--text-primary);justify-content:space-between;padding:.5rem 2rem}.app-header h1{font-size:2rem}.user-info{align-items:center;display:flex;gap:1rem}.user-info span{white-space:nowrap}.app-main{flex:1 1;margin:0 auto;max-width:1200px;padding:2rem;width:100%}.main-actions{gap:1.5rem;margin-bottom:2rem}.main-actions,.modal-overlay{display:flex;justify-content:center}.modal-overlay{align-items:center;background-color:#0000004d;bottom:0;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border:2px solid var(--text-secondary);border-radius:8px;display:flex;flex-direction:column;max-height:80vh;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;flex-shrink:0;justify-content:space-between;margin-bottom:1.5rem;padding:1.5rem 1.5rem 0}.modal-title{color:var(--text-primary);font-size:1.5rem;margin:0}.modal-body{flex:1 1;overflow-y:auto;padding:0 1.5rem 1.5rem}.modal-content:not(:has(.modal-header)) .modal-body{padding:1.5rem}@media (max-width:768px){.modal-content{margin:1rem;max-height:calc(100vh - 2rem)}.modal-header{margin-bottom:1rem;padding:1rem 1rem 0}.modal-body{padding:0 1rem 1rem}.modal-content:not(:has(.modal-header)) .modal-body{padding:1rem}}.login-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem;width:100%}.login-header h3{color:var(--text-primary);font-size:1.125rem;margin:0}.login-form{width:100%}.form-group,.login-form{display:flex;flex-direction:column}.form-group input{width:100%}.form-group input:disabled{background-color:#f8f9fa;cursor:not-allowed}.form-group input::placeholder,.form-group input:disabled{color:var(--text-secondary)}.error-message{color:#dc3545;font-size:.75rem;margin-bottom:.5rem;text-align:center}.login-help-text{color:var(--text-secondary);font-size:.8rem;line-height:1.4;margin:.75rem 0 0;text-align:center}@media (max-width:768px){.login-header{margin-bottom:1rem}}.lobby{margin:0 auto;max-width:800px}.lobby-loading{color:var(--text-secondary);padding:2rem;text-align:center}.lobby-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.lobby-header h2{color:var(--text-primary);font-size:1.8rem}.offline-message{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:4rem 2rem;text-align:center}.offline-message h2{color:var(--text-primary);font-size:1.5rem;margin-bottom:1rem}.offline-message p{color:var(--text-secondary);font-size:1rem;line-height:1.5;margin-bottom:2rem}.error-message{margin-bottom:1rem}.rooms-list{display:flex;flex-direction:column;gap:1rem}.no-rooms{color:var(--text-secondary);padding:3rem;text-align:center}.room-card{align-items:center;background:#fff;border:1px solid #e9ecef;border-radius:8px;display:flex;justify-content:space-between;padding:1.5rem;transition:box-shadow .2s}.room-card:hover{border-color:var(--primary)}.room-info h3{color:var(--text-primary);font-size:1.2rem;margin-bottom:.5rem}.room-details{align-items:center;display:flex;gap:1rem}.game-name{font-size:.8rem}.player-count{color:var(--text-secondary);font-size:.9rem}.status{border-radius:12px;font-size:.8rem;padding:.25rem .75rem;text-transform:capitalize}.status.waiting{background:#fff3cd;color:#856404}.status.playing{background:#d1ecf1;color:#0c5460}.room-actions{display:flex;gap:.5rem;justify-content:center}@keyframes jiggle{0%,to{transform:translateY(0)}20%{transform:translateY(-6px)}40%{transform:translateY(4px)}60%{transform:translateY(-3px)}80%{transform:translateY(2px)}}.refresh-button.jiggling{animation:jiggle .6s ease-in-out}.game-options{margin:1.5rem 0}.game-options-title{color:var(--text-primary);font-size:1.1rem;margin:0 0 1rem}.game-options-list{gap:1rem}.game-option,.game-options-list{display:flex;flex-direction:column}.game-option{gap:.5rem}.game-option-label{color:var(--text-primary);font-size:.9rem}.game-option-select{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;background-size:1rem;cursor:pointer;padding-right:2.5rem;width:100%}.game-option-select:disabled{background-color:#f8f9fa;color:var(--text-secondary);cursor:not-allowed}.game-option-toggle{align-items:center;cursor:pointer;display:flex;gap:.5rem;-webkit-user-select:none;user-select:none}.game-option-toggle input[type=checkbox]{background-color:#fff;border:2px solid #e9ecef;border-radius:3px;cursor:pointer;height:1.2rem;position:relative;transition:all .2s ease;width:1.2rem}.game-option-toggle input[type=checkbox]:checked{background-color:var(--primary);border-color:var(--primary)}.game-option-toggle input[type=checkbox]:checked:after{color:#fff;content:"✓";font-size:.8rem;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.game-option-toggle input[type=checkbox]:disabled{cursor:not-allowed}.game-option-number{width:100%}.game-option-number:disabled{background-color:#f8f9fa;color:var(--text-secondary);cursor:not-allowed}.game-option-description{color:var(--text-secondary);font-size:.8rem;font-style:italic;margin-top:.25rem}@media (max-width:768px){.game-options{margin:1rem 0}.game-options-title{font-size:1rem}.game-option-number,.game-option-select{font-size:.9rem;padding:.6rem}}.game-select{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;background-size:1rem;cursor:pointer;padding-right:2.5rem;width:100%}.game-select:disabled{background-color:#f8f9fa;color:var(--text-secondary);cursor:not-allowed}.game-options{margin-top:1.5rem}.game-options h3{color:var(--text-primary);font-size:1.2rem;margin:0 0 1rem}.option-buttons{display:flex;gap:10px}.option-btn{background:#fff;border:2px solid #e9ecef;border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:.9rem;padding:8px 16px;transition:all .2s ease}.option-btn:hover{background:#f8f9fa;border-color:var(--primary)}.option-btn.selected{background:var(--primary);border-color:var(--primary);color:#fff}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--text-primary);display:block;margin-bottom:.5rem}.board-size-select,.game-select,.room-name-input{width:100%}.board-size-select,.game-select{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;background-size:1rem;cursor:pointer;padding-right:2.5rem}.board-size-select:disabled,.game-select:disabled,.room-name-input:disabled{background-color:#f8f9fa;color:var(--text-secondary);cursor:not-allowed}.modal-footer{border-top:1px solid #e9ecef;display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1.5rem}.room-page{margin:0 auto;max-width:800px}.room-loading{color:var(--text-secondary);padding:2rem;text-align:center}.room-error{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:4rem 2rem;text-align:center}.room-error h2{color:var(--text-primary);font-size:1.5rem;margin-bottom:1rem}.room-error p{color:var(--text-secondary);font-size:1rem;line-height:1.5;margin-bottom:2rem}.room-header{align-items:flex-start;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.room-info h1{color:var(--text-primary);font-size:2rem;margin-bottom:.5rem}.room-meta{align-items:center;display:flex;gap:1rem}.game-name{border:1px solid var(--text-primary)}.game-name,.room-status{border-radius:12px;font-size:.9rem;padding:.25rem .75rem}.room-status{text-transform:capitalize}.room-status.waiting{background:#fff3cd;color:#856404}.room-status.playing{background:#d1ecf1;color:#0c5460}.error-message{background:#fee;border-radius:6px;color:#c33;margin-bottom:2rem;padding:1rem}.room-content{grid-gap:2rem;display:grid;gap:2rem}.players-section h2{color:var(--text-primary);font-size:1.5rem;margin-bottom:1rem}.players-list{display:flex;flex-direction:column;gap:.75rem}.player-card{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:1rem;transition:box-shadow .2s}.player-info{gap:.75rem}.player-name{color:var(--text-primary)}.badge{border-radius:8px;font-size:.75rem;padding:.2rem .5rem;text-transform:uppercase}.badge.creator{background:#ffeaa7;color:#d63031}.no-players{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;color:var(--text-secondary);padding:2rem;text-align:center}.room-actions{margin-top:2rem;text-align:center}.waiting-message{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:2rem}.waiting-message p{color:var(--text-secondary);font-size:1rem;margin:0}.game-in-progress{background:#d1ecf1;border:1px solid #bee5eb;border-radius:8px;padding:2rem}.game-in-progress h3{color:#0c5460;font-size:1.2rem;margin-bottom:.5rem}.game-in-progress p{color:#0c5460;margin:0}.game-page{background:var(--background);display:flex;flex-direction:column;min-height:60vh}.game-header{align-items:center;display:flex;justify-content:center;margin:0}.game-title{font-size:2rem;margin:0}.game-container{display:flex;flex:1 1;justify-content:center}.game-loading{padding:40px 20px;text-align:center}.game-loading h2{color:var(--primary);font-size:1.5rem;margin-bottom:10px}.game-loading p{color:var(--text-secondary);font-size:1rem}.game-error{padding:40px 20px;text-align:center}.game-error h2{color:var(--error);font-size:1.5rem;margin-bottom:10px}.game-error p{color:var(--text-secondary);font-size:1rem}.game-actions{border-top:1px dashed var(--text-secondary);display:flex;gap:1rem;justify-content:center;padding:20px}.rules-content{line-height:1.6}.rules-content p:empty{margin-bottom:.4rem}@media (max-width:768px){.game-header{flex-direction:column;gap:.5rem}}.gobblet-container{align-items:center;display:flex;flex-direction:column;margin-bottom:100px}.player-area.top{margin-bottom:20px}.player-area.bottom{margin-top:20px}.player-info{align-items:center;gap:10px;margin-bottom:10px}.player-name{color:var(--text);font-size:1rem}.turn-indicator{border-radius:12px;font-size:.8rem;padding:4px 8px}.current-turn,.turn-indicator{background:var(--primary);color:#fff}.current-turn{border-radius:20px;font-size:.9rem;padding:4px 12px}.inventory-pieces{align-items:center;display:flex;gap:15px;justify-content:center}.inventory-piece-container{align-items:center;display:flex;flex-direction:column;gap:5px}.inventory-piece{align-items:center;border:3px solid;border-radius:50%;display:flex;font-size:1.2rem;height:50px;justify-content:center;transition:all .2s ease;width:50px}.draggable-piece .inventory-piece:hover{border:2px solid var(--primary);transform:scale(1.05)}.draggable-piece .inventory-piece:active{cursor:grabbing}.non-draggable-piece .inventory-piece{cursor:default;opacity:.7}.piece-count{color:#666;font-size:.9rem}.game-board{grid-gap:1px;background:#ddd;border:1px solid var(--text-secondary);border-radius:12px;display:grid;gap:1px;outline:1px solid #ddd;overflow:hidden}.game-board.board-4x4{grid-template-columns:repeat(4,80px);grid-template-rows:repeat(4,80px)}.game-board.board-3x3{grid-template-columns:repeat(3,90px);grid-template-rows:repeat(3,90px)}.board-cell{background:#fff;cursor:pointer;position:relative;transition:all .2s ease}.board-cell:hover{background:#e9ecef;border-color:#adb5bd}.board-cell.drag-over{background:#e3f2fd;border-color:var(--primary)}.board-cell.drop-target{background:#4a90e21a;border-color:var(--primary);border-width:2px}.board-cell.invalid-drop{background:#f443361a;border-color:#f44336;border-color:var(--error,#f44336)}.cell-pieces{height:100%;position:relative;width:100%}.cell-pieces,.piece{align-items:center;display:flex;justify-content:center}.piece{border-radius:50%;color:#fff;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .2s ease}.draggable-piece .piece:hover{transform:translate(-50%,-50%) scale(1.05)!important}.draggable-piece .piece:active{cursor:grabbing}.non-draggable-piece .piece{cursor:default}.inventory-piece.piece-small,.piece-small{font-size:.8rem;height:30px;width:30px}.inventory-piece.piece-medium,.piece-medium{font-size:1rem;height:40px;width:40px}.inventory-piece.piece-large,.piece-large{font-size:1.2rem;height:50px;width:50px}.inventory-piece.piece-huge,.piece-huge{font-size:1.4rem;height:60px;width:60px}.inventory-piece.piece-player1,.piece-player1{background:var(--primary);color:#fff}.inventory-piece.piece-player2,.piece-player2{background:var(--secondary);color:#fff}.game-status{margin-top:20px;text-align:center}.turn-indicator{background:#fff;border:2px solid var(--primary);border-radius:25px;color:#333;font-size:1.2rem;padding:10px 20px}.game-over{border-radius:25px;font-size:1.5rem;padding:15px 30px;text-align:center}.winner.you-won{background:#d4edda;border:2px solid #28a745;color:#155724}.winner.you-lost{background:#f8d7da;border:2px solid #dc3545;color:#721c24}.tie{background:#fff3cd;border:2px solid #ffc107;color:#856404}.back-to-lobby-btn{margin-top:20px}.loading{color:#333;padding:40px}@media (max-width:768px){.gobblet-container{padding:10px}.game-board.board-4x4{grid-template-columns:repeat(4,60px);grid-template-rows:repeat(4,60px)}.game-board.board-3x3{grid-template-columns:repeat(3,70px);grid-template-rows:repeat(3,70px)}.piece-small{font-size:.7rem;height:24px;width:24px}.piece-medium{font-size:.9rem;height:32px;width:32px}.piece-large{font-size:1.1rem;height:40px;width:40px}.piece-huge{font-size:1.3rem;height:48px;width:48px}.inventory-pieces{gap:10px}.inventory-piece{font-size:1rem;height:40px;width:40px}}.game-end-content{padding:1rem 0;text-align:center}.game-result-icon{animation:bounce .6s ease-in-out;font-size:4rem;margin-bottom:1rem}.game-result-title{animation:fadeInUp .5s ease-out .2s both;font-size:2rem;margin:0 0 2rem}.game-result-message{color:var(--text-secondary);font-size:1.1rem;line-height:1.5;margin:0 0 2rem}.game-end-actions,.game-result-message{animation:fadeInUp .5s ease-out .4s both}.game-end-actions{display:flex;gap:1rem;justify-content:center}.game-result-win .game-result-title{color:#28a745}.game-result-loss .game-result-title{color:#dc3545;color:var(--error,#dc3545)}.game-result-tie .game-result-title{color:var(--secondary)}.game-result-neutral .game-result-title{color:var(--text-primary)}@keyframes bounce{0%,20%,53%,80%,to{transform:translateZ(0)}40%,43%{transform:translate3d(0,-20px,0)}70%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,-4px,0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.player-area{border:2px solid var(--border);border-radius:8px;display:flex;flex-direction:column;padding:1rem;transition:border-color .3s,opacity .3s}.player-area.active{border-style:solid;border-width:2px}.player-area.disabled{background:#f5f5f5;opacity:.5}.player-area .player-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem;width:100%}.player-area .player-name{font-size:1.1rem}.player-area .player-name.current-user{text-decoration:underline}.players-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem;max-width:1200px;width:100%}@media (max-width:768px){.players-grid{grid-template-columns:1fr}}.liars-dice-container{align-items:center;background:var(--background);color:var(--text-primary);display:flex;flex-direction:column}.current-bid{padding:.5rem 1rem}.round-result{background:#f0f0f0;border:2px solid var(--primary);border-radius:.5rem;margin-bottom:1rem;max-width:500px;padding:1rem;text-align:center}.round-result h3{color:var(--primary);margin:0 0 .5rem}.round-result p{margin:.25rem 0}.dice-count{border-radius:.25rem;color:var(--text-primary);font-size:.9rem;padding:.25rem .5rem}.player-dice{display:flex;flex-wrap:wrap;gap:.5rem;min-height:3rem}.die{align-items:center;background:#fff;border:2px solid var(--text-primary);border-radius:.5rem;color:var(--text-primary);display:flex;font-size:1.2rem;height:2.5rem;justify-content:center;width:2.5rem}.die.hidden{border-color:var(--text-secondary);color:var(--text-secondary)}.game-controls{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;padding:1.5rem}.bid-controls{flex-direction:column}.bid-controls,.bid-inputs{align-items:center;display:flex;gap:1rem}.bid-inputs label{display:flex;flex-direction:column;gap:.25rem}.bid-inputs input,.bid-inputs select{width:80px}.bid-actions{display:flex;gap:1rem}.my-dice{display:flex;gap:.5rem;height:40px;text-align:center}.my-dice h3{color:var(--text-primary);margin:0 0 1rem}.dice-display{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.loading{font-size:1.2rem}.dice-info{color:var(--text-secondary);display:flex;font-size:1.1rem;gap:2rem;justify-content:center;margin-top:.5rem}.personal-dice-area .dice-display{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:1rem}.no-dice{color:var(--text-secondary);font-size:1.1rem;font-style:italic}.back-controls{margin-top:2rem}@media (max-width:768px){.bid-inputs{flex-direction:column;gap:.5rem}.bid-actions{flex-direction:column;width:100%}.dice-info{flex-direction:column;gap:.5rem}}.round-end-content{padding:1rem 0;text-align:center}.round-end-actions{align-items:center;display:flex;flex-direction:column;gap:1rem;margin-top:2rem}.continue-status{color:var(--text-secondary);font-size:.9rem;font-style:italic}.round-end-content h3{color:var(--text-primary);margin:0 0 1rem}.round-end-content p{color:var(--text-primary);line-height:1.4;margin:.5rem 0}.sniper-holdem-container{align-items:center;display:flex;flex-direction:column;margin:0 auto;max-width:1200px;padding:1rem}.current-bet,.pot-info{color:var(--primary);font-size:1.1rem;margin:.5rem 0}.player-controls{align-items:center;display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.player-betting-controls{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.player-betting-area{margin:.5rem 0;min-height:80px}.community-area{margin-bottom:2rem;text-align:center}.community-area h3{color:var(--text-primary);margin-bottom:1rem}.community-cards{display:flex;gap:.5rem;justify-content:center;margin-bottom:1rem}.card{display:inline-block;height:109px;width:80px}.card.placeholder{align-items:center;background:#f8f8f8;border:2px dashed #ccc;border-radius:8px;color:#ccc;display:flex;font-size:1.2rem;justify-content:center;padding:.5rem}.card.card-back{margin:2px;overflow:hidden}.card.card-back .card-image{height:auto;max-width:60px;width:100%}.player-area.current-turn{border-style:solid}.player-area.folded{background:#f5f5f5;opacity:.5}.player-info{display:flex;justify-content:space-between;width:100%}.player-name{font-size:1.1rem}.player-name.current-user{text-decoration:underline}.bet-amount,.chips-count{color:var(--text-secondary);font-size:.9rem}.bet-amount{color:var(--primary)}.player-cards{margin-bottom:.5rem}.hidden-cards{display:flex;gap:.25rem}.hand-declaration{color:var(--secondary);font-size:.8rem;margin-top:.5rem}.sniped-indicator{color:var(--primary);font-size:.8rem;margin-top:.5rem}.betting-controls{border-radius:8px;margin-bottom:1rem;padding:1rem}.bet-actions{flex-wrap:wrap;gap:1rem}.bet-actions,.raise-controls{align-items:center;display:flex}.raise-controls{gap:.5rem}.raise-controls input{width:120px}.showdown-controls{background:#fff;border:1px solid var(--text-secondary);border-radius:8px;margin-bottom:1rem;padding:1rem}.declare-hand,.snipe-controls{margin-bottom:1.5rem}.declare-hand h3,.snipe-controls h3{color:var(--text-primary);font-size:1.1rem;margin-bottom:.5rem}.declaration-inputs,.snipe-inputs{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.player-hand{text-align:center;width:100%}.hand-display{display:flex;gap:.5rem;justify-content:center}.loading{color:var(--text-secondary);padding:2rem;text-align:center}@media (max-width:768px){.community-cards{flex-wrap:wrap}.bet-actions,.declaration-inputs,.snipe-inputs{align-items:stretch;flex-direction:column}.player-betting-controls{flex-direction:column;gap:.5rem}}.local-game-controls{background:var(--surface-2);border-radius:8px;margin:1rem 0;padding:1rem;text-align:center}.current-player-info{color:var(--text-primary);font-size:1.1rem;margin-bottom:1rem}.hand-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.hand-header h3{color:var(--text-primary);margin:0}.hand-header .btn{margin-left:1rem}.peek-button:active{transform:scale(.95)}.peek-controls{margin-top:.5rem}.snipe-phase-controls{border-radius:8px;color:var(--text-primary);margin:1rem 0;padding:1.5rem;text-align:center}.snipe-actions{display:flex;gap:1rem;justify-content:center;margin-top:1rem}.showdown-results{border-radius:8px;margin:1rem 0;padding:1.5rem;text-align:center}.showdown-results h3{color:var(--primary);margin-bottom:.5rem}.winner-announcement{background:var(--success);border-radius:8px;color:#fff;font-size:1.2rem;margin-top:1rem;padding:1rem}.header-container{margin-bottom:1rem;text-align:center}.game-info{color:var(--text-secondary);display:flex;font-size:.9rem;gap:1rem;justify-content:center;margin-top:.5rem}.hand-number{color:var(--primary)}.players-remaining{color:var(--success)}.eliminated-count{color:var(--error)}.player-area.eliminated .player-name{text-decoration:line-through}.banned-hand-indicator{background:#ff450033;border:1px solid var(--primary);border-radius:4px;color:var(--primary);font-size:.8rem;margin-top:.5rem;padding:.25rem .5rem}.banned-hands-list{background:var(--surface-2);border-radius:8px;margin:1rem 0;padding:1rem}.banned-hands-list h4{color:var(--primary);margin:0 0 .5rem}.banned-hand-item{color:var(--text-secondary);font-size:.9rem;padding:.25rem 0}.player-chips-display{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.pot-display{display:flex;justify-content:center;margin:1rem 0}@media (max-width:768px){.player-chips-display{align-items:flex-start;flex-direction:column;gap:.5rem}}.playing-card{cursor:pointer;display:inline-block}.playing-card:hover{transform:translateY(-2px)}.playing-card.disabled{cursor:default;opacity:.6}.playing-card.disabled:hover{transform:none}.card-image{display:block;height:auto;image-rendering:pixelated;-webkit-user-select:none;user-select:none;width:80px}.playing-card.small .card-image{width:60px}.playing-card.large .card-image{width:100px}.playing-card.selected{border:3px solid #007bff;transform:translateY(-8px)}.playing-card.flipped .card-image{content:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAC8AAABACAYAAACKhS4jAAABhGlDQ1BJQ0MgUHJvZmlsZQAAeJx9kT1Iw0AcxV9TxaoVQTuIOGSouthFRRxrFYpQodQKrTqYXPoFTRqSFBdHwbXg4Mdi1cHFWVcHV0EQ/ABxF5wUXaTE/yWFFjEeHPfj3b3H3TtAqJeZanZEAVWzjFQ8Jmayq2LXK7oRwAB6MS4xU59LJhPwHF/38PH1LsKzvM/9OfqUnMkAn0gcZbphEW8Qz2xaOud94hArSgrxOfGEQRckfuS67PIb54LDAs8MGenUPHGIWCy0sdzGrGioxNPEYUXVKF/IuKxw3uKslquseU/+wmBOW1nmOs0RxLGIJSQhQkYVJZRhIUKrRoqJFO3HPPzDjj9JLplcJTByLKACFZLjB/+D392a+alJNykYAzpfbPtjFOjaBRo12/4+tu3GCeB/Bq60lr9SB2Y/Sa+1tPAR0L8NXFy3NHkPuNwBhp50yZAcyU9TyOeB9zP6piwweAv0rLm9Nfdx+gCkqavEDXBwCIwVKHvd492B9t7+PdPs7wd0iXKnEj/xSwAAARNJREFUeJztmjEOgzAMRQnq9FnpgejB4UBhpasrRxilAVp1aYz0vxQSheX5JTA5NGswRmkukufjHnRurwae84YcfBn6xnu6ad7WtxI8f+kty9CnYYwbvMY2PZ5AN81p5GzpzufxCH7GtYMvT8HLfBj9YHVobLaU+7VmS76ffjRn8LWB8YXpI7wHYND8WB9cQ/Og+UjzQvNC80LzcAIOmh/rFwCaF5oXmgfNR5rX0DwcgWtoHjQfaV5oXmheaB5OwEHzY/0CQPNC80LzoPlI8xqahyNwDc2D5iPNC83L/82HVMHagFZ2z3lLt/JZ39muQc5rX2V3wPXWV2lVeS1gKW7Fpdtxgz7yAq7Uyd3aojbMLzHeF+BAqQ9aFDJqAAAAAElFTkSuQmCC)}.playing-card.flip-on-hover{position:relative}.playing-card.flip-on-hover .hover-image{left:0;opacity:0;position:absolute;top:0}.playing-card.flip-on-hover:hover .default-image{opacity:0}.playing-card.flip-on-hover:hover .hover-image{opacity:1}.poker-chips-container{align-items:flex-end;display:flex;flex-wrap:wrap;gap:10px;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.poker-chips-single-stack,.poker-chips-stack{display:inline-block;min-height:48px;min-width:32px;position:relative}.poker-chip{align-items:center;cursor:none;display:flex;font-size:.8rem;justify-content:center;position:absolute;transition:transform .2s ease;width:32px}.poker-chip.draggable{cursor:grab}.poker-chip.draggable:active{cursor:grabbing}.poker-chip.draggable:hover{transform:translateY(-10px)}.chip-image{display:block;height:auto;image-rendering:pixelated;left:0;position:absolute;top:0;-webkit-user-select:none;user-select:none;width:100%}.poker-chips-pot{align-items:center;border:2px solid var(--border);border-radius:100px;display:flex;flex-direction:column;height:100%;justify-content:center;padding:1rem;transition:all .3s ease;width:100%}.pot-label{color:var(--text-primary);font-size:1.1rem;margin-bottom:.5rem}.pot-content{align-items:center;display:flex;flex-direction:column;gap:.5rem}.pot-empty{font-style:italic;text-align:center}.pot-empty,.pot-total{color:var(--text-secondary)}.pot-total{font-size:.9rem}.add-to-pot-btn{border-radius:6px;font-size:.8rem;margin-top:.5rem;padding:4px 8px}@media (max-width:768px){.poker-chips-pot{min-height:80px;min-width:120px;padding:.75rem}}.poker-chips-betting-area{align-items:center;background:#fff;border:2px dashed #ccc;border-radius:12px;display:flex;flex-direction:column;justify-content:center;min-height:100px;min-width:150px;padding:1rem;transition:all .3s ease}.poker-chips-betting-area.drop-target{background:#f4f4f4}.poker-chips-betting-area{opacity:.5;transition:opacity .3s ease,border-color .3s ease}.poker-chips-betting-area.drop-target,.poker-chips-betting-area.has-chips{opacity:1}.betting-area-label{color:var(--text-primary);font-size:1.1rem;margin-bottom:.5rem}.betting-area-content{align-items:center;display:flex;flex-direction:column;gap:.5rem}.betting-area-empty{color:var(--text-secondary);text-align:center}.betting-area-total{color:var(--text-secondary);font-size:.9rem}@media (max-width:768px){.poker-chips-betting-area{min-height:80px;min-width:120px;padding:.75rem}}.mafia-game{margin:0 auto;max-width:1200px;padding:20px}.phase-info{background:#f8f9fa;background:var(--background-secondary,#f8f9fa);border-radius:8px;margin-bottom:30px;padding:20px;text-align:center}.phase-info h2{color:#252525;color:var(--text-primary,#252525);margin-bottom:10px}.elimination-notice{background:#fee;background:var(--error-light,#fee);border-radius:4px;color:#d32f2f;color:var(--error,#d32f2f);margin:10px 0;padding:10px}.player-list{margin-bottom:30px}.player-list h3{margin-bottom:15px}.player-list h3,.player-name{color:#252525;color:var(--text-primary,#252525)}.player-name{margin-bottom:5px}.player-status{color:#999;color:var(--text-secondary,#999);font-size:.9em}.player-role{background:#ff436c;background:var(--primary,#ff436c);border-radius:4px;color:#fff;font-size:.85em;margin-top:8px;padding:5px 8px}.action-panel{background:#fff;border:1px solid #e0e0e0;border:1px solid var(--border,#e0e0e0);border-radius:8px;margin-bottom:20px;padding:20px}.action-panel h3{color:#252525;color:var(--text-primary,#252525);margin-bottom:15px}.night-action-form,.vote-form{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.target-select{min-width:200px}.investigation-results{background:#e3f2fd;background:var(--secondary-light,#e3f2fd);border:1px solid #0abeeb;border:1px solid var(--secondary,#0abeeb);border-radius:8px;margin-bottom:20px;padding:15px}.investigation-results h3{color:#0abeeb;color:var(--secondary,#0abeeb);margin-bottom:10px}.vote-status{background:#fff;border:1px solid #e0e0e0;border:1px solid var(--border,#e0e0e0);border-radius:8px;padding:20px}.vote-status h3{color:#252525;color:var(--text-primary,#252525);margin-bottom:15px}.vote-entry{border-bottom:1px solid #f0f0f0;border-bottom:1px solid var(--border-light,#f0f0f0);color:#999;color:var(--text-secondary,#999);padding:5px 0}.vote-entry:last-child{border-bottom:none}.local-game{align-items:center;display:flex;justify-content:center;min-height:60vh}.setup-phase{background:#f8f9fa;background:var(--background-secondary,#f8f9fa);border-radius:12px;padding:40px;text-align:center}.setup-phase h2{color:#252525;color:var(--text-primary,#252525);margin-bottom:10px}.setup-phase p{color:#999;color:var(--text-secondary,#999)}.role-reveal-phase{max-width:500px;width:100%}.role-reveal-card{border:2px solid;border-radius:8px;cursor:pointer;height:300px;margin-bottom:30px;overflow:hidden;padding:40px;-webkit-user-select:none;user-select:none;width:400px}.role-display,.role-hidden,.role-reveal-card{align-items:center;display:flex;justify-content:center}.role-display,.role-hidden{flex-direction:column;height:100%;text-align:center;width:100%}.role-display h3{color:#252525;color:var(--text-primary,#252525);margin-bottom:20px}.role-name{border-radius:8px;color:#fff;display:inline-block;font-size:2.5em;margin-bottom:15px;padding:15px 25px}.role-mafia{background:#d32f2f;background:var(--primary,#d32f2f)}.role-doctor{background:#4caf50;background:var(--success,#4caf50)}.role-detective{background:#0abeeb;background:var(--secondary,#0abeeb)}.role-villager{background:#ff9800;background:var(--warning,#ff9800)}.role-description{color:#999;color:var(--text-secondary,#999);font-size:1.1em;line-height:1.4}.role-hidden h3{color:#252525;color:var(--text-primary,#252525);margin-bottom:15px}.peek-instruction{color:#999;color:var(--text-secondary,#999);font-size:1.1em}.role-reveal-actions{display:flex;gap:15px;justify-content:center;margin-bottom:20px}.reveal-button{min-width:200px}.next-button,.reveal-button{font-size:1.1em;padding:12px 24px}.player-progress{color:#999;color:var(--text-secondary,#999);font-size:.9em}.moderator-header{margin-bottom:30px;text-align:center}.moderator-header h2{color:#252525;color:var(--text-primary,#252525);margin-bottom:10px}.moderator-header p{color:#999;color:var(--text-secondary,#999);font-size:1.1em}.all-roles-grid{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}.player-role-card{background:#fff;border:2px solid;border-radius:8px;padding:12px;text-align:center;width:160px}.player-role-card .player-name{color:#252525;color:var(--text-primary,#252525);font-size:1.3em;margin-bottom:10px}.player-role-card .player-role{border-radius:6px;display:inline-block;font-size:1.5em;margin-bottom:10px;padding:8px 12px}.role-description-short{color:#999;color:var(--text-secondary,#999);font-size:.9em}.moderator-actions{background:#f8f9fa;background:var(--background-secondary,#f8f9fa);border-radius:8px;padding:20px;text-align:center}.moderator-actions .btn{font-size:1.1em;padding:12px 24px}@media (max-width:768px){.mafia-game{padding:10px}.players-grid{grid-template-columns:1fr}.night-action-form,.vote-form{align-items:stretch;flex-direction:column}.target-select{min-width:auto;width:100%}.role-reveal-container{padding:20px}.role-reveal-actions{flex-direction:column}.next-button,.reveal-button{min-width:auto;width:100%}}.footer{color:var(--text-secondary);margin-top:auto;padding:20px;text-align:center}a{color:var(--text-secondary)!important}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;color:#252525;font-family:Jersey\ 10,sans-serif;line-height:1.6}h1,h2,h3,h4,h5,h6{font-weight:400}input,select,textarea{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:#0000;border:none;box-sizing:border-box;color:inherit;font-family:inherit;font-size:inherit;line-height:inherit;margin:0;outline:none;padding:0}input[type=email],input[type=number],input[type=password],input[type=search],input[type=tel],input[type=text],input[type=url],select,textarea{background-color:initial;outline:none}input[type=checkbox],input[type=radio]{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:#0000;border:none;margin:0;padding:0}input[type=number]{-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}input[type=email],input[type=number],input[type=password],input[type=search],input[type=tel],input[type=text],input[type=url],select,textarea{background-color:#fff;border:2px solid #ebebeb;border:2px solid var(--border);border-radius:.25rem;color:#252525;color:var(--text-primary);font-size:1rem;padding:.5rem}input[type=email]:focus,input[type=number]:focus,input[type=password]:focus,input[type=search]:focus,input[type=tel]:focus,input[type=text]:focus,input[type=url]:focus,select:focus,textarea:focus{border-color:#0abeeb;border-color:var(--secondary);outline:none}:root{--primary:#ff436c;--primary-rgb:255,67,108;--primary-dark:#e63946;--secondary:#0abeeb;--text-primary:#252525;--text-secondary:#999;--background:#fff;--error:#de7b85;--error-hover:#c82333;--surface:#f8f9fa;--border:#ebebeb;--content-heading-color:var(--text-primary);--link:var(--primary);--player1:#ff436c;--player2:#0abeeb;--player3:#ecc904;--player4:#4ee16e;--player5:#ffa02c;--player6:#7451ff;--player7:#ff46e6;--player8:#b8f24d}.btn{align-items:center;border:2px solid #0000;border-radius:8px;box-shadow:0 0 0 0 #0000;color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:1rem;justify-content:center;padding:.6rem 1.2rem;text-decoration:none;transition:all .3s ease}.btn:disabled{box-shadow:none!important;cursor:not-allowed;opacity:.6;transform:none!important}.btn-sm{font-size:1rem;padding:.4rem 1rem}.btn-lg{font-size:1.4rem;padding:.8rem 1.4rem}.btn-primary{background:#ff436c;background:var(--primary);border-color:#ff436c;border-color:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 0 6px #ff436c;box-shadow:0 0 6px var(--primary)}.btn-secondary{background:#0abeeb;background:var(--secondary);border-color:#0abeeb;border-color:var(--secondary);color:#fff}.btn-secondary:hover:not(:disabled){box-shadow:0 0 6px #0abeeb;box-shadow:0 0 6px var(--secondary)}.btn-neutral{background:#999;background:var(--text-secondary);border-color:#999;border-color:var(--text-secondary);color:#fff}.btn-neutral:hover:not(:disabled){background:var(--text-secondary-hover);border-color:var(--text-secondary-hover);box-shadow:0 2px 8px #00000026}.btn-outlined{background:#fff;border-color:#999;border-color:var(--text-secondary);color:#999;color:var(--text-secondary)}.btn-outlined:hover:not(:disabled){background:#fff;box-shadow:0 0 6px #999;box-shadow:0 0 6px var(--text-secondary)}.btn-outlined.btn-primary{background:#fff;border-color:#ff436c;border-color:var(--primary);color:#ff436c;color:var(--primary)}.btn-outlined.btn-primary:hover:not(:disabled){background:#fff;box-shadow:0 0 6px #ff436c;box-shadow:0 0 6px var(--primary)}.btn-outlined.btn-secondary{background:#fff;border-color:#0abeeb;border-color:var(--secondary);color:#0abeeb;color:var(--secondary)}.btn-outlined.btn-secondary:hover:not(:disabled){box-shadow:0 0 6px #0abeeb;box-shadow:0 0 6px var(--secondary)}.btn-close{align-items:center;background:none;border:none;border-radius:50%;color:#999;color:var(--text-secondary);cursor:pointer;display:flex;font-size:2rem;height:32px;justify-content:center;line-height:1;padding:0;transition:color .2s ease;width:32px}.btn-close:hover{color:#252525;color:var(--text-primary)}.columns{display:flex;gap:1rem;width:100%}.column{flex:1 1}@media (max-width:768px){.columns{flex-direction:column}}
/*# sourceMappingURL=main.813cca2a.css.map*/