:root{--bg-primary:#0a0e14;--bg-secondary:#0d1117;--bg-tertiary:#161b22;--bg-card:#1c2128;--bg-card-hover:#22272e;--accent-primary:#00ff9d;--accent-primary-rgb:0,255,157;--accent-secondary:#00d4ff;--accent-tertiary:#ff6b00;--accent-warning:#ffb800;--accent-danger:#ff4757;--text-primary:#e6edf3;--text-secondary:#e6edf3bf;--text-muted:#e6edf380;--text-accent:var(--accent-primary);--border-color:#00ff9d26;--border-active:#00ff9d66;--glow-primary:0 0 20px #00ff9d4d;--glow-secondary:0 0 30px #00d4ff33;--grid-color:#00ff9d08;--font-mono:"JetBrains Mono","SF Mono","Consolas",monospace;--font-sans:"Sora",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%}body{background:#0a0e14;background:var(--bg-primary);color:#e6edf3;color:var(--text-primary);font-family:Sora,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-sans);line-height:1.6;min-height:100vh;overflow-x:hidden}body:before{background-image:linear-gradient(#00ff9d08 1px,#0000 0),linear-gradient(90deg,#00ff9d08 1px,#0000 0);background-image:linear-gradient(var(--grid-color) 1px,#0000 1px),linear-gradient(90deg,var(--grid-color) 1px,#0000 1px);background-size:50px 50px}body:after,body:before{content:"";height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:0}body:after{background:radial-gradient(ellipse at top right,#00ff9d0d 0,#0000 50%),radial-gradient(ellipse at bottom left,#00d4ff0d 0,#0000 50%)}#root{min-height:100vh;position:relative;z-index:1}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#0d1117;background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#00ff9d66;background:var(--border-active);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#00ff9d;background:var(--accent-primary)}::selection{background:#00ff9d4d;color:#e6edf3;color:var(--text-primary)}:focus-visible{outline:2px solid #00ff9d;outline:2px solid var(--accent-primary);outline-offset:2px}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #00ff9d4d;box-shadow:var(--glow-primary)}50%{box-shadow:0 0 30px #00ff9d80}}@keyframes scan-line{0%{transform:translateY(-100%)}to{transform:translateY(100vh)}}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.app{display:flex;flex-direction:column;min-height:100vh}.loading-screen{align-items:center;justify-content:center}.loading-content{align-items:center;display:flex;flex-direction:column;gap:1.5rem}.loading-spinner{animation:spin 1s linear infinite;border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-primary);height:50px;width:50px}.loading-text{color:var(--text-secondary);font-family:var(--font-mono);font-size:.875rem;letter-spacing:.2em}.cursor{animation:blink 1s infinite}.login-container{align-items:center;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:2rem;position:relative}.login-panel{animation:fadeIn .5s ease-out;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--glow-primary);max-width:420px;overflow:hidden;width:100%}.login-header{background:linear-gradient(180deg,var(--bg-tertiary) 0,var(--bg-card) 100%);border-bottom:1px solid var(--border-color);padding:1.5rem}.terminal-bar{display:flex;gap:6px;margin-bottom:1.5rem}.terminal-dot{border-radius:50%;height:12px;width:12px}.terminal-dot.red{background:#ff5f57}.terminal-dot.yellow{background:#ffbd2e}.terminal-dot.green{background:#28c840}.logo-section{text-align:center}.logo-text{font-family:var(--font-mono);font-size:1.75rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.5rem}.logo-accent{color:var(--accent-primary)}.logo-dot{color:var(--text-muted)}.logo-secondary{color:var(--accent-secondary)}.logo-tertiary{color:var(--text-secondary)}.logo-subtitle{color:var(--text-muted);font-family:var(--font-mono);font-size:.75rem;letter-spacing:.25em}.login-form{gap:1.25rem;padding:2rem}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{color:var(--text-secondary);font-family:var(--font-mono);font-size:.75rem;letter-spacing:.15em}.label-prefix{color:var(--accent-primary)}.form-group input{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-family:var(--font-mono);font-size:.9rem;padding:.875rem 1rem;transition:all .2s ease}.form-group input::placeholder{color:var(--text-muted)}.form-group input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #00ff9d1a;outline:none}.form-group input:disabled{cursor:not-allowed;opacity:.6}.error-message{align-items:center;animation:slideIn .3s ease-out;background:#ff47571a;border:1px solid #ff47574d;border-radius:6px;color:var(--accent-danger);display:flex;font-family:var(--font-mono);font-size:.8rem;gap:.5rem;padding:.75rem 1rem}.error-icon{font-size:1rem}.login-button{align-items:center;background:linear-gradient(135deg,var(--accent-primary) 0,#00ff9dcc 100%);border:none;border-radius:6px;color:var(--bg-primary);cursor:pointer;display:flex;font-family:var(--font-mono);font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;letter-spacing:.1em;margin-top:.5rem;padding:1rem 1.5rem;transition:all .2s ease}.login-button:hover:not(:disabled){box-shadow:0 4px 20px #00ff9d66;transform:translateY(-2px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{cursor:not-allowed;opacity:.7}.button-spinner{animation:spin .8s linear infinite;border:2px solid #0000;border-radius:50%;border-top:2px solid var(--bg-primary);height:16px;width:16px}.button-arrow{transition:transform .2s ease}.login-button:hover .button-arrow{transform:translateX(4px)}.login-footer{align-items:center;border-top:1px solid var(--border-color);display:flex;gap:1rem;padding:1.25rem 2rem}.footer-line{background:linear-gradient(90deg,#0000,var(--border-color),#0000);flex:1 1;height:1px}.footer-text{color:var(--text-muted);font-family:var(--font-mono);font-size:.65rem;letter-spacing:.2em}.decorative-elements{height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:0}.hex{border:1px solid var(--border-color);height:200px;opacity:.3;position:absolute;transform:rotate(45deg);width:200px}.hex-1{animation:float 20s ease-in-out infinite;left:-5%;top:10%}.hex-2{animation:float 25s ease-in-out infinite reverse;bottom:15%;height:300px;right:-8%;width:300px}.hex-3{animation:float 30s ease-in-out infinite;border-color:#00d4ff1a;height:500px;left:50%;top:50%;width:500px}@keyframes float{0%,to{transform:rotate(45deg) translate(0)}50%{transform:rotate(45deg) translate(20px,20px)}}.dashboard{display:flex;flex-direction:column;min-height:100vh}.dashboard-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);justify-content:space-between;padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.dashboard-header,.header-left{align-items:center;display:flex}.header-left{gap:1.5rem}.header-title{font-family:var(--font-mono);font-size:1.25rem;font-weight:700}.title-accent{color:var(--accent-primary)}.title-dot{color:var(--text-muted)}.connection-status{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:20px;display:flex;gap:.5rem;padding:.35rem .75rem}.status-dot{border-radius:50%;height:8px;transition:all .3s ease;width:8px}.status-dot.connected{animation:pulse-glow 2s infinite;background:var(--accent-primary);box-shadow:0 0 8px var(--accent-primary)}.status-dot.disconnected{background:var(--accent-danger)}.status-text{color:var(--text-secondary);font-size:.7rem;letter-spacing:.1em}.header-right{align-items:center;display:flex;gap:1rem}.logout-button,.refresh-button{align-items:center;border-radius:6px;cursor:pointer;display:flex;font-family:var(--font-mono);font-size:.8rem;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.refresh-button{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary)}.refresh-button:hover:not(:disabled){border-color:var(--accent-primary);color:var(--accent-primary)}.refresh-button:disabled{cursor:not-allowed;opacity:.6}.logout-button{background:#0000;border:1px solid #ff47574d;color:var(--accent-danger)}.logout-button:hover{background:#ff47571a;border-color:var(--accent-danger)}.logout-icon{font-size:.9rem}.dashboard-main{flex:1 1;margin:0 auto;max-width:1400px;padding:2rem;width:100%}.stats-bar{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;padding:1.25rem 1.5rem;text-align:center;transition:all .2s ease}.stat-card:hover{border-color:var(--border-active);box-shadow:var(--glow-primary)}.stat-value{color:var(--accent-primary);font-family:var(--font-mono);font-size:2.5rem;font-weight:700;line-height:1;margin-bottom:.5rem}.stat-value.small{color:var(--text-primary);font-size:1.25rem}.stat-label{font-size:.75rem;letter-spacing:.1em}.time-card .stat-value{color:var(--text-secondary)}.rooms-section{animation:fadeIn .3s ease-out}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.section-title{color:var(--text-primary);font-family:var(--font-mono);font-size:1rem;font-weight:600}.title-prefix{color:var(--accent-primary)}.room-count{background:var(--bg-tertiary);border-radius:20px;color:var(--text-muted);font-family:var(--font-mono);font-size:.8rem;padding:.25rem .75rem}.empty-state{align-items:center;background:var(--bg-card);border:1px dashed var(--border-color);border-radius:12px;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem}.empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-text{color:var(--text-secondary);font-family:var(--font-mono);font-size:1.1rem;margin-bottom:.5rem}.empty-subtext{color:var(--text-muted);font-size:.85rem}.rooms-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.room-card{animation:fadeIn .3s ease-out backwards;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;cursor:pointer;padding:1.25rem;transition:all .2s ease}.room-card:hover{background:var(--bg-card-hover);border-color:var(--accent-primary);box-shadow:var(--glow-primary);transform:translateY(-2px)}.room-card-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem}.room-code{color:var(--accent-primary);font-size:1.25rem;font-weight:700;letter-spacing:.1em}.room-code,.room-state{font-family:var(--font-mono)}.room-state{background:#ffffff0d;border-radius:4px;font-size:.65rem;font-weight:600;letter-spacing:.15em;padding:.25rem .5rem}.room-card-body{margin-bottom:1rem}.game-type{color:var(--text-primary);font-size:.95rem;font-weight:500;margin-bottom:.75rem}.player-count{align-items:center;color:var(--text-secondary);display:flex;gap:.5rem}.player-icon{font-size:1rem}.player-number{color:var(--text-primary);font-family:var(--font-mono);font-size:1.1rem;font-weight:600}.player-label{font-size:.85rem}.room-card-footer{border-top:1px solid var(--border-color);justify-content:space-between;padding-top:.75rem}.avatar,.player-avatars,.room-card-footer{align-items:center;display:flex}.avatar{background:var(--bg-tertiary);border:2px solid var(--bg-card);border-radius:50%;font-size:.8rem;height:28px;justify-content:center;margin-left:-8px;width:28px}.avatar:first-child{margin-left:0}.avatar.more{background:var(--accent-primary);color:var(--bg-primary);font-size:.65rem;font-weight:600}.avatar.more,.view-details{font-family:var(--font-mono)}.view-details{color:var(--text-muted);font-size:.75rem;transition:color .2s ease}.room-card:hover .view-details{color:var(--accent-primary)}@media (max-width:768px){.dashboard-header{flex-direction:column;gap:1rem;padding:1rem}.header-left,.header-right{justify-content:center;width:100%}.dashboard-main{padding:1rem}.stats-bar{grid-template-columns:repeat(2,1fr)}.rooms-grid{grid-template-columns:1fr}}.room-detail{animation:fadeIn .3s ease-out}.detail-nav{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.back-button{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-family:var(--font-mono);font-size:.85rem;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.back-button:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.back-arrow{font-size:1rem;transition:transform .2s ease}.back-button:hover .back-arrow{transform:translateX(-3px)}.refresh-button-detail{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;font-family:var(--font-mono);font-size:.85rem;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.refresh-button-detail:hover:not(:disabled){border-color:var(--accent-primary);color:var(--accent-primary)}.refresh-button-detail:disabled{cursor:not-allowed;opacity:.6}.refresh-icon{display:inline-block;font-size:1rem}.refresh-icon.spinning{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.detail-header{align-items:flex-start;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem;padding:1.5rem}.header-info{align-items:center;display:flex;flex-wrap:wrap;gap:1.5rem}.room-code-large{color:var(--text-primary);font-family:var(--font-mono);font-size:2rem;font-weight:700;letter-spacing:.05em}.code-prefix{color:var(--accent-primary)}.status-badge{align-items:center;background:var(--bg-tertiary);border:1px solid;border-radius:20px;display:flex;gap:.5rem;padding:.5rem 1rem}.status-icon{font-size:1rem}.status-text{font-family:var(--font-mono);font-size:.8rem;font-weight:500}.game-info{align-items:center;display:flex;gap:.75rem}.game-type-badge{background:linear-gradient(135deg,var(--accent-primary),#00ff9db3);border-radius:20px;color:var(--bg-primary);font-family:var(--font-mono);font-size:.85rem;font-weight:600;padding:.5rem 1.25rem}.detail-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:1fr 1fr}.detail-panel{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.panel-header{background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);padding:1rem 1.25rem}.panel-title{align-items:center;color:var(--text-primary);display:flex;font-family:var(--font-mono);font-size:.9rem;font-weight:600;gap:.5rem}.title-icon{font-size:1rem}.panel-content{padding:1rem 1.25rem}.players-panel{grid-row:span 2}.no-players{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;gap:.5rem;padding:2rem}.no-players-icon{font-size:2rem;opacity:.5}.players-list{display:flex;flex-direction:column;gap:.75rem}.player-row{align-items:center;background:var(--bg-secondary);border-radius:8px;display:flex;gap:.75rem;padding:.75rem;transition:all .2s ease}.player-row:hover{background:var(--bg-tertiary)}.player-rank{text-align:center;width:32px}.rank-badge{color:var(--text-muted);font-family:var(--font-mono);font-size:.85rem}.rank-1{font-size:1.1rem}.rank-2{font-size:1rem}.rank-3{font-size:.95rem}.player-avatar{align-items:center;background:var(--bg-card);border-radius:8px;display:flex;font-size:1.2rem;height:36px;justify-content:center;width:36px}.player-info{display:flex;flex:1 1;flex-direction:column;gap:.15rem;min-width:0}.player-name{align-items:center;color:var(--text-primary);display:flex;font-weight:500;gap:.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.host-badge{background:var(--accent-secondary);border-radius:4px;color:var(--bg-primary);flex-shrink:0;font-family:var(--font-mono);font-size:.6rem;font-weight:600;padding:.1rem .4rem}.player-joined{color:var(--text-muted);font-size:.75rem}.player-score{align-items:baseline;display:flex;gap:.25rem}.score-value{color:var(--accent-primary);font-family:var(--font-mono);font-size:1.1rem;font-weight:700}.score-label{color:var(--text-muted);font-size:.7rem}.settings-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.setting-item{display:flex;flex-direction:column;gap:.25rem}.setting-label{color:var(--text-muted);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase}.setting-value{color:var(--text-primary);font-family:var(--font-mono);font-size:.95rem;font-weight:500;text-transform:capitalize}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.stat-item{background:var(--bg-secondary);border-radius:8px;padding:.75rem;text-align:center}.stat-value-large{color:var(--accent-primary);font-family:var(--font-mono);font-size:1.5rem;font-weight:700;line-height:1.2}.stat-label{color:var(--text-muted);font-size:.7rem;letter-spacing:.05em;text-transform:uppercase}.question-panel{grid-column:span 2}.question-counter{color:var(--text-muted);font-size:.75rem;font-weight:400;margin-left:auto}.no-question{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;gap:.5rem;padding:2rem}.no-question-icon{font-size:2rem;opacity:.5}.question-content{display:flex;flex-direction:column;gap:1rem}.question-image-container{background:var(--bg-secondary);border-radius:8px;min-height:150px;overflow:hidden;position:relative}.image-loading{align-items:center;color:var(--text-muted);display:flex;font-family:var(--font-mono);font-size:.85rem;justify-content:center;padding:2rem}.question-image{display:block;max-height:300px;object-fit:contain;width:100%}.question-image.loading{opacity:0;position:absolute}.image-error{align-items:center;background:#ff47571a;border:1px solid #ff47574d;border-radius:8px;display:flex;flex-direction:column;gap:.5rem;padding:1.5rem}.image-error .error-icon{font-size:1.5rem}.image-error .error-text{color:var(--accent-danger);font-weight:500}.image-error .error-url{background:var(--bg-tertiary);border-radius:4px;color:var(--text-muted);font-size:.7rem;max-width:100%;word-break:break-all}.image-error .error-url,.image-status{font-family:var(--font-mono);padding:.5rem}.image-status{font-size:.75rem;text-align:center}.image-status.success{background:#00ff9d1a;color:var(--accent-primary)}.question-text{background:var(--bg-secondary);border-left:3px solid var(--accent-primary);border-radius:8px;color:var(--text-primary);font-size:1.1rem;font-weight:500;line-height:1.5;padding:1rem}.question-options{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr)}.option{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;display:flex;gap:.75rem;padding:.75rem 1rem;transition:all .2s ease}.option.correct{background:#00ff9d1a;border-color:var(--accent-primary)}.option-letter{align-items:center;background:var(--bg-tertiary);border-radius:4px;color:var(--text-muted);display:flex;font-family:var(--font-mono);font-size:.75rem;font-weight:600;height:24px;justify-content:center;width:24px}.option.correct .option-letter{background:var(--accent-primary);color:var(--bg-primary)}.option-text{color:var(--text-primary);flex:1 1;font-size:.9rem}.correct-badge{color:var(--accent-primary);font-weight:600}.question-fact{align-items:flex-start;background:#00d4ff1a;border:1px solid #00d4ff4d;border-radius:8px;display:flex;gap:.75rem;padding:1rem}.fact-icon{flex-shrink:0;font-size:1.1rem}.fact-text{color:var(--text-secondary);font-size:.85rem;line-height:1.5}.activity-panel{grid-column:span 2}.activity-log{display:flex;flex-direction:column;gap:.5rem;max-height:200px;overflow-y:auto}.activity-item{align-items:flex-start;border-bottom:1px solid var(--border-color);display:flex;gap:.75rem;padding:.5rem 0}.activity-item:last-child{border-bottom:none}.activity-time{color:var(--text-muted);font-family:var(--font-mono);font-size:.75rem;min-width:70px}.activity-message{color:var(--text-secondary);font-size:.85rem}.activity-message strong{color:var(--accent-primary)}.player-mention{color:var(--accent-secondary);font-weight:500}.event-icon{margin-right:.5rem}.event-detail{color:var(--text-muted);font-size:.8rem}.activity-item.event-started{background:#00ff9d0d;border-left:3px solid var(--accent-primary)}.activity-item.event-ended,.activity-item.event-started{margin-left:-.75rem;padding-left:calc(.75rem - 3px);padding-right:.75rem}.activity-item.event-ended{background:#00d4ff0d;border-left:3px solid var(--accent-secondary)}@media (max-width:900px){.detail-grid{grid-template-columns:1fr}.players-panel{grid-row:span 1}.activity-panel{grid-column:span 1}.detail-header{align-items:flex-start;flex-direction:column}.room-code-large{font-size:1.5rem}}
/*# sourceMappingURL=main.b10ab669.css.map*/