:root{font-family:Nunito,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;--primary-cyan: #00D4C8;--primary-teal: #00A99D;--secondary-purple: #A855F7;--secondary-pink: #EC4899;--accent-orange: #FF8A3D;--accent-yellow: #FFC107;--bg-primary: linear-gradient(135deg, #0EA5E9 0%, #06B6D4 50%, #10B981 100%);--bg-card: rgba(255, 255, 255, .95);--bg-sidebar: linear-gradient(180deg, #1E293B 0%, #0F172A 100%);--bg-dark: #0F172A;--bg-light: #F8FAFC;--text-primary: #1E293B;--text-secondary: #64748B;--text-white: #FFFFFF;--text-muted: #94A3B8;--border-radius: 16px;--border-radius-sm: 8px;--border-radius-lg: 24px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .12);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .16);--shadow-glow: 0 0 20px rgba(0, 212, 200, .3);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg-primary);color:var(--text-primary);overflow-x:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.room-card{background:var(--bg-card);border-radius:var(--border-radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:all .3s ease;position:relative;cursor:pointer}.room-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}.room-card.opened{border:3px solid var(--primary-cyan)}.room-card.closed{opacity:.7;filter:grayscale(.5)}.room-card[data-room-color=orange] .room-header{background:linear-gradient(135deg,#ff8a3d,#f59e0b)}.room-card[data-room-color=blue] .room-header{background:linear-gradient(135deg,#3b82f6,#06b6d4)}.room-card[data-room-color=red] .room-header{background:linear-gradient(135deg,#ef4444,#dc2626)}.room-card[data-room-color=green] .room-header{background:linear-gradient(135deg,#10b981,#34d399)}.room-card[data-room-color=neutral] .room-header{background:linear-gradient(135deg,#6b7280,#9ca3af)}.room-header{padding:24px;color:var(--text-white);position:relative;overflow:hidden}.room-header:before{content:"🎰";position:absolute;top:-10px;right:-10px;font-size:80px;opacity:.2;transform:rotate(-15deg)}.room-title-row{display:flex;align-items:center;gap:12px;margin-bottom:8px}.room-header h3{font-size:28px;font-weight:800;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.2);position:relative;z-index:1}.room-header h3 .event-id{font-size:14px;font-weight:500;opacity:.8;margin-left:8px}.room-mode-badge{width:45px;height:45px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.room-status{display:inline-block;background:#ffffff40;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:6px 16px;border-radius:20px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;position:relative;z-index:1}.room-body{padding:24px}.room-info{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:12px;background:linear-gradient(135deg,#06b6d40d,#10b9810d);border-radius:var(--border-radius-sm);border-left:3px solid var(--primary-cyan)}.info-row .label{font-weight:600;color:var(--text-secondary);font-size:14px;text-transform:capitalize}.info-row .value{font-weight:700;color:var(--text-primary);font-size:16px}.info-row.next-game-time{background:linear-gradient(135deg,#a855f726,#ec489926);border-left-color:var(--secondary-purple);margin-top:8px}.info-row.next-game-time .label{color:var(--secondary-purple);font-weight:700}.info-row.next-game-time .value{color:var(--secondary-pink);font-weight:800;font-size:14px}.room-timer{background:linear-gradient(135deg,var(--secondary-purple),var(--secondary-pink));color:var(--text-white);padding:16px;border-radius:var(--border-radius);text-align:center;margin-top:16px;box-shadow:0 4px 12px #a855f74d}.timer-label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;opacity:.9}.timer-value{display:block;font-size:25px;font-weight:800;text-shadow:0 2px 4px rgba(0,0,0,.2)}.room-footer{padding:0 24px 24px}.btn-join{width:100%;padding:16px;border:none;border-radius:var(--border-radius-sm);font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-sm)}.btn-join.enabled{background:linear-gradient(135deg,var(--primary-cyan),var(--primary-teal));color:var(--text-white)}.btn-join.enabled:hover{transform:scale(1.02);box-shadow:var(--shadow-glow)}.btn-join.disabled{background:var(--text-muted);color:#ffffffb3;cursor:not-allowed}.room-jackpots{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}.jackpot-badge{flex:1;min-width:80px;padding:8px 12px;border-radius:var(--border-radius-sm);text-align:center;font-weight:700;font-size:12px;color:var(--text-white);box-shadow:var(--shadow-sm)}.jackpot-badge.gold{background:linear-gradient(135deg,#fcd34d,#f59e0b)}.jackpot-badge.silver{background:linear-gradient(135deg,#d1d5db,#9ca3af)}.jackpot-badge.bronze{background:linear-gradient(135deg,#d97706,#92400e)}.jackpot-value{display:block;font-size:16px;margin-top:4px}.jackpots-section{margin-top:16px;padding-top:16px;border-top:1px solid rgba(0,0,0,.1)}.jackpots-title{font-weight:700;font-size:14px;color:var(--text-primary);margin-bottom:8px}.jackpot-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:var(--border-radius-sm);margin-bottom:6px;font-size:13px}.jackpot-item .jackpot-name{font-weight:700;text-transform:uppercase;font-size:11px;letter-spacing:.5px}.jackpot-item .jackpot-value{font-weight:700;font-size:14px;margin:0 8px}.jackpot-item .jackpot-threshold{font-size:11px;opacity:.8}.jackpot-oro{background:linear-gradient(135deg,#fcd34d,#f59e0b);color:#78350f;box-shadow:0 2px 8px #f59e0b4d}.jackpot-argento{background:linear-gradient(135deg,#e5e7eb,#9ca3af);color:#374151;box-shadow:0 2px 8px #9ca3af4d}.jackpot-bronzo{background:linear-gradient(135deg,#f59e0b,#92400e);color:#fff;box-shadow:0 2px 8px #d977064d}.prizes-section{margin-top:12px}.prize-row{background:linear-gradient(135deg,#06b6d41a,#3b82f61a);padding:8px 12px;border-radius:var(--border-radius-sm);margin-bottom:6px}.prize-row .label{font-weight:600}.prize-value{font-weight:700;color:var(--primary-cyan)}@media(max-width:480px){.room-header h3{font-size:24px}.timer-value{font-size:20px}.info-row{flex-direction:column;gap:8px;text-align:center}}.next-events{display:flex;flex-direction:column;gap:12px}.event-item{background:linear-gradient(135deg,#06b6d414,#10b98114);padding:16px;border-radius:var(--border-radius-sm);border-left:4px solid var(--primary-cyan);transition:all .3s ease;cursor:pointer}.event-item:hover{transform:translate(4px);background:linear-gradient(135deg,#06b6d41f,#10b9811f)}.event-room{font-weight:700;color:var(--text-primary);font-size:16px;margin-bottom:8px}.event-name{font-size:14px;color:var(--text-secondary);margin-bottom:8px}.event-time{font-size:12px;color:var(--text-muted);display:flex;align-items:center;gap:6px}.event-time:before{content:"🕐";font-size:14px}.event-price{display:inline-block;background:linear-gradient(135deg,var(--accent-orange),var(--accent-yellow));color:var(--text-white);padding:4px 12px;border-radius:12px;font-size:12px;font-weight:700;margin-top:8px}.no-events{text-align:center;padding:32px 16px;color:var(--text-muted);font-style:italic}.no-events:before{content:"📅";display:block;font-size:48px;margin-bottom:12px;opacity:.5}.live-event-notification{position:fixed;top:100px;left:50%;transform:translate(-50%);padding:1rem 2rem;border-radius:12px;font-weight:600;font-size:1.1rem;box-shadow:0 8px 24px #0000004d;z-index:1000;animation:slideDown .3s ease-out;max-width:600px}.live-event-notification.info{background:linear-gradient(135deg,#00bcd4,#0097a7);color:#fff}.live-event-notification.success{background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff}.live-event-notification.warning{background:linear-gradient(135deg,#ff8a3d40,#fbbf2433);border-color:var(--orange)}.live-event-notification.warning{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff}.live-event-notification.jackpot{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;animation:slideDown .3s ease-out,jackpotPulse 1s ease-in-out infinite}@keyframes jackpotPulse{0%,to{box-shadow:0 8px 24px #0000004d}50%{box-shadow:0 12px 32px #fbbf2499}}.notification-content{display:flex;align-items:center;justify-content:space-between;gap:12px}.notification-message{color:#fff;font-size:1.1rem;font-weight:600;flex:1;line-height:1.5}.notification-close{background:#fff3;border:none;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;cursor:pointer;transition:all .2s ease;flex-shrink:0}.notification-close:hover{background:#ffffff4d;transform:rotate(90deg)}@media(max-width:768px){.live-event-notification{max-width:90%;font-size:1rem;padding:.875rem 1.5rem}.notification-message{font-size:1rem}}.lobby-container{display:flex;min-height:calc(100vh - 80px);background:var(--bg-primary);padding:24px;gap:24px}.lobby-sidebar{width:280px;display:flex;flex-direction:column;gap:20px}.sidebar-card{background:var(--bg-card);border-radius:var(--border-radius);padding:20px;box-shadow:var(--shadow-md)}.sidebar-title{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:16px;display:flex;align-items:center;gap:8px}.sidebar-title:before{content:"🎯";font-size:24px}.lobby-main{flex:1;display:flex;flex-direction:column;gap:24px}.lobby-header{text-align:center;padding:32px 24px;background:#fffffff2;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg)}.lobby-title{font-size:48px;font-weight:800;background:linear-gradient(135deg,var(--primary-cyan),var(--secondary-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:12px}.lobby-subtitle{font-size:18px;color:var(--text-secondary);font-weight:500}.loading-spinner{display:flex;justify-content:center;align-items:center;min-height:300px;font-size:48px;animation:pulse 1.5s infinite}.error-message{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b;padding:20px;border-radius:var(--border-radius);text-align:center;font-weight:600;box-shadow:var(--shadow-md)}.rooms-section{background:var(--bg-card);border-radius:var(--border-radius-lg);padding:32px;box-shadow:var(--shadow-lg)}.section-title{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:24px;display:flex;align-items:center;gap:12px}.section-title:before{content:"🎰";font-size:32px}.rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;animation:fadeIn .6s ease-out}.no-rooms{text-align:center;padding:60px 24px;color:var(--text-secondary);font-size:18px}.no-rooms:before{content:"🎪";font-size:64px;display:block;margin-bottom:16px}.events-panel{background:var(--bg-card);border-radius:var(--border-radius);padding:24px;box-shadow:var(--shadow-md);max-height:500px;overflow-y:auto}.events-title{font-size:20px;font-weight:700;color:var(--text-primary);margin-bottom:16px;display:flex;align-items:center}.lobby-controls{background:var(--bg-card);border-radius:var(--border-radius);padding:20px;box-shadow:var(--shadow-md)}.control-buttons{display:flex;gap:10px;margin-bottom:15px}.btn-control{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;font-size:24px;cursor:pointer;transition:all .3s ease;opacity:.6}.btn-control.active{opacity:1;box-shadow:0 4px 12px #667eea66}.btn-control:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea80}.control-label{font-size:12px;font-weight:600;text-transform:uppercase}.language-selector{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;color:#333;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.language-selector option{color:#333;background:#fff;font-size:16px;padding:8px}.language-selector:hover{border-color:#667eea;background:#f9f9f9}.language-selector:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;gap:8px}.events-title:before{content:"📅";font-size:24px}.jackpot-panel{background:linear-gradient(135deg,var(--accent-orange),var(--accent-yellow));border-radius:var(--border-radius);padding:24px;color:var(--text-white);box-shadow:var(--shadow-lg);position:relative;overflow:hidden}.jackpot-panel:before{content:"💰";position:absolute;top:-20px;right:-20px;font-size:120px;opacity:.2}.jackpot-title{font-size:16px;font-weight:600;margin-bottom:8px;text-transform:uppercase;letter-spacing:1px}.jackpot-amount{font-size:36px;font-weight:800;text-shadow:0 2px 8px rgba(0,0,0,.2)}@media(max-width:1200px){.lobby-container{flex-direction:column}.lobby-sidebar{width:100%;flex-direction:row;overflow-x:auto}.sidebar-card{min-width:250px}}@media(max-width:768px){.lobby-container{padding:16px}.lobby-title{font-size:32px}.rooms-grid{grid-template-columns:1fr}.lobby-sidebar{flex-direction:column}.sidebar-card{min-width:auto}}.bingo-table{background:linear-gradient(135deg,#00bcd4,#0097a7);padding:1rem;border-radius:20px;box-shadow:0 8px 24px #0000004d;margin-left:20px}.table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.75rem 1rem;background:#0003;border-radius:12px}.table-header h3{font-size:1.5rem;color:#fff;font-weight:600}.last-number-badge{display:flex;align-items:center;gap:.75rem;background:#ffffff26;padding:.5rem 1rem;border-radius:25px;border:2px solid rgba(255,255,255,.3)}.last-number-badge .label{color:#ffffffe6;font-size:.85rem;font-weight:500}.last-number-badge .number{font-size:2rem;font-weight:700;color:#fff;font-family:Arial,sans-serif;min-width:50px;text-align:center;background:linear-gradient(135deg,#4caf50,#66bb6a);border-radius:50%;width:50px;height:50px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 8px #0000004d}.last-number-display{display:flex;align-items:center;gap:.75rem;background:#ffffff26;padding:.5rem 1rem;border-radius:25px;border:2px solid rgba(255,255,255,.3)}.last-number-display .label{color:#ffffffe6;font-size:.85rem;font-weight:500}.last-number-display .number{font-size:2rem;font-weight:700;color:#fff;font-family:Arial,sans-serif;min-width:50px;text-align:center;background:linear-gradient(135deg,#4caf50,#66bb6a);border-radius:50%;width:50px;height:50px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 8px #0000004d}.table-content{display:flex;gap:1rem;align-items:flex-start}.board-grid{display:grid;gap:8px;padding:1.5rem;background:#0003;border-radius:12px;max-width:1000px;flex-shrink:0}.board-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:#fff;border:none;border-radius:50%;font-size:1.1rem;font-weight:600;color:#37474f;transition:all .3s ease;box-shadow:0 2px 4px #0003;cursor:default;max-width:85px;max-height:85px;min-width:35px}.board-cell.drawn{background:linear-gradient(135deg,#00acc1,#0097a7);color:#fff;transform:scale(.95);box-shadow:0 4px 8px #00acc166}.board-cell.last{animation:pulse 1s ease-in-out infinite;background:linear-gradient(135deg,#4caf50,#66bb6a);color:#fff;box-shadow:0 0 20px #4caf50cc}@keyframes pulse{0%,to{transform:scale(.95);box-shadow:0 0 20px #4caf50cc}50%{transform:scale(1.05);box-shadow:0 0 30px #4caf50}}.drawn-numbers-list{background:#0003;padding:.75rem 1rem;border-radius:12px;flex:1;min-width:200px}.drawn-numbers-list h4{font-size:1rem;margin-bottom:.75rem;color:#fff;font-weight:500}.numbers-list{display:flex;flex-wrap:wrap;gap:.4rem}.drawn-number{background:linear-gradient(135deg,#00acc1,#0097a7);color:#fff;padding:.3rem .7rem;border-radius:20px;font-weight:700;font-size:.85rem;min-width:39px;text-align:center;box-shadow:0 2px 4px #0003}.bingo-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:16px;box-shadow:0 4px 6px #0000001a;position:relative;transition:all .3s ease;color:#fff}.bingo-card.selectable{cursor:pointer}.bingo-card.selectable:hover{transform:translateY(-4px);box-shadow:0 8px 12px #0003}.bingo-card.selected{border:3px solid #4CAF50;box-shadow:0 0 20px #4caf5080}.card-selection-indicator{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:#ffffff4d;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.bingo-card.selected .card-selection-indicator{background:#4caf50}.check-mark{font-size:20px;color:#fff;font-weight:700}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-weight:700;font-size:14px}.card-status{font-size:12px;opacity:.9}.card-column-headers{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;margin-bottom:8px}.column-header{text-align:center;font-weight:700;font-size:18px;padding:4px;color:gold;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.card-grid{display:flex;flex-direction:column;gap:4px;background:#ffffff1a;padding:8px;border-radius:8px}.card-row{display:flex;gap:4px}.card-cell{flex:1;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-weight:700;border-radius:6px;transition:all .3s ease;font-size:16px;min-width:0}.card-cell.filled{background:#fff;color:#333;box-shadow:inset 0 2px 4px #0000001a}.card-cell.empty{background:#fff3;color:transparent}.card-cell.extracted{background:#4caf50;color:#fff;box-shadow:0 0 10px #4caf5080;animation:pulse .5s ease}.card-cell.free-space{background:linear-gradient(135deg,gold,orange);color:#fff;font-weight:700;font-size:12px}.free-text{text-shadow:1px 1px 2px rgba(0,0,0,.3)}.bingo-card-classic .card-row{grid-template-columns:repeat(9,1fr)}.bingo-card-classic .card-cell{font-size:14px}.bingo-card-american .card-row{grid-template-columns:repeat(5,1fr)}.bingo-card-american .card-cell{font-size:18px}.bingo-card-30ball .card-row{grid-template-columns:repeat(3,1fr)}.bingo-card-30ball .card-cell{font-size:20px}.bingo-card-80ball .card-row{grid-template-columns:repeat(4,1fr)}.bingo-card-80ball .card-cell{font-size:18px}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@media(max-width:768px){.bingo-card{padding:12px}.card-cell{font-size:14px}.bingo-card-american .card-cell{font-size:16px}.bingo-card-30ball .card-cell{font-size:18px}.bingo-card-80ball .card-cell,.column-header{font-size:16px}}@media(max-width:480px){.bingo-card{padding:8px}.card-cell{font-size:12px}.card-grid,.card-row{gap:2px}}.chat-container{display:flex;flex-direction:column;height:100%;background:var(--card-bg);border-radius:15px;border:2px solid var(--border-color);overflow:hidden;padding:1rem}.chat-header{padding:1rem 1.5rem;background:linear-gradient(135deg,#00bcd4,#0097a7);border-bottom:none;display:flex;justify-content:space-between;align-items:center}.chat-header h3{font-size:1.3rem;color:#fff;font-weight:600}.guest-badge{background:#fff3;color:#fff;padding:.4rem .8rem;border-radius:15px;font-size:.85rem;font-weight:500;border:1px solid rgba(255,255,255,.3)}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem;background:#f5f5f5;min-height:250px;max-height:250px}.chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);text-align:center}.chat-empty p{margin:.5rem 0}.chat-hint{font-size:.85rem;opacity:.7}.chat-messages::-webkit-scrollbar{width:8px}.chat-messages::-webkit-scrollbar-track{background:var(--light-bg)}.chat-messages::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.chat-message{background:#fff;padding:.75rem 1rem;border-radius:12px;border-left:3px solid #00bcd4;box-shadow:0 1px 3px #0000001a;animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.message-username{font-weight:600;color:#00bcd4;font-size:.9rem}.message-time{font-size:.75rem;color:var(--text-secondary)}.message-text{color:var(--text-primary);line-height:1.4;word-wrap:break-word}.chat-input-form{display:flex;gap:.5rem;padding:1rem 0;background:var(--light-bg);border-top:2px solid var(--border-color)}.chat-input-form input{flex:1;background:var(--dark-bg);border:2px solid var(--border-color);color:var(--text-primary);padding:.75rem;border-radius:8px;font-size:.95rem;outline:none;background:#f5f5f5}.chat-input-form input:focus{border-color:var(--primary-color)}.chat-input-form button{background:var(--primary-color);color:#fff;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;background:#f44336}.chat-input-form button:hover:not(:disabled){background:var(--secondary-color)}.game-room{display:flex;flex-direction:column;min-height:calc(100vh - 100px);position:relative}.toast-notification{position:fixed;top:100px;left:50%;transform:translate(-50%);padding:1rem 2rem;border-radius:12px;font-weight:600;font-size:1.1rem;box-shadow:0 8px 24px #0000004d;z-index:1000;animation:slideDown .3s ease-out}.toast-notification.warning{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff}.toast-notification.success{background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff}.toast-notification.error{background:linear-gradient(135deg,#f44336,#d32f2f);color:#fff}.toast-notification.info{background:linear-gradient(135deg,#00bcd4,#0097a7);color:#fff}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.game-header{background:linear-gradient(135deg,#00bcd4,#0097a7);border-radius:15px;margin-bottom:1.5rem;box-shadow:0 4px 12px #0003;overflow:hidden;margin:10px 20px}.header-content{padding:1rem 1.5rem}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.header-left{display:flex;align-items:center;gap:1rem}.game-header h2{font-size:1.5rem;color:#fff;margin:0;font-weight:600}.spectator-badge{background:#fff3;color:#fff;padding:.3rem .75rem;border-radius:15px;font-size:.8rem;font-weight:600;border:1px solid rgba(255,255,255,.3)}.room-mode-badge-small{width:40px;height:40px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.room-details{display:flex;flex-wrap:wrap;gap:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.2)}.detail-item{display:inline-flex;align-items:center;gap:.4rem;background:#ffffff1a;padding:.35rem .75rem;border-radius:20px;white-space:nowrap}.detail-label{font-size:.8rem;color:#ffffffe6;font-weight:500}.detail-value{font-size:.85rem;color:#fff;font-weight:600}.detail-value.status{background:#4caf504d;padding:.15rem .5rem;border-radius:10px;font-size:.8rem}.countdown-item{background:linear-gradient(135deg,#ffc10733,#ff980033);border:1px solid rgba(255,193,7,.4)}.countdown-timer{font-size:1rem;color:#ffd54f;font-weight:700;font-family:Courier New,monospace;letter-spacing:.05em;text-shadow:0 0 10px rgba(255,193,7,.3)}.header-controls{display:flex;align-items:center;gap:.75rem}.btn-icon{background:#ffffff26;color:#fff;padding:.5rem .75rem;border-radius:8px;font-size:1.2rem;border:1px solid rgba(255,255,255,.2);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:40px}.btn-icon:hover{background:#ffffff40;transform:translateY(-1px)}.btn-icon.disabled{background:#ffffff0d;border-color:#ffffff1a;opacity:.6}.btn-leave{background:var(--danger-color);color:#fff;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:1rem}.btn-leave:hover{background:#d32f2f}.game-content{display:grid;grid-template-columns:1fr 350px;gap:1.5rem;padding-bottom:2rem;min-height:0}.game-main{display:flex;flex-direction:column;gap:1.5rem}.winners-panel{border-radius:15px;padding:1rem;display:flex;flex-direction:column;gap:1rem;animation:slideIn .5s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.winner-section{background:#ffffffb3;border-radius:10px;padding:.75rem}.winner-section h4{font-size:1.1rem;margin:0 0 .75rem;color:var(--secondary-color);display:flex;align-items:center;gap:.5rem;font-weight:700}.winners-list{display:flex;flex-direction:column;gap:.5rem}.winner-item{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:.6rem .75rem;border-radius:8px;border:1px solid rgba(255,215,0,.3);transition:all .2s ease;box-shadow:0 2px 4px #0000000d}.winner-item:hover{transform:translate(3px);box-shadow:0 3px 8px #ffd7004d}.winner-name{font-weight:600;color:var(--text-color);font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.winner-prize{font-weight:700;color:#f57c00;font-size:1rem;margin-left:.5rem;white-space:nowrap;background:linear-gradient(135deg,gold,#ff9800);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.cinquina-winners h4{color:#00bcd4}.bingo-winners h4{color:#ff5722}.game-sidebar{display:flex;flex-direction:column;gap:1rem;position:sticky;top:1rem;align-self:flex-start;overflow-y:auto;padding-right:.5rem}.game-sidebar::-webkit-scrollbar{width:8px}.game-sidebar::-webkit-scrollbar-track{background:#0000001a;border-radius:4px}.game-sidebar::-webkit-scrollbar-thumb{background:#00bcd480;border-radius:4px}.game-sidebar::-webkit-scrollbar-thumb:hover{background:#00bcd4b3}.user-cards{background:var(--card-bg);padding:1.5rem;border-radius:15px;border:2px solid var(--border-color)}.user-cards h3{font-size:1.5rem;margin-bottom:1rem;color:var(--secondary-color)}.btn-buy-cards{width:100%;padding:1.5rem;background:linear-gradient(135deg,#4caf50,#66bb6a);color:#fff;font-size:1.2rem;font-weight:700;border-radius:12px;text-transform:uppercase;letter-spacing:1px;border:none;cursor:pointer;box-shadow:0 6px 20px #4caf5066;transition:all .3s ease;position:relative;overflow:hidden}.btn-buy-cards:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.btn-buy-cards:hover:before{left:100%}.btn-buy-cards:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 10px 30px #4caf5080;background:linear-gradient(135deg,#66bb6a,#81c784)}.btn-buy-cards:active{transform:translateY(-1px) scale(1.01);box-shadow:0 4px 15px #4caf5066}.spectator-info{text-align:center;padding:2rem;background:linear-gradient(135deg,#ff6f001a,#ff98001a);border-radius:10px;border:2px dashed var(--warning-color)}.spectator-info p{margin-bottom:1rem;font-size:1.1rem;color:var(--text-primary)}.spectator-info p:first-child{font-size:1.3rem;font-weight:600;color:var(--warning-color)}.btn-login{background:linear-gradient(135deg,var(--primary-color),var(--accent-color));color:#fff;padding:1rem 2rem;border-radius:8px;font-weight:600;font-size:1.1rem;margin-top:1rem}.btn-login:hover{transform:scale(1.05)}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.bingo-card{background:linear-gradient(135deg,#96e9ff,#dffaff);padding:.75rem;border-radius:12px;box-shadow:0 4px 12px #00000040;position:relative}.card-header{display:flex;justify-content:space-between;align-items:center;padding:.25rem .5rem;margin-bottom:.5rem;font-size:.85rem;font-weight:700;color:#007592}.card-status{font-size:.75rem;color:#007592}.card-grid{background:#fff;padding:.25rem;border-radius:8px}.card-row{display:flex;gap:1px}.card-cell{flex:1;min-width:24px;max-width:24px;height:22px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;border-radius:2px}.card-cell.filled{background:#96e9ff;color:#000;border:1px solid #7DD4EC}.card-cell.empty{background:#cecece;border:1px solid #B0B0B0}.card-cell.extracted{background:#fff!important;color:#f03!important;border:2px solid #FF0033!important;font-weight:700}.card-cell.marked{background:#fff;color:#f03;border:2px solid #FF0033}.prizes-summary{background:var(--card-bg);border-radius:15px;padding:1rem;border:2px solid var(--border-color);flex-shrink:0}.jackpots-group{margin-bottom:.75rem}.prizes-title{color:var(--secondary-color);font-size:1.1rem;font-weight:700;margin-bottom:.75rem;text-align:center}.jackpots-stack{display:flex;flex-direction:column;gap:.5rem}.jackpot-badge{width:100%;padding:.75rem;border-radius:10px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 3px 8px #0003;transition:transform .2s ease}.jackpot-badge:hover{transform:translate(5px)}min-width: 150px; padding: .75rem 1rem; border-radius: 12px; display: flex; flex-direction: column; align-items: center; gap: .25rem; box-shadow: 0 4px 12px rgba(0,0,0,.3); transition: transform .2s ease; } .jackpot-badge .jackpot-name{font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px}.jackpot-badge .jackpot-value{font-size:1.1rem;font-weight:700}.jackpot-badge .jackpot-threshold{font-size:.7rem;opacity:.8}.jackpot-oro{background:linear-gradient(135deg,#fcd34d,#f59e0b);color:#78350f}.jackpot-argento{background:linear-gradient(135deg,#e5e7eb,#9ca3af);color:#374151}.jackpot-bronzo{background:linear-gradient(135deg,#f59e0b,#92400e);color:#fff}.regular-prizes{display:flex;flex-direction:column;gap:.5rem}.prize-badge{width:100%;padding:.6rem;border-radius:10px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 3px 8px #00000026;transition:transform .2s ease}.prize-badge:hover{transform:translate(5px)}.cinquina-prize{background:linear-gradient(135deg,#3b82f6e6,#2563ebe6);color:#fff}.bingo-prize{background:linear-gradient(135deg,#8b5cf6e6,#7c3aede6);color:#fff}.prize-badge .prize-label{font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.prize-badge .prize-value{font-size:1.3rem;font-weight:700}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.buy-dialog{background:var(--card-bg);padding:0;border-radius:20px;max-width:800px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0006}.buy-dialog-header{background:linear-gradient(135deg,var(--primary-cyan),var(--accent-yellow));padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center}.buy-dialog-header h3{font-size:1.8rem;margin:0;color:#fff;font-weight:700}.close-btn{background:#fff3;border:none;color:#fff;font-size:1.5rem;width:40px;height:40px;border-radius:50%;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.close-btn:hover{background:#ffffff4d;transform:rotate(90deg)}.buy-info{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:2rem;background:#0000000d}.info-card{background:#fff;padding:1.5rem;border-radius:15px;text-align:center;box-shadow:0 4px 12px #0000001a;transition:all .3s ease}.info-card:hover{transform:translateY(-5px);box-shadow:0 8px 20px #00000026}.price-card{border:2px solid var(--accent-orange)}.max-card{border:2px solid var(--primary-cyan)}.info-label{font-size:.9rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.info-value{font-size:2rem;font-weight:700;background:linear-gradient(135deg,var(--primary-cyan),var(--accent-yellow));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.buy-controls{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding:2rem}.card-quantity-btn{background:linear-gradient(135deg,#4caf50,#66bb6a);color:#fff;border:none;border-radius:12px;padding:1.2rem 1rem;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:.3rem;box-shadow:0 4px 12px #4caf504d;position:relative;overflow:hidden}.card-quantity-btn.selected{background:linear-gradient(135deg,var(--accent-yellow),#ffa726);box-shadow:0 6px 16px #ffc10780;transform:scale(1.05)}.card-quantity-btn:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2),transparent);opacity:0;transition:opacity .3s ease}.card-quantity-btn:hover:before{opacity:1}.card-quantity-btn:hover:not(:disabled){transform:translateY(-5px);box-shadow:0 8px 20px #4caf5066}.card-quantity-btn:active:not(:disabled){transform:translateY(-2px)}.card-quantity-btn:disabled{background:linear-gradient(135deg,#ccc,#999);cursor:not-allowed;opacity:.5;box-shadow:none}.card-quantity-btn .quantity{font-size:2rem;font-weight:700;line-height:1}.card-quantity-btn .label{font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;opacity:.9}.card-quantity-btn .total{font-size:1.1rem;font-weight:700;margin-top:.3rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.3);width:100%;text-align:center}.card-quantity-btn.max-btn{background:linear-gradient(135deg,#ff5722,#ff7043);box-shadow:0 4px 12px #ff57224d;grid-column:span 2}.card-quantity-btn.max-btn:hover:not(:disabled){box-shadow:0 8px 20px #ff572280}.card-quantity-btn.max-btn.selected{background:linear-gradient(135deg,#ff9800,#ffb74d)}.cards-info{display:flex;justify-content:space-around;padding:1rem 2rem;background:#ffffff0d;border-radius:8px;margin:0 2rem 1rem;gap:1rem}.cards-info span{font-size:.9rem;color:#fff;opacity:.9}.buy-step-title{font-size:1.1rem;font-weight:600;color:var(--secondary-color);text-align:center;padding:1rem 2rem;background:#0000000d}.generated-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;padding:2rem;max-height:400px;overflow-y:auto}.selectable-card{position:relative;background:#fff;border:3px solid #ddd;border-radius:12px;padding:1rem;cursor:pointer;transition:all .3s ease}.selectable-card:hover{border-color:var(--primary-cyan);transform:translateY(-5px);box-shadow:0 8px 20px #00bcd44d}.selectable-card.selected{border-color:var(--accent-yellow);background:linear-gradient(135deg,#ffc1071a,#ff98001a);box-shadow:0 6px 16px #ffc10766}.card-selection-check{position:absolute;top:-8px;right:-8px;width:32px;height:32px;background:var(--accent-yellow);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;box-shadow:0 2px 8px #0003;transition:all .3s ease}.selectable-card:not(.selected) .card-selection-check{background:#ddd;color:transparent}.mini-bingo-card{display:flex;flex-direction:column;gap:2px}.mini-card-row{display:flex;gap:2px}.mini-card-cell{flex:1;aspect-ratio:1;background:var(--primary-cyan);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;border-radius:4px}.mini-card-cell:empty{background:#0000000d}.dialog-actions{display:flex;gap:1rem;padding:1rem 2rem;background:#0000000d}.btn-purchase{flex:2;background:linear-gradient(135deg,#4caf50,#66bb6a);color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-weight:700;font-size:1.1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #4caf5066}.btn-purchase:hover:not(:disabled){background:linear-gradient(135deg,#66bb6a,#81c784);transform:translateY(-2px);box-shadow:0 6px 16px #4caf5080}.btn-purchase:disabled{background:#ccc;cursor:not-allowed;opacity:.5;box-shadow:none}.btn-regenerate{flex:1;background:var(--primary-cyan);color:#fff;border:none;padding:1rem;border-radius:12px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #00bcd44d}.btn-regenerate:hover{background:var(--accent-yellow);transform:translateY(-2px);box-shadow:0 6px 16px #ffc10766}.btn-generate{background:linear-gradient(135deg,var(--primary-cyan),#00acc1);color:#fff;border:none;padding:1.2rem 2rem;border-radius:12px;font-weight:700;font-size:1.2rem;cursor:pointer;transition:all .3s ease;margin:1rem 2rem;box-shadow:0 4px 12px #00bcd466}.btn-generate:hover{background:linear-gradient(135deg,#00acc1,var(--primary-cyan));transform:translateY(-2px);box-shadow:0 6px 16px #00bcd480}.cards-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.cards-header h3{margin:0}.generated-cards-section,.purchased-cards-section{margin-bottom:2rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:1rem;background:#ffc1071a;border-radius:12px;border-left:4px solid var(--accent-yellow)}.section-header h4{margin:0;color:var(--secondary-color)}.selection-actions{display:flex;gap:.5rem}.btn-select-all{background:linear-gradient(135deg,#2196f3,#42a5f5);color:#fff;border:none;padding:.8rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #2196f34d;white-space:nowrap}.btn-select-all:hover{background:linear-gradient(135deg,#42a5f5,#64b5f6);transform:translateY(-2px);box-shadow:0 4px 12px #2196f366}.btn-purchase-selected{background:linear-gradient(135deg,#4caf50,#66bb6a);color:#fff;border:none;padding:.8rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #4caf504d}.btn-purchase-selected:hover:not(:disabled){background:linear-gradient(135deg,#66bb6a,#81c784);transform:translateY(-2px);box-shadow:0 4px 12px #4caf5066}.btn-purchase-selected:disabled{background:#ccc;cursor:not-allowed;opacity:.5}.bingo-card.selectable{cursor:pointer;position:relative;transition:all .3s ease;border:3px solid transparent}.bingo-card.selectable:hover{border-color:var(--primary-cyan);transform:translateY(-5px);box-shadow:0 8px 20px #00bcd44d}.bingo-card.selectable.selected{border-color:var(--accent-yellow);background:linear-gradient(135deg,#ffc1071a,#ff98001a);box-shadow:0 6px 16px #ffc10766}.card-selection-indicator{position:absolute;top:-12px;right:-12px;width:40px;height:40px;background:var(--accent-yellow);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0003;opacity:0;transition:opacity .3s ease}.bingo-card.selectable.selected .card-selection-indicator{opacity:1}.check-mark{color:#fff;font-size:24px;font-weight:700}.no-cards-info{text-align:center;padding:3rem;color:var(--secondary-color);opacity:.6}.no-cards-info p:first-child{font-size:1.2rem;margin-bottom:.5rem}.cancel-btn{background:#f44336;color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s ease;margin:0 2rem 2rem;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 4px 12px #f443364d}.cancel-btn:hover{background:#d32f2f;transform:translateY(-2px);box-shadow:0 6px 16px #f4433666}@media(max-width:1200px){.game-content{grid-template-columns:1fr}.jackpots-list,.regular-prizes{flex-direction:column}.jackpot-badge,.prize-badge{min-width:100%}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e)}.login-box{background:var(--card-bg);padding:3rem;border-radius:20px;box-shadow:0 10px 40px #00000080;text-align:center;max-width:500px;width:90%}.login-box h1{font-size:3rem;color:var(--primary-color);margin-bottom:2rem;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.error-message{background:var(--danger-color);color:#fff;padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-weight:600}.login-info{color:var(--text-secondary);line-height:1.8}.login-info p{margin-bottom:1rem}*{margin:0;padding:0;box-sizing:border-box}#root{width:100%;min-height:100vh}.app{display:flex;flex-direction:column;min-height:100vh;background:var(--bg-primary)}.app-main{flex:1;display:flex;flex-direction:column}.container{max-width:1400px;margin:0 auto;padding:0 24px}.card{background:var(--bg-card);border-radius:var(--border-radius);box-shadow:var(--shadow-md);padding:24px;transition:all .3s ease}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn{padding:12px 24px;border:none;border-radius:var(--border-radius-sm);font-weight:600;font-size:14px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.btn-primary{background:linear-gradient(135deg,var(--primary-cyan),var(--primary-teal));color:var(--text-white);box-shadow:var(--shadow-sm)}.btn-primary:hover{box-shadow:var(--shadow-glow);transform:scale(1.05)}.btn-secondary{background:linear-gradient(135deg,var(--secondary-purple),var(--secondary-pink));color:var(--text-white)}.btn-disabled{background:var(--text-muted);cursor:not-allowed;opacity:.6}.btn-disabled:hover{transform:none}.gradient-cyan{background:linear-gradient(135deg,#06b6d4,#00d4c8)}.gradient-purple{background:linear-gradient(135deg,#a855f7,#ec4899)}.gradient-orange{background:linear-gradient(135deg,#ff8a3d,#f59e0b)}.gradient-green{background:linear-gradient(135deg,#10b981,#34d399)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.fade-in{animation:fadeIn .5s ease-out}.slide-in{animation:slideIn .3s ease-out}.pulse{animation:pulse 2s infinite}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0000001a;border-radius:4px}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,var(--primary-cyan),var(--primary-teal));border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary-teal)}
