:root{--paper: #f4f1e9;--paper-2: #ece7da;--surface: #fbf9f3;--ink: #23201a;--ink-soft: #463f35;--muted: #756c5d;--faint: #9a9183;--accent: #6b1f2a;--accent-soft: #f0e6e2;--rule: #ddd5c4;--rule-strong: #c9bfa8;--serif: "Iowan Old Style", "Palatino Linotype", Palatino, "Songti SC", Georgia, "Times New Roman", serif;--sans: "Inter", -apple-system, "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif;--g-tense: #9b4a3f;--g-clause: #9a7b3f;--g-subj: #6b4a7d;--g-inv: #8a4a63;--g-voice: #3f7a6b;--g-modal: #3f5a7d;--g-cond: #4a7d72;--g-nonfin: #a3653f;--g-compare: #5a5a8a;--g-emph: #8a7320;--g-other: #6b6357}:root[data-theme=dark]{--paper: #1c1a17;--paper-2: #211e19;--surface: #24201a;--ink: #e8e2d4;--ink-soft: #cfc8b8;--muted: #9c9385;--faint: #756c5d;--accent: #cf9a93;--accent-soft: #322321;--rule: #38322a;--rule-strong: #4a4338}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--serif);background:var(--paper);color:var(--ink);line-height:1.7;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3,h4{font-weight:600;letter-spacing:-.01em;margin:0;color:var(--ink)}h1{font-size:30px;line-height:1.25}h3{font-size:19px}.label,.cat,.meta{font-family:var(--sans);text-transform:uppercase;letter-spacing:.12em;font-size:11.5px;font-weight:500;color:var(--muted)}.muted{color:var(--muted);font-size:14px}.faint{color:var(--faint)}.error-text{color:var(--accent);font-size:14px;font-family:var(--sans)}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:var(--sans);cursor:pointer;border:1px solid var(--rule-strong);background:transparent;color:var(--ink);padding:8px 16px;border-radius:2px;font-size:13.5px;transition:all .15s ease}button:hover{border-color:var(--accent);color:var(--accent)}button:disabled{opacity:.4;cursor:not-allowed}button.primary{background:var(--accent);border-color:var(--accent);color:#fbf9f3}button.primary:hover{filter:brightness(1.1);color:#fbf9f3}button.block{width:100%}button.on{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}button.ghost{border:none;padding:4px 8px;color:var(--muted)}button.ghost:hover{color:var(--accent)}input,textarea{width:100%;font-family:var(--serif);background:var(--surface);border:1px solid var(--rule-strong);color:var(--ink);padding:10px 12px;border-radius:2px;font-size:16px;margin:6px 0}input:focus,textarea:focus{outline:none;border-color:var(--accent)}code{font-family:SF Mono,Menlo,Consolas,monospace;background:var(--paper-2);padding:2px 6px;border-radius:2px;font-size:13px;color:var(--ink-soft)}.app-shell{display:flex;min-height:100vh}.sidebar{width:220px;background:var(--paper-2);border-right:1px solid var(--rule);padding:28px 18px;display:flex;flex-direction:column;gap:2px;position:sticky;top:0;height:100vh}.brand{font-family:var(--serif);font-size:21px;font-weight:600;margin-bottom:8px;padding:0 8px;color:var(--ink)}.brand-sub{font-family:var(--sans);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);padding:0 8px;margin-bottom:22px}.nav-item{font-family:var(--sans);display:flex;align-items:center;gap:11px;padding:9px 12px;color:var(--muted);text-decoration:none;font-size:14.5px;border-left:2px solid transparent}.nav-item:hover{color:var(--ink);text-decoration:none}.nav-item.active{color:var(--accent);border-left-color:var(--accent)}.nav-icon{font-size:15px;width:18px;text-align:center}.logout{margin-top:auto}.content{flex:1;padding:44px 40px 90px;max-width:820px;margin:0 auto;width:100%}.page{display:flex;flex-direction:column;gap:26px}.page>h1{border-bottom:2px solid var(--ink);padding-bottom:12px}.bottom-nav{display:none}.toc{display:flex;flex-direction:column}.toc-item{padding:20px 4px;border-bottom:1px solid var(--rule);cursor:pointer;display:flex;flex-direction:column;gap:7px}.toc-item:first-child{border-top:1px solid var(--rule)}.toc-item:hover .toc-title{color:var(--accent)}.toc-head{display:flex;gap:14px;align-items:baseline}.toc-title{font-size:21px;font-weight:600;line-height:1.35;transition:color .15s}.toc-meta{display:flex;gap:16px}.article-view{gap:18px}.back{font-family:var(--sans);background:none;border:none;color:var(--muted);padding:0;font-size:13px;align-self:flex-start}.back:hover{color:var(--accent)}.article-header{display:flex;flex-direction:column;gap:14px;border-bottom:2px solid var(--ink);padding-bottom:18px}.article-title{font-size:32px;line-height:1.22}.article-meta{display:flex;flex-wrap:wrap;gap:18px}.reading-toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.chip{font-family:var(--sans);font-size:12.5px;padding:6px 13px;border:1px solid var(--rule-strong);border-radius:2px;background:transparent;color:var(--muted)}.chip.on{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.legend{display:flex;flex-wrap:wrap;gap:16px;padding:14px 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}.legend-item{font-family:var(--sans);font-size:12px;color:var(--muted);display:inline-flex;align-items:center;gap:7px}.dot{width:22px;height:0;border-bottom:2px solid;display:inline-block}.reader{max-width:660px}.article-body{font-size:19px;line-height:1.95;color:var(--ink-soft)}.article-body p{margin:0 0 1.3em}.grammar-hl{cursor:pointer;border-bottom:1.5px solid var(--hl);padding-bottom:1px}.grammar-hl:hover{background:var(--accent-soft)}.word{cursor:pointer;background:var(--accent-soft);border-radius:2px;padding:0 1px}.word:hover{color:var(--accent)}.hint-line{font-family:var(--sans);font-size:13px}.collapsible{border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}.collapsible-head{width:100%;display:flex;justify-content:space-between;align-items:center;padding:16px 0;background:none;border:none;border-radius:0;font-family:var(--serif);font-size:17px;font-weight:600;color:var(--ink)}.collapsible-head:hover{color:var(--accent)}.chevron{font-family:var(--sans);font-size:11px;color:var(--muted)}.collapsible-body{padding:0 0 20px}.translation-text{margin:0;line-height:1.95;color:var(--ink-soft)}.quiz{border-top:2px solid var(--ink);padding-top:18px}.quiz-q{margin:18px 0}.quiz-opt{padding:9px 14px;border:1px solid var(--rule);border-radius:2px;margin:6px 0;cursor:pointer;font-size:16px}.quiz-opt:hover{border-color:var(--accent)}.quiz-opt.correct{border-color:var(--g-voice);color:var(--g-voice)}.quiz-opt.wrong{border-color:var(--accent);color:var(--accent)}.panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#14100c73;display:flex;align-items:center;justify-content:center;padding:20px;z-index:60}.panel{background:var(--surface);border:1px solid var(--rule-strong);border-radius:3px;padding:28px;max-width:480px;width:100%;max-height:85vh;overflow-y:auto}.panel.wide{max-width:640px}.panel-title{font-size:22px;margin:6px 0 4px}.panel-row{margin:14px 0}.panel-row b{font-family:var(--sans);display:block;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}.panel-row p{margin:0}.quote{font-style:italic;color:var(--muted)}.stat-row{display:flex;flex-wrap:wrap;gap:0;border:1px solid var(--rule)}.stat-cell{flex:1;min-width:120px;padding:18px 20px;border-right:1px solid var(--rule)}.stat-cell:last-child{border-right:none}.stat-value{font-size:30px;font-weight:600;color:var(--ink)}.stat-label{font-family:var(--sans);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:3px}.block-card{border:1px solid var(--rule);padding:22px}.section-title{font-family:var(--sans);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}.calendar{border:1px solid var(--rule)}.cal-head{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--rule)}.cal-title{font-size:18px;font-weight:600}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr)}.cal-dow{font-family:var(--sans);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);text-align:center;padding:10px 0;border-bottom:1px solid var(--rule)}.cal-cell{aspect-ratio:1.3;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:8px;font-family:var(--sans);font-size:13px;color:var(--ink-soft);position:relative}.cal-cell:nth-child(7n){border-right:none}.cal-cell.empty{background:var(--paper-2)}.cal-cell.has{cursor:pointer}.cal-cell.has:hover{background:var(--accent-soft)}.cal-cell.today{box-shadow:inset 0 0 0 2px var(--accent)}.cal-mark{position:absolute;bottom:8px;left:8px;font-size:10.5px;color:var(--accent);display:flex;align-items:center;gap:3px}.cal-mark .pip{width:5px;height:5px;border-radius:50%;background:var(--accent);display:inline-block}.cat-list{display:flex;flex-direction:column}.cat-row{border-bottom:1px solid var(--rule)}.cat-row:first-child{border-top:1px solid var(--rule)}.cat-head{display:flex;justify-content:space-between;align-items:center;padding:16px 4px;cursor:pointer}.cat-head:hover .cat-name{color:var(--accent)}.cat-name{font-size:18px;font-weight:600}.cat-count{font-family:var(--sans);font-size:13px;color:var(--muted)}.points{padding:4px 0 16px 18px;display:flex;flex-direction:column;gap:16px}.point{border-left:2px solid var(--rule-strong);padding-left:16px}.point-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px}.point-name{font-size:16px;font-weight:600}.point-ex{font-style:italic;color:var(--muted);margin:6px 0 0}.practice-intro{display:flex;flex-direction:column;gap:8px;border-bottom:2px solid var(--ink);padding-bottom:16px}.concept-tags{display:flex;flex-wrap:wrap;gap:8px}.concept-tag{font-family:var(--sans);font-size:12px;color:var(--muted);border:1px solid var(--rule);padding:3px 10px;border-radius:2px}.exercise{padding:22px 0;border-bottom:1px solid var(--rule)}.ex-no{font-family:var(--sans);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}.ex-grammar{font-family:var(--sans);font-size:12px;color:var(--muted)}.ex-prompt{font-size:18px;margin:8px 0;line-height:1.7}.verdict{border-left:3px solid;padding:8px 14px;margin-top:10px;font-size:15px}.verdict.correct{border-color:var(--g-voice)}.verdict.partial{border-color:var(--g-emph)}.verdict.wrong{border-color:var(--accent)}.list{display:flex;flex-direction:column}.list-item{padding:18px 4px;border-bottom:1px solid var(--rule)}.list-item:first-child{border-top:1px solid var(--rule)}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.login-card{width:100%;max-width:360px;border:1px solid var(--rule-strong);padding:40px 34px;background:var(--surface)}.login-card h1{font-size:26px}.login-card .brand-sub{padding:0;margin:4px 0 24px}.login-card button[type=submit]{width:100%;margin-top:12px}.switch{font-family:var(--sans);color:var(--accent);cursor:pointer;text-align:center;font-size:13px;margin-top:16px}.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.field{margin:18px 0}.field>.section-title{margin-bottom:8px}.state{text-align:center;padding:60px 20px;color:var(--muted);font-family:var(--sans)}.state-icon{font-size:30px}.spinner{width:30px;height:30px;margin:0 auto 14px;border:2px solid var(--rule);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.sidebar{display:none}.content{padding:24px 18px 84px;padding-top:max(24px,env(safe-area-inset-top))}.article-title,h1{font-size:25px}.reader{max-width:100%}.article-body{font-size:18px}.stat-cell{min-width:33%}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--paper-2);border-top:1px solid var(--rule);padding:8px 0 max(8px,env(safe-area-inset-bottom));z-index:50}.bottom-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--muted);text-decoration:none;font-family:var(--sans);font-size:10.5px}.bottom-item span:first-child{font-size:17px}.bottom-item.active{color:var(--accent)}}
