body{margin:0;min-width:320px;min-height:100vh}*{box-sizing:border-box;margin:0;padding:0}:root{--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--success: #00d68f;--danger: #ff6b6b;--warning: #ffc107;--font: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}:root{--brand-blue: #19BBFF;--brand-purple: #8234D4;--brand-magenta: #ED0797;--brand-yellow: #FFD000;--brand-offwhite: #F9F7F4;--brand-black: #1A1A1A}[data-theme=light]{--bg: #F9F7F4;--bg-card: #ffffff;--bg-elevated: #ffffff;--text: #1A1A1A;--text-muted: #6b7280;--primary: #19BBFF;--primary-hover: #0da8eb;--border: #e5e5e5;--input-bg: #ffffff;--input-border: #d1d5db;--input-focus: #19BBFF}[data-theme=dark]{--bg: #0f1117;--bg-card: #1a1d27;--bg-elevated: #232735;--text: #e8eaf0;--text-muted: #8b8fa3;--primary: #B8FF57;--primary-hover: #c9ff7a;--border: #2d3142;--marked: #B8FF57;--marked-bg: rgba(184, 255, 87, .12);--free-bg: rgba(0, 214, 143, .15)}body{font-family:var(--font);min-height:100vh;margin:0;background:#0f1117}.app{background:var(--bg);color:var(--text);min-height:100vh;position:relative;overflow-x:hidden;transition:background .4s ease,color .4s ease}#root{max-width:100%;margin:0;padding:0;text-align:left}button{cursor:pointer;border:none;border-radius:10px;font-size:.9rem;font-weight:600;padding:10px 20px;transition:all .2s ease;font-family:var(--font)}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--bg-elevated);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){opacity:.85}.btn-large{padding:16px 32px;font-size:1.1rem;width:100%;max-width:320px}.btn-small{padding:4px 10px;font-size:.75rem}.btn-back{background:none;color:var(--text-muted);padding:8px 0;font-size:.9rem}.btn-back:hover{color:var(--text)}.btn-link{background:none;color:var(--primary);padding:0;font-size:.8rem;margin-left:8px}[data-theme=light] .btn-primary{background:var(--brand-blue);color:#fff;border-radius:10px;font-weight:700}[data-theme=light] .btn-primary:hover:not(:disabled){background:#0da8eb}[data-theme=light] .btn-primary.btn-large{border-radius:50px;padding:18px 40px;box-shadow:0 4px 16px #19bbff40}[data-theme=light] .btn-primary.btn-large:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 24px #19bbff59}[data-theme=light] .btn-secondary{background:#fff;color:var(--brand-black);border:2px solid var(--brand-black)}[data-theme=light] .btn-secondary:hover:not(:disabled){background:#f5f5f5}[data-theme=light] .btn-secondary.btn-large{border-radius:50px;padding:18px 40px;font-weight:700}[data-theme=light] .btn-back{color:#6b7280}[data-theme=light] .btn-back:hover{color:var(--brand-black)}[data-theme=dark] .btn-primary{background:var(--primary);color:#0f1117;font-weight:700}[data-theme=dark] .btn-primary:hover:not(:disabled){background:var(--primary-hover)}.home-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:24px;gap:28px;position:relative;z-index:1}.hero{display:flex;flex-direction:column;align-items:center;gap:12px}.hero-mascot{width:140px;height:auto;filter:drop-shadow(0 8px 24px rgba(130,52,212,.2));animation:mascotFloat 3s ease-in-out infinite}@keyframes mascotFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.hero h1{font-size:3.5rem;font-weight:800;text-align:center;color:var(--text)}[data-theme=light] .hero h1{color:var(--brand-black);background:none;-webkit-text-fill-color:unset;-webkit-background-clip:unset}.tagline{color:var(--text-muted);font-size:1.2rem;font-weight:500;text-align:center;margin-top:0}.home-actions{display:flex;flex-direction:column;gap:16px;align-items:center}.connection-status{display:flex;align-items:center;gap:6px;color:var(--text-muted);font-size:.8rem}.dot{width:8px;height:8px;border-radius:50%}.dot.connected{background:var(--success)}.dot.disconnected{background:var(--danger)}.screen-container{max-width:600px;margin:0 auto;padding:24px;position:relative;z-index:1;animation:fadeIn .3s ease}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:.85rem;font-weight:600;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.form-group input,.form-group textarea{width:100%;padding:12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:1rem;font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary)}[data-theme=light] .form-group label{color:#374151}[data-theme=light] .form-group input,[data-theme=light] .form-group textarea{background:#f9fafb;border:1.5px solid #d1d5db;color:#1a1a1a;border-radius:10px;padding:14px}[data-theme=light] .form-group input:focus,[data-theme=light] .form-group textarea:focus{border-color:var(--brand-blue);box-shadow:0 0 0 3px #19bbff1f}[data-theme=light] .form-group input::placeholder,[data-theme=light] .form-group textarea::placeholder{color:#9ca3af}.code-input{font-size:1.5rem!important;letter-spacing:6px;text-align:center;font-weight:700;text-transform:uppercase}.hint{font-size:.8rem;color:var(--text-muted);margin-top:4px;display:block}.radio-group{display:flex;gap:16px;flex-wrap:wrap}.radio-label{display:flex!important;align-items:center;gap:6px;font-size:.9rem!important;text-transform:none!important;letter-spacing:0!important;color:var(--text)!important;cursor:pointer}.template-buttons{display:flex;gap:10px;flex-wrap:wrap}.template-btn{flex:1;min-width:150px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;padding:12px 14px;text-align:left;display:flex;flex-direction:column;gap:4px;transition:all .2s ease}.template-btn:hover{border-color:var(--primary)}[data-theme=light] .template-btn{background:#fff;border:1.5px solid #e5e5e5;border-radius:12px;box-shadow:0 1px 3px #0000000a}[data-theme=light] .template-btn:hover{border-color:var(--brand-blue);background:#fafafa;box-shadow:0 2px 8px #19bbff1a}.template-name{font-size:.85rem;font-weight:700;color:var(--text)}.template-desc{font-size:.7rem;color:var(--text-muted);font-weight:400}.error-msg{background:#ff6b6b1a;border:1px solid var(--danger);color:var(--danger);padding:10px 14px;border-radius:8px;font-size:.85rem;margin-bottom:16px}.bingo-card{max-width:500px;margin:0 auto}.bingo-card.compact{max-width:350px}.bingo-header{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;margin-bottom:4px}.bingo-letter{text-align:center;font-size:1.3rem;font-weight:800;color:var(--primary);padding:8px 0}.compact .bingo-letter{font-size:1rem;padding:4px 0}.bingo-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px}.bingo-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;padding:4px;position:relative;overflow:hidden;transition:all .2s ease}.bingo-cell.clickable:hover{border-color:var(--primary);background:var(--marked-bg)}.bingo-cell.marked{background:var(--marked-bg);border-color:var(--marked, var(--primary));animation:cellMark .3s ease}.bingo-cell.free{background:var(--free-bg);border-color:var(--success)}.cell-text{font-size:.65rem;text-align:center;line-height:1.2;word-break:break-word;z-index:1}.compact .cell-text{font-size:.5rem}.mark-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:1.8rem;color:var(--primary);opacity:.3}.compact .mark-overlay{font-size:1.2rem}.admin-dashboard{padding:16px;max-width:1200px;margin:0 auto;position:relative;z-index:1;animation:fadeIn .3s ease}.admin-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:16px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border)}.game-info{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.game-info h2{font-size:1.4rem;font-weight:800}.game-code-display{background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;padding:8px 16px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:border-color .2s}.game-code-display:hover{border-color:var(--primary)}.code-label{color:var(--text-muted);font-size:.8rem}.code-value{font-size:1.2rem;font-weight:700;letter-spacing:3px}.copy-hint{font-size:.7rem;color:var(--text-muted)}.status-badge{padding:4px 12px;border-radius:20px;font-size:.7rem;font-weight:700;letter-spacing:1px}.status-badge[data-status=waiting]{background:#ffc10726;color:var(--warning)}.status-badge[data-status=live]{background:#00d68f26;color:var(--success)}.status-badge[data-status=paused]{background:#ffc10726;color:var(--warning)}.status-badge[data-status=ended]{background:#ff6b6b26;color:var(--danger)}.admin-controls{display:flex;gap:8px;flex-wrap:wrap}.admin-body{display:grid;grid-template-columns:250px 1fr 280px;gap:16px}@media(max-width:900px){.admin-body{grid-template-columns:1fr}}.panel{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:16px}.panel h3{font-size:.95rem;margin-bottom:12px}.panel h4{font-size:.8rem;color:var(--text-muted);margin-top:16px;margin-bottom:8px}.panel-hint{font-size:.75rem;color:var(--text-muted);margin-bottom:12px}.empty-state{color:var(--text-muted);font-size:.85rem;text-align:center;padding:20px}.player-item{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border);font-size:.85rem}.player-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.player-item.connected .player-dot{background:var(--success)}.player-item.disconnected .player-dot{background:var(--text-muted)}.player-name{flex:1}.player-progress{color:var(--text-muted);font-size:.75rem}.trigger-list{display:flex;flex-wrap:wrap;gap:6px;max-height:400px;overflow-y:auto}.trigger-btn{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text);padding:6px 12px;font-size:.75rem;border-radius:6px}.trigger-btn:hover:not(:disabled){border-color:var(--primary);background:var(--marked-bg, rgba(184, 255, 87, .12))}.detected-list{display:flex;flex-direction:column;gap:4px}.detected-item{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-muted)}.detected-check{color:var(--success);font-size:.7rem}.feed-list{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}.feed-item{display:flex;gap:8px;font-size:.8rem;padding:6px 0;border-bottom:1px solid var(--border)}.feed-time{color:var(--text-muted);font-size:.7rem;flex-shrink:0}.winner-item{font-size:.85rem;padding:6px 0}.bingo-verification{background:var(--bg-card);border:2px solid var(--warning);border-radius:12px;padding:20px;margin-bottom:20px;text-align:center}.bingo-verification h3{color:var(--warning);font-size:1.2rem}.verification-card{margin:16px auto}.verification-actions{display:flex;gap:12px;justify-content:center;margin-top:16px}.player-view{max-width:500px;margin:0 auto;padding:16px;position:relative;z-index:1;animation:fadeIn .3s ease}.player-header{text-align:center;margin-bottom:16px}.player-header h2{font-size:1.4rem;font-weight:800;margin-bottom:8px}.player-info{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}.player-name-tag{background:var(--bg-elevated);padding:4px 12px;border-radius:20px;font-size:.8rem;border:1px solid var(--border)}.player-count{color:var(--text-muted);font-size:.8rem}.waiting-state{text-align:center;padding:20px;color:var(--text-muted)}.waiting-state p:first-child{font-size:1.1rem;color:var(--text);margin-bottom:8px}.btn-bingo{display:block;width:100%;max-width:500px;margin:16px auto;padding:16px;font-size:1.5rem;font-weight:800;letter-spacing:6px;background:linear-gradient(135deg,#b8ff57,#8cd93a);color:#0f1117;border-radius:14px;border:none;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 24px #b8ff574d}.btn-bingo:hover{transform:scale(1.02);box-shadow:0 6px 32px #b8ff5773}.btn-bingo:active{transform:scale(.98)}.notification-toast{position:fixed;top:16px;left:50%;transform:translate(-50%);background:var(--bg-elevated);border:1px solid var(--primary);color:var(--text);padding:12px 24px;border-radius:10px;font-size:.9rem;font-weight:600;z-index:1000;animation:slideDown .3s ease}@keyframes slideDown{0%{transform:translate(-50%) translateY(-20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.winner-announcement{position:fixed;inset:0;background:#000000e0;display:flex;align-items:center;justify-content:center;z-index:2000;cursor:pointer}.winner-content{text-align:center;animation:popIn .4s ease}.winner-emoji{font-size:4rem;margin-bottom:16px}.winner-content h2{font-size:2.5rem;margin-bottom:8px;color:#b8ff57}.winner-content p{color:var(--text-muted)}@keyframes popIn{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.activity-ticker{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:12px 16px;margin-top:16px;max-width:500px;margin-left:auto;margin-right:auto}.activity-ticker h4{font-size:.8rem;color:var(--text-muted);margin-bottom:8px}.ticker-item{font-size:.8rem;padding:4px 0;color:var(--text-muted)}.ticker-check{color:var(--success);margin-right:4px}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1500;padding:16px}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:24px;max-width:450px;width:100%;text-align:center}.modal h3{margin-bottom:16px}.modal .btn-secondary{margin-top:16px}.meeting-panel{margin-bottom:16px}.meeting-connect-form{display:flex;gap:8px;margin-bottom:8px}.meeting-connect-form input{flex:1;padding:10px 12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.9rem;font-family:var(--font)}.meeting-connect-form input:focus{outline:none;border-color:var(--primary)}.meeting-connect-form input::placeholder{color:var(--text-muted);opacity:.6}.meeting-status-display{display:flex;align-items:center;gap:10px;padding:10px 0}.meeting-status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.meeting-status-dot.connecting{background:var(--warning);animation:pulse 1.5s infinite}.meeting-status-dot.active{background:var(--success);animation:pulse 1.5s infinite}.meeting-status-dot.ended{background:var(--text-muted)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.meeting-status-text{font-size:.9rem;font-weight:600}.loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-muted)}.decorative-shapes{position:fixed;inset:0;pointer-events:none;z-index:0}.deco-shape{position:absolute;opacity:.85;transition:opacity .3s ease}.deco-confetti-left,.deco-confetti-right{opacity:.45}@media(max-width:600px){.deco-shape{opacity:.5;transform:scale(.6)!important}.deco-confetti-left,.deco-confetti-right{opacity:.25}}.app[data-theme=dark]:before,.app[data-theme=dark]:after{content:"";position:fixed;width:500px;height:500px;border-radius:50%;filter:blur(120px);opacity:.12;pointer-events:none;z-index:0}.app[data-theme=dark]:before{top:-150px;right:-150px;background:radial-gradient(circle,#B8FF57 0%,transparent 70%)}.app[data-theme=dark]:after{bottom:-150px;left:-150px;background:radial-gradient(circle,#6C9BCF 0%,transparent 70%)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes cellMark{0%{transform:scale(1)}50%{transform:scale(1.08)}to{transform:scale(1)}}@media(max-width:600px){.hero h1{font-size:2.5rem}.app[data-theme=dark]:before,.app[data-theme=dark]:after{width:300px;height:300px;filter:blur(80px);opacity:.08}}
