.app{height:100vh;width:100%;max-width:480px;display:flex;flex-direction:column;overflow:hidden;background:#0a0a0a;margin:0 auto;position:relative}.version-banner{position:fixed;top:10px;right:calc(50% - 230px);background:#0009;color:#fff;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:500;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.2);pointer-events:none}@media (max-width: 480px){.version-banner{right:10px}}.app-content{height:100%;width:100%;display:flex;flex-direction:column;overflow:hidden;padding:4px;gap:4px}.bingo-title-header{flex-shrink:0;text-align:center;padding:8px 0}.bingo-title-header h1{color:#ffc107;font-size:1.8rem;font-weight:700;letter-spacing:4px;margin:0}.info-cards{display:grid;grid-template-columns:repeat(4,1fr) auto;gap:6px;flex-shrink:0;height:50px}.info-card{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;padding:4px 6px;text-align:center;display:flex;flex-direction:column;justify-content:center;min-width:0;box-shadow:0 2px 4px #0003;transition:all .2s ease}.info-card-label{font-size:.65rem;color:#888;margin-bottom:2px;text-transform:uppercase;letter-spacing:.5px}.info-card-value{font-size:.9rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.action-button{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:all .2s ease;flex-shrink:0;align-self:center;box-shadow:0 2px 8px #667eea66}.action-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea99}.action-button:active{transform:translateY(0);box-shadow:0 2px 4px #667eea66}.user-id-display{text-align:center;font-size:.7rem;color:#666;padding:2px 0;flex-shrink:0}.main-game-layout{flex:1;display:grid;grid-template-columns:.75fr 1.25fr;gap:0;overflow:hidden;min-height:0;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;padding:4px;box-shadow:0 2px 8px #0003}.master-board-section{background:transparent;border:none;border-radius:0;padding:4px;overflow:hidden;display:flex;flex-direction:column;min-height:0;box-shadow:none;border-right:1px solid #2a2a2a}.master-board-section h2{color:#ffc107;margin-bottom:6px;font-size:.85rem;font-weight:700;text-align:center;flex-shrink:0;letter-spacing:1px}.game-sidebar{display:flex;flex-direction:column;gap:6px;overflow:hidden;min-height:0;padding-left:4px}.called-numbers-sidebar{background:transparent;border:none;border-radius:0;padding:4px;flex-shrink:0;overflow:hidden;box-shadow:none}.player-card-section{background:transparent;border:none;border-radius:0;padding:4px;flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column;box-shadow:none}.player-card-section::-webkit-scrollbar{width:6px}.player-card-section::-webkit-scrollbar-track{background:#0a0a0a;border-radius:3px}.player-card-section::-webkit-scrollbar-thumb{background:#667eea;border-radius:3px}.countdown-timer{background:linear-gradient(135deg,#667eea,#764ba2);border:1px solid #2a2a2a;border-radius:12px;padding:12px;text-align:center;flex-shrink:0;box-shadow:0 4px 12px #667eea66;margin-bottom:6px}.countdown-label{color:#ffffffe6;font-size:.7rem;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.countdown-value{color:#fff;font-size:1.5rem;font-weight:700;font-variant-numeric:tabular-nums}.status-messages{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;padding:6px 8px;flex-shrink:0;box-shadow:0 2px 4px #0003}.status-message{color:#fff;font-size:.75rem;margin-bottom:3px;line-height:1.3}.status-message:last-child{margin-bottom:0}.info-box{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;padding:8px;flex-shrink:0;max-height:70px;overflow-y:auto;margin-top:auto;box-shadow:0 2px 4px #0003}.info-box h3{color:#fff;font-size:.75rem;margin:0 0 4px;font-weight:600}.info-box-content{color:#ccc;font-size:.7rem;line-height:1.3}.info-box-content p{margin:0}.info-box::-webkit-scrollbar{width:6px}.info-box::-webkit-scrollbar-track{background:#0a0a0a;border-radius:3px}.info-box::-webkit-scrollbar-thumb{background:#667eea;border-radius:3px}.bingo-button{width:auto;min-width:100px;padding:10px 20px;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;border-radius:12px;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #f5576c66;margin:8px auto 0;flex-shrink:0;align-self:center}.bingo-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #f5576c99}.bingo-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #f5576c66}.bingo-button:disabled{background:#2a2a2a;color:#666;cursor:not-allowed;box-shadow:none}.auth-section{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;padding:40px;text-align:center;max-width:500px;margin:auto}.auth-section h2{color:#fff;margin-bottom:30px;font-size:1.8rem}.input-group{display:flex;flex-direction:column;gap:15px}.input-group label{color:#888;font-weight:600;text-align:left}.input-group input{padding:15px;background:#0a0a0a;border:1px solid #2a2a2a;border-radius:8px;color:#fff;font-size:1rem}.input-group input:focus{outline:none;border-color:#667eea}.input-group button{padding:15px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s}.input-group button:hover{transform:translateY(-2px)}.card-selection-full{grid-column:1 / -1;height:100%;display:flex;flex-direction:column;overflow:hidden;min-height:0}.card-selection-container{height:100%;display:flex;flex-direction:column;overflow:hidden;min-height:0}.card-button{padding:8px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;transition:all .2s}.card-button:hover:not(:disabled){background:#2a2a2a;border-color:#667eea}.card-button:disabled,.card-button.card-taken{background:#0a0a0a;border-color:#f44;color:#666;cursor:not-allowed;opacity:.6}.bingo-card-container{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:100%}.bingo-card-container h2{margin-bottom:6px;color:#fff;text-align:center;font-size:.75rem;flex-shrink:0}.bingo-card{display:inline-block;border:none;border-radius:12px;overflow:visible;background:#1a1a1a;margin:0 auto;flex-shrink:0;max-width:100%;padding:2px;box-shadow:none}.bingo-header{display:grid;grid-template-columns:repeat(5,1fr);background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;gap:3px;margin-bottom:3px}.bingo-header-cell{padding:6px;text-align:center;font-weight:700;font-size:.95rem}.bingo-row{display:grid;grid-template-columns:repeat(5,1fr);gap:3px;margin-bottom:5px}.bingo-row:last-child{margin-bottom:0}.bingo-cell{width:48px;height:48px;border:1px solid #2a2a2a;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:600;background:#2a2a2a;color:#fff;transition:all .2s ease;padding:0}.bingo-cell.clickable{cursor:pointer}.bingo-cell.clickable:hover:not(.called){background:#1a1a1a;border-color:#667eea}.bingo-cell.clickable:active{transform:scale(.95)}.bingo-cell.called{background:#28a745;border-color:#28a745;color:#fff;transform:scale(1.05);box-shadow:0 2px 8px #00000080;font-weight:700}.bingo-cell.winning{background:#ffc107!important;border-color:#ffc107!important;color:#000!important;transform:scale(1.1);box-shadow:0 4px 12px #ffc10799;font-weight:900;animation:pulse 1.5s ease-in-out infinite;position:relative}.bingo-cell.winning:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;background:#ff6b00;border-radius:50%;box-shadow:0 0 8px #ff6b00cc;animation:centerPulse 1s ease-in-out infinite}@keyframes centerPulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:1}50%{transform:translate(-50%,-50%) scale(1.3);opacity:.7}}@keyframes pulse{0%,to{box-shadow:0 4px 12px #ffc10799}50%{box-shadow:0 6px 20px #ffc107e6}}.bingo-cell.free{background:#ffc107;color:#000;font-weight:700}.free-space{font-size:.65rem}@media (max-width: 600px){.bingo-cell{width:36px;height:36px;font-size:.7rem}}.winner-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.winner-modal-content{background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border-radius:20px;padding:30px;max-width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080;border:2px solid #667eea;animation:slideUp .3s ease;position:relative}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.winner-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #667eea}.winner-modal-header h2{margin:0;color:#fff;font-size:1.8rem;text-align:center;flex:1}.winner-modal-close{background:transparent;border:none;color:#fff;font-size:2.5rem;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;line-height:1}.winner-modal-close:hover{background:#ffffff1a;transform:rotate(90deg)}.winner-modal-body{display:flex;flex-direction:column;align-items:center;gap:20px}.winning-patterns-info{margin-top:20px;padding:15px;background:#667eea1a;border-radius:10px;border:1px solid #667eea;width:100%;max-width:400px}.winning-patterns-info h3{margin:0 0 10px;color:#fff;font-size:1.2rem}.winning-patterns-info ul{margin:0;padding-left:20px;color:#fff}.winning-patterns-info li{margin:8px 0;font-size:1rem}@media (max-width: 600px){.winner-modal-content{padding:20px;max-width:95%}.winner-modal-header h2{font-size:1.4rem}}.called-numbers-container{width:100%;overflow:hidden}.called-numbers-empty{text-align:center;color:#666;padding:12px;font-style:italic;font-size:.8rem}.called-numbers-list{display:flex;flex-direction:row;gap:6px;align-items:center;justify-content:center;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;padding:4px 0}.called-numbers-list::-webkit-scrollbar{height:5px}.called-numbers-list::-webkit-scrollbar-track{background:#0a0a0a;border-radius:3px}.called-numbers-list::-webkit-scrollbar-thumb{background:#667eea;border-radius:3px}.called-number-item{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:8px;font-weight:700;font-size:.9rem;box-shadow:0 2px 8px #0000004d;transition:all .2s ease;flex-shrink:0}.called-number-item.empty{background:transparent;border:2px dashed #2a2a2a;box-shadow:none}.called-number-item:hover:not(.empty){transform:translateY(-2px);box-shadow:0 4px 12px #0006}.called-number-item.purple{background:linear-gradient(135deg,#6f42c1,#8b5cf6);color:#fff}.called-number-item.yellow{background:linear-gradient(135deg,#ffc107,#ffd54f);color:#000}.called-number-item.green{background:linear-gradient(135deg,#28a745,#20c997);color:#fff}.called-number-item.red{background:linear-gradient(135deg,#dc3545,#e74c3c);color:#fff}.called-number-item:last-child:not(.empty){width:56px;height:56px;font-size:1.1rem;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 2px 8px #0000004d,0 0 20px #ffffff4d,0 4px 12px #0006}50%{transform:scale(1.15);box-shadow:0 4px 16px #00000080,0 0 30px #fff9,0 8px 20px #0009}}.called-number-letter{font-size:.8em;margin-right:2px;opacity:.9}.called-number-value{font-size:.9em}.card-selection-container{height:100%;display:flex;flex-direction:column;overflow:hidden;min-height:0;background:#1a1a1a}.card-selection-container h2{color:#fff;margin-bottom:10px;text-align:center;font-size:1rem;flex-shrink:0}.card-list-container{flex:1;overflow:auto;min-height:0}.card-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:6px;padding:5px}.card-button{padding:8px;background:#2a2a2a;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;transition:all .2s}.card-button:hover:not(:disabled){background:#3a3a3a}.card-button:disabled,.card-button.card-taken{background:#0a0a0a;border:1px solid #ff4444;color:#666;cursor:not-allowed;opacity:.6}.card-button.card-recently-selected{animation:cardSelectedPulse .5s ease-in-out;border:2px solid #ffc107;background:#2a2a2a}@keyframes cardSelectedPulse{0%{transform:scale(1);box-shadow:0 0 #ffc107b3}50%{transform:scale(1.05);box-shadow:0 0 10px 5px #ffc10780}to{transform:scale(1);box-shadow:0 0 #ffc10700}}.card-preview-section{height:100%;display:flex;flex-direction:column;overflow:hidden;min-height:0}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;flex-shrink:0}.preview-header h3{color:#fff;font-size:.9rem}.cancel-button{padding:6px 12px;background:#2a2a2a;border:1px solid #2a2a2a;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;transition:all .2s}.cancel-button:hover{background:#3a3a3a;border-color:#667eea}.preview-card-wrapper{flex:1;overflow:auto;display:flex;justify-content:center;align-items:flex-start;min-height:0}.confirmation-section{margin-top:10px;flex-shrink:0}.confirm-button{width:100%;padding:10px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;font-size:.9rem;font-weight:700;cursor:pointer;transition:transform .2s}.confirm-button:hover{transform:translateY(-2px)}.master-board-container{flex:1;overflow:auto;min-height:0;display:flex;justify-content:center;align-items:flex-start;padding:2px;margin-bottom:4px}.master-board-container::-webkit-scrollbar{width:8px}.master-board-container::-webkit-scrollbar-track{background:#0a0a0a;border-radius:4px}.master-board-container::-webkit-scrollbar-thumb{background:#667eea;border-radius:4px}.master-board{display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:auto repeat(15,1fr);gap:2px 4px;row-gap:6px;justify-content:center;align-items:start}.master-header-empty{background:transparent;border:none}.master-row-header{background:#1a1a1a;color:#fff;padding:0 2px;text-align:center;font-size:.6rem;font-weight:600;border-radius:2px;display:flex;align-items:center;justify-content:center;min-width:20px;min-height:20px}.master-letter-header{background:#1a1a1a;color:#fff;padding:0 2px;text-align:center;font-size:.7rem;font-weight:700;border-radius:2px;display:flex;align-items:center;justify-content:center;min-width:26px;min-height:20px}.master-number-cell{min-width:26px;min-height:20px;padding:0;background:#2a2a2a;border:1px solid #2a2a2a;border-radius:6px;text-align:center;font-size:.8rem;font-weight:600;color:#fff;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.master-number-cell.called{transform:scale(1.05);box-shadow:0 2px 8px #00000080;font-weight:700}.master-number-cell.called.red{background:#dc3545;border-color:#dc3545;color:#fff}.master-number-cell.called.purple{background:#6f42c1;border-color:#6f42c1;color:#fff}.master-number-cell.called.green{background:#28a745;border-color:#28a745;color:#fff}.master-number-cell.called.yellow{background:#ffc107;color:#000;border-color:#ffc107}@media (max-width: 768px){.master-number-cell,.master-letter-header,.master-row-header{min-width:28px;min-height:22px;font-size:.6rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0a0a0a;color:#fff;height:100vh;width:100vw;overflow:hidden;display:flex;justify-content:center;align-items:center}#root{height:100vh;width:100vw;max-width:480px;max-height:100vh;overflow:hidden;margin:0 auto;display:flex;justify-content:center;align-items:center}
