*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#4f8ef7;--primary-dark:#2563eb;--secondary:#f76b4f;--secondary-dark:#e05a3e;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--bg:#f0f4ff;--card:#fff;--border:#e2e8f0;--text:#1e293b;--muted:#64748b;--radius:14px;--shadow:0 2px 16px #4f8ef71f;--upper-color:#4f8ef7;--lower-color:#f76b4f}html,body{background:var(--bg);overscroll-behavior:none;width:100%;height:100%;margin:0;padding:0;overflow-x:hidden}body{color:var(--text);min-height:100vh;font-family:PingFang SC,Microsoft YaHei,sans-serif}button{cursor:pointer;border:none;outline:none;font-family:inherit}input{outline:none;font-family:inherit}.app{flex-direction:column;min-height:100vh;display:flex}.topbar{color:#fff;width:100%;padding:0;padding-top:constant(safe-area-inset-top);padding-top:env(safe-area-inset-top,44px);z-index:100;background:linear-gradient(135deg,#4f8ef7,#6366f1);position:sticky;top:0;box-shadow:0 2px 12px #4f8ef74d}.topbar-content{justify-content:space-between;align-items:center;width:100%;max-width:1000px;height:60px;margin:0 auto;padding:0 24px;display:flex}@media (max-width:600px){.topbar-content{height:52px;padding:0}.topbar-title{font-size:16px}}.topbar-title{letter-spacing:.5px;font-size:18px;font-weight:700}.topbar-title span{opacity:.8;margin-left:6px;font-size:14px;font-weight:400}.topbar-right{align-items:center;gap:12px;display:flex}.student-badge{cursor:pointer;background:#fff3;border:1px solid #ffffff4d;border-radius:20px;padding:6px 14px;font-size:13px;transition:background .2s}.student-badge:hover{background:#ffffff4d}.main{padding:24px;padding-top:env(safe-area-inset-top,24px);padding-bottom:calc(80px + env(safe-area-inset-bottom,0px));flex:1;width:100%;max-width:1000px;margin:0 auto}@media (max-width:600px){.main{padding:12px;padding-bottom:calc(70px + env(safe-area-inset-bottom,0px))}}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}.card+.card{margin-top:16px}.card-title{align-items:center;gap:8px;margin-bottom:16px;font-size:16px;font-weight:700;display:flex}.btn{white-space:nowrap;border-radius:10px;justify-content:center;align-items:center;gap:6px;padding:9px 20px;font-size:14px;font-weight:600;transition:all .18s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px)}.btn-secondary{background:var(--secondary);color:#fff}.btn-secondary:hover{background:var(--secondary-dark);transform:translateY(-1px)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-ghost{color:var(--muted);border:1.5px solid var(--border);background:0 0}.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}.btn-sm{border-radius:8px;padding:6px 14px;font-size:13px}.btn-lg{border-radius:12px;padding:13px 28px;font-size:16px}.welcome-hero{text-align:center;padding:48px 0 32px}.welcome-hero .emoji{margin-bottom:16px;font-size:64px;display:block}.welcome-hero h1{color:var(--primary);margin-bottom:8px;font-size:28px;font-weight:800}.welcome-hero p{color:var(--muted);font-size:15px}.student-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-top:20px;display:grid}.student-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);text-align:center;border:2px solid #0000;padding:24px 16px;transition:all .2s;position:relative}.student-card:hover{border-color:var(--primary);transform:translateY(-2px)}.student-card.active{border-color:var(--primary);background:#eff6ff}.sc-main{cursor:pointer}.student-avatar{margin-bottom:10px;font-size:40px}.student-name{margin-bottom:4px;font-size:15px;font-weight:700}.student-sub{color:var(--muted);font-size:12px}.sc-current-badge{background:var(--primary);color:#fff;border-radius:6px;margin-top:6px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-block}.sc-delete-btn{cursor:pointer;width:26px;height:26px;color:var(--muted);opacity:0;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:6px;right:6px}.student-card:hover .sc-delete-btn{opacity:1}.sc-delete-btn:hover{color:var(--danger);background:#ef44441a}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay.hidden{display:none}.modal{background:#fff;border-radius:20px;width:380px;max-width:95vw;padding:32px;box-shadow:0 8px 40px #0003}.modal h2{text-align:center;margin-bottom:20px;font-size:20px;font-weight:800}.form-row{margin-bottom:16px}.form-row label{color:var(--muted);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-row input{border:2px solid var(--border);border-radius:10px;width:100%;padding:10px 14px;font-size:15px;transition:border .2s}.form-row input:focus{border-color:var(--primary)}.avatar-grid{flex-wrap:wrap;gap:8px;margin-top:6px;display:flex}.avatar-opt{background:var(--bg);cursor:pointer;border:2px solid #0000;border-radius:10px;justify-content:center;align-items:center;width:44px;height:44px;font-size:24px;transition:all .15s;display:flex}.avatar-opt.selected{border-color:var(--primary);background:#eff6ff}.avatar-opt:hover{transform:scale(1.1)}.stats-row{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;display:grid}.stat-card{background:var(--card);box-shadow:var(--shadow);text-align:center;border-radius:12px;padding:16px}.stat-num{color:var(--primary);font-size:28px;font-weight:800}.stat-label{color:var(--muted);margin-top:4px;font-size:12px}.progress-bar-wrap{background:var(--border);border-radius:100px;height:8px;margin-top:4px;overflow:hidden}.progress-bar{background:linear-gradient(90deg,var(--primary),#818cf8);border-radius:100px;height:100%;transition:width .5s}.book-tabs{gap:10px;margin-bottom:20px;display:flex}.book-tab{background:var(--card);border:2px solid var(--border);color:var(--muted);cursor:pointer;border-radius:10px;padding:9px 22px;font-size:14px;font-weight:600;transition:all .2s}.book-tab.active-upper{border-color:var(--upper-color);color:var(--upper-color);background:#eff6ff}.book-tab.active-lower{border-color:var(--lower-color);color:var(--lower-color);background:#fff3ef}.lesson-list{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;display:grid}.lesson-item{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;border:2px solid #0000;padding:18px;transition:all .2s;position:relative;overflow:hidden}.lesson-item:hover{transform:translateY(-3px);box-shadow:0 6px 24px #4f8ef72e}.lesson-item.upper:hover{border-color:var(--upper-color)}.lesson-item.lower:hover{border-color:var(--lower-color)}.lesson-num{color:var(--primary);margin-bottom:6px;font-size:24px;font-weight:800}.lesson-item.lower .lesson-num{color:var(--secondary)}.lesson-title{margin-bottom:8px;font-size:14px;font-weight:700;line-height:1.4}.lesson-meta{color:var(--muted);margin-bottom:8px;font-size:12px}.lesson-progress{font-size:12px}.lesson-score-badge{background:var(--success);color:#fff;border-radius:6px;padding:3px 8px;font-size:11px;font-weight:700;position:absolute;top:12px;right:12px}.lesson-score-badge.low{background:var(--warning)}.lesson-score-badge.fail{background:var(--danger)}.lesson-hero{color:#fff;min-height:200px;padding:40px 28px 36px;position:relative;overflow:hidden}.lesson-hero-bg{pointer-events:none;position:absolute;inset:0;overflow:hidden}.hero-bubble{background:#ffffff14;border-radius:50%;animation:6s ease-in-out infinite hero-float;position:absolute}@keyframes hero-float{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-18px)scale(1.1)}}.lesson-hero-content{z-index:1;position:relative}.hero-top-row{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.hero-back-btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;background:#ffffff2e;border:1px solid #ffffff40;border-radius:10px;align-items:center;gap:6px;padding:7px 16px;font-size:13px;font-weight:600;transition:all .2s;display:inline-flex}.hero-back-btn:hover{background:#ffffff4d}.hero-tag{letter-spacing:1px;text-transform:uppercase;background:#fff3;border-radius:8px;margin-bottom:10px;padding:4px 14px;font-size:12px;font-weight:700;display:inline-block}.hero-title{margin-bottom:6px;font-size:28px;font-weight:800;line-height:1.3}.hero-book-label{opacity:.75;align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.lesson-stats{z-index:2;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:-24px;padding:0 24px;display:grid;position:relative}.lstat-card{background:#fff;border-radius:14px;align-items:center;gap:12px;padding:16px;transition:transform .2s;display:flex;box-shadow:0 2px 16px #00000014}.lstat-card:hover{transform:translateY(-2px)}.lstat-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.lstat-info{flex:1;min-width:0}.lstat-num{color:var(--text);font-size:20px;font-weight:800;line-height:1.2}.lstat-label{color:var(--muted);margin-top:2px;font-size:12px;font-weight:500}.lesson-overall-progress{background:#fff;border-radius:14px;margin:20px 24px 0;padding:16px 20px;box-shadow:0 2px 12px #0000000f}.lop-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.lop-title{color:var(--text);font-size:13px;font-weight:700}.lop-pct{color:var(--primary);font-size:14px;font-weight:800}.lop-bar{background:#e2e8f0;border-radius:100px;height:8px;overflow:hidden}.lop-fill{border-radius:100px;height:100%;transition:width .8s cubic-bezier(.16,1,.3,1)}.lesson-content{padding:20px 24px 0}.section-title{color:var(--text);align-items:center;gap:8px;margin-bottom:16px;font-size:17px;font-weight:800;display:flex}.kp-section{border-top:3px solid var(--upper-color);background:#fff;border-radius:16px;padding:24px;box-shadow:0 2px 12px #0000000f}.kp-section.lower{border-top-color:var(--lower-color)}.kp-header{align-items:center;gap:10px;margin-bottom:16px;display:flex}.kp-icon-wrap{width:36px;height:36px;color:var(--upper-color);background:linear-gradient(135deg,#eff6ff,#f0f4ff);border-radius:10px;justify-content:center;align-items:center;display:flex}.kp-section.lower .kp-icon-wrap{color:var(--lower-color);background:linear-gradient(135deg,#fff3ef,#fff8f6)}.kp-header h3{color:var(--text);font-size:16px;font-weight:700}.kp-list{padding:0;list-style:none}.kp-item{background:var(--bg);color:var(--text);border-radius:10px;margin-bottom:8px;padding:10px 14px 10px 32px;font-size:14px;line-height:1.6;position:relative}.kp-item:before{content:"";background:var(--upper-color);border-radius:50%;width:6px;height:6px;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.kp-section.lower .kp-item:before{background:var(--lower-color)}.kp-item:last-child{margin-bottom:0}.kp-empty{text-align:center;color:var(--muted);padding:24px 0}.kp-empty-icon{margin-bottom:8px;font-size:32px}.kp-empty p{font-size:14px}.kp-content{flex-direction:column;gap:16px;display:flex}.kp-image-wrap{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:8px;overflow:hidden}.kp-image{object-fit:contain;border-radius:8px;width:100%;height:auto;max-height:600px;display:block}.ex-list{flex-direction:column;gap:14px;display:flex}.ex-card{background:#fff;border:1px solid #e2e8f099;border-radius:14px;transition:all .2s;display:flex;overflow:hidden;box-shadow:0 1px 6px #0000000a}.ex-card:hover{box-shadow:0 2px 12px #00000014}.ex-card.done{border-color:#10b9814d}.ex-card.partial{border-color:#f59e0b4d}.ex-accent{flex-shrink:0;width:3px;transition:background .2s}.ex-card-main{flex:1;min-width:0}.ex-card-top{justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.ex-card-left{cursor:pointer;flex:1;min-width:0}.ex-card-title{color:var(--text);align-items:center;gap:10px;margin-bottom:8px;font-size:15px;font-weight:700;line-height:1.4;display:flex}.ex-card-meta{color:var(--muted);align-items:center;gap:10px;font-size:12px;font-weight:400;display:flex}.ex-type-tag{white-space:nowrap;opacity:.85;border-radius:5px;align-items:center;gap:3px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.ex-score{font-weight:700}.ex-score.done{color:var(--success)}.ex-score.partial{color:var(--warning)}.ex-qcount{color:var(--muted);font-weight:400}.ex-card-right{flex-shrink:0;align-items:center;margin-left:12px;display:flex}.ex-start-btn{color:#fff;white-space:nowrap;border-radius:10px;align-items:center;gap:4px;padding:8px 16px;font-size:13px;font-weight:700;text-decoration:none;transition:all .2s;display:inline-flex}.ex-start-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4f8ef74d}.ex-detail{border-top:0 solid var(--border);max-height:0;transition:max-height .3s ease-out;overflow:hidden}.ex-detail.open{border-top-width:1px;max-height:none}.ex-detail-empty{text-align:center;color:var(--muted);padding:24px 20px}.ex-detail-empty-icon{margin-bottom:6px;font-size:28px}.ex-detail-empty p{font-size:13px}.lesson-header{align-items:center;gap:12px;margin-bottom:20px;display:flex}.quiz-title-bar{border-bottom:1px solid #e2e8f0cc;justify-content:space-between;align-items:center;margin-top:24px;margin-bottom:28px;padding:12px 0 20px;display:flex}@media (max-width:600px){.quiz-title-bar{margin-top:16px;margin-bottom:20px;padding:8px 0 16px}}.quiz-title-left{flex-direction:column;flex:1;gap:0;min-width:0;display:flex}.quiz-title-main,.lesson-heading{color:var(--text);text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.02em;font-size:22px;font-weight:850;line-height:1.2;overflow:hidden}.quiz-title-sub{color:var(--primary);text-transform:uppercase;letter-spacing:.1em;font-size:11px;font-weight:700;line-height:1.5}.back-btn{background:var(--bg);color:var(--muted);cursor:pointer;border:none;border-radius:10px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.back-btn:hover{color:var(--primary);background:#fff;box-shadow:0 2px 8px #4f8ef71a}.back-btn span{font-size:16px;transition:transform .2s}.back-btn:hover span{transform:translate(-3px)}.lesson-num-tag{background:var(--primary);color:#fff;vertical-align:middle;letter-spacing:.3px;border-radius:6px;margin-right:8px;padding:2px 8px;font-size:12px;font-weight:700;display:inline-block}.lesson-num-tag.lower{background:var(--secondary)}.exercise-list{flex-direction:column;gap:14px;display:flex}.exercise-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.exercise-header{cursor:pointer;border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.exercise-header:hover{background:var(--bg)}.exercise-title-wrap{align-items:center;gap:10px;display:flex}.exercise-status{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex}.exercise-status.done{color:var(--success);background:#d1fae5}.exercise-status.partial{color:var(--warning);background:#fef3c7}.exercise-status.todo{background:var(--bg);color:var(--muted)}.exercise-name{font-size:14px;font-weight:700}.exercise-score-info{color:var(--muted);font-size:12px}.exercise-body{padding:20px;display:none}.exercise-body.open{display:block}.quiz-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.quiz-progress-text{color:var(--muted);white-space:nowrap;text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:700}.quiz-progress-bar{background:var(--border);border-radius:100px;flex:1;height:5px;margin:0 12px;overflow:hidden}.quiz-progress-fill{background:linear-gradient(90deg,var(--primary),#818cf8);border-radius:100px;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.page-indicator{background:var(--card);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:16px;padding:10px 14px;display:flex}.group-nav{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:6px;padding:12px 0;display:flex;overflow-x:auto}.group-nav::-webkit-scrollbar{display:none}.group-nav-item{border:1px solid var(--border);background:var(--card);cursor:pointer;border-radius:12px;flex-direction:column;flex-shrink:0;align-items:center;gap:2px;min-width:60px;padding:10px 14px;transition:all .2s;display:flex;box-shadow:0 1px 2px #00000005}.group-nav-item:hover:not(:disabled){border-color:var(--primary);background:#4f8ef705;transform:translateY(-1px)}.group-nav-item.active{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #4f8ef714,0 4px 6px #4f8ef70d}.group-nav-item.done{border-color:var(--success);background:#10b98105}.group-nav-item.done.active{border-color:var(--primary)}.group-nav-item:disabled{cursor:default;opacity:.8}.group-nav-num{color:var(--text);font-size:16px;font-weight:700}.group-nav-item.done .group-nav-num{color:var(--success)}.group-nav-label{color:var(--muted);white-space:nowrap;font-size:11px}.group-nav-item.done .group-nav-label{color:var(--success)}.page-info{color:var(--muted);font-size:13px;font-weight:500}.page-btn{border:1.5px solid var(--border);cursor:pointer;color:var(--text);background:#fff;border-radius:8px;padding:5px 14px;font-size:13px;font-weight:600}.page-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.page-btn:disabled{opacity:.35;cursor:not-allowed}.page-nav-bottom{flex-wrap:wrap;justify-content:center;gap:12px;padding:16px 0;display:flex}.blank-line{vertical-align:text-bottom;border-bottom:1.5px solid var(--text);height:1em;display:inline-block}.ib-correct{border-color:var(--success)!important;color:var(--success)!important;background:#22c55e14!important}.ib-wrong{border-color:var(--danger)!important;color:var(--danger)!important;background:#ef444414!important}.reading-card{padding:20px!important}.reading-passage{color:var(--text);text-align:left;word-break:break-word;padding:16px 0;font-size:15px;line-height:2.2}.reading-blank-wrap{vertical-align:middle;align-items:center;gap:3px;margin:0 2px;display:inline-flex}.blank-num{color:var(--muted);text-align:center;min-width:16px;font-size:11px;font-weight:700}.reading-blank{text-align:center;border-width:1.5px!important;border-radius:6px!important;width:110px!important;padding:4px 8px!important;font-size:14px!important}.reading-blank.correct{border-color:var(--success)!important;color:var(--success)!important;background:#22c55e14!important}.reading-blank.wrong{border-color:var(--danger)!important;color:var(--danger)!important;background:#ef444414!important}.reading-correct-ans{color:var(--success);white-space:nowrap;font-size:12px;font-weight:600}.question-card{background:0 0;border-bottom:1px solid #e2e8f099;margin-bottom:0;padding:16px 0;transition:all .2s}.question-card:last-of-type{border-bottom:none}.question-card.correct{border:2px solid var(--success);border-bottom-color:var(--success);background:#10b98108;border-radius:12px;padding-left:12px;padding-right:12px}.question-card.wrong{border:2px solid var(--danger);border-bottom-color:var(--danger);background:#ef444408;border-radius:12px;padding-left:12px;padding-right:12px}.q-num{color:var(--muted);margin-bottom:4px;font-size:12px;font-weight:600}.q-image{text-align:center;margin:8px 0 12px}.q-image img{border:1px solid var(--border);object-fit:contain;border-radius:8px;max-width:100%;max-height:200px}.q-text{margin-bottom:8px;font-size:15px;font-weight:600;line-height:1.8}.q-text>div{margin-bottom:2px}.q-text>div:last-child{margin-bottom:0}.q-hint{color:var(--muted);margin-top:4px;font-size:13px;font-weight:500}.q-hint-inline{color:var(--muted);margin-left:4px;font-size:13px;font-weight:500}.q-input{border:2px solid var(--border);background:#fff;border-radius:8px;width:100%;padding:10px 14px;font-size:15px;transition:border .2s}.q-input:focus{border-color:var(--primary)}.q-input.correct{border-color:var(--success);background:#f0fdf4}.q-input.wrong{border-color:var(--danger);background:#fff5f5}.options-grid{flex-wrap:wrap;gap:8px;display:flex}.opt-btn{border:2px solid var(--border);cursor:pointer;background:#fff;border-radius:8px;padding:9px 18px;font-size:14px;font-weight:600;transition:all .15s}.opt-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.opt-btn.selected{border-color:var(--primary);color:var(--primary);background:#eff6ff}.opt-btn.correct{border-color:var(--success);color:var(--success);pointer-events:none;background:#d1fae5}.opt-btn.wrong-sel{border-color:var(--danger);color:var(--danger);pointer-events:none;background:#fee2e2}.opt-btn:disabled{opacity:.7;cursor:not-allowed}.word-choice{flex-direction:column;gap:12px;margin-top:8px;display:flex}.wc-blank-label{color:var(--text-secondary);margin-bottom:2px;font-size:13px;font-weight:600}.tf-opts{gap:12px;display:flex}.tf-opt{text-align:center;border:2px solid var(--border);cursor:pointer;background:#fff;border-radius:10px;flex:1;padding:12px;font-size:15px;font-weight:700;transition:all .15s}.tf-opt:hover:not(:disabled){transform:scale(1.04)}.tf-opt.T-sel{border-color:var(--success);color:var(--success);background:#d1fae5}.tf-opt.F-sel{border-color:var(--danger);color:var(--danger);background:#fee2e2}.tf-opt.correct{border-color:var(--success);background:#d1fae5}.tf-opt.wrong-sel{border-color:var(--danger);background:#fee2e2}.feedback{margin-top:8px;font-size:13px;font-weight:600}.feedback.ok{color:var(--success)}.feedback.err{color:var(--danger)}.feedback .correct-ans{font-weight:800}.error-correction{margin-top:8px}.ec-labels{gap:12px;margin-bottom:8px;display:flex}.ec-label{color:var(--muted);text-align:center;background:var(--bg);border-radius:8px;flex:1;padding:4px 0;font-size:12px;font-weight:700}.ec-inputs{align-items:center;gap:10px;display:flex}.ec-input{text-align:center;flex:1}.ec-arrow{color:var(--muted);flex-shrink:0;font-size:18px;font-weight:700}.ec-feedback{margin-top:8px}.yes-no-question{flex-direction:column;gap:4px;margin-top:8px;display:flex}.yn-label{color:var(--muted);margin-bottom:2px;font-size:13px;font-weight:600}.yn-input{box-sizing:border-box;width:100%}.result-screen{text-align:center;padding:32px 0}.result-emoji{margin-bottom:16px;font-size:80px}.result-title{margin-bottom:8px;font-size:26px;font-weight:800}.result-sub{color:var(--muted);margin-bottom:28px;font-size:16px}.result-score-ring{width:140px;height:140px;color:var(--primary);background:conic-gradient(var(--primary) var(--pct), var(--border) 0);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 28px;font-size:40px;font-weight:800;display:flex;position:relative}.result-score-ring:before{content:"";background:#fff;border-radius:50%;position:absolute;inset:16px}.result-score-ring span{z-index:1;position:relative}.wrong-review{text-align:left;background:var(--bg);border-radius:var(--radius);margin:20px 0;padding:20px}.wrong-review h4{color:var(--danger);margin-bottom:12px;font-size:14px;font-weight:700}.wrong-item{border-left:3px solid var(--danger);background:#fff;border-radius:10px;margin-bottom:8px;padding:10px;font-size:13px;line-height:1.6}.wrong-item .ans-row{color:var(--success);margin-top:4px;font-weight:700}.progress-hero{text-align:center;background:linear-gradient(135deg,#6366f1,#4f8ef7);padding:28px 24px 24px}.progress-hero-emoji{margin-bottom:6px;font-size:36px}.progress-hero-title{color:#fff;margin:0 0 4px;font-size:22px;font-weight:800}.progress-hero-sub{color:#fffc;font-size:13px;font-weight:500}.progress-stats-row{z-index:2;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:-18px;padding:0 24px;display:grid;position:relative}.pstat-card{text-align:center;background:#fff;border-radius:12px;padding:14px 8px;box-shadow:0 2px 12px #00000014}.pstat-num{color:var(--text);font-size:20px;font-weight:800;line-height:1.2}.pstat-label{color:var(--muted);margin-top:2px;font-size:11px;font-weight:600}.progress-overall-bar{padding:16px 24px 0}.pob-track{background:var(--border);border-radius:100px;height:6px;overflow:hidden}.pob-fill{background:linear-gradient(90deg,#6366f1,#4f8ef7);border-radius:100px;height:100%;transition:width .8s cubic-bezier(.16,1,.3,1)}.progress-book-section{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);margin:16px 24px 0;overflow:hidden}.progress-book-header{align-items:center;gap:12px;padding:18px 20px 0;display:flex}.progress-book-icon{font-size:28px}.progress-book-info{flex:1;min-width:0}.progress-book-name{font-size:16px;font-weight:700}.progress-book-sub{color:var(--muted);margin-top:2px;font-size:12px}.progress-book-pct{font-size:22px;font-weight:800}.progress-book-stats{gap:0;padding:12px 20px 14px;display:flex}.pbs-item{text-align:center;flex:1}.pbs-val{color:var(--text);font-size:16px;font-weight:700}.pbs-lbl{color:var(--muted);margin-top:1px;font-size:11px}.progress-lesson-list{padding:0 8px 8px}.progress-lesson-row{color:inherit;cursor:pointer;border-radius:12px;align-items:center;gap:12px;margin:0 0 2px;padding:12px;text-decoration:none;transition:background .15s;display:flex}.progress-lesson-row:hover{background:#6366f10f}.progress-lesson-row:last-child{margin-bottom:0}.progress-lesson-row:active{background:#6366f11a}.plr-status-dot{background:var(--border);color:#0000;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;font-weight:700;display:flex}.plr-status-dot.done{background:var(--success);color:#fff}.plr-status-dot.partial{background:var(--warning);color:#fff}.plr-left{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.plr-info{flex:1;min-width:0}.plr-name{color:var(--text);align-items:baseline;gap:6px;font-size:13px;font-weight:600;line-height:1.4;display:flex}.plr-num{color:var(--muted);flex-shrink:0;font-size:11px;font-weight:700}.plr-meta{margin-top:1px}.plr-score{font-size:11px;font-weight:600}.plr-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.plr-bar-wrap{background:var(--border);border-radius:100px;width:48px;height:5px;overflow:hidden}.plr-bar{border-radius:100px;height:100%;transition:width .5s}.plr-go{color:var(--muted);justify-content:center;align-items:center;display:flex}.progress-lesson-row:hover .plr-go{color:var(--primary)}@media (max-width:600px){.stats-row{grid-template-columns:repeat(2,1fr)}.main{padding:16px}.topbar{padding:0 16px}.lesson-list{grid-template-columns:1fr 1fr}.lesson-stats{grid-template-columns:repeat(2,1fr);gap:10px;margin-top:-18px;padding:0 16px}.lesson-hero{padding:16px}.hero-title{font-size:22px}.lstat-card{padding:12px}.lstat-num{font-size:17px}.lstat-icon{width:36px;height:36px}.lesson-content{padding:16px 16px 0}.lesson-overall-progress{margin:16px 16px 0}.ex-card-top{padding:14px 16px}.ex-start-btn{padding:7px 14px;font-size:12px}.progress-hero{padding:24px 18px 20px}.progress-stats-row{grid-template-columns:repeat(2,1fr);gap:8px;margin-top:-14px;padding:0 16px}.pstat-num{font-size:18px}.progress-book-section{margin:14px 16px 0}.progress-book-header{padding:14px 16px 0}.progress-book-stats{padding:10px 16px 12px}.plr-name{font-size:12px}.progress-hero-title{font-size:20px}}.bottom-nav{border-top:1px solid var(--border);z-index:900;padding-bottom:calc(constant(safe-area-inset-bottom) + 5px);padding-bottom:calc(env(safe-area-inset-bottom,0px) + 5px);background:#fff;justify-content:space-around;align-items:stretch;display:flex;position:fixed;bottom:-5px;left:0;right:0;box-shadow:0 -8px 24px #0000001f}.nav-item{height:65px;color:var(--muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;font-size:11px;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.bottom-nav .nav-item{border-radius:0;margin:0}.nav-item.active{color:var(--primary);background:#4f8ef70d}.nav-icon{font-size:22px;transition:transform .2s}.nav-item.active .nav-icon{transform:scale(1.1)translateY(-2px)}@media (max-width:600px){.nav-item{height:56px;font-size:10px}.nav-icon{font-size:20px}}@keyframes pop{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.pop-in{animation:.25s ease-out pop}@keyframes confetti-fall{0%{opacity:1;transform:translateY(-20px)rotate(0)}to{opacity:0;transform:translateY(100px)rotate(720deg)}}.confetti-piece{pointer-events:none;z-index:999;font-size:20px;animation:1.2s ease-in forwards confetti-fall;position:fixed}.empty-state{text-align:center;color:var(--muted);padding:48px 0}.empty-state .emoji{margin-bottom:12px;font-size:48px;display:block}
