:root{color-scheme:dark;--navy: #0a0f24;--navy-2: #060a1a;--gold: #ffd166;--cyan: #6cf3ff;--pink: #ff7ad9;--green: #7cf08c;--red: #ff5a5a;--text: #e8efff;--muted: #8a96b8;--mark-focus: #4da3ff;--mark-none: #5c7bbf;--mark-skip: var(--pink)}*{box-sizing:border-box;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:pan-x pan-y}html,body{margin:0;padding:0;height:100%;overflow:hidden;overscroll-behavior:none}body{background:radial-gradient(ellipse at center,#0e1638 0%,var(--navy-2) 70%);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}input,textarea{-webkit-user-select:text;user-select:text;-webkit-touch-callout:default}@keyframes star-twinkle{0%,to{opacity:.55}50%{opacity:1}}@keyframes star-drift-a{0%{transform:translateZ(0)}to{transform:translate3d(-300px,-300px,0)}}@keyframes star-drift-b{0%{transform:translateZ(0)}to{transform:translate3d(-440px,-440px,0)}}body:before,body:after{content:"";position:fixed;inset:-440px;z-index:0;pointer-events:none;background-repeat:repeat;will-change:transform}body:before{background-size:300px 300px;background-image:radial-gradient(1.5px 1.5px at 20px 40px,#ffffff,transparent),radial-gradient(1px 1px at 70px 110px,#cfe0ff,transparent),radial-gradient(2px 2px at 130px 30px,#ffe8c0,transparent),radial-gradient(1px 1px at 180px 200px,#ffffff,transparent),radial-gradient(1.5px 1.5px at 240px 80px,#cfe0ff,transparent),radial-gradient(1px 1px at 60px 250px,#ffffff,transparent),radial-gradient(1.5px 1.5px at 110px 170px,#ffe8c0,transparent),radial-gradient(1px 1px at 200px 260px,#cfe0ff,transparent),radial-gradient(2px 2px at 280px 150px,#ffffff,transparent),radial-gradient(1px 1px at 40px 140px,#ffffff,transparent),radial-gradient(1.5px 1.5px at 150px 90px,#cfe0ff,transparent),radial-gradient(1px 1px at 90px 20px,#ffffff,transparent),radial-gradient(1.5px 1.5px at 260px 40px,#ffe8c0,transparent),radial-gradient(1px 1px at 30px 210px,#cfe0ff,transparent),radial-gradient(2px 2px at 220px 180px,#ffffff,transparent),radial-gradient(1px 1px at 170px 50px,#ffffff,transparent),radial-gradient(1.5px 1.5px at 100px 290px,#cfe0ff,transparent),radial-gradient(1px 1px at 250px 230px,#ffe8c0,transparent);animation:star-twinkle 5s ease-in-out infinite,star-drift-a 90s linear infinite}body:after{background-size:440px 440px;opacity:.85;background-image:radial-gradient(2.5px 2.5px at 60px 80px,#ffffff,transparent),radial-gradient(2px 2px at 300px 120px,#dceaff,transparent),radial-gradient(2.5px 2.5px at 180px 300px,#ffffff,transparent),radial-gradient(2px 2px at 380px 260px,#fff0d0,transparent),radial-gradient(3px 3px at 120px 200px,#ffffff,transparent),radial-gradient(2px 2px at 260px 360px,#dceaff,transparent),radial-gradient(2.5px 2.5px at 40px 340px,#ffffff,transparent),radial-gradient(2px 2px at 340px 40px,#fff0d0,transparent),radial-gradient(2.5px 2.5px at 200px 60px,#ffffff,transparent),radial-gradient(2px 2px at 90px 400px,#dceaff,transparent);animation:star-twinkle 7s ease-in-out infinite 1.5s,star-drift-b 140s linear infinite reverse}#renderCanvas{position:fixed;inset:0;width:100%;height:100%;display:block;outline:none;touch-action:none;z-index:1}#stage{position:fixed;top:50%;left:50%;width:1280px;height:720px;transform:translate(-50%,-50%) scale(var(--ui-scale, 1));transform-origin:center center;pointer-events:none;z-index:5}#hud,#ui{position:absolute;inset:0;pointer-events:none}#hud{z-index:10}.hud-top{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:16px 24px;pointer-events:none}.hud-top>*{pointer-events:auto}.hud-top-center{justify-content:center}.ui-parent-head-actions{display:flex;align-items:center;gap:10px}.hud-stars{display:inline-flex;align-items:center;gap:8px;background:#0a0f248c;backdrop-filter:blur(8px);border:1px solid rgba(255,209,102,.35);border-radius:999px;padding:8px 16px;font-size:18px;font-weight:600;color:var(--gold);box-shadow:0 0 24px #ffd16626}.hud-stars:before{content:"★";font-size:20px}.hud-title{font-size:22px;font-weight:700;letter-spacing:.02em;text-shadow:0 0 24px rgba(108,243,255,.5)}.hud-back{background:#0a0f248c;backdrop-filter:blur(8px);border:1px solid rgba(108,243,255,.35);color:var(--cyan);border-radius:999px;padding:10px 18px;font-size:16px;font-weight:600;cursor:pointer;transition:all .15s ease}.hud-back:hover{background:#6cf3ff26}.hud-back:active{transform:scale(.96)}.hud-prompt{position:absolute;top:70px;left:50%;transform:translate(-50%);width:min(92%,880px);text-align:center;font-size:56px;font-weight:800;letter-spacing:.02em;line-height:1.06;text-shadow:0 0 30px rgba(108,243,255,.6),0 0 60px rgba(108,243,255,.3);pointer-events:none}.hud-prompt.small{font-size:40px}.hud-feedback{position:absolute;bottom:12%;left:50%;transform:translate(-50%);font-size:50px;font-weight:800;letter-spacing:.04em;pointer-events:none;opacity:0;transition:opacity .2s ease}.hud-feedback.show{opacity:1}.hud-feedback.correct{color:var(--green);text-shadow:0 0 30px rgba(124,240,140,.7)}.hud-feedback.wrong{color:var(--pink);text-shadow:0 0 30px rgba(255,122,217,.6)}.summary{position:absolute;inset:0;z-index:50;display:grid;grid-template-columns:minmax(0,1fr);grid-template-rows:minmax(0,1fr);place-items:center;padding:24px;background:radial-gradient(ellipse at center,#0e1638 0%,var(--navy-2) 75%);pointer-events:auto}.summary-card{width:min(760px,94%);max-height:672px;display:flex;flex-direction:column;background:linear-gradient(180deg,#131c3e,#0b1126);border:1px solid rgba(108,243,255,.25);border-radius:20px;box-shadow:0 24px 80px #0009;padding:28px}.summary-title{margin:0 0 4px;font-size:34px;font-weight:800;text-align:center;text-shadow:0 0 30px rgba(108,243,255,.45)}.summary-overall{text-align:center;margin:6px 0 18px}.summary-overall-pct{display:block;font-size:56px;font-weight:900;color:var(--gold);line-height:1}.summary-overall-sub{font-size:15px;color:var(--muted)}.summary-empty{text-align:center}.summary-table{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column;gap:4px}.summary-row{display:grid;grid-template-columns:minmax(0,1fr) 78px 64px 210px;align-items:center;gap:12px;padding:9px 12px;border-radius:10px;font-size:15px}.summary-row:not(.summary-head):nth-child(2n){background:#6cf3ff0a}.summary-head{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);position:sticky;top:0;background:#0d1430}.summary-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.summary-num{text-align:right;font-variant-numeric:tabular-nums}.summary-pct{font-weight:800;color:var(--cyan)}.summary-trend-h{text-align:right}.summary-trend{text-align:right;font-variant-numeric:tabular-nums}.trend{display:inline-flex;align-items:center;gap:6px;justify-content:flex-end}.trend .trend-arrow{font-size:13px}.trend.up{color:var(--green)}.trend.down{color:var(--pink)}.trend.flat{color:var(--gold)}.trend.none{color:var(--muted);font-size:13px}.summary-end{margin-top:22px;align-self:center;display:inline-flex;align-items:center;gap:10px;padding:14px 28px;font-size:17px;font-weight:700}.summary-end svg{flex:none}.summary-exit-hint{margin:10px 0 0;align-self:center;color:var(--muted);font-size:13px;text-align:center}.hud-fade{position:absolute;inset:0;background:var(--navy-2);opacity:0;transition:opacity .4s ease;pointer-events:none}.hud-fade.show{opacity:1}.action-timer{position:absolute;left:20px;top:50%;transform:translateY(-50%);width:8px;height:280px;background:#0a0f248c;border:1px solid rgba(108,243,255,.3);border-radius:999px;overflow:hidden;display:flex;align-items:flex-end;opacity:0;transition:opacity .2s ease;pointer-events:none;box-shadow:0 0 24px #6cf3ff1f}.action-timer.show{opacity:1}.action-timer-fill{width:100%;height:100%;border-radius:999px;background-color:var(--green)}@keyframes action-drain{0%{height:100%;background-color:var(--green)}50%{background-color:var(--gold)}75%{background-color:#ff5a5a}to{height:0%;background-color:#ff5a5a}}.hud-tip{position:absolute;bottom:24px;left:50%;transform:translate(-50%);font-size:14px;color:var(--muted);letter-spacing:.05em}.ui-root{position:absolute;inset:0;z-index:20;pointer-events:none}.ui-root button,.ui-root input{pointer-events:auto;font-family:inherit}.ui-corner{position:absolute;display:flex;gap:10px}.ui-corner-tr{top:16px;right:20px}.ui-iconbtn{width:44px;height:44px;display:grid;place-items:center;font-size:20px;background:#0a0f2499;backdrop-filter:blur(8px);border:1px solid rgba(108,243,255,.3);border-radius:12px;color:var(--text);cursor:pointer;transition:transform .12s ease,background .12s ease}.ui-iconbtn:hover{background:#6cf3ff29}.ui-iconbtn:active{transform:scale(.94)}.ui-backdrop{position:absolute;inset:0;background:#0407129e;backdrop-filter:blur(3px);display:grid;grid-template-columns:minmax(0,1fr);grid-template-rows:minmax(0,1fr);place-items:center;pointer-events:auto}.ui-panel{background:linear-gradient(180deg,#131c3e,#0b1126);border:1px solid rgba(108,243,255,.25);border-radius:18px;box-shadow:0 24px 80px #0009;color:var(--text);padding:24px}.ui-panel h2{margin:0 0 16px;font-size:22px}.ui-panel h3{margin:18px 0 8px;font-size:15px;color:var(--muted);font-weight:600}.ui-pin{width:300px;text-align:center}.ui-pin-display{font-size:28px;letter-spacing:.3em;height:40px;color:var(--gold);margin-bottom:16px}.ui-pin-display.error{color:var(--pink);font-size:18px;letter-spacing:normal}.ui-pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}.ui-pin-key{height:56px;font-size:22px;font-weight:700;background:#6cf3ff14;border:1px solid rgba(108,243,255,.22);border-radius:12px;color:var(--text);cursor:pointer}.ui-pin-key:active{background:#6cf3ff38;transform:scale(.96)}.ui-row{display:flex;gap:12px}.ui-btn{flex:1;padding:12px 16px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;border:1px solid transparent}.ui-btn.primary{background:var(--cyan);color:#06205c}.ui-btn.ghost{background:transparent;border-color:#8a96b866;color:var(--text)}.ui-btn.danger{background:#ff5a5a2e;border-color:#ff5a5a80;color:#ffb0b0}.ui-btn:disabled{opacity:.4;cursor:default}.ui-parent{width:min(1040px,94%);height:664px;max-height:664px;min-width:0;display:flex;flex-direction:column}.ui-parent-head{display:flex;align-items:center;justify-content:space-between}.ui-tabs{display:flex;gap:8px;margin:8px 0 16px;border-bottom:1px solid rgba(138,150,184,.2)}.ui-tab{background:none;border:none;color:var(--muted);cursor:pointer;padding:10px 14px;font-size:15px;font-weight:600;border-bottom:2px solid transparent}.ui-tab.active{color:var(--cyan);border-bottom-color:var(--cyan)}.ui-parent-body{flex:1;min-height:0;overflow:auto;min-width:0}.ui-stat-row{display:flex;gap:16px}.ui-stat{flex:1;background:#6cf3ff0f;border-radius:14px;padding:16px;text-align:center}.ui-stat-value{font-size:28px;font-weight:800;color:var(--gold)}.ui-stat-label{font-size:13px;color:var(--muted);margin-top:4px}.ui-concepts{display:flex;flex-direction:column;gap:8px}.ui-concept{display:grid;grid-template-columns:160px 1fr 44px;align-items:center;gap:12px;font-size:14px}.ui-concept-name{text-transform:capitalize;color:var(--text)}.ui-bar{height:10px;background:#8a96b82e;border-radius:999px;overflow:hidden}.ui-bar-fill{display:block;height:100%;background:linear-gradient(90deg,var(--cyan),var(--green))}.ui-concept-count{text-align:right;color:var(--muted)}.ui-subtabs{display:flex;align-items:center;gap:12px;margin:0 0 14px}.ui-tabs-mantine{margin-bottom:12px}.ui-subtab{background:none;border:none;color:var(--muted);cursor:pointer;padding:7px 18px;font-size:14px;font-weight:600;border-radius:9px}.ui-subtab.active{color:#06205c;background:var(--cyan)}.dom-progress{display:flex;flex-direction:column;gap:6px}.lp-caption{font-size:12px;line-height:1.4;margin:-4px 0 4px}.lp-caption b{color:var(--cyan)}.lp-list,.lp-group{display:flex;flex-direction:column;gap:4px}.lp-group+.lp-group{margin-top:8px}.lp-group-head{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;padding:6px 8px 2px;border-left:4px solid transparent}.lp-group-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--cyan)}.lp-group-desc{font-size:12px;color:var(--muted);line-height:1.4}.lp-row{display:grid;grid-template-columns:minmax(0,1fr) 200px 46px 52px 128px 76px;align-items:center;gap:10px;font-size:13px;padding:4px 8px;border-radius:8px}.lp-row:not(.lp-head):nth-child(2n){background:#6cf3ff0a}.lp-type-tag{flex:0 0 auto;align-self:center;width:0;height:0;border-style:solid;border-width:0 0 13px 13px;border-color:transparent;border-bottom-color:var(--muted)}.lp-head{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);position:sticky;top:0;background:#0d1430;z-index:1;border-left-color:transparent}.lp-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600;color:var(--text)}.lp-name-cell{display:flex;align-items:center;gap:8px;min-width:0}.lp-name-cell .lp-name{flex:1 1 auto;min-width:0}.lp-prev{flex:0 0 auto;width:22px;height:22px;border-radius:6px;padding:0;display:grid;place-items:center;cursor:pointer;line-height:1;background:#080e2299;border:1px solid var(--cyan);color:var(--cyan);transition:transform .12s ease,background .12s ease,color .12s ease}.lp-prev:hover{transform:scale(1.1);background:var(--cyan);color:#06205c}.lp-chip{justify-self:start;font-size:10px;font-weight:700;padding:2px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.03em;border:1px solid currentColor;white-space:nowrap;display:inline-flex;align-items:center;gap:5px}.lp-chip-ic{flex:0 0 auto}.lp-chip.inactive{color:#8a96b8}.lp-chip.baseline{color:var(--pink)}.lp-chip.running{color:var(--cyan)}.lp-chip.maintenance{color:var(--gold)}.lp-chip.mastered{color:var(--green)}.lp-cells{display:flex;gap:2px;align-items:center}.cell{width:7px;height:16px;border-radius:2px;background:#8a96b829;flex:0 0 auto}.cell.empty{background:#8a96b812}.cell.ok{background:var(--green)}.cell.miss{background:var(--pink)}.cell.recent{box-shadow:inset 0 -3px #ffd1668c}.cell.divide{position:relative;margin-left:9px}.cell.divide:before{content:"";position:absolute;left:-5px;top:-3px;bottom:-3px;width:1px;background:#ffd16699}.lp-score{text-align:right;font-variant-numeric:tabular-nums;color:var(--muted)}.lp-score.hit{color:var(--green);font-weight:800}.lp-status{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.lp-assess{font-size:11px;color:var(--muted);display:inline-flex;align-items:center;gap:4px}.lp-assess-ic{flex:0 0 auto}.lp-actions{display:flex;align-items:center;justify-content:flex-end;gap:6px}.lp-actions-head{text-align:right}.reset-btn{flex:0 0 auto;width:26px;height:26px;border-radius:8px;display:grid;place-items:center;cursor:pointer;background:#10183899;border:1px solid rgba(138,150,184,.3);color:var(--muted);transition:transform .1s ease,color .1s ease,border-color .1s ease,background .1s ease}.reset-btn:hover:not(:disabled){transform:translateY(-1px);color:var(--red);border-color:#ff5a5a8c}.reset-btn:disabled{opacity:.3;cursor:default}.mark-badge{flex:0 0 auto;width:28px;height:28px;border-radius:50%;padding:0;display:grid;place-items:center;line-height:1;background:#080e2299;border:3px solid var(--muted);color:var(--muted);cursor:pointer;transition:transform .12s ease,background .12s ease}.mark-badge:hover{transform:scale(1.1)}.mark-badge.focus{border-color:var(--green);background:var(--green)}.mark-badge.skip{border-color:var(--red);background:var(--red)}.feed{display:flex;flex-direction:column;font-size:13px;font-variant-numeric:tabular-nums}.feed-row{display:grid;grid-template-columns:minmax(0,1fr) 28px 56px 84px;align-items:center;gap:8px;padding:6px 8px;border-radius:8px}.feed-row:nth-child(2n){background:#6cf3ff0a}.feed-row.miss{background:#ff5a5a14}.feed-lesson{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600;color:var(--text)}.feed-rt,.feed-time{text-align:right;color:var(--muted)}.act-ok{color:var(--green);font-weight:700;display:grid;place-items:center}.act-bad{color:var(--pink);font-weight:700;display:grid;place-items:center}.ui-session-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.ui-session-domain{width:90px;font-weight:600}.ui-session-total{margin-left:auto}.ui-stepper-label{font-size:12px;color:var(--muted)}.ui-seg{display:inline-flex;gap:4px;padding:4px;border-radius:12px;background:#10183899}.ui-seg-btn{background:none;border:none;cursor:pointer;padding:7px 14px;font-size:14px;font-weight:600;border-radius:9px;color:var(--muted);transition:background .12s ease,color .12s ease}.ui-seg-btn:hover:not(.active){color:var(--text)}.ui-seg-btn.active{color:#06205c;background:var(--cyan)}.dag-wrap{display:flex;flex-direction:column;gap:12px}.dag-svg{max-width:100%;overflow:visible;background:#060a1a80;border-radius:12px}.dag-node{cursor:pointer}.dag-id{fill:#fff;font-size:15px;font-weight:800}.dag-label{fill:var(--muted);font-size:10px}.dag-detail{font-size:14px;min-height:48px}.dag-detail p{margin:4px 0}.dag-status{text-transform:capitalize;font-weight:700}.dag-status.completed{color:var(--green)}.dag-status.frontier{color:var(--pink)}.dag-status.locked,.muted{color:var(--muted)}.ui-settings{display:flex;flex-direction:column;gap:16px}.ui-setting{display:flex;align-items:center;gap:12px}.ui-setting>span:first-child{width:160px}.ui-input{background:#6cf3ff14;border:1px solid rgba(108,243,255,.22);border-radius:10px;padding:10px 12px;color:var(--text);font-size:16px;width:120px}.ui-ok{color:var(--green);font-size:14px}.ui-corner{z-index:30}.ui-backdrop{z-index:60}#stage:has(.ui-backdrop) .hud-prompt,#stage:has(.ui-backdrop) .hud-feedback,#stage:has(.ui-backdrop) .hud-top,#stage:has(.ui-backdrop) .action-timer,#stage:has(.ui-backdrop) .hud-tip{visibility:hidden}.lock-btn{position:relative;width:48px;height:48px;display:grid;place-items:center;background:#0a0f2499;backdrop-filter:blur(8px);border:1px solid rgba(108,243,255,.28);border-radius:14px;color:var(--text);cursor:pointer;transition:background .12s ease,transform .12s ease}.lock-btn:hover{background:#6cf3ff24}.lock-btn.holding{transform:scale(.95);color:var(--cyan)}.lock-ring{position:absolute;inset:0;pointer-events:none}.play-progress{position:absolute;left:0;right:0;bottom:16px;padding:0 6%;pointer-events:none;z-index:8}.pp-water{position:relative;height:24px}.pp-water-base,.pp-water-fill{position:absolute;left:0;bottom:0;height:100%;-webkit-mask:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='32'%20height='24'%3E%3Cpath%20d='M0,8C8,2,8,2,16,8S24,14,32,8V24H0Z'%20fill='%23000'/%3E%3C/svg%3E") repeat-x;mask:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='32'%20height='24'%3E%3Cpath%20d='M0,8C8,2,8,2,16,8S24,14,32,8V24H0Z'%20fill='%23000'/%3E%3C/svg%3E") repeat-x;-webkit-mask-size:32px 24px;mask-size:32px 24px;animation:pp-waves 2.6s linear infinite}.pp-water-base{right:0;background:#28467873}.pp-water-fill{background:linear-gradient(90deg,var(--cyan),var(--green));box-shadow:0 0 18px #6cf3ff4d;transition:width .5s ease;animation-duration:2.1s}@keyframes pp-waves{to{-webkit-mask-position-x:-32px;mask-position-x:-32px}}.pp-cone{position:absolute;bottom:10px;width:28px;height:42px;transform-origin:50% 100%;transform:translate(-50%);background:linear-gradient(160deg,#5a6a98,#2f3a5e);clip-path:polygon(50% 0,100% 100%,0 100%);animation:pp-sway 2.6s ease-in-out infinite;opacity:.5}.pp-cone.on{background:linear-gradient(160deg,#ffe39a,#f0a020);opacity:1;filter:drop-shadow(0 0 8px rgba(255,209,102,.6))}@keyframes pp-sway{0%,to{transform:translate(-50%) rotate(-5deg)}50%{transform:translate(-50%) rotate(5deg)}}.pp-char{position:absolute;bottom:16px;transform:translate(-50%);transition:left .5s ease;animation:pp-hover 2.8s ease-in-out infinite}.pp-facing{display:block;transition:transform .3s ease}.pp-hop{animation:pp-hop .5s ease}.pp-char-img{width:52px;height:52px;display:block;filter:drop-shadow(0 6px 8px rgba(0,0,0,.45))}.pp-char-face{position:absolute;inset:0;width:52px;height:52px}.pp-char3d{width:116px;height:104px;display:block;filter:drop-shadow(0 8px 10px rgba(0,0,0,.5))}@keyframes pp-hover{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-9px)}}@keyframes pp-hop{0%{transform:translateY(0)}35%{transform:translateY(-16px)}to{transform:translateY(0)}}.streak-progress{position:absolute;left:0;right:0;bottom:16px;padding:0 6%;pointer-events:none;z-index:8;display:flex;justify-content:center}.streak-stars{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:6px 10px;padding:8px 16px;border-radius:999px;background:#0a0f2473;backdrop-filter:blur(2px)}.streak-star{display:inline-flex;color:#788cbe80;transform:scale(.9);transition:color .3s ease,transform .3s ease,filter .3s ease}.streak-star.on{color:var(--gold, #ffd166);transform:scale(1);filter:drop-shadow(0 0 7px rgba(255,209,102,.7));animation:streak-pop .4s ease}@keyframes streak-pop{0%{transform:scale(.9)}45%{transform:scale(1.35)}to{transform:scale(1)}}.ui-corner-tl{top:16px;left:20px}.home{position:fixed;inset:0;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:auto}.home-title{font-size:76px;font-weight:800;margin:0;text-shadow:0 0 40px rgba(108,243,255,.5)}.home-sub{color:var(--muted);margin:6px 0 30px;font-size:18px;letter-spacing:.04em}.home-grid{display:flex;gap:22px;flex-wrap:wrap;justify-content:center;padding:0 16px}.home-card{position:relative;width:210px;min-height:210px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:24px 18px;background:#101838b8;border:1px solid rgba(108,243,255,.3);border-radius:22px;color:var(--text);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;backdrop-filter:blur(8px)}.home-card:hover:not(.disabled){transform:translateY(-4px);border-color:var(--cyan);box-shadow:0 0 40px #6cf3ff40}.home-card:active:not(.disabled){transform:translateY(0) scale(.98)}.home-card.disabled{opacity:.5;cursor:default;border-color:#8a96b840}.home-card-icon{display:flex;align-items:center;justify-content:center;color:var(--cyan)}.home-card-label{font-size:26px;font-weight:800}.home-card-blurb{font-size:13px;color:var(--muted);text-align:center}.home-card-soon{position:absolute;top:12px;right:12px;font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--gold);border:1px solid rgba(255,209,102,.5);border-radius:999px;padding:3px 9px}.ui-deck{display:flex;flex-direction:column;gap:8px}.deck-card{display:flex;align-items:center;gap:12px;padding:10px 12px;background:#10183880;border:1px solid rgba(138,150,184,.18);border-left-width:4px;border-radius:12px}.deck-card.locked{opacity:.65}.deck-card.baseline{border-left-color:var(--pink)}.deck-card.mastered{border-left-color:var(--green)}.deck-card.maintenance{border-left-color:var(--gold)}.deck-card.retired{border-left-color:#6c7bbf}.deck-card-id{flex:0 0 auto;width:30px;height:30px;display:grid;place-items:center;background:#6cf3ff1f;border-radius:8px;font-weight:700;font-size:14px;color:var(--cyan)}.deck-card-text{flex:1 1 auto;display:flex;flex-direction:column;min-width:0}.deck-card-name{font-weight:600;font-size:15px}.deck-card-desc{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.deck-status{flex:0 0 auto;font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px;background:#8a96b826;color:var(--muted)}.deck-status.baseline{color:var(--pink)}.deck-status.mastered{color:var(--green)}.deck-status.maintenance{color:var(--gold)}.deck-status.retired{color:#aeb8e0}.deck-preview{flex:0 0 auto;padding:6px 12px;font-size:13px}.nodemap-panel{display:flex;flex-direction:column;gap:10px;min-width:0}.nodemap-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px;border-radius:10px;background:#10183880;border:1px solid rgba(138,150,184,.18)}.nodemap-hint{font-size:13px;color:var(--muted)}.nodemap-hint b{color:var(--cyan)}.nodemap-zoom{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px}.nm-zoom-btn{width:26px;height:26px;border-radius:8px;padding:0;display:grid;place-items:center;line-height:1;font-size:18px;font-weight:700;cursor:pointer;background:#6cf3ff1a;border:1px solid rgba(108,243,255,.3);color:var(--cyan);transition:background .12s ease}.nm-zoom-btn:hover:not(:disabled){background:#6cf3ff33}.nm-zoom-btn:disabled{opacity:.4;cursor:default}.nm-zoom-val{min-width:40px;text-align:center;font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}.nodemap-legend{display:flex;flex-wrap:wrap;align-items:center;gap:6px 14px;padding:2px 4px;font-size:12px;color:var(--muted)}.legend-item{display:inline-flex;align-items:center;gap:5px}.legend-ic{flex:0 0 auto}.legend-dot{flex:0 0 auto;width:10px;height:10px;border-radius:50%}.legend-sep{width:1px;height:14px;background:#8a96b859}.legend-cap{color:var(--muted);font-weight:700}.legend-bsw{flex:0 0 auto;width:18px;height:13px;border-radius:3px;border:2px solid var(--mark-none)}.legend-bsw.mark-focus{border-color:var(--mark-focus);border-width:3px}.legend-bsw.mark-none{border-color:var(--mark-none)}.legend-bsw.mark-skip{border-color:var(--mark-skip)}.legend-tri{flex:0 0 auto;width:0;height:0;border-style:solid;border-width:13px 0 0 13px;border-color:transparent;transform:scaleX(-1)}.nodemap-fit{overflow:auto;max-height:420px;border-radius:12px;display:flex;justify-content:safe center;touch-action:pan-x pan-y;scrollbar-width:none;-ms-overflow-style:none}.nodemap-fit::-webkit-scrollbar{display:none}.nodemap-scaler{position:relative;flex:0 0 auto}.nodemap{position:relative}.nodemap-edges{position:absolute;left:0;top:0;pointer-events:none}.nodemap-node{position:absolute}.nodemap-node .lesson-card{width:100%;height:100%}.lesson-card{position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center;gap:3px;padding:8px 34px 8px 12px;min-height:44px;background:#101838eb;border:2px solid var(--mark-none);border-radius:12px;color:var(--text);font-size:13px;font-weight:600;text-align:left;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.lesson-card.detail{min-height:100%;gap:5px;padding:9px 36px 10px 13px}.lesson-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #00000073}.lesson-card.mark-none{border-color:var(--mark-none)}.lesson-card.mark-focus{border-color:var(--mark-focus);border-width:3px;box-shadow:0 0 0 2px #4da3ff38,0 0 16px #4da3ff52;z-index:3}.lesson-card.mark-skip{border-color:var(--mark-skip)}.lesson-card.mark-skip .lesson-card-name{text-decoration:line-through;text-decoration-color:var(--pink)}.lesson-card.status-inactive{opacity:.5}.lesson-card-head{display:flex;align-items:center;gap:7px;min-width:0}.phase-dot{flex:0 0 auto;width:12px;height:12px;border-radius:50%;border:1px solid var(--navy);box-shadow:0 0 0 2px #00000040}.lesson-card-name{flex:1 1 auto;min-width:0;overflow:hidden;line-height:1.18;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.lesson-card-desc{margin:0;font-size:11px;font-weight:500;color:#aeb8d4;line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}.lesson-card-warn{flex:0 0 auto;display:grid;place-items:center}.type-tag{position:absolute;top:0;right:0;width:0;height:0;border-style:solid;border-width:18px 0 0 18px;border-color:transparent;border-top-color:var(--muted)}.lesson-card-prev{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;padding:0;display:grid;place-items:center;background:#080e22eb;border:1px solid var(--cyan);color:var(--cyan);line-height:1;cursor:pointer;opacity:.9;transition:background .12s ease,color .12s ease,box-shadow .12s ease}.lesson-card-prev:hover{background:var(--cyan);color:#06205c;opacity:1;box-shadow:0 0 10px #6cf3ff80}.topic-card{position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center;gap:5px;width:100%;height:100%;padding:9px 38px 10px 13px;background:#101838eb;border:2px solid var(--mark-none);border-radius:12px;color:var(--text);text-align:left;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.topic-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #00000073}.topic-card.tstatus-locked{opacity:.55}.topic-card.mark-focus{border-color:var(--mark-focus);border-width:3px;box-shadow:0 0 0 2px #4da3ff38,0 0 16px #4da3ff52;z-index:3}.topic-card.mark-skip{border-color:var(--mark-skip)}.topic-card.mark-skip .topic-card-name{text-decoration:line-through;text-decoration-color:var(--pink)}.topic-card-head{display:flex;align-items:center;gap:7px;min-width:0}.topic-card-name{flex:1 1 auto;min-width:0;font-size:14px;font-weight:700;overflow:hidden;line-height:1.18;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.topic-card-meta{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--muted)}.topic-diff{letter-spacing:1px;color:var(--gold);font-size:9px}.topic-card .topic-mark{position:absolute;right:7px;top:50%;transform:translateY(-50%);width:24px;height:24px;border-width:2px}.topic-pills{position:sticky;top:0;z-index:5;display:flex;gap:8px;overflow-x:auto;scrollbar-width:thin;padding:8px 0;margin:0 0 4px;background:#0e1530;box-shadow:0 6px 10px -8px #0009}.topic-pill{flex:0 0 auto;display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border-radius:999px;cursor:pointer;background:#101838b3;border:1px solid rgba(138,150,184,.35);color:var(--text);font-size:12px;font-weight:600;white-space:nowrap;transition:transform .1s ease,border-color .1s ease,background .1s ease}.topic-pill:hover{transform:translateY(-1px)}.topic-pill.tstatus-active{border-color:#6cf3ff80;background:#6cf3ff1f}.topic-pill.tstatus-complete{border-color:#7cf08c99;background:#7cf08c24}.topic-pill.tstatus-locked{opacity:.55}.topic-pill.active{background:var(--cyan);color:#06205c;border-color:var(--cyan)}.dom-overview{display:flex;flex-direction:column;gap:6px}.ov-topics{display:flex;flex-direction:column;gap:6px;margin-bottom:4px}.ov-topic{display:grid;grid-template-columns:160px 1fr 44px;align-items:center;gap:12px;font-size:13px}.ov-topic.tstatus-locked{opacity:.55}.ov-topic-label{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ov-bar{height:10px;background:#8a96b82e;border-radius:999px;overflow:hidden}.ov-bar-fill{display:block;height:100%;background:linear-gradient(90deg,var(--cyan),var(--green));border-radius:999px}.ov-topic.tstatus-complete .ov-bar-fill{background:var(--green)}.ov-topic.tstatus-locked .ov-bar-fill{background:#8a96b880}.ov-topic-pct{text-align:right;font-variant-numeric:tabular-nums;font-weight:800;color:var(--muted)}.lp-group-pct{font-size:11px;font-weight:800;font-variant-numeric:tabular-nums;color:var(--cyan)}.lp-topic-mark{width:22px;height:22px;border-width:2px;margin-left:auto}.nm-back{flex:0 0 auto;background:#101838b3;border:1px solid var(--cyan);color:var(--cyan);font-size:12px;font-weight:700;padding:5px 12px;border-radius:999px;cursor:pointer;transition:background .12s ease,color .12s ease}.nm-back:hover{background:var(--cyan);color:#06205c}.nodemap-sub .nodemap-fit{border:1.5px solid rgba(138,150,184,.4);border-radius:12px;background:#080e2259}.nodemap-sub.tstatus-active .nodemap-fit{border-color:#6cf3ff80}.nodemap-sub.tstatus-complete .nodemap-fit{border-color:#7cf08c8c}.nodemap-sub.tstatus-locked .nodemap-fit{border-color:#8a96b873}.focus-switch{margin-left:auto;display:inline-flex;align-items:center;gap:10px}.focus-switch-count{font-size:11px;color:var(--muted);white-space:nowrap}.focus-toggle{display:inline-flex;align-items:center;gap:8px;cursor:pointer;background:none;border:none;color:var(--muted);font-size:13px;font-weight:600;padding:4px 6px}.focus-toggle.on{color:var(--cyan)}.focus-toggle-track{position:relative;width:36px;height:20px;border-radius:999px;background:#8a96b84d;transition:background .15s ease}.focus-toggle.on .focus-toggle-track{background:var(--cyan)}.focus-toggle-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#0d1430;transition:transform .15s ease}.focus-toggle.on .focus-toggle-knob{transform:translate(16px)}.focus-toggle-label{white-space:nowrap}.student-avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;border:2px solid;flex:none;line-height:1;font-weight:800}.student-gate{position:fixed;inset:0;z-index:40;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:32px;pointer-events:auto;background:radial-gradient(ellipse at center,#0e1638f5,#060a1afa 70%);backdrop-filter:blur(6px)}.sg-close{position:absolute;top:18px;right:20px}.sg-title{font-size:44px;font-weight:800;margin:0;text-shadow:0 0 36px rgba(108,243,255,.45)}.sg-sub{color:var(--muted);margin:0 0 18px;font-size:16px}.sg-grid{display:flex;flex-wrap:wrap;gap:18px;justify-content:center;max-width:880px}.sg-card{width:150px;min-height:168px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:20px 14px;background:#101838b8;border:1px solid rgba(108,243,255,.3);border-radius:22px;color:var(--text);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.sg-card:hover:not(:disabled){transform:translateY(-4px);border-color:var(--cyan);box-shadow:0 0 36px #6cf3ff38}.sg-card:active:not(:disabled){transform:scale(.97)}.sg-card:disabled{opacity:.6;cursor:default}.sg-card.current{border-color:var(--gold);box-shadow:0 0 28px #ffd16640}.sg-name{font-size:19px;font-weight:700;text-align:center}.sg-add{border-style:dashed}.sg-add-plus{width:92px;height:92px;border-radius:50%;display:grid;place-items:center;color:var(--cyan);background:#6cf3ff14;border:2px dashed rgba(108,243,255,.4)}.sg-formwrap{width:min(440px,92%)}.sg-footer{position:absolute;bottom:22px;display:flex;gap:14px;align-items:center;flex-wrap:wrap;justify-content:center}.sg-link{background:none;border:none;color:var(--cyan);cursor:pointer;font-size:14px;text-decoration:underline;padding:0}.sg-account{color:var(--muted);font-size:13px}.student-form{display:flex;flex-direction:column;gap:12px;background:#0a0f2480;border:1px solid rgba(108,243,255,.18);border-radius:16px;padding:16px}.sf-row{display:flex;align-items:center;gap:12px}.sf-preview{width:52px;height:52px;font-size:26px}.sf-name{flex:1;width:auto}.sf-pick{display:flex;flex-wrap:wrap;gap:6px}.sf-emoji{width:38px;height:38px;font-size:20px;line-height:1;background:#6cf3ff0f;border:1px solid transparent;border-radius:10px;cursor:pointer}.sf-emoji.active{border-color:var(--cyan);background:#6cf3ff29}.sf-color{width:30px;height:30px;border-radius:50%;border:2px solid transparent;cursor:pointer}.sf-color.active{border-color:var(--text);box-shadow:0 0 0 2px #ffffff40}.sf-err{color:#ffb0b0;font-size:13px}.sf-actions{display:flex;gap:10px}.sf-actions .ui-btn{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px}.parent-student-chip{display:inline-flex;align-items:center;gap:8px;cursor:pointer;background:#6cf3ff14;border:1px solid rgba(108,243,255,.3);border-radius:999px;padding:4px 12px 4px 5px;color:var(--text);font-weight:600;font-size:14px}.parent-student-chip:hover{border-color:var(--cyan)}.psc-name{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.psc-switch{font-size:12px;color:var(--cyan);font-weight:700}.students-mgr{display:flex;flex-direction:column;gap:14px}.sm-list{display:flex;flex-direction:column;gap:8px}.sm-row{display:flex;align-items:center;gap:12px;background:#10183880;border:1px solid rgba(138,150,184,.2);border-left:4px solid rgba(138,150,184,.25);border-radius:12px;padding:10px 12px}.sm-row.active{border-left-color:var(--gold);background:#ffd1660f}.sm-row.editing{display:block}.sm-name{font-size:17px;font-weight:700}.sm-badge{font-size:11px;font-weight:700;letter-spacing:.04em;color:var(--gold);border:1px solid rgba(255,209,102,.5);border-radius:999px;padding:3px 9px}.sm-row-actions{margin-left:auto;display:flex;align-items:center;gap:8px}.sm-btn{flex:0 0 auto;padding:8px 14px;font-size:14px}.sm-add-btn{flex:0 0 auto;align-self:flex-start}.sm-edit{width:100%;display:flex;flex-direction:column;gap:12px}.admin-panel{display:flex;flex-direction:column;gap:6px}.adm-add{display:flex;gap:10px;margin:8px 0 12px}.adm-input{flex:1;width:auto}.adm-addbtn{flex:0 0 auto}.adm-list{display:flex;flex-direction:column;gap:6px}.adm-row{display:flex;align-items:center;gap:10px;background:#10183880;border:1px solid rgba(138,150,184,.2);border-radius:10px;padding:8px 12px}.adm-email{font-weight:600}.adm-by{color:var(--muted);font-size:12px}.adm-rm{margin-left:auto}.adm-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.adm-chip{font-size:13px;color:var(--muted);background:#6cf3ff0f;border:1px solid rgba(108,243,255,.2);border-radius:999px;padding:5px 12px}.adm-chip.super{color:var(--gold);border-color:#ffd16666}#tester{position:fixed;top:0;left:0;bottom:0;z-index:50;width:360px;max-width:92vw;display:flex;flex-direction:column;background:#080c1ceb;backdrop-filter:blur(10px);border-right:1px solid rgba(108,243,255,.25);color:var(--text);pointer-events:auto}.lt{display:flex;flex-direction:column;min-height:0;height:100%}.lt button,.lt input,.lt textarea{font-family:inherit;pointer-events:auto}.lt-head{padding:14px 16px 10px;border-bottom:1px solid rgba(138,150,184,.18)}.lt-head h1{margin:0;font-size:18px}.lt-sub{margin:4px 0 10px;font-size:12px;color:var(--muted)}.lt-search{width:100%;background:#6cf3ff14;border:1px solid rgba(108,243,255,.22);border-radius:10px;padding:8px 10px;color:var(--text);font-size:14px}.lt-controls{padding:12px 16px;border-bottom:1px solid rgba(138,150,184,.18);display:flex;flex-direction:column;gap:12px}.lt-current{display:flex;flex-direction:column;gap:2px}.lt-current-name{font-size:16px;font-weight:700}.lt-current-id{font-size:11px;color:var(--muted);font-family:ui-monospace,monospace}.lt-field{display:flex;flex-direction:column;gap:6px}.lt-field>label{font-size:11px;font-weight:700;letter-spacing:.04em;color:var(--muted);text-transform:uppercase}.lt-seg{display:flex;flex-wrap:wrap;gap:4px}.lt-seg-btn{padding:5px 9px;font-size:12px;font-weight:600;cursor:pointer;background:#6cf3ff0f;border:1px solid rgba(108,243,255,.18);border-radius:8px;color:var(--text)}.lt-seg-btn.active{background:var(--cyan);color:#06205c;border-color:var(--cyan)}.lt-actions{display:flex;gap:6px;flex-wrap:wrap}.lt-btn{flex:1;min-width:84px;padding:8px 10px;font-size:13px;font-weight:700;cursor:pointer;background:#6cf3ff1a;border:1px solid rgba(108,243,255,.3);border-radius:9px;color:var(--text)}.lt-btn.ok{background:#7cf08c29;border-color:#7cf08c80;color:#c7ffce}.lt-btn.bad{background:#ff5a5a29;border-color:#ff5a5a80;color:#ffb6b6}.lt-btn:disabled{opacity:.5;cursor:default}.lt-note{font-size:12px;color:var(--cyan)}.lt-note.muted{color:var(--muted)}.lt-image{display:flex;flex-direction:column;gap:8px}.lt-image-frame{width:100%;aspect-ratio:1 / 1;border-radius:12px;overflow:hidden;background:#0000004d;border:1px solid rgba(138,150,184,.25);display:grid;place-items:center}.lt-image-frame img{width:100%;height:100%;object-fit:contain}.lt-image-key{font-size:11px;color:var(--muted);font-family:ui-monospace,monospace;word-break:break-all}.lt-prompt{width:100%;background:#6cf3ff0f;border:1px solid rgba(108,243,255,.2);border-radius:10px;padding:8px 10px;color:var(--text);font-size:13px;resize:vertical}.lt-list{flex:1;min-height:0;overflow:auto;padding:8px 10px 24px}.lt-domain>h2{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--gold);margin:12px 6px 4px}.lt-topic>h3{font-size:12px;color:var(--muted);margin:8px 6px 4px;font-weight:600}.lt-lesson{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;text-align:left;padding:7px 10px;margin:2px 0;cursor:pointer;background:#10183880;border:1px solid transparent;border-left:3px solid rgba(138,150,184,.25);border-radius:8px;color:var(--text);font-size:13px}.lt-lesson:hover{border-color:#6cf3ff66}.lt-lesson.active{border-left-color:var(--cyan);background:#6cf3ff1f}.lt-lesson-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lt-lesson-dom{font-size:10px;color:var(--muted);flex:none}.home-card-btn{border-radius:18px;transition:transform .15s ease}.home-card-btn:hover:not(:disabled){transform:translateY(-4px)}.home-card-btn:active:not(:disabled){transform:scale(.98)}.home-card-btn:disabled{opacity:.5;cursor:default}.home-card-m{position:relative;height:100%;transition:border-color .15s ease,box-shadow .15s ease}.home-card-btn:hover:not(:disabled) .home-card-m{border-color:var(--cyan);box-shadow:0 0 36px #6cf3ff38}.sg-card-btn{border-radius:18px;transition:transform .15s ease}.sg-card-btn:hover:not(:disabled){transform:translateY(-4px)}.sg-card-btn:active:not(:disabled){transform:scale(.97)}.sg-card-btn:disabled{opacity:.6;cursor:default}.sg-card-m{position:relative;transition:border-color .15s ease,box-shadow .15s ease}.sg-card-btn:hover:not(:disabled) .sg-card-m{border-color:var(--cyan);box-shadow:0 0 28px #6cf3ff33}.sg-card-m.current{border-color:var(--gold);box-shadow:0 0 24px #ffd16638}
