:root{--bg: #f6f8fb;--panel: #ffffff;--line: #dde3ec;--text: #1c2430;--muted: #5f6c7b;--primary: #1155cc;--primary-soft: #e7f0ff;--success: #1f8b4c;--warning: #c97a00;--danger: #c44536}*{box-sizing:border-box}html,body,#app{width:100%;min-height:100%;margin:0;padding:0;font-family:PingFang SC,Microsoft YaHei,Noto Sans SC,sans-serif;color:var(--text);background:radial-gradient(circle at top right,#edf4ff,var(--bg) 40%)}h1,h2,h3,h4,p{margin:0}button,input,textarea,select{font:inherit}.layout{min-height:100vh;display:grid;grid-template-columns:240px 1fr}.sidebar{padding:28px 20px;border-right:1px solid var(--line);background:#fdfefe;display:flex;flex-direction:column;gap:20px}.sidebar h1{font-size:24px;line-height:1.2}.nickname{color:var(--muted)}.menu{display:grid;gap:10px}.menu-btn{border:1px solid var(--line);background:#fff;border-radius:10px;padding:10px 12px;text-align:left;cursor:pointer}.menu-btn.active{border-color:var(--primary);background:var(--primary-soft);color:var(--primary);font-weight:700}.main-content{padding:26px}.view{max-width:980px;display:grid;gap:16px}.view>h2{font-size:28px}.hero-card,.card,.history-item,.login-card,.modal-panel{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px}.profile-row{display:flex;align-items:center;gap:14px;margin-bottom:18px}.avatar{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700}.metric-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:16px}.metric-item{border-radius:10px;border:1px dashed var(--line);padding:10px;display:grid;gap:4px}.metric-item span{color:var(--muted);font-size:13px}.metric-item strong{font-size:22px}.btn{border:1px solid var(--line);background:#fff;color:var(--text);border-radius:10px;padding:10px 14px;cursor:pointer}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn:disabled{opacity:.5;cursor:not-allowed}.logout-btn{margin-top:auto}.glimpse-sentence{font-size:18px;margin:8px 0}.glimpse-translation{color:var(--muted);margin-bottom:8px}.glimpse-tip,.muted{color:var(--muted)}.mini-chart{height:140px;display:flex;align-items:flex-end;gap:6px;margin:10px 0}.bar{flex:1;min-width:10px;border-radius:8px 8px 4px 4px;background:linear-gradient(180deg,#8db5ff,#326ce8)}.elo-change{font-weight:600}.elo-change.up{color:var(--success)}.elo-change.down{color:var(--danger)}.practice-view textarea,.practice-view select,.practice-view input{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px;background:#fff}.practice-view textarea{min-height:120px;resize:vertical}.control-group{display:grid;gap:8px;margin-bottom:14px}.control-group label{font-size:14px;color:var(--muted)}.origin-text{padding:12px;background:#f8fbff;border:1px solid var(--line);border-radius:10px;margin:10px 0;line-height:1.7}.compare-box{margin-top:10px;display:grid;gap:10px}.anno-line{display:flex;flex-wrap:wrap;gap:6px}.anno{border:1px solid var(--line);border-radius:8px;background:#fff;padding:5px 8px;cursor:pointer}.anno-error,.anno-missing{border-color:#ef9a9a;background:#ffefef}.anno-correct{border-color:#a5d6a7;background:#effcf0}.tooltip{border:1px solid #f2c078;background:#fff8ea;border-radius:10px;padding:12px;display:grid;gap:8px}.rich{display:grid;gap:6px}.rich p{line-height:1.7}.rich code{background:#edf3ff;color:#0e4bb0;padding:2px 6px;border-radius:6px}.rich ul{margin:0;padding-left:18px}.history-grid{display:grid;gap:10px}.history-item{width:100%;text-align:left;display:grid;grid-template-columns:70px 1fr;gap:14px;cursor:pointer}.history-item .score{border-radius:12px;display:grid;place-items:center;font-size:22px;font-weight:700;background:#f4f6f9}.history-item .score.good{background:#e5f7eb;color:var(--success)}.history-item .score.mid{background:#fff4de;color:var(--warning)}.history-content{display:grid;gap:8px}.time{color:var(--muted);font-size:13px}.question{line-height:1.5}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#11172373;display:grid;place-items:center;padding:20px}.modal-panel{width:min(920px,100%);max-height:90vh;overflow:auto;display:grid;gap:12px}.modal-header{display:flex;justify-content:space-between;align-items:center}.chip-row{display:flex;gap:8px;overflow:auto;padding-bottom:6px}.chip{border:1px solid var(--line);border-radius:999px;background:#fff;padding:6px 12px;white-space:nowrap;cursor:pointer}.chip.active{border-color:var(--primary);color:var(--primary);background:var(--primary-soft)}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:18px}.login-card{width:min(440px,100%);display:grid;gap:10px}.login-card .sub-title{color:var(--muted)}.qr-area{border:1px dashed var(--line);border-radius:12px;padding:14px;display:grid;place-items:center;min-height:240px}.qr-image{width:220px;height:220px;object-fit:cover}.code-login-box{display:grid;gap:10px}.code-input{width:100%;border:1px solid var(--line);border-radius:10px;padding:12px;font-size:24px;letter-spacing:6px;text-align:center}.placeholder{color:var(--muted)}.status-text,.expire-text{color:var(--muted);font-size:13px}.error{color:var(--danger)}.fallback-panel{border-top:1px solid var(--line);padding-top:8px}.login-link{color:var(--primary);font-size:13px;text-decoration:none}.login-link:hover{text-decoration:underline}.fallback-body{margin-top:8px;display:grid;gap:8px}.fallback-body input,.fallback-body textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:8px}.fallback-body textarea{min-height:90px}@media (max-width: 960px){.layout{grid-template-columns:1fr}.sidebar{border-right:none;border-bottom:1px solid var(--line)}.menu{grid-template-columns:repeat(3,1fr)}.logout-btn{margin-top:0}.main-content{padding:16px}.metric-row{grid-template-columns:1fr}}
