*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none;touch-action:manipulation}html,body,#root{height:100%;background:#0a0a0f;color:#f4f4f8;font-family:system-ui,-apple-system,Segoe UI,sans-serif;overflow:hidden}a{color:inherit;text-decoration:none}button{font-family:inherit}.error{color:#ff5078}.muted{opacity:.6}.subtle{opacity:.7;font-size:1.25rem;max-width:800px}.home{height:100%;background:#fff;color:#1a1a2e;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}.home-nav{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 2rem;border-bottom:1px solid #eaecf0;position:sticky;top:0;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10}.home-logo{font-size:1.4rem;font-weight:800;color:#3071ab;letter-spacing:-.5px}.home-nav-join{font-size:.875rem;color:#3071ab;font-weight:600;padding:.45rem 1rem;border:2px solid #3071ab;border-radius:8px;transition:background .15s,color .15s}.home-nav-join:hover{background:#3071ab;color:#fff}.home-hero{flex:1;display:flex;flex-direction:column;align-items:center;padding:clamp(2rem,5vw,4rem) clamp(1.25rem,5vw,3rem);gap:2.5rem}.home-hero-inner{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1.25rem;max-width:720px}.home-headline{font-size:clamp(2.2rem,5.5vw,3.75rem);font-weight:800;line-height:1.13;color:#0f1923;letter-spacing:-.02em}.home-headline-accent{color:#3071ab}.home-sub{font-size:clamp(1rem,2vw,1.15rem);color:#5a6a7a;line-height:1.65;max-width:540px}.home-ctas{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-top:.5rem}.home-cta-primary{background:#3071ab;color:#fff;padding:.875rem 2rem;border-radius:10px;font-weight:700;font-size:1rem;box-shadow:0 4px 14px #3071ab59;transition:background .15s,transform .1s,box-shadow .15s}.home-cta-primary:hover{background:#255a8f;transform:translateY(-2px);box-shadow:0 6px 20px #3071ab66}.home-cta-primary:active{transform:translateY(0)}.home-cta-secondary{background:#f0f4f8;color:#3071ab;padding:.875rem 2rem;border-radius:10px;font-weight:700;font-size:1rem;transition:background .15s}.home-cta-secondary:hover{background:#dce8f5}.home-features{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;width:100%;max-width:900px}.home-feature{background:#f7f9fc;border:1px solid #e5eaf0;border-radius:14px;padding:1.75rem 1.5rem;display:flex;flex-direction:column;gap:.6rem}.home-feature-icon{font-size:1.75rem;line-height:1}.home-feature h3{font-size:.95rem;font-weight:700;color:#1a1a2e}.home-feature p{font-size:.875rem;color:#6b7a8d;line-height:1.55}.home-footer{padding:1.25rem 2rem;text-align:center;border-top:1px solid #eaecf0;font-size:.875rem;color:#9aa5b4}.home-footer a{color:#3071ab;font-weight:600}.home-footer a:hover{text-decoration:underline}@media (max-width: 680px){.home-features{grid-template-columns:1fr}.home-ctas{flex-direction:column;align-items:stretch;width:100%;max-width:320px}.home-cta-primary,.home-cta-secondary{text-align:center}}.centered-screen{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1.5rem;text-align:center}.centered-screen .title{font-size:clamp(3rem,8vw,7rem);letter-spacing:.05em}.centered-screen .hint{opacity:.4;margin-top:1.5rem}.centered-screen code{background:#1c1c25;padding:.2rem .5rem;border-radius:.3rem}.start-btn{background:#4ad991;color:#0a0a0f;border:none;padding:1.25rem 2.5rem;border-radius:.75rem;font-size:clamp(1.1rem,2vw,1.75rem);font-weight:700;cursor:pointer;transition:transform .05s,background .1s}.start-btn:hover{background:#5ce0a0}.start-btn:active{transform:scale(.97)}.start-btn:disabled{opacity:.4;cursor:not-allowed}.start-btn.primary{background:#f1c40f}.start-btn.primary:hover{background:#f5d54a}.winner{font-size:clamp(3rem,10vw,9rem);font-weight:900;letter-spacing:.08em}.winner-draw{color:#f1c40f}.final-score{font-size:clamp(1.25rem,3vw,2rem);display:flex;gap:1rem;align-items:center}.score-red{color:#ff5078;font-weight:700}.score-blue{color:#5ab2ff;font-weight:700}.score-divider{opacity:.4}.lobby-screen{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1.5rem;text-align:center;overflow:auto}.lobby-title{font-size:clamp(3rem,8vw,7rem);letter-spacing:.05em}.mode-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;width:100%;max-width:1400px;margin-top:1.5rem}.mode-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:2rem 1rem;background:#15151c;color:#f4f4f8;border:3px solid #2a2a36;border-radius:1rem;cursor:pointer;transition:transform .05s,background .1s,border-color .1s;min-height:200px}.mode-btn:hover{background:#1c1c25}.mode-btn:active{transform:scale(.97)}.mode-btn:disabled{opacity:.4;cursor:not-allowed}.mode-btn .mode-icon{font-size:clamp(3rem,6vw,5rem);font-weight:900;line-height:1}.mode-btn .mode-label{font-size:clamp(1rem,2vw,1.5rem);font-weight:700;letter-spacing:.05em}.mode-btn .mode-sub{font-size:.85rem;opacity:.6;font-weight:500}.mode-btn.mode-multiply{border-color:#f1c40f}.mode-btn.mode-multiply .mode-icon{color:#f1c40f}.mode-btn.mode-divide{border-color:#4ad991}.mode-btn.mode-divide .mode-icon{color:#4ad991}.mode-btn.mode-add{border-color:#5ab2ff}.mode-btn.mode-add .mode-icon{color:#5ab2ff}.mode-btn.mode-subtract{border-color:#ff5078}.mode-btn.mode-subtract .mode-icon{color:#ff5078}.mode-btn.mode-quiz{border-color:#c084fc}.mode-btn.mode-quiz .mode-icon{color:#c084fc}.tv-screen{height:100vh;display:grid;grid-template-rows:auto 38vh 1fr;background:#0a0a0f}.question-bar{display:grid;grid-template-columns:auto 1fr auto;align-items:center;padding:1rem 1.5rem;background:#15151c;border-bottom:2px solid #2a2a36;gap:1.5rem}.q-counter{font-size:clamp(.9rem,1.5vw,1.25rem);opacity:.6;font-weight:600;letter-spacing:.05em}.q-prompt{text-align:center;font-size:clamp(2rem,6vw,5rem);font-weight:800;letter-spacing:.05em}.q-score{display:flex;gap:.75rem;align-items:center;font-size:clamp(1.25rem,3vw,2.25rem);font-weight:800}.rope-arena{display:grid;grid-template-columns:1fr 4fr 1fr;align-items:center;background:linear-gradient(180deg,#15151c,#0a0a0f);border-bottom:4px solid #2a2a36;height:100%;overflow:hidden}.team-zone{height:100%;display:flex;align-items:center;justify-content:center}.red-zone{background:#d6234a2e}.blue-zone{background:#2a8df02e}.team-label{font-size:clamp(2rem,4vw,4rem);font-weight:800;letter-spacing:.1em}.red-zone .team-label{color:#ff5078}.blue-zone .team-label{color:#5ab2ff}.rope-track{position:relative;height:100%;display:flex;align-items:center;justify-content:center}.center-marker{position:absolute;top:0;bottom:0;left:50%;width:4px;background:#f1c40f;opacity:.6;transform:translate(-50%)}.rope{width:60%;height:18px;background:repeating-linear-gradient(90deg,#8b5a2b 0,#8b5a2b 24px,#6b4220 24px,#6b4220 28px);border-radius:9px;position:relative;display:flex;align-items:center;justify-content:center;transition:transform .25s ease-out;box-shadow:0 0 24px #0009}.rope .flag{position:absolute;font-size:3rem;top:-3.5rem;color:#f1c40f;font-weight:900}.numpads{display:flex;flex-direction:row;align-items:stretch;justify-content:space-between;gap:clamp(4px,1vw,16px);padding:clamp(4px,1vw,24px);background:#2a2a36;min-height:0;overflow:hidden;box-sizing:border-box}.numpad{flex:1 1 0;display:grid;grid-template-rows:auto 1fr;gap:clamp(4px,.8vmin,8px);padding:clamp(4px,.8vmin,8px);min-height:0;min-width:0;box-sizing:border-box}@media (min-width: 1100px){.numpad{flex:0 0 45%;max-width:45%}}@media (min-width: 1400px){.numpad{flex:0 0 35%;max-width:35%}}@media (min-width: 1900px){.numpad{flex:0 0 30%;max-width:30%}}@media (min-width: 2400px){.numpad{flex:0 0 25%;max-width:25%}}@media (min-width: 3200px){.numpad{flex:0 0 22%;max-width:22%}}.numpad-red{background:#d6234a1a;border-radius:.5rem}.numpad-blue{background:#2a8df01a;border-radius:.5rem}.input-display{font-size:clamp(1.5rem,5vmin,4rem);font-weight:800;text-align:center;padding:clamp(.25rem,1vmin,.5rem) clamp(.5rem,2vmin,1rem);background:#0a0a0f;border:2px solid #2a2a36;border-radius:.6rem;letter-spacing:.1em;min-height:1.3em;box-sizing:border-box}.numpad-red .input-display{border-color:#d6234a;color:#ff5078}.numpad-blue .input-display{border-color:#2a8df0;color:#5ab2ff}.numpad-keys{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:1fr;gap:clamp(4px,.8vmin,8px);min-height:0;min-width:0}.numpad-key{background:#1c1c25;color:#f4f4f8;border:2px solid #2a2a36;border-radius:.6rem;font-size:clamp(.9rem,3.5vmin,2.5rem);font-weight:700;cursor:pointer;min-height:0;min-width:0;padding:0;display:flex;align-items:center;justify-content:center;transition:transform .05s,background .1s}.numpad-red .numpad-key{border-color:#d6234a}.numpad-blue .numpad-key{border-color:#2a8df0}.numpad-key:active{transform:scale(.95)}.numpad-red .numpad-key:active{background:#d6234a}.numpad-blue .numpad-key:active{background:#2a8df0}.numpad-key.key-clear{background:#2a2a36;border-color:#444;color:#aaa}.numpad-key.key-ok{background:#4ad991;color:#0a0a0f;border-color:#4ad991}.numpad-key.key-ok:active{background:#5ce0a0}.mcq-grids{display:flex;flex-direction:row;align-items:stretch;justify-content:space-between;gap:clamp(4px,1vw,16px);padding:clamp(4px,1vw,24px);background:#2a2a36;min-height:0;overflow:hidden;box-sizing:border-box}.mcq-grid{position:relative;display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:1fr;gap:clamp(4px,1vmin,10px);padding:clamp(4px,1vmin,12px);min-height:0;min-width:0;flex:1 1 0;box-sizing:border-box}@media (min-width: 1100px){.mcq-grid{flex:0 0 45%;max-width:45%}}@media (min-width: 1400px){.mcq-grid{flex:0 0 35%;max-width:35%}}@media (min-width: 1900px){.mcq-grid{flex:0 0 30%;max-width:30%}}@media (min-width: 2400px){.mcq-grid{flex:0 0 25%;max-width:25%}}@media (min-width: 3200px){.mcq-grid{flex:0 0 22%;max-width:22%}}.mcq-red{background:#d6234a1a;border-radius:.5rem}.mcq-blue{background:#2a8df01a;border-radius:.5rem}.mcq-btn{background:#1c1c25;color:#f4f4f8;border:2px solid #2a2a36;border-radius:.6rem;font-size:clamp(1rem,2.8vmin,2rem);font-weight:700;cursor:pointer;padding:clamp(.4rem,1.5vmin,1rem);text-align:center;word-break:break-word;transition:transform .05s,background .1s;min-height:0;min-width:0}.mcq-red .mcq-btn{border-color:#d6234a}.mcq-blue .mcq-btn{border-color:#2a8df0}.mcq-btn:active{transform:scale(.97)}.mcq-red .mcq-btn:active{background:#d6234a}.mcq-blue .mcq-btn:active{background:#2a8df0}.mcq-btn:disabled{opacity:.4;cursor:not-allowed}.locked-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0a0a0fd9;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;border-radius:.6rem;font-weight:800;letter-spacing:.1em}.locked-overlay span{font-size:clamp(1.5rem,3vw,2.5rem);color:#ff9a3c}.locked-overlay small{opacity:.7;font-weight:500;letter-spacing:0}.play-screen{height:100dvh;min-height:100dvh;max-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:clamp(.4rem,2vmin,1.25rem);gap:clamp(.4rem,1.5vmin,1rem);text-align:center;overflow:hidden;box-sizing:border-box}.play-screen h1{font-size:clamp(1.2rem,6vmin,2rem);letter-spacing:.1em;margin:0}.play-red h1{color:#ff5078}.play-blue h1{color:#5ab2ff}.phone-counter{opacity:.6;font-weight:600;font-size:clamp(.8rem,2.4vmin,1rem);flex:0 0 auto}.phone-question{font-size:clamp(1.3rem,6vmin,3rem);font-weight:800;word-break:break-word;margin:0;line-height:1.15;flex:0 0 auto}.phone-input{font-size:clamp(1.4rem,6vmin,3rem);font-weight:800;width:100%;max-width:360px;padding:clamp(.25rem,1vmin,.5rem);background:#0a0a0f;border:3px solid currentColor;border-radius:.6rem;letter-spacing:.1em;min-height:1.4em;box-sizing:border-box;flex:0 0 auto}.play-red .phone-input{color:#ff5078}.play-blue .phone-input{color:#5ab2ff}.phone-end{font-size:clamp(1.4rem,6vmin,2rem);font-weight:800;margin-top:1rem}.phone-back-link{margin-top:1rem;padding:.75rem 1.5rem;background:#2a2a36;border-radius:.5rem;font-weight:600}.phone-locked{background:#ff9a3c;color:#0a0a0f;padding:.5rem 1rem;border-radius:.4rem;font-weight:800;letter-spacing:.05em;font-size:clamp(.85rem,2.6vmin,1rem);flex:0 0 auto}.phone-keys{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:1fr;gap:clamp(4px,1.2vmin,8px);width:100%;max-width:min(360px,90vw);flex:1 1 0;min-height:0;box-sizing:border-box}.phone-key{background:#1c1c25;color:#f4f4f8;border:2px solid currentColor;border-radius:.6rem;font-size:clamp(1rem,5vmin,2rem);font-weight:700;cursor:pointer;transition:transform .05s;min-width:0;min-height:0;padding:0;display:flex;align-items:center;justify-content:center}.play-red .phone-key{border-color:#d6234a;color:#f4f4f8}.play-blue .phone-key{border-color:#2a8df0;color:#f4f4f8}.phone-key:active{transform:scale(.95)}.phone-key.key-clear{background:#2a2a36;border-color:#444;color:#aaa}.phone-key.key-ok{background:#4ad991;color:#0a0a0f;border-color:#4ad991}.phone-mcq{display:grid;grid-template-columns:1fr;gap:clamp(6px,1.5vmin,10px);width:100%;max-width:min(420px,95vw);flex:1 1 0;min-height:0;overflow-y:auto;box-sizing:border-box}.phone-mcq-btn{background:#1c1c25;color:#f4f4f8;border:2px solid currentColor;border-radius:.6rem;font-size:clamp(.95rem,3.5vmin,1.25rem);font-weight:700;padding:clamp(.55rem,2vmin,1rem);display:flex;align-items:center;gap:.75rem;cursor:pointer;text-align:left;transition:transform .05s;min-height:0}.play-red .phone-mcq-btn{border-color:#d6234a}.play-blue .phone-mcq-btn{border-color:#2a8df0}.phone-mcq-btn:active{transform:scale(.97)}.phone-mcq-btn:disabled{opacity:.4;cursor:not-allowed}.phone-mcq-btn .option-letter{background:#2a2a36;border-radius:.4rem;padding:.25rem .6rem;font-weight:800;font-size:clamp(.85rem,2.6vmin,1rem);flex:0 0 auto}.phone-mcq-btn .option-text{flex:1;word-break:break-word}.play-screen-dual{height:100dvh;min-height:100dvh;max-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(.6rem,2vmin,2rem);padding:clamp(.5rem,2vmin,2rem);text-align:center;overflow:hidden;box-sizing:border-box}.play-screen-dual-message{font-size:clamp(1.5rem,6vmin,4rem);font-weight:900;text-align:center}.play-screen-dual-message h1{font-size:clamp(1.5rem,8vmin,5rem);letter-spacing:.1em;margin:0}.play-screen-dual.play-red h1{color:#ff5078}.play-screen-dual.play-blue h1{color:#5ab2ff}.dual-panel{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:clamp(.4rem,1.5vmin,1rem);text-align:center;min-width:0;min-height:0;flex:1 1 0;width:100%;max-width:480px;box-sizing:border-box}@media (min-width: 900px){.play-screen-dual{flex-direction:row;align-items:stretch;justify-content:space-between;padding:clamp(1rem,3vmin,3rem)}.dual-panel{flex:0 0 38%;max-width:38%}}@media (min-width: 1400px){.dual-panel{flex:0 0 32%;max-width:32%}}@media (min-width: 1900px){.dual-panel{flex:0 0 28%;max-width:28%}}@media (min-width: 2400px){.dual-panel{flex:0 0 25%;max-width:25%}}@media (min-width: 3200px){.dual-panel{flex:0 0 22%;max-width:22%}}.team-picker{height:100%;display:flex;flex-direction:column;position:relative;background:#0a0a0f;overflow:hidden}.team-picker-code{position:absolute;top:1rem;left:50%;transform:translate(-50%);z-index:10;font-size:.78rem;font-weight:700;letter-spacing:.12em;background:#f1c40f1a;border:1px solid #f1c40f;color:#f1c40f;padding:.25rem .75rem;border-radius:999px;white-space:nowrap;font-family:ui-monospace,SF Mono,Menlo,monospace}.team-picker-wrong{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);z-index:10;font-size:.78rem;color:#ffffff4d;white-space:nowrap;font-weight:500;border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:1px}.team-picker-wrong:hover{color:#fff9}.team-half{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;text-decoration:none;transition:filter .1s;-webkit-tap-highlight-color:transparent}.team-half:active{filter:brightness(1.4)}.team-half-red{background:#140209;color:#ff5078;border-bottom:1px solid rgba(255,80,120,.2)}.team-half-blue{background:#00091c;color:#5ab2ff}.team-half-label{font-size:clamp(4rem,20vw,8rem);font-weight:900;letter-spacing:.06em;line-height:1}.team-half-hint{font-size:.8rem;font-weight:600;opacity:.4;letter-spacing:.1em;text-transform:uppercase}.teacher-screen{height:100%;display:grid;grid-template-columns:1fr 240px;overflow:hidden;background:#f0f4f8}.teacher-main{display:flex;flex-direction:column;gap:1.25rem;overflow-y:auto;padding:1.5rem 1.75rem;background:#f0f4f8}.teacher-topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding-bottom:.25rem}.teacher-breadcrumb{display:flex;align-items:center;gap:.5rem}.teacher-brand{font-size:1.1rem;font-weight:800;color:#3071ab}.teacher-breadcrumb-sep{color:#9aa5b4;font-size:1rem}.teacher-breadcrumb-page{font-size:1rem;font-weight:600;color:#4a5568}.t-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.9rem}.t-card-head{display:flex;align-items:center;gap:.6rem}.t-card-icon{font-size:1.1rem;line-height:1}.t-card-title{font-size:1rem;font-weight:700;color:#1a202c;display:flex;align-items:center;gap:.6rem;flex:1}.t-card-desc{font-size:.875rem;color:#718096;line-height:1.55}.t-sync-badge{font-size:.7rem;font-weight:700;padding:.2rem .55rem;border-radius:999px;background:#fef3c7;color:#b45309;border:1px solid #fcd34d;letter-spacing:.04em}.t-sync-badge.t-sync-ok{background:#d1fae5;color:#065f46;border-color:#6ee7b7}.t-input{background:#f7f9fc;border:1.5px solid #cbd5e0;color:#1a202c;padding:.65rem .9rem;border-radius:8px;font-size:.95rem;font-family:inherit;width:100%;transition:border-color .15s}.t-input:focus{outline:none;border-color:#3071ab;background:#fff}.t-input:disabled{opacity:.5}.t-ai-row{display:flex;gap:.6rem;flex-wrap:wrap;align-items:stretch}.t-ai-topic{flex:1 1 260px}.t-input-count{width:72px;text-align:center;flex-shrink:0}.t-btn-primary{background:#3071ab;color:#fff;border:none;padding:.65rem 1.4rem;border-radius:8px;font-size:.95rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .15s,transform .1s;flex-shrink:0}.t-btn-primary:hover:not(:disabled){background:#255a8f}.t-btn-primary:active:not(:disabled){transform:scale(.97)}.t-btn-primary:disabled{opacity:.45;cursor:not-allowed}.t-btn-ghost{background:transparent;color:#718096;border:1.5px solid #cbd5e0;padding:.65rem 1.1rem;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.t-btn-ghost:hover{background:#f0f4f8;color:#4a5568}.t-feedback{font-size:.875rem;font-weight:600;padding:.55rem .85rem;border-radius:8px}.t-feedback-ok{background:#d1fae5;color:#065f46;border:1px solid #6ee7b7}.t-feedback-err{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.t-hint-warn{font-size:.85rem;color:#b45309}.t-options-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}.t-option{display:flex;align-items:center;gap:.45rem;background:#f7f9fc;border:1.5px solid #cbd5e0;border-radius:8px;padding:.45rem .6rem;transition:border-color .15s}.t-option:has(input[type=radio]:checked){border-color:#3071ab;background:#ebf4ff}.t-option input[type=radio]{width:1rem;height:1rem;accent-color:#3071ab;cursor:pointer;flex-shrink:0}.t-option-letter{background:#3071ab;color:#fff;font-size:.7rem;font-weight:800;padding:.15rem .45rem;border-radius:4px;flex-shrink:0}.t-option .t-input{border:none;background:transparent;padding:.2rem .3rem;font-size:.9rem;flex:1;min-width:0}.t-option .t-input:focus{background:transparent}.t-form-actions{display:flex;gap:.6rem;flex-wrap:wrap}.t-quiz-list{list-style:none;display:flex;flex-direction:column;gap:.6rem}.t-quiz-item{background:#f7f9fc;border:1px solid #e2e8f0;border-radius:10px;padding:.75rem 1rem;display:flex;flex-direction:column;gap:.5rem}.t-quiz-item-head{display:flex;align-items:flex-start;gap:.6rem}.t-quiz-num{background:#3071ab;color:#fff;font-size:.7rem;font-weight:800;padding:.15rem .45rem;border-radius:4px;flex-shrink:0;margin-top:2px}.t-quiz-prompt-text{flex:1;font-size:.95rem;font-weight:600;color:#1a202c}.t-quiz-delete{background:transparent;border:1px solid #e2e8f0;color:#a0aec0;padding:.2rem .5rem;border-radius:6px;cursor:pointer;font-size:.8rem;flex-shrink:0;transition:background .15s,color .15s,border-color .15s}.t-quiz-delete:hover{background:#fee2e2;color:#c53030;border-color:#feb2b2}.t-quiz-opts{display:flex;flex-wrap:wrap;gap:.4rem;padding-left:1.6rem}.t-quiz-opt{display:inline-flex;align-items:center;gap:.3rem;font-size:.8rem;padding:.2rem .55rem;border-radius:999px;background:#edf2f7;color:#4a5568;border:1px solid #e2e8f0}.t-quiz-opt-correct{background:#d1fae5;color:#065f46;border-color:#6ee7b7;font-weight:700}.t-quiz-opt-letter{font-weight:800;font-size:.7rem;opacity:.7}.teacher-sidebar{background:#3071ab;color:#fff;display:flex;flex-direction:column;padding:1.25rem 1rem;gap:.75rem;overflow-y:auto}.sidebar-brand{padding-bottom:.25rem}.sidebar-brand-link{font-size:1.1rem;font-weight:800;color:#ffffffe6;letter-spacing:-.3px}.sidebar-status-block{background:#0000002e;border-radius:10px;padding:.75rem .9rem}.sidebar-status-label{font-size:.65rem;font-weight:700;letter-spacing:.1em;opacity:.7;margin-bottom:.3rem}.sidebar-status-value{font-size:.85rem;font-weight:700;line-height:1.35}.sidebar-status-lobby{color:#fef3c7}.sidebar-status-playing{color:#6ee7b7}.sidebar-status-ended{color:#fca5a5}.sidebar-status-connecting{opacity:.5}.sidebar-divider{height:1px;background:#ffffff26}.sidebar-section-label{font-size:.65rem;font-weight:700;letter-spacing:.1em;opacity:.65;padding-top:.25rem}.sidebar-modes{display:flex;flex-direction:column;gap:.45rem}.sidebar-mode-btn{display:flex;align-items:center;gap:.65rem;width:100%;background:#ffffff1f;border:1px solid rgba(255,255,255,.18);color:#fff;padding:.6rem .85rem;border-radius:9px;font-family:inherit;font-weight:600;font-size:.875rem;cursor:pointer;text-align:left;transition:background .15s}.sidebar-mode-btn:hover:not(:disabled){background:#ffffff38}.sidebar-mode-btn:disabled{opacity:.35;cursor:not-allowed}.sidebar-mode-icon{font-size:1rem;font-weight:900;width:1.25rem;text-align:center;flex-shrink:0}.sidebar-mode-label{flex:1}.sidebar-mode-count{opacity:.75;font-weight:500}.sidebar-mode-multiply{border-left:3px solid #f1c40f}.sidebar-mode-divide{border-left:3px solid #4ad991}.sidebar-mode-add{border-left:3px solid #93c5fd}.sidebar-mode-subtract{border-left:3px solid #ff5078}.sidebar-mode-quiz{border-left:3px solid #c084fc}.sidebar-spacer{flex:1;min-height:1rem}.sidebar-reset-btn{width:100%;background:#0003;border:1px solid rgba(255,255,255,.2);color:#fffc;padding:.65rem .85rem;border-radius:9px;font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s}.sidebar-reset-btn:hover:not(:disabled){background:#00000059;color:#fff}.sidebar-reset-btn:disabled{opacity:.35;cursor:not-allowed}.tv-3d-arena{position:relative;width:100%;height:100%;overflow:hidden;background:#2b1810}.tv-3d-arena canvas{display:block;width:100%!important;height:100%!important;touch-action:none}.video-arena{position:relative;width:100%;height:100%;overflow:hidden;background:#fff}.video-slide-wrapper{position:absolute;left:50%;top:0;bottom:0}.arena-video{display:block;height:100%;width:auto;max-width:none;border:none;outline:none}.arena-centre-line{position:absolute;left:50%;top:4%;bottom:4%;width:4px;transform:translate(-50%);z-index:10;pointer-events:none;border-radius:2px;background:linear-gradient(to bottom,transparent 0%,#5c3a1e 8%,#5c3a1e 92%,transparent 100%);box-shadow:0 0 10px #5c3a1e8c,0 0 3px #ffd28c66}.video-draw-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(#f3c98c,#e89a55 60%,#b96a36)}.tv-end-screen{width:100vw;height:100vh;background:#0a0a0f;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;padding:.75rem 0}.tv-end-arena{position:relative;width:100%;height:52vh;flex-shrink:0}.winner{margin:0;font-size:clamp(2.5rem,7vw,5rem);font-weight:900;letter-spacing:.05em;text-shadow:0 4px 24px rgba(0,0,0,.7)}.winner-red{color:#ff5078}.winner-blue{color:#5ab2ff}.winner-draw{color:#f4f4f8}.final-score{display:flex;gap:1rem;font-size:clamp(1.1rem,2.2vw,1.6rem);font-weight:700;background:#00000073;padding:.4rem 1.25rem;border-radius:.75rem}.end-play-again-btn{font-size:clamp(1rem,1.8vw,1.4rem);padding:.85rem 2.2rem;background:#4ad991;color:#0a0a0f;border:none;border-radius:.75rem;font-weight:800;cursor:pointer;box-shadow:0 6px 20px #00000080;transition:background .15s}.end-play-again-btn:hover{background:#5be3a3}.end-play-again-btn:active{transform:scale(.97)}.tv-lobby{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:clamp(1rem,3vh,3rem) clamp(1rem,3vw,3rem);gap:clamp(1rem,2.5vh,2rem);text-align:center;overflow:auto}.tv-lobby-title{font-size:clamp(2rem,5vw,4rem);letter-spacing:.05em;margin:0}.tv-lobby-join{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1rem,3vw,3rem);width:100%;max-width:1400px;align-items:stretch}@media (max-width: 800px){.tv-lobby-join{grid-template-columns:1fr}}.tv-lobby-qr-card,.tv-lobby-code-card{background:#15151c;border:2px solid #2a2a36;border-radius:1.25rem;padding:clamp(1rem,2vw,2rem);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(.5rem,1vh,1.25rem)}.tv-lobby-card-label{font-size:clamp(.85rem,1.4vw,1.1rem);letter-spacing:.15em;text-transform:uppercase;opacity:.6;font-weight:700}.tv-lobby-qr{width:clamp(180px,26vw,360px);height:clamp(180px,26vw,360px);background:#fff;border-radius:.75rem;padding:.5rem;box-shadow:0 8px 32px #0006}.tv-lobby-qr svg{width:100%;height:100%;display:block}.qr-loading{width:clamp(180px,26vw,360px);height:clamp(180px,26vw,360px);background:#ffffff0d;border-radius:.75rem}.tv-lobby-url{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:clamp(.9rem,1.4vw,1.2rem);opacity:.65;word-break:break-all}.tv-lobby-code{display:flex;gap:clamp(.4rem,1vw,1rem);margin:.5rem 0}.tv-lobby-code-char{display:inline-flex;align-items:center;justify-content:center;width:clamp(50px,7vw,100px);height:clamp(70px,9vw,130px);background:#0a0a0f;border:3px solid #f1c40f;border-radius:.6rem;color:#f1c40f;font-size:clamp(2.5rem,5.5vw,5rem);font-weight:900;font-family:ui-monospace,SF Mono,Menlo,monospace;letter-spacing:0}.tv-lobby-code-hint{opacity:.5;font-size:clamp(.8rem,1.2vw,1rem)}.tv-lobby-counts{display:flex;gap:clamp(1rem,2vw,2rem);margin-top:.75rem;font-size:clamp(1rem,1.5vw,1.3rem);font-weight:700}.tv-lobby-counts .count-red{color:#ff5078}.tv-lobby-counts .count-blue{color:#5ab2ff}.tv-lobby-prompt{font-size:clamp(1rem,1.6vw,1.4rem);opacity:.75;margin:0}.q-score-and-code{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.q-code-badge{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:clamp(.75rem,1vw,.95rem);letter-spacing:.15em;background:#0a0a0f;border:1px solid #f1c40f;color:#f1c40f;padding:.2rem .6rem;border-radius:.3rem;font-weight:700}.play-code-badge{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:clamp(.75rem,2.4vmin,.9rem);letter-spacing:.1em;background:#f1c40f1f;border:1px solid #f1c40f;color:#f1c40f;padding:.25rem .7rem;border-radius:999px;font-weight:700;flex:0 0 auto}.join-screen{height:100%;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem;gap:1.5rem;overflow-y:auto}.join-logo{font-size:1.4rem;font-weight:800;color:#3071ab;letter-spacing:-.3px}.join-card{background:#f7f9fc;border:1px solid #e2e8f0;border-radius:20px;padding:2rem 1.75rem;width:100%;max-width:340px;display:flex;flex-direction:column;align-items:center;gap:.85rem;text-align:center}.join-title{font-size:1.4rem;font-weight:800;color:#1a202c}.join-sub{font-size:.875rem;color:#718096;line-height:1.5}.join-code-input{width:100%;padding:.9rem .5rem;background:#fff;border:2.5px solid #cbd5e0;color:#3071ab;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:clamp(2rem,12vw,3rem);font-weight:900;letter-spacing:.45em;text-align:center;border-radius:12px;text-transform:uppercase;transition:border-color .15s,box-shadow .15s}.join-code-input:focus{outline:none;border-color:#3071ab;box-shadow:0 0 0 3px #3071ab26}.join-code-input::placeholder{color:#cbd5e0;letter-spacing:.3em}.join-error{font-size:.85rem;color:#c53030;font-weight:500}.join-btn{width:100%;background:#3071ab;color:#fff;border:none;padding:.85rem;border-radius:10px;font-size:1rem;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 4px 14px #3071ab4d;transition:background .15s,transform .1s}.join-btn:hover:not(:disabled){background:#255a8f}.join-btn:active:not(:disabled){transform:scale(.98)}.join-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.join-back{font-size:.875rem;color:#9aa5b4;font-weight:500}.join-back:hover{color:#3071ab}
