html,body,#root{height:100%}body{margin:0}:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}body{color:#e7e7ea;background:#0f1115;margin:0}.app{max-width:720px;margin:0 auto;padding:1.5rem 1rem}.topbar{z-index:50;background:#12141b;border-bottom:1px solid #2a2d36;position:sticky;top:0}.topbar-inner{justify-content:space-between;align-items:center;gap:1rem;max-width:960px;margin:0 auto;padding:.6rem 1rem;display:flex}.brand{color:#e7e7ea;letter-spacing:.06em;cursor:pointer;background:0 0;border:none;width:auto;padding:0;font-size:1.35rem;font-weight:700}.brand:hover{color:#7aa2ff}.topbar-right{align-items:center;gap:.7rem;display:flex}.room{color:#aab0bd;font-size:.85rem}.room code{background:#1a1d24;border-radius:4px;padding:.15rem .45rem}.nav-btn{color:#e7e7ea;cursor:pointer;background:#1f2330;border:1px solid #2f3545;border-radius:7px;width:auto;padding:.4rem .8rem;font-size:.85rem}.nav-btn:hover{background:#272c3b}.nav-btn.leave{color:#ff9b9b;border-color:#5a3640}.nav-btn.leave:hover{background:#3a2730}.account{position:relative}.account-btn{color:#e7e7ea;cursor:pointer;background:#1f2330;border:1px solid #2f3545;border-radius:7px;align-items:center;gap:.5rem;width:auto;padding:.3rem .6rem .3rem .3rem;display:flex}.account-btn:hover{background:#272c3b}.avatar{color:#0f1115;background:#7aa2ff;border-radius:50%;justify-content:center;align-items:center;width:46px;height:46px;font-size:1.2rem;font-weight:700;display:inline-flex}.account-name{text-overflow:ellipsis;white-space:nowrap;max-width:140px;font-size:.85rem;overflow:hidden}.caret{color:#8b909c;font-size:.7rem}.menu-backdrop{z-index:40;position:fixed;inset:0}.account-menu{z-index:60;background:#1a1d24;border:1px solid #2f3545;border-radius:8px;flex-direction:column;min-width:150px;padding:.3rem;display:flex;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 8px 24px #0006}.account-menu button{color:#e7e7ea;text-align:left;cursor:pointer;background:0 0;border:none;border-radius:6px;width:100%;padding:.5rem .6rem;font-size:.9rem}.account-menu button:hover{background:#272c3b}.modal-overlay{z-index:100;background:#080a0eb3;justify-content:center;align-items:flex-start;padding:4rem 1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.modal{background:#161922;border:1px solid #2a2d36;border-radius:12px;width:100%;max-width:420px;padding:1.4rem;position:relative}.modal.wide{max-width:620px}.modal-close{color:#8b909c;cursor:pointer;background:0 0;border:none;width:auto;padding:.2rem .4rem;font-size:1.4rem;line-height:1;position:absolute;top:.5rem;right:.6rem}.modal-close:hover{color:#e7e7ea}.card{background:#161922;border:1px solid #2a2d36;border-radius:12px;flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.tabs{gap:.5rem;display:flex}.tabs button{color:#a3a8b5;cursor:pointer;background:0 0;border:1px solid #2a2d36;border-radius:8px;padding:.4rem .9rem}.tabs button.active{color:#fff;background:#2a2f3d;border-color:#3f4658}label{color:#a3a8b5;flex-direction:column;gap:.35rem;font-size:.9rem;display:flex}input{color:#e7e7ea;background:#0f1115;border:1px solid #2a2d36;border-radius:8px;padding:.55rem .7rem;font-size:1rem}input:focus{outline-offset:1px;outline:2px solid #5a7cff}button{color:#fff;cursor:pointer;background:#5a7cff;border:none;border-radius:8px;padding:.6rem 1rem;font-size:1rem}button:disabled{color:#6b7280;cursor:not-allowed;background:#2a2d36}.topics{flex-wrap:wrap;gap:.5rem;display:flex}.topic{color:#e7e7ea;background:#1a1d24;border:1px solid #2a2d36;border-radius:8px;flex-direction:row;align-items:center;gap:.4rem;padding:.4rem .7rem}.big-code{letter-spacing:.2em;background:#0f1115;border:1px solid #2a2d36;border-radius:6px;padding:.3rem .7rem;font-size:1.5rem;display:inline-block}.player-list,.standings,.reveal-list{margin:0;padding:0;list-style:none}.player-list li{border-bottom:1px solid #1f2230;padding:.45rem 0}.player-list li:last-child{border-bottom:none}.badge{color:#a3a8b5;background:#2a2f3d;border-radius:999px;margin-left:.3rem;padding:.1rem .4rem;font-size:.7rem}.badge.offline{color:#ff8b8b;background:#3a1f1f}.round-header{color:#a3a8b5;justify-content:space-between;align-items:center;font-size:.9rem;display:flex}.topic-pill{color:#cdd2dd;background:#2a2f3d;border-radius:999px;padding:.15rem .6rem}.timer{font-variant-numeric:tabular-nums;color:#5a7cff;font-weight:600}.headline{letter-spacing:.01em;color:#ffd96b;margin:.5rem 0 .25rem;font-size:1.15rem;font-weight:700}.question{color:#cdd2dd;margin:0 0 1rem;font-size:1.05rem;font-weight:400;line-height:1.55}.meta{color:#6b7280;margin:0;font-size:.85rem}.reveal-list li,.standings li{border-bottom:1px solid #1f2230;justify-content:space-between;gap:.6rem;padding:.4rem 0;display:flex}.reveal-list .ans{color:#a3a8b5;text-align:center;flex:1}.reveal-list .pts{color:#7ee787;font-weight:600}.me{color:#ffd96b}.winner{text-align:center;font-size:1.2rem}.error{color:#ffb3b3;background:#3a1f1f;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.6rem .8rem;display:flex}.error button{color:#ffb3b3;background:0 0;padding:0}textarea{color:#e7e7ea;resize:vertical;background:#0f1115;border:1px solid #2a2d36;border-radius:8px;min-height:80px;padding:.55rem .7rem;font-family:inherit;font-size:1rem}textarea:focus{outline-offset:1px;outline:2px solid #5a7cff}.difficulty-pill{border-radius:999px;padding:.15rem .6rem;font-size:.8rem;font-weight:600}.difficulty-pill.easy{color:#7ee787;background:#1e3a2b}.difficulty-pill.medium{color:#ffd96b;background:#3d3522}.difficulty-pill.hard{color:#ff8b8b;background:#3a1f1f}.model-answer{background:#1a1d24;border:1px solid #2a2d36;border-radius:8px;padding:.8rem 1rem}.model-answer .label{text-transform:uppercase;letter-spacing:.1em;color:#6b7280;margin-bottom:.4rem;font-size:.75rem}.model-answer p{color:#cdd2dd;margin:0;line-height:1.5}.reveal-header{color:#6b7280;justify-content:space-between;align-items:center;font-size:.78rem;display:flex}.reveal-round-label{text-transform:uppercase;letter-spacing:.1em}.reveal-list{flex-direction:column;gap:.8rem;display:flex}.reveal-list li{background:#0f1115;border:1px solid #1f2230;border-radius:12px;padding:1.1rem 1.3rem;display:block}.reveal-list .reveal-top{justify-content:space-between;align-items:center;margin-bottom:.6rem;display:flex}.reveal-list .reveal-who{color:#cdd2dd;font-size:.95rem;font-weight:500}.reveal-list .reveal-big-score{font-variant-numeric:tabular-nums;letter-spacing:-.02em;font-size:3rem;font-weight:800;line-height:.9}.reveal-list .reveal-big-score.high{color:#7ee787}.reveal-list .reveal-big-score.mid{color:#ffd96b}.reveal-list .reveal-big-score.low{color:#ffb347}.reveal-list .reveal-big-score.zero{color:#ff8b8b}.reveal-list .verdict{letter-spacing:.02em;text-transform:uppercase;margin:0 0 .5rem;font-size:.95rem;font-weight:700}.reveal-list .verdict.high{color:#7ee787}.reveal-list .verdict.mid{color:#ffd96b}.reveal-list .verdict.low{color:#ffb347}.reveal-list .verdict.zero{color:#ff8b8b}.reveal-list .judge-line{color:#e7e7ea;gap:.5rem;margin:.25rem 0;font-size:1rem;line-height:1.45;display:flex}.reveal-list .judge-line .icon{text-align:center;flex-shrink:0;width:1.1rem;font-weight:700}.reveal-list .judge-line.got .icon{color:#7ee787}.reveal-list .judge-line.missed .icon{color:#ff8b8b}.reveal-list .judge-line.missed.bonus-only{color:#a3a8b5}.reveal-list .judge-line.missed.bonus-only .icon{color:#ffd96b}.reveal-list .reveal-meta .ans{color:#6b7280;font-size:.85rem;font-style:italic}.reveal-list .bonus-noted{color:#7ee787;margin-top:.4rem;font-size:.8rem}.reveal-list .breakdown{color:#6b7280;font-variant-numeric:tabular-nums;border-top:1px solid #1f2230;margin-top:.5rem;padding-top:.5rem;font-size:.78rem}.reveal-list .breakdown strong{color:#cdd2dd;font-weight:600}.model-answer-compact{color:#a3a8b5;background:0 0;border:1px dashed #2a2d36;border-radius:8px;padding:.55rem .8rem;font-size:.88rem;line-height:1.5}.model-answer-compact .label{text-transform:uppercase;letter-spacing:.1em;color:#6b7280;margin-right:.4rem;font-size:.72rem}.standings-compact{flex-direction:column;gap:.15rem;margin:0;padding:0;list-style:none;display:flex}.standings-compact li{color:#a3a8b5;grid-template-columns:1.5rem auto 1fr auto;align-items:baseline;gap:.6rem;padding:.2rem 0;font-size:.85rem;display:grid}.standings-compact .rank{color:#6b7280}.standings-compact .who{color:#cdd2dd;font-weight:500}.standings-compact .summary{color:#6b7280;white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-style:italic;overflow:hidden}.standings-compact .pts{font-variant-numeric:tabular-nums;color:#cdd2dd}.standings-compact li.me,.standings-compact li.me .who{color:#ffd96b}.standings-compact li.me .summary{color:#c9a957}.config-banner{color:#a3a8b5;border:1px dashed #2a2d36;border-radius:8px;flex-wrap:wrap;gap:.7rem;margin-bottom:.75rem;padding:.4rem .6rem;font-size:.78rem;display:flex}.config-banner .flag{color:#7ee787}.config-banner .flag.strict{color:#ffd96b}.sudden-death-banner{color:#ff8b8b;text-align:center;background:#3a1f1f;border-radius:8px;padding:.5rem .8rem;font-weight:600}.summary-line{color:#a3a8b5;margin-top:.15rem;font-size:.82rem}.summary-line strong{color:#cdd2dd;font-weight:500}.reveal-footer{align-items:center;gap:.8rem;margin-top:.5rem;display:flex}.reveal-footer button{flex-shrink:0;padding:.5rem 1.2rem}.auth-bar{border-bottom:1px solid #2a2f3a;justify-content:space-between;align-items:center;gap:.6rem;margin-bottom:.7rem;padding-bottom:.7rem;font-size:.9rem;display:flex}.auth-bar .muted{color:#8b909c}.auth-form{border-bottom:1px solid #2a2f3a;margin-bottom:.8rem;padding-bottom:.8rem}.auth-actions{align-items:center;gap:.6rem;margin-top:.6rem;display:flex}.auth-error{color:#ff8e8e;margin-top:.4rem;font-size:.82rem}button.link{color:#7aa2ff;cursor:pointer;background:0 0;border:none;width:auto;padding:0;font-size:.9rem}button.link:hover{text-decoration:underline}.topics.directions{grid-template-columns:repeat(2,1fr);gap:.3rem .8rem;display:grid}.profile-link{margin-bottom:.6rem}.profile-panel{background:#161922;border:1px solid #2a2f3a;border-radius:8px;margin-bottom:.9rem;padding:.8rem}.profile-head{justify-content:space-between;align-items:center;margin-bottom:.4rem;display:flex}.profile-head h3{margin:0;font-size:1rem}.calibrating-note{margin-top:.4rem;font-size:.8rem}.spider{margin:0 auto;display:block}.spider .ring{fill:none;stroke:#2c313d;stroke-width:1px}.spider .ring.baseline{stroke:#3c4250;stroke-dasharray:3 3}.spider .spoke{stroke:#262b35;stroke-width:1px}.spider .rating-area{fill:#7aa2ff40;stroke:#7aa2ff;stroke-width:2px}.spider .point{fill:#7aa2ff}.spider .axis-label{fill:#aab0bd;font-size:9px}.spider .axis.calibrating .axis-label{fill:#6b7180;font-style:italic}.spider .axis.calibrating .point{fill:none;stroke:#6b7180;stroke-dasharray:2 2}.confirm h3{margin:0 0 .5rem}.confirm .muted{font-size:.9rem}.confirm-actions{justify-content:flex-end;gap:.6rem;margin-top:1.1rem;display:flex}.confirm-actions .nav-btn{padding:.5rem 1rem}.lobby{flex-direction:column;gap:1rem;display:flex}.lobby-bar{grid-template-columns:1fr 1fr auto;align-items:stretch;gap:.8rem;display:grid}.config-card{cursor:pointer;text-align:left;color:#e7e7ea;background:#161922;border:1px solid #2a2d36;border-radius:12px;flex-direction:column;align-items:flex-start;gap:.25rem;width:100%;padding:.9rem 1rem;display:flex}.config-card:hover:not(:disabled){background:#1a1e29;border-color:#5a7cff}.config-card:disabled{cursor:default;opacity:.85}.config-card-label{text-transform:uppercase;letter-spacing:.06em;color:#8b909c;font-size:.72rem}.config-card-value{font-size:1rem;font-weight:600}.start-btn{color:#fff;background:linear-gradient(#57c45e,#3da943);border-radius:12px;align-self:stretch;min-width:180px;padding:0 2rem;font-size:1.05rem;font-weight:700}.start-btn:disabled{color:#6b7280;background:#2a2d36}.choose-topics h3,.settings-panel h3{text-align:center;margin:0 0 .3rem}.choose-topics-sub{text-align:center;margin:0 0 1rem;font-size:.85rem}.topic-grid{grid-template-columns:repeat(2,1fr);gap:.8rem;max-height:64vh;padding:.2rem;display:grid;overflow-y:auto}.topic-card{text-align:left;cursor:pointer;color:#fff;filter:grayscale(.55)brightness(.6);border:2px solid #0000;border-radius:14px;align-items:flex-end;width:100%;height:96px;padding:.9rem;transition:transform 80ms,filter .12s;display:flex;position:relative;overflow:hidden}.topic-card:hover{transform:translateY(-2px)}.topic-card.selected{filter:none;border-color:#fff;box-shadow:0 6px 18px #00000073}.topic-card-icon{opacity:.35;pointer-events:none;font-size:3.4rem;line-height:1;position:absolute;bottom:-.4rem;right:.3rem}.topic-card-name{text-shadow:0 1px 4px #0009;max-width:75%;font-size:.98rem;font-weight:700;line-height:1.2;position:relative}.topic-card-check{background:#ffffff2e;border:1.5px solid #ffffff80;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.85rem;font-weight:800;display:inline-flex;position:absolute;top:.5rem;right:.5rem}.topic-card.selected .topic-card-check{color:#111;background:#fff;border-color:#fff}.setting-block{margin-bottom:1.1rem}.setting-label{color:#cdd2dd;margin-bottom:.5rem;font-size:.85rem;font-weight:600}.stepper-row{justify-content:space-between;align-items:center;padding:.3rem 0;display:flex}.stepper{align-items:center;gap:.6rem;display:flex}.stepper button{color:#e7e7ea;background:#1f2330;border:1px solid #2f3545;border-radius:8px;width:30px;height:30px;padding:0;font-size:1.1rem;line-height:1}.stepper button:disabled{opacity:.4}.stepper-value{text-align:center;font-variant-numeric:tabular-nums;min-width:22px;font-weight:700}.setting-block input[type=range]{accent-color:#5a7cff;width:100%}.toggles .toggle-row{color:#e7e7ea;flex-direction:row;justify-content:space-between;align-items:center;padding:.45rem 0;font-size:.95rem}.toggle-row input[type=checkbox]{accent-color:#5a7cff;width:18px;height:18px}.lang-select{color:#e7e7ea;background:#0f1115;border:1px solid #2a2d36;border-radius:8px;width:100%;padding:.55rem .7rem;font-size:1rem}.auth-screen h2{margin:0}.auth-screen .muted{margin:0;font-size:.9rem}.name-editor{margin-bottom:1rem}.name-row{align-items:stretch;gap:.5rem;display:flex}.name-row input{flex:1}.name-row .nav-btn{white-space:nowrap}.name-saved{color:#7ee787;margin-top:.35rem;font-size:.82rem}.auth-divider{text-align:center;color:#6b7280;align-items:center;margin:.9rem 0 .7rem;font-size:.8rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:#2a2d36;flex:1;height:1px}.auth-divider span{padding:0 .7rem}.gsi-button{justify-content:center;min-height:40px;display:flex}.avatar-img{object-fit:cover}.account-btn .avatar-img{border-radius:50%;width:46px;height:46px}.avatar-picker{margin:.8rem 0 .3rem}.avatar-picker-head{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.avatar-group{margin-bottom:.7rem}.avatar-group-label{text-transform:uppercase;letter-spacing:.05em;color:#8b909c;margin-bottom:.35rem;font-size:.72rem}.avatar-grid{flex-wrap:wrap;gap:.5rem;display:flex}.avatar-choice{cursor:pointer;background:#1a1e29;border:3px solid #2a2f3a;border-radius:50%;width:96px;height:96px;padding:0;overflow:hidden}.avatar-choice img{object-fit:cover;width:100%;height:100%;display:block}.avatar-choice:hover{border-color:#5a7cff}.avatar-choice.selected{border-color:#fff;box-shadow:0 0 0 2px #5a7cff}.profile-identity{border-bottom:1px solid #2a2f3a;align-items:center;gap:1rem;margin-bottom:.6rem;padding-bottom:1rem;display:flex}.profile-identity .avatar{flex-shrink:0;box-shadow:0 4px 14px #0006}.profile-id-main{flex:1;min-width:0}.profile-name{font-size:1.45rem;font-weight:700;line-height:1.1}.profile-id-actions{align-items:center;gap:.5rem;margin-top:.35rem;display:flex}.profile-id-actions .dot{color:#4a505e}.profile-chart-hero{flex-direction:column;align-items:center;margin-top:.5rem;display:flex}.chart-title{text-transform:uppercase;letter-spacing:.08em;color:#8b909c;margin-bottom:.3rem;font-size:.78rem}.profile-chart-hero .calibrating-note{text-align:center;max-width:340px}.profile-avatar-edit{cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;padding:0;line-height:0;position:relative}.profile-avatar-edit .avatar{box-shadow:0 4px 14px #0006}.avatar-edit-overlay{color:#fff;opacity:0;background:#080a0e8c;border-radius:50%;justify-content:center;align-items:center;transition:opacity .15s;display:flex;position:absolute;inset:0}.profile-avatar-edit:hover .avatar-edit-overlay,.profile-avatar-edit:focus-visible .avatar-edit-overlay{opacity:1}.standings-compact li,.player-row{align-items:center;gap:.5rem;display:flex}.standings-compact .who{flex:none}.standings-compact .summary{flex:1}.rl-who{align-items:center;gap:.45rem;display:inline-flex}
