*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0b1120;--bg2:#111827;--bg3:#1a2332;--bg4:#1e293b;--accent:#07c160;--accent2:#06a04f;--text:#e2e8f0;--text2:#b0bdd0;--border:#1e293b;--danger:#ef4444;--warn:#f59e0b;--info:#3b82f6;--radius:10px;--shadow:0 4px 24px #0006;--warm-amber:#f0a500;--warm-bamboo:#5cb83e;--warm-cream:#f5f0e8}:root[data-theme=light]{--bg:#f5f0e8;--bg2:#fff;--bg3:#ede8dc;--bg4:#e4ddd0;--text:#2c2416;--text2:#7a6e5e;--border:#d6cebc;--shadow:0 4px 24px #0000001a;--warm-bamboo:#3d9e25}:root[data-theme=light] body{background:var(--bg)}:root[data-theme=light] input,:root[data-theme=light] select,:root[data-theme=light] textarea{background:var(--bg3);color:var(--text)}:root[data-theme=light] .chat-msg.user{color:#fff;background:#f0a500}:root[data-theme=light] .chat-msg.ai{background:var(--bg2);border:1px solid var(--border)}:root[data-theme=light] #nav{border-right-color:var(--border)}:root[data-theme=light] .tab-btn{color:var(--text2)}:root[data-theme=light] .tab-btn.active{color:var(--warm-amber)}body{background:var(--bg);color:var(--text);height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;font-size:18px;transition:background .25s,color .25s;display:flex;overflow:hidden}#nav{background:var(--bg2);border-right:1px solid var(--border);z-index:10;flex-direction:column;flex-shrink:0;width:240px;min-width:240px;height:100vh;padding:12px 0;display:flex;overflow-y:auto}#nav .logo{letter-spacing:3px;background:linear-gradient(135deg,var(--warm-amber),var(--accent));color:#fff;border-radius:0 0 10px;justify-content:center;align-items:center;gap:8px;margin-bottom:10px;padding:8px 16px 10px;font-size:18px;font-weight:700;display:flex}#nav .logo span{font-size:24px}#nav a{color:var(--text2);cursor:pointer;border-left:3px solid #0000;justify-content:center;align-items:center;gap:10px;padding:12px 20px;font-size:15px;text-decoration:none;transition:all .2s;display:flex}#nav a:hover{background:var(--bg3);color:var(--text)}.divider{border:none;border-top:1px solid var(--border);margin:1px 0}#nav a.active{background:var(--bg3);color:var(--warm-amber);border-left-color:var(--warm-amber);font-weight:600}#nav .nav-section{color:var(--text2);text-transform:uppercase;letter-spacing:1px;text-align:center;padding:16px 20px 6px;font-size:12px}#main{flex:1;padding:54px 40px 30px;overflow-y:auto}.page{display:none}.page.active{display:block}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:20px;padding:32px}.card-title{color:var(--warm-amber);align-items:center;gap:8px;margin-bottom:16px;font-size:22px;font-weight:600;display:flex}.btn{cursor:pointer;background:var(--warm-amber);color:#fff;border:none;border-radius:8px;align-items:center;gap:6px;padding:10px 20px;font-size:15px;font-weight:600;transition:all .2s;display:inline-flex}.btn-sm{padding:6px 14px;font-size:13px}.btn:hover{background:#d69300;transform:translateY(-1px);box-shadow:0 4px 12px #f0a5004d}.btn-outline{border:2px solid var(--warm-amber);color:var(--warm-amber);background:0 0}.btn-outline:hover{background:var(--warm-amber);color:#fff}.btn-danger{background:var(--danger)}.btn-warn{background:var(--warn);color:#000}.btn-info{background:var(--info)}input,select,textarea{background:var(--bg3);border:1px solid var(--border);width:100%;color:var(--text);border-radius:8px;outline:none;padding:14px 18px;font-size:17px;transition:border .2s}input:focus,select:focus,textarea:focus{border-color:var(--warm-amber)}label{color:var(--text2);margin-bottom:8px;font-size:16px;font-weight:600;display:block}.form-group{margin-bottom:16px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.checkbox-group{flex-wrap:wrap;gap:10px;display:flex}.checkbox-group label{color:var(--text);cursor:pointer;align-items:center;gap:6px;margin-bottom:0;font-size:14px;font-weight:400;display:flex}.checkbox-group input[type=checkbox]{width:auto;accent-color:var(--accent)}textarea{resize:vertical;min-height:80px}.tag{background:var(--bg4);color:var(--text2);cursor:pointer;border:1px solid #0000;border-radius:20px;margin:2px 4px 2px 0;padding:4px 12px;font-size:13px;transition:all .2s;display:inline-block}.tag:hover{border-color:var(--warm-bamboo);color:var(--warm-bamboo)}.tag.sel{background:var(--warm-amber);color:#fff}.home-grid{grid-template-columns:repeat(3,1fr);gap:20px;margin-top:20px;display:grid}.home-card{background:var(--bg2);border:2px solid var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;padding:30px 20px;transition:all .3s}.home-card:hover{border-color:var(--warm-amber);transform:translateY(-4px);box-shadow:0 8px 30px #f0a50026}.home-card .icon{margin-bottom:12px;font-size:56px}.home-card h3{color:var(--warm-amber);margin-bottom:8px;font-size:24px}.home-card p{color:var(--text2);font-size:16px}.greeting{margin-bottom:8px;font-size:32px;font-weight:700}.greeting-sub{color:var(--text2);margin-bottom:24px;font-size:18px}.tabs{border-bottom:2px solid var(--border);gap:4px;margin-bottom:20px;display:flex}.tab-btn{color:var(--text2);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:14px 24px;font-size:17px;font-weight:500;transition:all .2s}.tab-btn:hover{color:var(--warm-bamboo)}.tab-btn.active{color:var(--warm-amber);border-bottom-color:var(--warm-amber);font-weight:600}.tab-content{display:none}.tab-content.active{display:block}.poem-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;margin-bottom:10px;padding:16px;transition:all .2s}.poem-card:hover{border-color:var(--warm-bamboo)}.poem-card .title-row{justify-content:space-between;align-items:center;display:flex}.poem-card h4{color:var(--warm-amber);font-size:18px}.poem-card .author{color:var(--text2);font-size:13px}.poem-card .expand{color:var(--text2);font-size:12px}.poem-card .body{border-top:1px solid var(--border);margin-top:12px;padding-top:12px;display:none}.poem-card .body.show{display:block}.poem-card .poem-text{white-space:pre-line;color:var(--text);margin-bottom:10px;font-size:17px;line-height:2}.poem-card .poem-trans{color:var(--text2);font-size:16px;line-height:1.8}.tree-node{margin-left:20px}.tree-toggle{cursor:pointer;color:var(--warm-amber);-webkit-user-select:none;user-select:none;align-items:center;gap:6px;padding:6px 0;font-size:15px;font-weight:600;display:flex}.tree-toggle:before{content:"▶";width:14px;font-size:10px;transition:transform .2s;display:inline-block}.tree-toggle.open:before{transform:rotate(90deg)}.tree-children{margin-left:16px;display:none}.tree-children.show{display:block}.tree-leaf{color:var(--text2);cursor:pointer;align-items:center;gap:8px;padding:4px 0 4px 20px;font-size:14px;transition:all .2s;display:flex}.tree-leaf:hover{color:var(--warm-bamboo)}.tree-leaf input[type=checkbox]{width:auto;accent-color:var(--accent)}.chat-area{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:12px;height:400px;margin-bottom:16px;padding:20px;display:flex;overflow-y:auto}.chat-msg{word-wrap:break-word;max-width:80%;padding:16px 18px;font-size:15px;line-height:1.8;position:relative}.chat-msg.user{color:var(--text);border:1px solid #7ecf5140;border-right:3px solid var(--warm-bamboo);background:#7ecf511f;border-radius:12px 4px 12px 12px;align-self:flex-end}.chat-msg.ai{border:1px solid #f0a50033;border-left:3px solid var(--warm-amber);background:linear-gradient(135deg,#f0a5000a,#7ecf510a);border-radius:4px 12px 12px;align-self:flex-start}.chat-msg.ai:before{content:"";pointer-events:none;background:repeating-linear-gradient(#0000,#0000 28px,#f0a5000d 28px 29px);height:100%;position:absolute;top:0;left:20px;right:20px}.chat-msg .time{opacity:.6;margin-top:4px;font-size:11px}.quick-chips{flex-wrap:wrap;gap:8px;margin-bottom:10px;display:flex}.chip{color:var(--warm-amber);cursor:pointer;white-space:nowrap;background:#f0a50014;border:1px solid #f0a50033;border-radius:20px;align-items:center;gap:4px;padding:6px 14px;font-size:13px;transition:all .2s;display:inline-flex}.chip:hover{border-color:var(--warm-amber);background:#f0a50029;transform:translateY(-1px)}.chip.active{background:var(--warm-amber);color:#fff;border-color:var(--warm-amber)}.chat-input-row{gap:10px;display:flex}.chat-input-row input,.chat-input-row textarea{flex:1}.chat-welcome{text-align:center;padding:40px 20px}.chat-welcome .welcome-icon{margin-bottom:16px;font-size:64px}.chat-welcome h3{color:var(--accent);margin-bottom:8px;font-size:20px}.chat-welcome p{color:var(--text2);margin-bottom:24px;font-size:15px}.welcome-tips{grid-template-columns:repeat(2,1fr);gap:10px;max-width:500px;margin:0 auto;display:grid}.tip-card{background:var(--bg3);border:1px solid var(--border);cursor:pointer;color:var(--text);text-align:left;border-radius:10px;align-items:center;gap:8px;padding:14px;font-size:14px;transition:all .2s;display:flex}.tip-card:hover{border-color:var(--warm-amber);background:#f0a50014;transform:translateY(-2px)}.tip-card span{font-size:20px}.error-item{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);justify-content:space-between;align-items:center;margin-bottom:10px;padding:14px;display:flex}.error-item .info{flex:1}.error-item .info .q{margin-bottom:4px;font-weight:600}.error-item .info .ans{color:var(--warm-bamboo);font-size:14px}.error-item .info .date{color:var(--text2);font-size:12px}.word-item{background:var(--bg3);border:1px solid var(--border);text-align:center;cursor:pointer;border-radius:8px;padding:10px 14px;transition:all .2s}.word-item:hover{border-color:var(--warm-bamboo)}.word-item .en{color:var(--warm-amber);font-size:16px;font-weight:600}.word-item .cn{color:var(--text2);margin-top:4px;font-size:13px}.grammar-item{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;margin-bottom:8px;padding:14px 16px;transition:all .2s}.grammar-item:hover{border-color:var(--warm-bamboo)}.grammar-item .g-title{color:var(--warm-amber);justify-content:space-between;font-size:15px;font-weight:600;display:flex}.grammar-item .g-body{color:var(--text2);border-top:1px solid var(--border);margin-top:10px;padding-top:10px;font-size:14px;line-height:1.8;display:none}.grammar-item .g-body.show{display:block}.lvl{border-radius:12px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.lvl-a{color:#07c160;background:#07c16033}.lvl-b{color:#3b82f6;background:#3b82f633}.lvl-c{color:#f59e0b;background:#f59e0b33}.lvl-d{color:#ef4444;background:#ef444433}.result-area{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);white-space:pre-wrap;min-height:200px;margin-top:16px;padding:24px;font-size:17px;line-height:1.8}.result-area.loading{color:var(--warm-amber);justify-content:center;align-items:center;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--warm-amber);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.toast{background:var(--bg2);border:1px solid var(--warm-amber);color:var(--warm-amber);z-index:999;border-radius:8px;padding:12px 20px;font-size:14px;animation:.3s fadeIn;position:fixed;top:20px;right:20px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}}.essay-types{flex-wrap:wrap;gap:10px;margin-bottom:16px;display:flex}@media (width<=768px){#nav{width:60px;min-width:60px}#main{margin-left:60px}#nav a span.nav-text,#nav .logo span.nav-text,#nav .nav-section{display:none}#nav a{justify-content:center;padding:12px}#main{padding:20px}.home-grid,.form-row{grid-template-columns:1fr}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--warm-amber)}.advanced-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;margin-bottom:12px;padding:18px;transition:all .2s}.advanced-card:hover{border-color:var(--warm-amber)}.advanced-card .ac-header{justify-content:space-between;align-items:center;display:flex}.advanced-card .ac-title{color:var(--warm-amber);font-size:16px;font-weight:600}.advanced-card .ac-badge{background:var(--bg4);color:var(--text2);border-radius:10px;padding:2px 10px;font-size:12px}.advanced-card .ac-body{border-top:1px solid var(--border);margin-top:14px;padding-top:14px;display:none}.advanced-card .ac-body.show{display:block}.advanced-card .ac-q{color:var(--text);margin-bottom:12px;font-size:15px;line-height:1.7}.advanced-card .ac-answer{border-left:3px solid var(--accent);background:#07c16014;border-radius:0 8px 8px 0;margin-bottom:10px;padding:12px 16px}.advanced-card .ac-answer strong{color:var(--accent);font-size:15px}.advanced-card .ac-solution{color:var(--text2);font-size:14px;line-height:1.8}.classical-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;margin-bottom:12px;padding:18px;transition:all .2s}.classical-card:hover{border-color:var(--warm-bamboo)}.classical-card .cc-header{justify-content:space-between;align-items:center;display:flex}.classical-card .cc-title{color:var(--warm-bamboo);font-size:16px;font-weight:600}.classical-card .cc-source{color:var(--text2);font-size:12px}.classical-card .cc-body{border-top:1px solid var(--border);margin-top:14px;padding-top:14px;display:none}.classical-card .cc-body.show{display:block}.classical-card .cc-original{color:var(--text);background:var(--bg2);white-space:pre-line;border-radius:8px;margin-bottom:12px;padding:14px;font-size:16px;line-height:2}.classical-card .cc-notes{color:var(--text2);margin-bottom:10px;font-size:13px;line-height:1.8}.classical-card .cc-notes span{color:var(--warm-amber);font-weight:600}.classical-card .cc-trans{color:var(--text2);background:#7ecf510f;border-radius:6px;margin-bottom:12px;padding:10px;font-size:14px;line-height:1.8}.classical-card .cc-quiz{background:var(--bg2);border-radius:8px;margin-top:10px;padding:12px 14px}.classical-card .cc-quiz .qz-q{color:var(--warm-amber);margin-bottom:8px;font-weight:600}.classical-card .cc-quiz .qz-opt{background:var(--bg4);cursor:pointer;border:1px solid #0000;border-radius:6px;margin:4px 0;padding:6px 10px;font-size:14px;transition:all .2s;display:block}.classical-card .cc-quiz .qz-opt:hover{border-color:var(--warm-bamboo)}.classical-card .cc-quiz .qz-opt.correct{border-color:var(--accent);color:var(--accent);background:#07c16026}.classical-card .cc-quiz .qz-opt.wrong{border-color:var(--danger);color:var(--danger);background:#ef444426}.vocab-table{border-collapse:collapse;width:100%;margin-top:12px;font-size:14px}.vocab-table th{background:var(--bg4);text-align:left;color:var(--warm-amber);border-bottom:2px solid var(--border);padding:10px;font-weight:600}.vocab-table td{border-bottom:1px solid var(--border);color:var(--text);padding:10px}.vocab-table tr:hover td{background:var(--bg3)}.vocab-table .vt-en{color:var(--warm-amber);font-weight:600}.reading-passage{background:var(--bg2);white-space:pre-line;border-radius:8px;margin-bottom:12px;padding:16px;font-size:14px;line-height:1.9}.reading-quiz .rq-q{color:var(--warm-amber);margin-bottom:6px;font-weight:600}.reading-quiz .rq-opt{background:var(--bg4);cursor:pointer;border:1px solid #0000;border-radius:6px;margin:3px 0;padding:6px 10px;font-size:14px;transition:all .2s;display:block}.reading-quiz .rq-opt:hover{border-color:var(--info)}.reading-quiz .rq-opt.correct{border-color:var(--accent);color:var(--accent);background:#07c16026}.reading-quiz .rq-opt.wrong{border-color:var(--danger);color:var(--danger);background:#ef444426}.grammar-block{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;margin-bottom:12px;padding:18px;transition:all .2s}.grammar-block:hover{border-color:var(--info)}.grammar-block .gb-title{color:var(--info);justify-content:space-between;font-size:17px;font-weight:600;display:flex}.grammar-block .gb-body{border-top:1px solid var(--border);margin-top:12px;padding-top:12px;display:none}.grammar-block .gb-body.show{display:block}.grammar-block .gb-explain{color:var(--text2);margin-bottom:10px;font-size:14px;line-height:1.8}.grammar-block .gb-examples{color:var(--text);margin-bottom:10px;font-size:14px;line-height:1.8}.grammar-block .gb-examples .eg{background:var(--bg2);border-radius:4px;margin:4px 0;padding:6px 12px;display:block}.grammar-block .gb-examples .eg strong{color:var(--info)}.grammar-block .gb-exercise{background:var(--bg2);border-radius:8px;margin-top:10px;padding:12px}.grammar-block .gb-exercise .ex-item{margin-bottom:10px}.grammar-block .gb-exercise input{width:100%;margin-top:6px}.grammar-block .gb-exercise .ex-fb{border-radius:4px;margin-top:4px;padding:4px 8px;font-size:13px;display:none}.grammar-block .gb-exercise .ex-fb.show{display:inline-block}.pomo-header{cursor:pointer;border-top:1px solid var(--border);-webkit-user-select:none;user-select:none;border-left:3px solid #0000;justify-content:space-between;align-items:center;padding:12px 20px;transition:all .3s;display:flex}.pomo-header:hover{background:var(--bg3)}.pomo-header.active{border-left-color:var(--warm-amber);border-color:var(--warm-amber);animation:2s ease-in-out infinite pomo-pulse}@keyframes pomo-pulse{0%,to{box-shadow:0 0 #f0a50000}50%{box-shadow:0 0 8px 2px #f0a50026}}.pomo-header .pomo-title{color:var(--text2);align-items:center;gap:6px;font-size:15px;display:flex}.pomo-header .pomo-collapsed-time{color:#d4a000;font-size:14px;font-weight:700;display:none}.pomo-header .pomo-toggle{color:var(--text2);font-size:10px;transition:transform .3s}.pomo-header .pomo-toggle.open{transform:rotate(180deg)}.pomo-body{padding:0 20px 12px;transition:all .3s;display:none;overflow:hidden}.pomo-body-inner{text-align:center;margin:8px 0}.pomo-ring-wrap{justify-content:center;align-items:center;margin:8px 0;display:inline-flex;position:relative}.pomo-ring-wrap svg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotate(-90deg)}#pomodoro-display{color:var(--warm-amber);z-index:1;font-size:22px;font-weight:700;position:relative}#pomodoro-display.running{color:#d4a000}.pomo-preset{cursor:pointer;background:var(--bg4);color:var(--text2);border-radius:12px;padding:4px 10px;font-size:11px;transition:all .2s;display:inline-block}.pomo-preset:hover{background:var(--bg3);color:var(--warm-amber)}.pomo-preset.sel{background:var(--warm-amber);color:#fff}.modal-overlay{z-index:100;background:#000000b3;justify-content:center;align-items:center;width:100%;height:100%;display:none;position:fixed;top:0;left:0}.modal-overlay.show{display:flex}.modal-box{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);width:90%;max-width:600px;max-height:80vh;box-shadow:var(--shadow);padding:30px;overflow-y:auto}.modal-box h3{color:var(--warm-amber);margin-bottom:16px}.question-block{background:var(--bg3);border-radius:8px;margin-bottom:12px;padding:16px}.question-block .q-num{color:var(--warm-amber);margin-bottom:6px;font-weight:600}.question-block .q-text{margin-bottom:10px;font-size:15px;line-height:1.6}.question-block input{margin-top:8px}.question-block .q-feedback{border-radius:6px;margin-top:6px;padding:6px 10px;font-size:13px}.q-correct{color:var(--accent);background:#07c16026}.q-wrong{color:var(--danger);background:#ef444426}.pwd-wrap{position:relative}.pwd-wrap input{padding-right:44px}.pwd-wrap .eye{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text2);font-size:18px;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.resource-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-top:16px;display:grid}.resource-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:20px;transition:all .3s}.resource-card:hover{border-color:var(--warm-bamboo);transform:translateY(-2px);box-shadow:0 6px 20px #f0a5001a}.resource-card .rc-icon{margin-bottom:10px;font-size:32px}.resource-card .rc-title{color:var(--warm-amber);margin-bottom:12px;font-size:17px;font-weight:700}.resource-card .rc-links{flex-direction:column;gap:6px;display:flex}.resource-card .rc-link{background:var(--bg2);color:var(--text);border:1px solid #0000;border-radius:6px;align-items:center;gap:6px;padding:8px 12px;font-size:14px;text-decoration:none;transition:all .2s;display:flex}.resource-card .rc-link:hover{background:var(--bg4);border-color:var(--warm-bamboo);color:var(--warm-bamboo)}.resource-card .rc-link .link-icon{opacity:.7;font-size:14px}.school-msg-list{flex-direction:column;gap:8px;display:flex}.school-msg{background:var(--bg3);border:1px solid var(--border);border-left:3px solid var(--warm-amber);border-radius:8px;padding:14px}.school-msg .msg-source{color:var(--warm-amber);margin-bottom:4px;font-size:12px}.school-msg .msg-date{color:var(--text2);float:right;font-size:11px}.school-msg .msg-text{font-size:14px;line-height:1.6}.school-msg .msg-time{color:var(--text2);float:right;font-size:11px}.msg-date-header{color:var(--warm-amber);border-bottom:1px solid var(--border);margin-top:8px;margin-bottom:8px;padding:12px 0 6px;font-size:14px;font-weight:700}.connect-card{background:var(--bg3);border:1px solid var(--border);text-align:center;border-radius:10px;flex:1;min-width:140px;padding:20px}.connect-card .cc-icon{margin-bottom:8px;font-size:32px}.connect-card .cc-name{margin-bottom:4px;font-size:16px;font-weight:600}.connect-card .cc-status{color:var(--warn);margin-bottom:10px;font-size:12px}.empty-state{text-align:center;color:var(--text2);padding:40px;font-size:16px}
