.boot{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--app-bg);padding:24px}.boot-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px 40px;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;box-shadow:var(--shadow-md);max-width:440px}.boot-card .spin{color:var(--brand);animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.boot-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center}.boot-icon--danger{background:var(--danger-soft);color:var(--danger)}.boot-title{font-family:var(--font-heading);font-weight:700;font-size:18px;color:var(--text-primary)}.boot-sub{font-size:13.5px;color:var(--text-secondary);line-height:1.5}.boot-actions{display:flex;gap:10px;margin-top:8px}.shell-desktop{display:flex;height:100vh;background:var(--app-bg)}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;gap:4px;padding:18px 14px;height:100%}.brand{display:flex;align-items:center;gap:10px;padding:6px 8px 14px}.brand-logo{width:38px;height:38px;border-radius:8px;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-weight:800;font-size:19px;flex-shrink:0}.brand-name{font-family:var(--font-heading);font-weight:800;font-size:17px;letter-spacing:.3px;color:var(--text-primary)}.brand-sub{font-size:11px;font-weight:500;color:var(--text-muted)}.nav-item{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:8px;font-size:14px;font-weight:500;color:var(--text-secondary);width:100%;text-align:left;transition:background .14s ease,color .14s ease}.nav-item:hover{background:var(--surface-2)}.nav-item.active{background:var(--brand-soft);color:var(--brand);font-weight:600}.nav-item .nav-ico{flex-shrink:0}.nav-spacer{flex:1}.sidebar-file{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;display:flex;flex-direction:column;gap:7px;margin-top:6px}.sidebar-file-top{display:flex;align-items:center;gap:8px}.sidebar-file-name{font-size:12px;font-weight:600;color:var(--text-primary)}.sidebar-file-sub{font-size:11px;color:var(--text-muted)}.shell-main{flex:1;height:100%;overflow-y:auto;background:var(--app-bg)}.shell-main-inner{display:flex;flex-direction:column;gap:22px;padding:28px 32px 40px;max-width:var(--content-max);margin:0 auto;width:100%}.screen-head{display:flex;align-items:center;justify-content:space-between;gap:16px}.screen-title{font-family:var(--font-heading);font-weight:800;font-size:26px;color:var(--text-primary)}.screen-sub{font-size:14px;color:var(--text-secondary);margin-top:5px}.shell-mobile{min-height:100vh;display:flex;flex-direction:column;background:var(--app-bg)}.shell-mobile-scroll{flex:1;display:flex;flex-direction:column;padding-bottom:82px}.bottom-nav{position:fixed;left:0;right:0;bottom:0;height:70px;background:var(--surface);border-top:1px solid var(--border);display:flex;align-items:center;padding:0 6px;z-index:40;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;height:100%;color:var(--text-muted);font-size:11px;font-weight:600}.bottom-nav-item.active{color:var(--brand)}.m-topbar{position:sticky;top:0;z-index:30;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 16px;height:58px}.m-topbar h1{font-family:var(--font-heading);font-weight:800;font-size:19px;color:var(--text-primary)}.m-content{display:flex;flex-direction:column;gap:14px;padding:16px}.m-avatar{width:36px;height:36px;border-radius:999px;background:var(--brand-soft);color:var(--brand);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;font-family:var(--font-heading)}.icon-btn{width:38px;height:38px;border-radius:999px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);background:var(--surface-2)}.icon-btn:hover{background:var(--border)}.connect-wrap{width:100%;min-height:70vh;display:flex;align-items:center;justify-content:center;padding:24px}.connect-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:36px 40px;max-width:460px;width:100%;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}.connect-icon{width:60px;height:60px;border-radius:16px;background:var(--brand-soft);color:var(--brand);display:flex;align-items:center;justify-content:center;margin-bottom:4px}.connect-title{font-family:var(--font-heading);font-weight:800;font-size:20px;color:var(--text-primary)}.connect-sub{font-size:14px;line-height:1.55;color:var(--text-secondary)}.connect-hint{font-size:12.5px;color:var(--text-muted);margin-top:6px}@media(max-width:879px){.screen-head{display:none}.connect-card{padding:28px 22px}}.mb{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700;white-space:nowrap}.mb-dot{width:6px;height:6px;border-radius:999px;flex-shrink:0}.mb--new{background:var(--m-new-bg);color:var(--m-new-fg)}.mb--new .mb-dot{background:var(--m-new-fg)}.mb--weak{background:var(--m-weak-bg);color:var(--m-weak-fg)}.mb--weak .mb-dot{background:var(--m-weak-bar)}.mb--med{background:var(--m-med-bg);color:var(--m-med-fg)}.mb--med .mb-dot{background:var(--m-med-bar)}.mb--good{background:var(--m-good-bg);color:var(--m-good-fg)}.mb--good .mb-dot{background:var(--m-good-bar)}.mb--master{background:var(--m-master-bg);color:var(--m-master-fg)}.mb--master .mb-dot{background:var(--m-master-bar)}.mbar{width:100%;height:8px;border-radius:999px;background:#eef1f6;overflow:hidden}.mbar-fill{height:100%;border-radius:999px;transition:width .5s cubic-bezier(.22,1,.36,1)}.mbar-fill--new{background:var(--m-new-bar)}.mbar-fill--weak{background:var(--m-weak-bar)}.mbar-fill--med{background:var(--m-med-bar)}.mbar-fill--good{background:var(--m-good-bar)}.mbar-fill--master{background:var(--m-master-bar)}.stars{display:inline-flex;align-items:center;gap:3px}.tier{display:inline-flex;align-items:center;justify-content:center;min-width:26px;height:22px;padding:0 7px;border-radius:6px;font-size:12px;font-weight:700;background:var(--brand-soft);color:var(--brand)}.tier--1{background:#e8f5ee;color:#15a06b}.tier--2{background:#e7eefe;color:#2563eb}.tier--3{background:#fbf1cf;color:#9a7b06}.tier--4{background:#fcebd6;color:#c26a06}.tier--5{background:#fbe3e4;color:#c5343a}.icon-chip{display:flex;align-items:center;justify-content:center;border-radius:8px;flex-shrink:0}.statcard{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;gap:14px;flex:1;min-width:0}.statcard-top{display:flex;align-items:center;justify-content:space-between}.statcard-label{font-size:13px;font-weight:500;color:var(--text-secondary)}.statcard-value{font-family:var(--font-heading);font-weight:800;font-size:28px;color:var(--text-primary);line-height:1}.statcard-caption{font-size:12px;color:var(--text-muted)}.chip{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:9px 14px;font-size:13px;font-weight:600;color:var(--text-primary)}.chip--streak{color:var(--text-primary)}.chip--streak-zero{color:var(--text-muted);background:var(--surface-2);border-style:dashed}.toast-host{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:10px;z-index:90;align-items:center;pointer-events:none}.toast{pointer-events:auto;display:flex;align-items:center;gap:10px;background:var(--text-primary);color:#fff;border-radius:var(--radius-md);padding:12px 16px;font-size:13.5px;font-weight:500;box-shadow:var(--shadow-md);animation:pop .2s ease both;max-width:92vw}.toast--success{background:#0f3d2e}.toast--danger{background:#5b1d1d}.seg{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:4px;gap:4px}.seg-item{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:9px 12px;border-radius:9px;font-size:13.5px;font-weight:600;color:var(--text-secondary);white-space:nowrap}.seg-item.active{background:var(--brand);color:#fff}.empty-block{display:flex;flex-direction:column;align-items:center;gap:8px;padding:48px 24px;text-align:center;color:var(--text-secondary)}.empty-block .empty-title{font-family:var(--font-heading);font-weight:700;font-size:16px;color:var(--text-primary)}.home-greeting-title{font-family:var(--font-heading);font-weight:800;font-size:26px;color:var(--text-primary)}.home-greeting-sub{font-size:14px;color:var(--text-secondary);margin-top:5px}.hero{background:var(--hero-gradient);border-radius:var(--radius-lg);padding:28px 32px;display:flex;align-items:center;justify-content:space-between;gap:24px;color:#fff;box-shadow:var(--shadow-lg)}.hero-text{display:flex;flex-direction:column;gap:10px;max-width:620px}.hero-tag{align-self:flex-start;background:#ffffff26;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700;letter-spacing:1px}.hero-title{font-family:var(--font-heading);font-weight:800;font-size:26px}.hero-sub{font-size:14px;line-height:1.45;color:#ffffffd9}.hero-cta{background:#fff;color:var(--brand);border-radius:var(--radius-md);padding:15px 26px;display:inline-flex;align-items:center;gap:10px;font-family:var(--font-heading);font-weight:700;font-size:15px;flex-shrink:0;transition:transform .08s ease,box-shadow .15s ease}.hero-cta:hover{box-shadow:0 8px 20px #0000002e;transform:translateY(-1px)}.hero-actions{display:flex;flex-direction:column;gap:10px;flex-shrink:0}.hero-cta--ghost{background:#ffffff24;color:#fff;border:1px solid rgba(255,255,255,.4)}.hero-cta--ghost:hover{background:#ffffff3d;box-shadow:0 8px 20px #00000024}.summary-strip{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);display:flex;align-items:center;padding:20px 8px}.summary-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px}.summary-val{font-family:var(--font-heading);font-weight:800;font-size:25px;color:var(--text-primary)}.summary-val.is-good{color:var(--success)}.summary-val.is-bad{color:var(--m-weak-fg)}.summary-lbl{font-size:13px;color:var(--text-secondary)}.summary-div{width:1px;height:46px;background:var(--border);flex-shrink:0}.qf-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.qf-title{font-family:var(--font-heading);font-weight:700;font-size:18px;color:var(--text-primary)}.qf-sub{font-size:13px;color:var(--text-secondary);margin-top:3px}.qf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.qf-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;display:flex;flex-direction:column;gap:12px;text-align:left;align-items:stretch;transition:transform .1s ease,box-shadow .16s ease,border-color .16s ease}.qf-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--border-strong)}.qf-card-top{display:flex;align-items:center;justify-content:space-between}.qf-card-title{font-family:var(--font-heading);font-weight:700;font-size:15px;color:var(--text-primary)}.qf-card-desc{font-size:13px;line-height:1.46;color:var(--text-secondary)}.qf-count{align-self:flex-start;border-radius:999px;padding:4px 11px;font-size:12px;font-weight:700}.qf-arrow{color:var(--text-muted);transition:transform .16s ease}.qf-card:hover .qf-arrow{transform:translate(3px)}.section-block{display:flex;flex-direction:column;gap:14px}.m-greeting-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.m-greeting-row .chip--streak{flex-shrink:0;padding:7px 11px;font-size:12px;gap:6px}.m-hero{background:var(--hero-gradient);border-radius:var(--radius-lg);padding:18px;color:#fff;display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow-lg)}.m-hero .hero-title{font-size:21px}.m-hero .hero-sub{font-size:13px}.m-hero-cta{margin-top:6px;background:#fff;color:var(--brand);border-radius:var(--radius-md);padding:13px;display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-heading);font-weight:700;font-size:15px;width:100%}.m-hero-cta--ghost{margin-top:8px;background:#ffffff24;color:#fff;border:1px solid rgba(255,255,255,.4)}.m-summary{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 6px}.m-qf-list{display:flex;flex-direction:column;gap:10px}.m-qf-row{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;text-align:left;width:100%}.m-qf-row-text{flex:1;min-width:0}.m-qf-row-title{font-family:var(--font-heading);font-weight:700;font-size:15px;color:var(--text-primary)}.m-qf-row-count{font-size:12.5px;color:var(--text-muted);margin-top:1px}.section-label{display:flex;align-items:center;justify-content:space-between}.section-label .lbl-title{font-family:var(--font-heading);font-weight:700;font-size:17px;color:var(--text-primary)}.section-label .lbl-link{font-size:13px;font-weight:600;color:var(--brand)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a6b;display:flex;align-items:center;justify-content:center;z-index:80;padding:20px;animation:fadeUp .18s ease both}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:460px;box-shadow:var(--shadow-md);overflow:hidden;animation:pop .18s ease both}.modal-head{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 22px 0}.modal-title{font-family:var(--font-heading);font-weight:700;font-size:18px}.modal-sub{font-size:13px;color:var(--text-secondary);margin-top:4px}.modal-body{padding:16px 22px 22px}.cat-chip-grid{display:flex;flex-wrap:wrap;gap:9px}.cat-chip{border:1px solid var(--border);border-radius:999px;padding:9px 15px;font-size:13.5px;font-weight:600;color:var(--text-secondary);background:var(--surface)}.cat-chip.on{background:var(--brand-soft);border-color:var(--brand);color:var(--brand)}.modal-foot{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.stat-overview{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.suggest-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}.suggest-card{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px}.suggest-card.is-weak{background:var(--m-med-bg);border-color:#f3dcbf}.suggest-card.is-wrong{background:var(--m-weak-bg);border-color:#f4cdce}.suggest-text{flex:1;min-width:0}.suggest-title{font-family:var(--font-heading);font-weight:700;font-size:15px;color:var(--text-primary);display:flex;align-items:center;gap:8px}.suggest-sub{font-size:12.5px;color:var(--text-secondary);margin-top:3px;line-height:1.4}.mastery-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 22px}.mastery-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}.mastery-head .mh-title{font-family:var(--font-heading);font-weight:700;font-size:16px;color:var(--text-primary)}.mastery-head .mh-sub{font-size:12.5px;color:var(--text-secondary);margin-top:3px}.legend{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;color:var(--text-secondary)}.legend-dot{width:9px;height:9px;border-radius:999px}.mtable{width:100%}.mtable-head,.mtable-row{display:grid;grid-template-columns:1.4fr 2fr 1.1fr 1.2fr .8fr .7fr;align-items:center;gap:12px}.mtable-head{padding:0 0 10px;border-bottom:1px solid var(--border)}.mtable-head>div{font-size:11px;font-weight:700;letter-spacing:.4px;color:var(--text-muted)}.mtable-row{padding:14px 0;border-bottom:1px solid var(--border)}.mtable-row:last-child{border-bottom:none}.mt-topic{display:flex;flex-direction:column;gap:2px}.mt-topic-name{font-weight:600;font-size:14px;color:var(--text-primary)}.mt-topic-meta{font-size:11.5px;color:var(--text-muted)}.mt-bar-cell{display:flex;align-items:center;gap:10px}.mt-pct{font-size:13px;font-weight:700;color:var(--text-primary);min-width:38px;text-align:right}.mt-pct.is-null{color:var(--text-muted)}.mt-cov{font-size:12.5px;color:var(--text-secondary)}.mt-cov.low{color:var(--m-med-fg)}.mt-wrong{font-size:13px;font-weight:700;color:var(--m-weak-fg)}.mt-wrong.zero{color:var(--text-muted);font-weight:500}.mt-action{justify-self:end}.mt-ron{display:inline-flex;align-items:center;gap:5px;color:var(--brand);font-size:13px;font-weight:600;padding:6px 10px;border-radius:8px}.mt-ron:hover{background:var(--brand-soft)}.m-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.m-mastery-list{display:flex;flex-direction:column;gap:12px}.m-mastery-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:13px 14px;display:flex;flex-direction:column;gap:9px}.m-mastery-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.m-mastery-name{font-weight:600;font-size:14px;color:var(--text-primary)}.m-mastery-bottom{display:flex;align-items:center;gap:10px}.m-mastery-bottom .mt-pct{min-width:36px}.source-chip{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:8px 13px;font-size:13px;font-weight:500;color:var(--text-secondary)}.streak-activity-row{display:grid;grid-template-columns:1fr 1.55fr;gap:18px}.streak-card{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px}.streak-flame{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;background:var(--m-med-bg);flex-shrink:0}.streak-num{flex:1;min-width:0}.streak-big{font-family:var(--font-heading);font-weight:800;font-size:30px;line-height:1;color:var(--text-primary)}.streak-lbl{font-size:12.5px;color:var(--text-secondary);margin-top:5px}.streak-best{display:flex;flex-direction:column;align-items:flex-end;gap:2px;font-size:11.5px;color:var(--text-muted);text-align:right}.streak-best strong{font-family:var(--font-heading);font-size:15px;color:var(--text-primary)}.activity-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 20px;display:flex;flex-direction:column;gap:12px}.activity-title{font-family:var(--font-heading);font-weight:700;font-size:14px;color:var(--text-primary)}.activity-bars{flex:1;display:grid;grid-template-columns:repeat(7,1fr);gap:8px;align-items:end}.abar-col{display:flex;flex-direction:column;align-items:center;gap:7px}.abar{width:100%;max-width:30px;height:64px;display:flex;align-items:flex-end}.abar-fill{width:100%;border-radius:6px;background:var(--border-strong);min-height:6px;transition:height .45s cubic-bezier(.22,1,.36,1)}.abar-fill.has{background:var(--brand)}.abar-fill.today{background:var(--accent-violet)}.abar-day{font-size:11px;font-weight:600;color:var(--text-muted)}.abar-day.today{color:var(--accent-violet)}.ach-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 22px}.ach-count{display:inline-flex;align-items:center;gap:6px;background:var(--brand-soft);color:var(--brand);border-radius:999px;padding:6px 12px;font-size:13px;font-weight:700;white-space:nowrap}.ach-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.ach-item{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;background:var(--surface-2);opacity:.72}.ach-item.unlocked{opacity:1;background:var(--surface);border-color:var(--m-master-bar)}.ach-ico{width:38px;height:38px;border-radius:10px;flex-shrink:0;display:grid;place-items:center;background:var(--m-new-bg);color:var(--text-muted)}.ach-item.unlocked .ach-ico{background:var(--m-master-bg);color:var(--m-master-fg)}.ach-text{flex:1;min-width:0}.ach-title{font-family:var(--font-heading);font-weight:700;font-size:14px;color:var(--text-primary)}.ach-desc{font-size:12px;color:var(--text-secondary);margin-top:2px;line-height:1.4}.ach-prog{margin-top:8px;height:6px;border-radius:999px;background:#eef1f6;overflow:hidden}.ach-prog-fill{height:100%;border-radius:999px;background:var(--brand);transition:width .5s ease}.ach-meta{font-size:11.5px;font-weight:600;color:var(--text-muted);margin-top:6px}.ach-meta.unlocked{color:var(--m-master-fg);display:inline-flex;align-items:center;gap:4px}@media(max-width:879px){.streak-activity-row{grid-template-columns:1fr}.ach-card{padding:16px}.ach-grid{grid-template-columns:1fr 1fr}}.bank-actions{display:flex;align-items:center;gap:10px}.bank-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-box{flex:1;min-width:220px;display:flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 14px}.search-box input{flex:1;border:none;outline:none;background:transparent;font-size:14px;color:var(--text-primary)}.search-box input::placeholder{color:var(--text-muted)}.filter-select{position:relative}.filter-trigger{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 14px;font-size:13.5px;font-weight:600;color:var(--text-primary);white-space:nowrap}.filter-trigger.has-value{border-color:var(--brand);color:var(--brand);background:var(--brand-soft)}.filter-trigger:hover{border-color:var(--border-strong)}.filter-bm{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 14px;font-size:13.5px;font-weight:600;color:var(--text-primary);white-space:nowrap}.filter-bm:hover{border-color:var(--border-strong)}.filter-bm.on{border-color:var(--accent-amber);color:var(--accent-amber);background:var(--m-med-bg)}.dropdown-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:45}.filter-menu{position:absolute;top:calc(100% + 6px);left:0;z-index:50;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:6px;min-width:190px;display:flex;flex-direction:column;gap:2px}.filter-opt{display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:8px;font-size:13.5px;color:var(--text-primary);text-align:left;width:100%}.filter-opt:hover{background:var(--surface-2)}.filter-opt .opt-check{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border-strong);display:flex;align-items:center;justify-content:center;flex-shrink:0}.filter-opt.on .opt-check{background:var(--brand);border-color:var(--brand);color:#fff}.bank-table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.bank-table-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);gap:12px}.bth-title{font-family:var(--font-heading);font-weight:700;font-size:15px;color:var(--text-primary)}.bth-sub{font-size:12.5px;color:var(--text-muted);margin-top:2px}.bank-table-pager{display:flex;align-items:center;gap:16px}.page-size{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);white-space:nowrap}.page-size select{border:1px solid var(--border);border-radius:8px;padding:6px 8px;font-size:13px;font-weight:600;color:var(--text-primary);background:var(--surface);outline:none;cursor:pointer}.page-size select:hover{border-color:var(--border-strong)}.page-size select:focus{border-color:var(--brand)}.pager{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}.pager button{width:30px;height:30px;border-radius:8px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.pager button:hover:not(:disabled){background:var(--surface-2)}.pager button:disabled{opacity:.4;cursor:not-allowed}.qtable{width:100%}.qt-head,.qt-row{display:grid;grid-template-columns:78px 70px 100px 1fr 150px 120px 64px 78px;align-items:center;gap:12px;padding:0 20px}.qt-head{height:42px;background:var(--surface-2);border-bottom:1px solid var(--border)}.qt-head>div{font-size:11px;font-weight:700;letter-spacing:.3px;color:var(--text-muted)}.qt-row{min-height:58px;padding-top:12px;padding-bottom:12px;border-bottom:1px solid var(--border)}.qt-row:last-child{border-bottom:none}.qt-row.inactive{opacity:.55}.qt-id{font-family:var(--font-body);font-size:12.5px;font-weight:600;color:var(--text-muted)}.qt-q{font-size:13.5px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.qt-correct{font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qt-times{font-size:13px;font-weight:600;color:var(--text-secondary)}.qt-row-actions{display:flex;align-items:center;gap:4px;justify-self:end}.row-icon-btn{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.row-icon-btn:hover{background:var(--brand-soft);color:var(--brand)}.row-icon-btn.danger:hover{background:var(--danger-soft);color:var(--danger)}.row-icon-btn.bm-on{color:var(--accent-amber)}.row-icon-btn.bm-on:hover{background:var(--m-med-bg);color:var(--accent-amber)}.m-bank-filters{display:flex;gap:8px;flex-wrap:wrap}.m-bank-filters .filter-trigger,.m-bank-filters .filter-bm{flex:1;justify-content:center;padding:9px 10px;font-size:13px}.qcard{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;display:flex;flex-direction:column;gap:9px}.qcard.inactive{opacity:.6}.qcard-top{display:flex;align-items:center;gap:8px}.qcard-cat{font-size:13px;font-weight:600;color:var(--text-secondary)}.qcard-q{font-size:14.5px;font-weight:500;color:var(--text-primary);line-height:1.4}.qcard-bottom{display:flex;align-items:center;justify-content:space-between;gap:8px}.qcard-meta{font-size:12.5px;color:var(--text-muted);display:flex;align-items:center;gap:6px}.editor{max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column}.editor .modal-body{overflow-y:auto}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:12.5px;font-weight:600;color:var(--text-secondary)}.field input[type=text],.field textarea,.field select{border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;font-size:14px;color:var(--text-primary);background:var(--surface);outline:none;width:100%}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--brand)}.field textarea{resize:vertical;min-height:64px;font-family:inherit}.answer-edit{display:flex;align-items:center;gap:10px}.answer-edit .pick{width:22px;height:22px;border-radius:999px;border:2px solid var(--border-strong);flex-shrink:0;display:flex;align-items:center;justify-content:center}.answer-edit .pick.on{border-color:var(--m-master-bar);background:var(--m-master-bar);color:#fff}.answer-edit input{flex:1}.answer-edit-group{margin-bottom:12px}.answer-edit-group .opt-exp{margin-top:6px;font-size:13px;padding:7px 11px;background:var(--surface-2);color:var(--text-secondary);border-left:3px solid var(--border-strong)}.answer-edit-group .opt-exp::placeholder{color:var(--text-muted)}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field-err{font-size:12px;color:var(--danger)}.editor-hint{font-size:12px;color:var(--text-muted);margin-bottom:10px}.dstars-pick{display:flex;gap:6px;align-items:center}.dstars-pick button{display:flex}.data-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:18px;align-items:start}.data-col{display:flex;flex-direction:column;gap:18px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.panel-title{font-family:var(--font-heading);font-weight:700;font-size:15px;color:var(--text-primary)}.panel-sub{font-size:12.5px;color:var(--text-secondary);margin-top:3px}.file-card-top{display:flex;align-items:center;gap:14px;margin-bottom:16px}.file-thumb{width:48px;height:48px;border-radius:var(--radius-md);background:var(--success-soft);color:var(--success);display:flex;align-items:center;justify-content:center;flex-shrink:0}.file-name-row{display:flex;align-items:center;gap:8px}.file-name{font-family:var(--font-heading);font-weight:700;font-size:16px;color:var(--text-primary)}.file-meta{font-size:12.5px;color:var(--text-muted);margin-top:2px}.badge-live{display:inline-flex;align-items:center;gap:5px;background:var(--success-soft);color:var(--m-master-fg);border-radius:999px;padding:3px 9px;font-size:11px;font-weight:700}.badge-live .dot{width:6px;height:6px;border-radius:999px;background:var(--success)}.file-actions{display:flex;gap:10px}.file-foot{margin-top:14px;padding-top:14px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:12.5px;color:var(--text-muted)}.io-row{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--border)}.io-row:last-child{border-bottom:none}.io-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.io-text{flex:1;min-width:0}.io-title{font-weight:600;font-size:14px;color:var(--text-primary)}.io-sub{font-size:12.5px;color:var(--text-muted);margin-top:2px}.setting-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}.setting-row:last-child{border-bottom:none}.setting-label{font-size:13.5px;font-weight:500;color:var(--text-primary)}.setting-hint{display:block;margin-top:3px;font-size:12px;font-weight:400;color:var(--text-secondary)}.setting-value{font-size:13px;color:var(--text-secondary);font-weight:600}.toggle{width:42px;height:24px;border-radius:999px;background:#cbd5e1;position:relative;flex-shrink:0;transition:background .18s ease}.toggle.on{background:var(--brand)}.toggle:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:999px;background:#fff;transition:transform .18s ease;box-shadow:0 1px 2px #0003}.toggle.on:after{transform:translate(18px)}.setting-input{width:160px;max-width:52%;border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:13.5px;font-family:var(--font-body);color:var(--text-primary);background:var(--surface)}.setting-input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}.seg-choice{display:inline-flex;gap:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:3px;flex-shrink:0}.seg-opt{min-width:42px;padding:6px 10px;border-radius:7px;font-size:13px;font-weight:600;color:var(--text-secondary);transition:background .14s ease,color .14s ease}.seg-opt.on{background:var(--brand);color:#fff}.sheets-panel{border-color:#cfe0fd;background:linear-gradient(180deg,#f5f9ff 0%,var(--surface) 60%)}.sheets-top{display:flex;align-items:center;gap:14px}.sheets-top .btn{flex-shrink:0}.sheets-hint{margin-top:12px;font-size:12.5px;line-height:1.5;color:var(--text-secondary)}.spin{animation:spin .9s linear infinite}.guard-list{display:flex;flex-direction:column;gap:12px}.guard-item{display:flex;gap:10px;font-size:13px;line-height:1.5;color:var(--text-secondary)}.guard-item svg{flex-shrink:0;margin-top:2px;color:var(--success)}.roadmap{background:var(--brand-soft);border:1px solid #cfe0fd;border-radius:var(--radius-md);padding:14px 16px;display:flex;gap:11px;font-size:12.5px;line-height:1.5;color:var(--brand-dark)}.roadmap svg{flex-shrink:0;margin-top:1px}.danger-panel{background:var(--danger-soft);border:1px solid #f4cdce;border-radius:var(--radius-lg);padding:18px 20px}.danger-title{display:flex;align-items:center;gap:8px;font-family:var(--font-heading);font-weight:700;font-size:15px;color:var(--danger)}.danger-sub{font-size:12.5px;color:#9b3030;margin:6px 0 14px;line-height:1.45}@media(max-width:879px){.data-grid{grid-template-columns:1fr}}.play-root{min-height:100vh;min-height:100dvh;height:100vh;height:100dvh;display:flex;flex-direction:column;background:var(--app-bg);overflow:hidden}.play-topbar{flex-shrink:0;height:64px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;gap:16px}.play-exit{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:600;color:var(--text-secondary);padding:8px 12px;border-radius:8px}.play-exit:hover{background:var(--surface-2);color:var(--text-primary)}.play-top-center{flex:1;display:flex;align-items:center;justify-content:center;gap:16px;min-width:0}.play-top-right{display:flex;align-items:center;justify-content:flex-end;gap:14px;min-width:150px}.play-counter{font-size:14px;font-weight:700;color:var(--text-primary);white-space:nowrap;font-family:var(--font-heading)}.play-endless-tag{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:999px;background:var(--brand-soft);color:var(--brand);font-family:var(--font-heading);font-weight:700;font-size:12.5px;white-space:nowrap}.seg-bar{display:flex;gap:4px;width:100%;max-width:420px}.seg{flex:1;height:6px;border-radius:999px;background:#e2e8f0;transition:background .3s ease}.seg.done{background:var(--m-master-bar)}.seg.current{background:var(--brand)}.play-content{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}.play-stage{width:100%;max-width:760px;display:flex;flex-direction:column;gap:18px}.reveal-banner{display:flex;align-items:center;gap:10px;border-radius:var(--radius-md);padding:13px 16px;font-size:13.5px;font-weight:600}.reveal-banner.wrong{background:var(--m-weak-bg);color:var(--m-weak-fg)}.reveal-banner.right{background:var(--success-soft);color:var(--m-master-fg)}.play-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.play-meta-left{display:flex;align-items:center;gap:14px}.cat-chip{display:inline-flex;align-items:center;gap:7px;background:var(--brand-soft);color:var(--brand);border-radius:999px;padding:5px 12px;font-size:13px;font-weight:600}.diff-inline{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--text-muted);font-weight:500}.lifelines{display:flex;align-items:center;gap:8px}.ll{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px 13px;font-size:13px;font-weight:600;color:var(--text-primary);transition:background .14s ease,border-color .14s ease,opacity .14s ease}.ll:hover:not(:disabled){background:var(--brand-soft);border-color:var(--brand)}.ll:disabled{opacity:.4;cursor:not-allowed}.ll .ll-ico{color:var(--brand)}.question-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:30px 28px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;box-shadow:var(--shadow-sm)}.question-kicker{font-size:11px;font-weight:700;letter-spacing:1px;color:var(--text-muted)}.question-text{font-family:var(--font-heading);font-weight:700;font-size:24px;line-height:1.32;color:var(--text-primary)}.answers{display:grid;grid-template-columns:1fr 1fr;gap:14px}.answer{display:flex;align-items:center;gap:14px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:16px 18px;text-align:left;font-size:15px;color:var(--text-primary);transition:border-color .14s ease,background .14s ease,box-shadow .14s ease,opacity .2s ease;width:100%}.answer:hover:not(:disabled):not(.locked){border-color:var(--border-strong);background:var(--surface-2)}.answer-letter{width:30px;height:30px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:var(--text-secondary);flex-shrink:0;transition:background .14s ease,color .14s ease,border-color .14s ease}.answer-text{flex:1;min-width:0}.answer-mark{margin-left:auto;flex-shrink:0;display:flex}.answer.selected{border-color:var(--brand);background:var(--brand-soft)}.answer.selected .answer-letter{background:var(--brand);color:#fff;border-color:var(--brand)}.answer.correct{border-color:var(--m-master-bar);background:var(--success-soft)}.answer.correct .answer-letter{background:var(--m-master-bar);color:#fff;border-color:var(--m-master-bar)}.answer.wrong{border-color:var(--m-weak-bar);background:var(--m-weak-bg)}.answer.wrong .answer-letter{background:var(--m-weak-bar);color:#fff;border-color:var(--m-weak-bar)}.answer.eliminated{opacity:.4;pointer-events:none}.answer.locked{cursor:default}.answer.correct{animation:mk-correct-glow .5s cubic-bezier(.16,1,.3,1)}.answer.wrong{animation:mk-shake .42s cubic-bezier(.16,1,.3,1)}@media(prefers-reduced-motion:reduce){.answer.correct,.answer.wrong{animation:none}}.play-mute{width:38px;height:38px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-secondary);border:1px solid var(--border);background:var(--surface);transition:border-color .14s ease,color .14s ease,background .14s ease}.play-mute:hover{background:var(--surface-2);color:var(--text-primary)}.play-mute.off{color:var(--text-muted)}.play-actions{display:flex;justify-content:center}.play-actions .btn{min-width:220px;padding:14px 26px;font-size:15px;font-family:var(--font-heading)}.play-actions--bar{flex-shrink:0;background:var(--surface);border-top:1px solid var(--border);padding:12px 16px calc(12px + env(safe-area-inset-bottom))}.play-actions--bar .btn{width:100%;min-width:0}.explain-box{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px 18px;display:flex;flex-direction:column;gap:6px}.explain-label{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;color:var(--warning);text-transform:uppercase;letter-spacing:.4px}.explain-text{font-size:14px;line-height:1.55;color:var(--text-secondary)}.explain-panel{display:flex;flex-direction:column;gap:12px}.explain-breakdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 18px;display:flex;flex-direction:column;gap:10px}.explain-bd-title{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}.bd-row{display:flex;align-items:flex-start;gap:9px}.bd-mark{flex-shrink:0;display:flex;margin-top:1px;color:var(--m-weak-bar)}.bd-row.ok .bd-mark{color:var(--m-master-bar)}.bd-body{display:flex;flex-direction:column;gap:2px;min-width:0}.bd-opt{font-size:13.5px;font-weight:600;color:var(--text-primary)}.bd-row.ok .bd-opt{color:var(--m-master-fg)}.bd-reason{font-size:13px;line-height:1.5;color:var(--text-secondary)}.play-segwrap{flex-shrink:0;padding:12px 16px 6px;background:var(--surface);border-bottom:1px solid var(--border)}.play-streak-mini{display:inline-flex;align-items:center;gap:5px;font-size:14px;font-weight:700;color:var(--flame)}.play-top-mini{display:inline-flex;align-items:center;gap:10px}.play-timer{position:relative;width:40px;height:40px;border-radius:999px;display:grid;place-items:center;flex-shrink:0;background:conic-gradient(var(--ring, var(--brand)) calc(var(--p, 100) * 1%),var(--border) 0);transition:background .3s linear}.play-timer:before{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:999px;background:var(--surface)}.play-timer span{position:relative;z-index:1;display:inline-flex;align-items:center;font-family:var(--font-heading);font-weight:800;font-size:14px;color:var(--text-primary)}.play-timer.danger{--ring: var(--m-weak-bar)}.play-timer.danger span{color:var(--m-weak-fg)}.play-timer.done{--ring: var(--m-master-bar)}.play-timer.done span{color:var(--m-master-fg)}.play-bookmark{width:32px;height:32px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-muted);border:1px solid var(--border);background:var(--surface);transition:border-color .14s ease,color .14s ease,background .14s ease}.play-bookmark:hover{border-color:var(--accent-amber);color:var(--accent-amber)}.play-bookmark.on{background:var(--m-med-bg);border-color:var(--accent-amber);color:var(--accent-amber)}.kbd-hints{display:flex;justify-content:center;gap:18px;font-size:12px;color:var(--text-muted);margin-top:2px}.kbd-hints span{display:inline-flex;align-items:center;gap:5px}.kbd{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 5px;border:1px solid var(--border-strong);border-bottom-width:2px;border-radius:5px;background:var(--surface);font-family:var(--font-body);font-size:11px;font-weight:700;color:var(--text-secondary)}@media(max-width:879px){.answers{grid-template-columns:1fr;gap:10px}.play-content{align-items:stretch;justify-content:flex-start;padding:14px 16px 18px}.question-text{font-size:20px}.question-card{padding:22px 18px}.play-meta{gap:10px}.lifelines{width:100%}.ll{flex:1;justify-content:center}.play-timer{width:34px;height:34px}.play-timer span{font-size:13px}.play-mute{width:34px;height:34px}}.otg-root{min-height:100vh;min-height:100dvh;height:100vh;height:100dvh;display:flex;flex-direction:column;background:var(--app-bg);overflow:hidden}.otg-topbar{flex-shrink:0;height:60px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px;gap:12px}.otg-exit{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:600;color:var(--text-secondary);padding:8px 12px;border-radius:8px}.otg-exit:hover{background:var(--surface-2);color:var(--text-primary)}.otg-title{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-heading);font-weight:700;font-size:14px;color:var(--text-primary);white-space:nowrap}.otg-pausebtn{width:38px;height:38px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-secondary);border:1px solid var(--border);background:var(--surface);transition:border-color .14s ease,color .14s ease,background .14s ease}.otg-pausebtn:hover{background:var(--surface-2);color:var(--text-primary)}.otg-pausebtn.on{background:var(--brand-soft);border-color:var(--brand);color:var(--brand)}.otg-content{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:22px 20px 28px}.otg-stage{width:100%;max-width:640px;display:flex;flex-direction:column;align-items:center;gap:14px}.otg-orb{position:relative;width:132px;height:132px;border-radius:999px;display:grid;place-items:center;margin-top:6px;flex-shrink:0}.otg-orb-core{position:relative;z-index:2;width:96px;height:96px;border-radius:999px;display:grid;place-items:center;color:#fff;background:var(--hero-gradient);box-shadow:var(--shadow-md);transition:background .25s ease}.otg-orb.listening .otg-orb-core{background:linear-gradient(140deg,#10b6a4,#0d9488)}.otg-orb.idle .otg-orb-core,.otg-orb.paused .otg-orb-core{background:linear-gradient(140deg,#94a3b8,#64748b)}.otg-orb.revealing .otg-orb-core{background:var(--surface);color:var(--text-primary);border:2px solid var(--border)}.otg-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:999px;border:2px solid var(--brand);opacity:0;z-index:1}.otg-orb.listening .otg-ring{border-color:var(--accent-teal)}.otg-orb.asking .otg-ring,.otg-orb.listening .otg-ring{animation:otg-pulse 1.8s ease-out infinite}.otg-ring.r2{animation-delay:.9s}@keyframes otg-pulse{0%{transform:scale(.75);opacity:.55}to{transform:scale(1.25);opacity:0}}@media(prefers-reduced-motion:reduce){.otg-ring{display:none}}.otg-status{font-family:var(--font-heading);font-weight:700;font-size:19px;color:var(--text-primary);text-align:center}.otg-caption{font-size:14px;color:var(--text-muted);font-style:italic;text-align:center;min-height:20px;max-width:100%}.otg-caption-hint{display:inline-block}.otg-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:center}.otg-meta .cat-chip{display:inline-flex;align-items:center;gap:7px;background:var(--brand-soft);color:var(--brand);border-radius:999px;padding:5px 12px;font-size:13px;font-weight:600}.otg-diff{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--text-muted);font-weight:500}.otg-question{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px 24px;font-family:var(--font-heading);font-weight:700;font-size:21px;line-height:1.35;color:var(--text-primary);text-align:center;box-shadow:var(--shadow-sm)}.otg-answers{width:100%;display:flex;flex-direction:column;gap:11px}.otg-answer{display:flex;align-items:center;gap:14px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:16px 18px;text-align:left;font-size:15.5px;color:var(--text-primary);width:100%;transition:border-color .14s ease,background .14s ease,opacity .2s ease}.otg-answer:hover:not(:disabled):not(.locked){border-color:var(--border-strong);background:var(--surface-2)}.otg-answer:disabled{cursor:default}.otg-letter{width:34px;height:34px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:var(--text-secondary);flex-shrink:0}.otg-answer-text{flex:1;min-width:0}.otg-answer-mark{margin-left:auto;flex-shrink:0}.otg-answer.correct{border-color:var(--m-master-bar);background:var(--success-soft)}.otg-answer.correct .otg-letter{background:var(--m-master-bar);color:#fff;border-color:var(--m-master-bar)}.otg-answer.wrong{border-color:var(--m-weak-bar);background:var(--m-weak-bg)}.otg-answer.wrong .otg-letter{background:var(--m-weak-bar);color:#fff;border-color:var(--m-weak-bar)}.otg-hints{display:inline-flex;align-items:center;gap:7px;flex-wrap:wrap;justify-content:center;font-size:12.5px;color:var(--text-muted);text-align:center;margin-top:2px}.otg-hints b{color:var(--text-secondary)}.otg-bar{flex-shrink:0;background:var(--surface);border-top:1px solid var(--border);padding:12px 16px calc(12px + env(safe-area-inset-bottom));display:flex;align-items:center;justify-content:center;gap:10px}.otg-bar .btn{padding:13px 18px;font-size:14px}.otg-bar-main{min-width:220px}.otg-bar-stop{margin-left:auto}.otg-intro{width:100%;max-width:560px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;padding-top:8px}.otg-intro-orb{width:96px;height:96px;border-radius:999px;display:grid;place-items:center;color:#fff;background:var(--hero-gradient);box-shadow:var(--shadow-lg);margin-bottom:4px}.otg-intro-title{font-family:var(--font-heading);font-weight:800;font-size:26px;color:var(--text-primary)}.otg-intro-sub{font-size:14.5px;line-height:1.55;color:var(--text-secondary);max-width:480px}.otg-cmd-grid{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:6px 0 4px}.otg-cmd{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 14px;font-size:13.5px;color:var(--text-secondary);text-align:left}.otg-cmd svg{color:var(--brand);flex-shrink:0}.otg-cmd b{color:var(--text-primary)}.otg-warn{width:100%;background:var(--m-weak-bg);color:var(--m-weak-fg);border-radius:var(--radius-md);padding:12px 14px;font-size:13px;line-height:1.5;text-align:left}.otg-note{width:100%;background:var(--surface-2);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 14px;font-size:13px;line-height:1.5;text-align:left}.otg-begin{margin-top:8px;min-width:200px;padding:14px 28px;font-size:15px;font-family:var(--font-heading)}.otg-intro-foot{font-size:12.5px;color:var(--text-muted)}@media(max-width:879px){.otg-question{font-size:18px;padding:18px}.otg-cmd-grid{grid-template-columns:1fr}.otg-orb{width:116px;height:116px}.otg-orb-core{width:84px;height:84px}.otg-bar-stop{margin-left:0}}.result-root{min-height:100vh;display:flex;flex-direction:column;background:var(--app-bg)}.result-topbar{height:64px;flex-shrink:0;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px}.result-topbar .rt-title{font-family:var(--font-heading);font-weight:700;font-size:15px;color:var(--text-primary)}.result-saved{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--success)}.result-scroll{flex:1;overflow-y:auto}.result-inner{max-width:920px;margin:0 auto;width:100%;padding:28px 32px 48px;display:flex;flex-direction:column;gap:20px}.result-banner{background:var(--hero-gradient);border-radius:var(--radius-lg);padding:28px 32px;display:flex;align-items:center;justify-content:space-between;gap:24px;color:#fff;box-shadow:var(--shadow-lg)}.result-banner-tag{align-self:flex-start;background:#ffffff26;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700;letter-spacing:1px}.result-score{font-family:var(--font-heading);font-weight:800;font-size:40px;margin:10px 0 6px;line-height:1}.result-score-sub{font-size:13.5px;color:#ffffffd9}.result-streak-chip{display:inline-flex;align-items:center;gap:7px;margin-top:12px;background:#ffffff26;border-radius:999px;padding:6px 12px;font-size:12.5px;font-weight:600}.result-trophy{width:76px;height:76px;border-radius:999px;background:#ffffff29;display:flex;align-items:center;justify-content:center;flex-shrink:0}.result-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.result-actions{display:flex;gap:12px;flex-wrap:wrap}.result-actions .btn{flex:1;min-width:160px}.review-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:4px}.review-head .rv-title{font-family:var(--font-heading);font-weight:700;font-size:17px;color:var(--text-primary)}.review-head .rv-sub{font-size:12.5px;color:var(--text-secondary);margin-top:2px}.review-toggle{display:flex;gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:4px}.review-toggle button{padding:7px 14px;border-radius:999px;font-size:13px;font-weight:600;color:var(--text-secondary)}.review-toggle button.on{background:var(--brand);color:#fff}.review-list{display:flex;flex-direction:column;gap:12px}.review-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px 18px;display:flex;flex-direction:column;gap:10px;border-left:3px solid var(--m-master-bar)}.review-item.wrong{border-left-color:var(--m-weak-bar);background:snow}.review-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.review-meta{display:flex;align-items:center;gap:10px;font-size:12.5px;color:var(--text-muted);flex-wrap:wrap}.review-meta .rm-num{font-weight:700;color:var(--text-secondary)}.review-top-actions{display:inline-flex;align-items:center;gap:8px;flex-shrink:0}.rv-bm{width:28px;height:28px;border-radius:7px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-muted);border:1px solid var(--border);background:var(--surface);transition:border-color .14s ease,color .14s ease,background .14s ease}.rv-bm:hover{border-color:var(--accent-amber);color:var(--accent-amber)}.rv-bm.on{background:var(--m-med-bg);border-color:var(--accent-amber);color:var(--accent-amber)}.review-q{font-weight:600;font-size:15px;color:var(--text-primary);line-height:1.4}.review-ans{display:flex;flex-direction:column;gap:4px;font-size:13px}.review-ans .ra{display:flex;align-items:center;gap:7px}.review-ans .ra.ok{color:var(--m-master-fg)}.review-ans .ra.bad{color:var(--m-weak-fg)}.res-badge{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700}.res-badge.ok{background:var(--success-soft);color:var(--m-master-fg)}.res-badge.bad{background:var(--m-weak-bg);color:var(--m-weak-fg)}@media(max-width:879px){.result-inner{padding:16px 16px 40px;gap:16px}.result-banner{padding:20px}.result-score{font-size:32px}.result-stats{grid-template-columns:1fr 1fr}.result-trophy{width:56px;height:56px}.result-actions .btn{min-width:0}.review-toggle button{padding:6px 11px;font-size:12.5px}}:root{--brand: #2563eb;--brand-dark: #1d4ed8;--brand-soft: #e7eefe;--accent-amber: #f59e0b;--accent-teal: #0d9488;--accent-violet: #7c3aed;--app-bg: #f4f6fb;--surface: #ffffff;--surface-2: #f8fafc;--border: #e7ebf2;--border-strong: #d3dae6;--text-primary: #0f172a;--text-secondary: #5a6b85;--text-muted: #677488;--text-on-dark: #eaf0fb;--text-on-dark-muted: #93a1bc;--sidebar-bg: #0f172a;--sidebar-hover: #1b2740;--sidebar-active: #2563eb;--success: #15a06b;--success-soft: #dbf5e9;--warning: #c2790b;--warning-soft: #fbefd3;--danger: #dc2626;--danger-soft: #fbe0e0;--m-new-bar: #cbd5e1;--m-new-bg: #eef1f6;--m-new-fg: #64748b;--m-weak-bar: #ef5350;--m-weak-bg: #fbe3e4;--m-weak-fg: #c5343a;--m-med-bar: #f59e0b;--m-med-bg: #fcebd6;--m-med-fg: #c26a06;--m-good-bar: #e3b008;--m-good-bg: #fbf1cf;--m-good-fg: #9a7b06;--m-master-bar: #22a36b;--m-master-bg: #dbf5e9;--m-master-fg: #0f8a5a;--teal-soft: #d6f1ed;--violet-soft: #ece6fb;--flame: #f2820c;--star-empty: #d7deea;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-pill: 999px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--font-body: "Inter", system-ui, -apple-system, sans-serif;--font-heading: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--sidebar-w: 248px;--content-max: 1216px;--hero-gradient: linear-gradient(116deg, #2f6bf2 30%, #1d4ed8 70%);--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 6px 20px rgba(15, 23, 42, .08);--shadow-lg: 0 18px 48px rgba(29, 78, 216, .28)}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font-body);background:var(--app-bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3,h4{margin:0;font-family:var(--font-heading)}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;padding:0}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}a{color:inherit;text-decoration:none}ul{margin:0;padding:0;list-style:none}:focus-visible{outline:2px solid var(--brand);outline-offset:2px}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#cdd5e3;border-radius:999px;border:3px solid transparent;background-clip:content-box}::-webkit-scrollbar-thumb:hover{background:#b6c0d3;background-clip:content-box}.app-root{height:100%}.font-heading{font-family:var(--font-heading)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:var(--radius-md);font-family:var(--font-body);font-size:14px;font-weight:600;padding:11px 18px;transition:background .15s ease,border-color .15s ease,transform .05s ease,box-shadow .15s ease,opacity .15s ease;white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{background:var(--brand-dark)}.btn-ghost{background:var(--surface);color:var(--text-primary);border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface-2);border-color:var(--border-strong)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{filter:brightness(.95)}.btn-sm{padding:8px 13px;font-size:13px;border-radius:var(--radius-sm)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.pill{display:inline-flex;align-items:center;gap:6px;border-radius:var(--radius-pill);font-size:12px;font-weight:700;padding:4px 11px}.divider{background:var(--border)}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:fadeUp .28s ease both}@keyframes pop{0%{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}:root{--mk-dur-fast: .14s;--mk-dur-base: .24s;--mk-dur-slow: .42s;--mk-dur-celebrate: .9s;--mk-ease-out: cubic-bezier(.16, 1, .3, 1);--mk-ease-spring: cubic-bezier(.34, 1.56, .64, 1);--mk-correct: #16a34a;--mk-correct-soft: #22c55e;--mk-wrong: #dc2626;--mk-gold: #f59e0b}@keyframes mk-pop-in{0%{opacity:0;transform:scale(.8)}60%{opacity:1;transform:scale(1.04)}to{opacity:1;transform:scale(1)}}@keyframes mk-fade-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-6px)}}@keyframes mk-row-in{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.mk-pop-in{animation:mk-pop-in var(--mk-dur-base) var(--mk-ease-spring) both}.mk-fade-out{animation:mk-fade-out var(--mk-dur-base) var(--mk-ease-out) both}.mk-row-in{animation:mk-row-in var(--mk-dur-base) var(--mk-ease-out) both}@keyframes mk-correct-glow{0%{box-shadow:0 0 #22c55e00;transform:scale(1)}30%{box-shadow:0 0 0 6px #22c55e59;transform:scale(1.03)}to{box-shadow:0 0 #22c55e00;transform:scale(1)}}@keyframes mk-check-draw{to{stroke-dashoffset:0}}.mk-correct{animation:mk-correct-glow var(--mk-dur-slow) var(--mk-ease-out) both;border-color:var(--mk-correct)!important}.mk-check-draw{stroke-dasharray:48;stroke-dashoffset:48;animation:mk-check-draw .38s var(--mk-ease-out) 80ms both}@keyframes mk-shake{0%,to{transform:translate(0)}15%{transform:translate(-8px)}30%{transform:translate(7px)}45%{transform:translate(-5px)}60%{transform:translate(4px)}75%{transform:translate(-2px)}}@keyframes mk-wrong-flash{0%{background-color:#dc262600}25%{background-color:#dc26262e}to{background-color:#dc262600}}.mk-wrong{animation:mk-shake var(--mk-dur-slow) var(--mk-ease-out) both,mk-wrong-flash var(--mk-dur-slow) ease-out both;border-color:var(--mk-wrong)!important}@keyframes mk-reveal{0%{filter:brightness(1)}50%{filter:brightness(1.25)}to{filter:brightness(1)}}.mk-reveal{animation:mk-reveal var(--mk-dur-slow) ease-in-out both}@keyframes mk-eliminate{0%{opacity:1;transform:scale(1)}to{opacity:.15;transform:scale(.96);filter:grayscale(1)}}.mk-eliminate{animation:mk-eliminate var(--mk-dur-base) var(--mk-ease-out) both}.mk-progress-fill{transition:width var(--mk-dur-slow) var(--mk-ease-out)}@keyframes mk-milestone-pulse{0%{transform:scale(1);background-color:var(--mk-gold)}40%{transform:scale(1.25);box-shadow:0 0 12px 3px #f59e0b99}to{transform:scale(1)}}.mk-milestone{animation:mk-milestone-pulse var(--mk-dur-slow) var(--mk-ease-spring) both}@keyframes mk-number-bump{0%{transform:translateY(0)}50%{transform:translateY(-4px) scale(1.08)}to{transform:translateY(0)}}.mk-number-bump{animation:mk-number-bump var(--mk-dur-base) var(--mk-ease-spring) both}@keyframes mk-badge-in{0%{opacity:0;transform:scale(.4) rotate(-12deg)}60%{opacity:1;transform:scale(1.12) rotate(4deg)}to{opacity:1;transform:scale(1) rotate(0)}}.mk-badge-in{animation:mk-badge-in .52s var(--mk-ease-spring) both}@keyframes mk-sparkle{0%{opacity:0;transform:scale(.4) rotate(0)}50%{opacity:1;transform:scale(1) rotate(90deg)}to{opacity:0;transform:scale(.4) rotate(180deg)}}.mk-sparkle{animation:mk-sparkle .7s ease-in-out both}@keyframes mk-confetti-fall{0%{opacity:1;transform:translateZ(0) rotate(0)}to{opacity:.9;transform:translate3d(var(--mk-x, 0),var(--mk-y, 120px),0) rotate(var(--mk-r, 360deg))}}.mk-confetti-piece{position:fixed;top:0;left:0;width:10px;height:14px;pointer-events:none;z-index:9999;will-change:transform,opacity;animation:mk-confetti-fall var(--mk-confetti-dur, 1.6s) var(--mk-ease-out) forwards}@keyframes mk-mastery-pulse{0%{box-shadow:0 0 #22c55e80}70%{box-shadow:0 0 0 14px #22c55e00}to{box-shadow:0 0 #22c55e00}}.mk-mastery{animation:mk-mastery-pulse var(--mk-dur-celebrate) var(--mk-ease-out) both}@keyframes mk-toast-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.mk-toast-in{animation:mk-toast-in var(--mk-dur-base) var(--mk-ease-out) both}@keyframes mk-save-spin{to{transform:rotate(360deg)}}.mk-saving{animation:mk-save-spin .8s linear infinite}.mk-input-error{animation:mk-shake var(--mk-dur-base) var(--mk-ease-out) both;border-color:var(--mk-wrong)!important}@media(prefers-reduced-motion:reduce){.mk-pop-in,.mk-fade-out,.mk-row-in,.mk-correct,.mk-wrong,.mk-reveal,.mk-eliminate,.mk-milestone,.mk-number-bump,.mk-badge-in,.mk-sparkle,.mk-confetti-piece,.mk-mastery,.mk-toast-in,.mk-input-error{animation-duration:1ms!important;animation-iteration-count:1!important}.mk-saving{animation-duration:1.2s}.mk-check-draw{stroke-dashoffset:0;animation:none}}
