.stu-app{max-width:480px;margin:0 auto;min-height:100vh;background:#f5f6f8;display:flex;flex-direction:column;position:relative}.stu-body{flex:1;display:flex;flex-direction:column}.stu-tabbar{position:sticky;bottom:0;display:flex;background:#fff;border-top:1px solid var(--border);height:56px}.stu-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:11px;color:var(--muted);text-decoration:none}.stu-tab.active{color:var(--primary)}.stu-tab-icon{font-size:20px}.stu-page{padding:20px 16px 24px}.stu-header{margin-bottom:18px}.stu-greeting{font-size:22px;font-weight:700;color:var(--text)}.stu-subtitle{font-size:13px;color:var(--muted);margin-top:4px}.stu-empty{padding:60px 20px;text-align:center;color:var(--muted)}.stu-banner-err{background:#fef2f2;color:var(--danger);padding:10px 12px;border-radius:8px;font-size:13px;margin:10px 0}.stu-btn-primary{width:100%;padding:13px;border:none;border-radius:10px;background:var(--primary);color:#fff;font-size:15px;font-weight:600;cursor:pointer}.stu-btn-primary:disabled{opacity:.6}.stu-btn-secondary{width:100%;padding:12px;border:1px solid var(--border);border-radius:10px;background:#fff;color:var(--text);font-size:14px;cursor:pointer}.stu-login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#2563eb,#1e40af);padding:20px}.stu-login-card{background:#fff;border-radius:18px;padding:36px 28px;width:100%;max-width:360px;text-align:center}.stu-login-logo{font-size:48px}.stu-login-card h1{font-size:20px;margin:12px 0 6px}.stu-login-sub{font-size:13px;color:var(--muted);margin-bottom:22px}.stu-login-input{width:100%;padding:13px;border:1px solid var(--border);border-radius:10px;font-size:18px;text-align:center;letter-spacing:3px;margin-bottom:12px;text-transform:uppercase}.stu-login-err{color:var(--danger);font-size:13px;margin-bottom:12px}.stu-subject-list{display:flex;flex-direction:column;gap:12px}.stu-subject-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:16px;text-align:left;cursor:pointer;width:100%}.stu-subject-card:active{background:#f0f2f5}.stu-subject-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.stu-subject-name{font-size:16px;font-weight:600}.stu-badge-due{background:#fef2f2;color:var(--danger);font-size:11px;padding:2px 8px;border-radius:10px;font-weight:600}.stu-progress-bar{height:6px;background:#eef0f3;border-radius:3px;overflow:hidden}.stu-progress-fill{height:100%;background:var(--primary);border-radius:3px}.stu-subject-meta{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-top:8px}.stu-session{min-height:100vh;display:flex;flex-direction:column;background:#f5f6f8;padding:12px 16px 20px;position:relative}.stu-session-center{align-items:center;justify-content:center;text-align:center;gap:6px}.stu-session-center h2{font-size:20px}.stu-session-center .stu-btn-primary{max-width:240px;margin-top:16px}.stu-finish-emoji{font-size:60px}.stu-session-top{display:flex;align-items:center;gap:12px;margin-bottom:16px}.stu-close{border:none;background:none;font-size:20px;color:var(--muted);cursor:pointer;padding:4px;line-height:1}.stu-session-progress{flex:1;height:6px;background:#e3e5e9;border-radius:3px;overflow:hidden}.stu-session-progress-fill{height:100%;background:var(--primary);border-radius:3px;transition:width .2s}.stu-session-count{font-size:12px;color:var(--muted);min-width:44px;text-align:right}.stu-card-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding-top:20px}.stu-card-tags{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;margin-bottom:20px}.stu-tag{font-size:11px;padding:2px 8px;border-radius:5px;background:#fff;color:var(--muted);border:1px solid var(--border)}.stu-tag.high{background:#fef2f2;color:var(--high);border-color:#f6cccc}.stu-tag.mid{background:#fffbeb;color:var(--mid);border-color:#f3ddb0}.stu-tag.low{background:#f0fdf4;color:var(--low);border-color:#bfe6c8}.stu-tag.new{background:#eef2ff;color:var(--primary);border-color:#c7d2fe}.stu-card-front{font-size:24px;font-weight:700;text-align:center;line-height:1.5;padding:20px 10px;color:var(--text)}.stu-show-btn{max-width:240px;margin-top:10px}.stu-card-back{width:100%;background:#fff;border:1px solid var(--border);border-radius:14px;padding:16px;margin-top:8px}.stu-card-back-label{font-size:12px;color:var(--muted);margin-bottom:8px}.stu-card-back-text{font-size:15px;line-height:1.8;color:var(--text);white-space:pre-wrap}.stu-card-mnemonic{margin-top:12px;padding:10px 12px;background:#fffbeb;border-radius:8px;font-size:13px;color:#92660b}.stu-rating-bar{display:flex;gap:10px;margin-top:16px}.stu-rating-btn{flex:1;padding:14px 0;border:none;border-radius:12px;font-size:15px;font-weight:600;color:#fff;cursor:pointer}.stu-rating-btn:disabled{opacity:.6}.stu-rating-btn.forgot{background:#ef4444}.stu-rating-btn.hard{background:#f59e0b}.stu-rating-btn.good{background:#16a34a}.stu-streak-card{background:linear-gradient(135deg,#2563eb,#1e40af);color:#fff;border-radius:16px;padding:24px;text-align:center;margin-bottom:14px}.stu-streak-num{font-size:44px;font-weight:800;line-height:1}.stu-streak-label{font-size:13px;opacity:.85;margin-top:6px}.stu-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}.stu-stat-box{background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px;text-align:center}.stu-stat-num{font-size:24px;font-weight:700;color:var(--primary)}.stu-stat-label{font-size:12px;color:var(--muted);margin-top:4px}.stu-section-title{font-size:14px;font-weight:600;margin:4px 0 10px}.stu-setting-chips{display:flex;gap:8px}.stu-setting-chip{flex:1;padding:10px 0;border:1px solid var(--border);border-radius:10px;background:#fff;font-size:14px;cursor:pointer;color:var(--text)}.stu-setting-chip.active{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600}.stu-setting-custom{display:flex;align-items:center;gap:8px;margin-top:10px;font-size:13px;color:var(--muted)}.stu-setting-custom input{width:72px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:14px;text-align:center;color:var(--text)}.stu-setting-custom button{margin-left:auto;padding:8px 16px;border:1px solid var(--primary);background:#fff;color:var(--primary);border-radius:8px;font-size:13px;font-weight:600;cursor:pointer}.stu-setting-custom button:disabled{opacity:.45;cursor:not-allowed}.stu-setting-hint{font-size:12px;color:var(--muted);margin:10px 0 4px;line-height:1.6}.stu-heatmap{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px}.stu-heat-cell{aspect-ratio:1;border-radius:3px;background:#ebedf0}.stu-heat-cell.l0{background:#ebedf0}.stu-heat-cell.l1{background:#b7d4f5}.stu-heat-cell.l2{background:#7eb0ec}.stu-heat-cell.l3{background:#4287e0}.stu-heat-cell.l4{background:#1d4ed8}.stu-heat-legend{display:flex;align-items:center;gap:4px;justify-content:flex-end;font-size:11px;color:var(--muted);margin-top:8px}.stu-heat-legend .stu-heat-cell{width:11px;height:11px;aspect-ratio:auto}.stu-logout{margin-top:10px}.stu-back{border:none;background:none;color:var(--primary);font-size:13px;cursor:pointer;padding:0}.stu-practice-entries{display:flex;gap:10px;margin-bottom:20px}.stu-practice-entry{flex:1;padding:16px 8px;border:none;border-radius:12px;font-size:14px;font-weight:600;color:#fff;cursor:pointer}.stu-practice-entry.random{background:#6366f1}.stu-practice-entry.highfreq{background:#f97316}.stu-chapter-list{display:flex;flex-direction:column;gap:8px}.stu-chapter-row{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px;text-align:left;cursor:pointer;width:100%}.stu-chapter-row:active{background:#f0f2f5}.stu-chapter-info{flex:1;min-width:0}.stu-chapter-name{font-size:14px;font-weight:600}.stu-chapter-stat{text-align:right;flex-shrink:0}.stu-chapter-count{font-size:18px;font-weight:700;color:var(--primary)}.stu-chapter-mastered{font-size:11px;color:var(--muted)}.stu-browse-list{display:flex;flex-direction:column;gap:8px}.stu-browse-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px;cursor:pointer}.stu-browse-card:active{background:#f0f2f5}.stu-browse-front{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:15px;font-weight:600}.stu-browse-learned{font-size:10px;color:var(--low);background:#f0fdf4;padding:1px 6px;border-radius:4px;flex-shrink:0}.stu-browse-back{margin-top:12px;padding-top:12px;border-top:1px dashed var(--border)}.stu-forecast{background:#eef2ff;color:var(--primary);border-radius:10px;padding:11px 14px;font-size:13px;margin-bottom:14px}.stu-forecast b{font-size:15px}.stu-subject-est{font-size:11px;color:var(--muted);margin-top:6px;padding-top:6px;border-top:1px dashed var(--border)}.stu-feedback-pill{position:absolute;top:56px;left:50%;padding:8px 16px;border-radius:20px;color:#fff;font-size:13px;font-weight:600;white-space:nowrap;z-index:20;pointer-events:none;animation:stu-feedback 1.4s ease forwards}.stu-feedback-pill.good{background:#16a34a}.stu-feedback-pill.hard{background:#f59e0b}.stu-feedback-pill.forgot{background:#ef4444}@keyframes stu-feedback{0%{opacity:0;transform:translate(-50%,8px)}15%{opacity:1;transform:translate(-50%)}75%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,-6px)}}*{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f5f6f8;--panel: #fff;--border: #e3e5e9;--text: #1f2329;--muted: #8a8f99;--primary: #2563eb;--primary-dark: #1d4ed8;--danger: #dc2626;--high: #dc2626;--mid: #d97706;--low: #16a34a}body{font-family:-apple-system,PingFang SC,Microsoft YaHei,sans-serif;background:var(--bg);color:var(--text);font-size:14px}.app{display:flex;flex-direction:column;height:100vh}.topnav{display:flex;align-items:center;gap:8px;background:var(--panel);border-bottom:1px solid var(--border);padding:0 20px;height:52px;flex-shrink:0}.topnav .brand{font-weight:700;font-size:16px;margin-right:20px}.topnav .tab{padding:8px 14px;border-radius:6px;cursor:pointer;color:var(--muted)}.topnav .tab.active{background:#eef2ff;color:var(--primary);font-weight:600}.content{flex:1;overflow:hidden}.manager{display:flex;height:100%}.col{background:var(--panel);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.col-subjects{width:220px}.col-chapters{width:240px}.col-cards{flex:1}.col-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.col-header h3{font-size:13px;color:var(--muted)}.col-body{overflow-y:auto;flex:1;padding:6px}.list-item{padding:9px 10px;border-radius:6px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:6px}.list-item:hover{background:var(--bg)}.list-item.active{background:#eef2ff;color:var(--primary)}.list-item .count{font-size:12px;color:var(--muted)}.list-item .name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-row{padding:10px 12px;border:1px solid var(--border);border-radius:8px;margin-bottom:8px;cursor:pointer;background:var(--panel)}.card-row:hover{border-color:var(--primary)}.card-row .front{font-weight:600;margin-bottom:4px}.card-row .back-preview{color:var(--muted);font-size:13px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-row .tags{margin-top:6px;display:flex;gap:6px;flex-wrap:wrap}.tag{font-size:11px;padding:1px 7px;border-radius:4px;background:var(--bg);color:var(--muted)}.tag.high{background:#fef2f2;color:var(--high)}.tag.mid{background:#fffbeb;color:var(--mid)}.tag.low{background:#f0fdf4;color:var(--low)}button{font-family:inherit;font-size:13px;cursor:pointer;border:1px solid var(--border);background:var(--panel);color:var(--text);padding:6px 12px;border-radius:6px}button:hover{background:var(--bg)}button.primary{background:var(--primary);color:#fff;border-color:var(--primary)}button.primary:hover{background:var(--primary-dark)}button.danger{color:var(--danger);border-color:#f3c2c2}button.sm{padding:3px 8px;font-size:12px}button:disabled{opacity:.5;cursor:not-allowed}input,textarea,select{font-family:inherit;font-size:13px;width:100%;border:1px solid var(--border);border-radius:6px;padding:7px 10px}textarea{resize:vertical;min-height:90px}label{display:block;font-size:12px;color:var(--muted);margin-bottom:4px;margin-top:12px}.empty{padding:40px 20px;text-align:center;color:var(--muted)}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:var(--panel);border-radius:10px;width:560px;max-width:92vw;max-height:88vh;overflow-y:auto;padding:20px}.modal h3{margin-bottom:4px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.row2{display:flex;gap:12px}.row2>div{flex:1}.import-page{padding:20px;max-width:1100px;margin:0 auto;overflow-y:auto;height:100%}.import-grid{display:flex;gap:20px}.import-grid>div{flex:1}.import-page h2{margin-bottom:6px}.hint{color:var(--muted);font-size:13px;line-height:1.7;margin-bottom:12px}.import-textarea{min-height:320px;font-family:ui-monospace,Menlo,monospace}.preview-box{border:1px solid var(--border);border-radius:8px;padding:12px;max-height:360px;overflow-y:auto;background:var(--panel)}.banner{padding:10px 12px;border-radius:6px;margin:10px 0;font-size:13px}.banner.ok{background:#f0fdf4;color:var(--low)}.banner.err{background:#fef2f2;color:var(--danger)}.code-block{background:#f6f7f9;border:1px solid var(--border);border-radius:6px;padding:12px;font-family:ui-monospace,Menlo,monospace;font-size:12px;white-space:pre-wrap;line-height:1.6}.dash{padding:20px;max-width:1100px;margin:0 auto;height:100%;overflow-y:auto}.dash h2{margin-bottom:4px}.dash-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin:16px 0 8px}.dash-stat{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:16px 12px;text-align:center}.dash-stat-num{font-size:26px;font-weight:700;color:var(--primary)}.dash-stat-label{font-size:12px;color:var(--muted);margin-top:4px}.dash-section-title{font-size:15px;font-weight:600;margin:26px 0 10px;display:flex;align-items:center;gap:8px}.dash-risk-count{background:var(--danger);color:#fff;font-size:12px;padding:0 7px;border-radius:9px;font-weight:600}.dash-allgood{background:#f0fdf4;color:var(--low);padding:14px;border-radius:8px;font-size:13px}.dash-risk-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px}.dash-risk-card{border:1px solid var(--border);border-radius:10px;padding:12px 14px;border-left-width:4px}.dash-risk-card.warning{border-left-color:var(--mid);background:#fffbeb}.dash-risk-card.inactive{border-left-color:var(--muted);background:#f7f8fa}.dash-risk-name{font-weight:600}.dash-risk-class{font-size:12px;color:var(--muted);margin-left:8px}.dash-risk-info{font-size:12px;color:var(--muted);margin-top:4px}.dash-table{width:100%;border-collapse:collapse;font-size:13px}.dash-table th{text-align:left;color:var(--muted);font-weight:500;padding:8px 10px;border-bottom:1px solid var(--border)}.dash-table td{padding:9px 10px;border-bottom:1px solid var(--border)}.dash-table tbody tr:hover{background:var(--bg)}.dash-badge{font-size:11px;padding:2px 8px;border-radius:4px;font-weight:600}.dash-badge.ok{background:#f0fdf4;color:var(--low)}.dash-badge.warn{background:#fffbeb;color:var(--mid)}.dash-badge.idle{background:#f0f1f3;color:var(--muted)}.dash-rate-bar{display:inline-block;width:60px;height:6px;background:#eef0f3;border-radius:3px;overflow:hidden;vertical-align:middle;margin-right:8px}.dash-rate-fill{display:block;height:100%;background:var(--danger)}
