:root{--bg: #f5f8f5;--bg-soft: #edf3ed;--panel: rgba(255, 255, 255, .96);--panel-strong: #ffffff;--surface: #f7faf7;--line: rgba(37, 70, 46, .12);--line-strong: rgba(37, 70, 46, .24);--text: #18211b;--muted: #607067;--accent: #2f7d4b;--accent-strong: #3f9960;--accent-dark: #26653d;--teal: #4aa176;--gold: #c5a447;--danger: #cd5a4e;--shadow: 0 20px 50px rgba(34, 56, 39, .09)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;color:var(--text);background:radial-gradient(circle at top left,rgba(63,153,96,.12),transparent 24%),radial-gradient(circle at bottom right,rgba(74,161,118,.1),transparent 22%),linear-gradient(180deg,#fbfdfb,#eef5ef);font-family:Bahnschrift,Segoe UI Variable Display,Aptos,sans-serif}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:linear-gradient(rgba(47,125,75,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(47,125,75,.035) 1px,transparent 1px);background-size:28px 28px;-webkit-mask-image:radial-gradient(circle at center,black 42%,transparent 88%);mask-image:radial-gradient(circle at center,black 42%,transparent 88%)}a{color:var(--accent-dark)}button,input,select,textarea{font:inherit}button{transition:transform .12s ease,border-color .12s ease,background .12s ease,color .12s ease,box-shadow .12s ease}button:hover{transform:translateY(-1px)}input,select,textarea,button{outline:none}input:focus,select:focus,textarea:focus,button:focus-visible,.nav-link:focus-visible,.role-button:focus-visible{box-shadow:0 0 0 3px #3f996029;border-color:#3f996066}.page-shell{display:grid;grid-template-columns:320px 1fr;min-height:100vh}.sidebar{position:relative;display:flex;flex-direction:column;gap:22px;padding:28px 22px 24px;background:linear-gradient(180deg,#eff5ef,#e8f0e8),linear-gradient(90deg,rgba(255,255,255,.7),transparent);border-right:1px solid var(--line)}.brand-block{display:grid;gap:18px}.logo-slot{display:grid;gap:2px;width:fit-content;min-width:116px;padding:12px 14px;border:1px dashed rgba(47,125,75,.28);background:#ffffffbd;color:var(--text)}.logo-slot.compact{min-width:96px;padding:10px 12px}.logo-slot-kicker{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}.brand-logo{min-width:0;padding:0;border:0;background:transparent}.brand-logo-image{display:block;width:min(100%,250px);height:auto}.brand-logo.compact .brand-logo-image{width:132px}.brand{display:grid;gap:10px}.brand-kicker,.header-kicker,.panel-chip{font-size:11px;letter-spacing:.22em;text-transform:uppercase}.brand-kicker,.header-kicker{color:var(--muted)}.brand-title{font-size:38px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.brand-copy{margin:0;color:#18211bbd;line-height:1.68;font-size:14px;display:none}.nav-group{display:grid;gap:10px}.nav-link{display:grid;grid-template-columns:44px 1fr;align-items:center;gap:12px;min-height:52px;padding:0 14px;border:1px solid transparent;background:#ffffff85;color:var(--text);text-decoration:none}.nav-link.active{background:linear-gradient(90deg,#3f996024,#ffffffeb);border-color:#3f99604d}.nav-tag{display:inline-flex;justify-content:center;align-items:center;min-height:30px;border:1px solid rgba(47,125,75,.16);background:#ffffffb3;font-size:11px;letter-spacing:.14em;color:var(--muted)}.sidebar-footer{margin-top:auto;display:grid;gap:8px;padding:18px 16px;border:1px solid var(--line);background:#ffffffb3}.sidebar-footer p{margin:0;color:#18211bc2;font-size:13px}.meta-chip{width:fit-content;padding:5px 8px;border:1px solid rgba(63,153,96,.34);color:var(--accent-dark);background:#3f996014;font-size:10px;font-weight:700;letter-spacing:.18em}.main-area{padding:28px}.header-bar{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:28px}.header-copy h1{margin:8px 0 0;font-size:40px;line-height:1.04;letter-spacing:.02em}.header-copy p{max-width:56ch;margin:10px 0 0;color:var(--muted);line-height:1.65}.header-actions{display:flex;align-items:center;gap:12px}.ghost-button,.accent-button{min-height:44px;padding:0 18px;border:1px solid var(--line-strong);cursor:pointer}.accent-button{background:linear-gradient(90deg,var(--accent),var(--accent-strong));border-color:transparent;color:#fff;font-weight:700}.ghost-button{background:#ffffffd1;color:var(--text)}.dashboard-grid{display:grid;gap:18px}.dashboard-preview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.section-stack{display:grid;gap:18px}.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.summary-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.summary-item{padding:14px 16px;border:1px solid var(--line);background:linear-gradient(180deg,#fffffffa,#f5f9f5f5)}.summary-label{margin:0;color:var(--muted);font-size:11px;letter-spacing:.14em;text-transform:uppercase}.summary-value{margin:10px 0 0;font-size:28px;line-height:1}.summary-note{margin:8px 0 0;color:#18211bb8;font-size:13px;line-height:1.55;display:none}.align-end{align-self:end}.hero-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px}.hero-panel{padding:20px 22px}.hero-panel h2{margin:10px 0 0;font-size:30px;line-height:1.08}.hero-panel p{margin:12px 0 0;color:var(--muted);line-height:1.68}.hero-panel.hero-panel-intro{display:none}.hero-list{display:grid;gap:10px;margin-top:18px}.hero-item{display:grid;grid-template-columns:56px 1fr;gap:12px;align-items:start;padding-top:10px;border-top:1px solid var(--line)}.hero-code{color:var(--accent-dark);font-size:11px;font-weight:700;letter-spacing:.16em}.hero-item p{margin:0}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.card{background:linear-gradient(180deg,#fffffff5,#f9fcf9fa);border:1px solid var(--line);box-shadow:var(--shadow)}.stat-card{position:relative;padding:18px 18px 20px;min-height:168px}.stat-topline,.panel-rule{width:44px;height:4px;background:linear-gradient(90deg,var(--accent),var(--teal))}.stat-label{margin:14px 0 0;color:var(--muted);font-size:12px;letter-spacing:.14em;text-transform:uppercase}.stat-value{margin:18px 0 10px;font-size:clamp(34px,4vw,52px);line-height:1;letter-spacing:.02em}.stat-note{margin:0;color:#18211bb3;line-height:1.6}.content-grid{display:grid;grid-template-columns:1.35fr 1fr;gap:18px}.panel{padding:22px}.panel-head{display:grid;gap:12px;margin-bottom:18px}.panel h2{margin:0;font-size:28px;line-height:1.08}.panel-subtitle{margin:8px 0 0;color:var(--muted);line-height:1.65;display:none}.preview-list-card{gap:16px}.preview-list-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.preview-list-head h2{margin:12px 0 0;font-size:24px}.preview-list-subtitle{margin:8px 0 0;color:var(--muted);font-size:13px;line-height:1.6}.preview-list{display:grid;gap:10px}.preview-list-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:12px 14px;border:1px solid var(--line);background:#ffffffd6}.preview-list-copy{min-width:0}.preview-list-primary{font-size:14px;font-weight:600;line-height:1.5;word-break:break-word}.preview-list-secondary{margin-top:6px;color:var(--muted);font-size:13px;line-height:1.55;word-break:break-word}.preview-list-badge{flex-shrink:0}.preview-list-empty{padding:16px;border:1px dashed var(--line-strong);background:#f7faf7eb;color:var(--muted)}.table-wrap{width:100%;overflow-x:auto;border:1px solid rgba(47,125,75,.08)}.stack-grid{display:grid;gap:18px}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:14px 12px;border-bottom:1px solid var(--line);text-align:left;font-size:14px;vertical-align:top}.table th{color:var(--muted);font-size:12px;letter-spacing:.12em;text-transform:uppercase;background:#3f99600d}.pill{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border:1px solid transparent;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.pill.red{color:#af473f;background:#cd5a4e1f;border-color:#cd5a4e38}.pill.gold{color:#8e7330;background:#c5a44724;border-color:#c5a44738}.pill.teal{color:var(--accent-dark);background:#4aa1761f;border-color:#4aa17638}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.field{display:grid;gap:8px}.field.full{grid-column:1 / -1}.field label{color:var(--muted);font-size:12px;letter-spacing:.1em;text-transform:uppercase}.field input,.field select,.field textarea,.compact-input,.compact-display{width:100%;border:1px solid var(--line);background:#fff;color:var(--text);min-height:44px;padding:10px 12px}.compact-display{display:flex;align-items:center}.field textarea{min-height:108px;resize:vertical}.toolbar-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}.toolbar-actions{display:flex;justify-content:flex-end;margin-bottom:14px}.toolbar-stack{display:grid;gap:16px}.table-actions{display:flex;flex-wrap:wrap;gap:8px}.checkbox-label{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:12px;font-weight:700}.sort-header{border:0;padding:0;background:none;color:inherit;font:inherit;font-weight:700;letter-spacing:inherit;text-transform:inherit;cursor:pointer}.inline-toolbar{display:flex;gap:12px;flex-wrap:wrap;align-items:end}.course-actions{display:grid;grid-template-columns:190px minmax(220px,1fr) auto;gap:10px;align-items:center}.compact-input{min-height:40px;font-size:13px}.timetable-wrap{width:100%;overflow-x:auto;border:1px solid rgba(47,125,75,.08)}.timetable-grid{width:100%;border-collapse:collapse;min-width:980px;table-layout:fixed}.timetable-grid th,.timetable-grid td{border:1px solid var(--line);vertical-align:top}.timetable-grid th{padding:10px 8px;background:#3f99600d;color:var(--muted);font-size:12px;letter-spacing:.08em}.timetable-head-blocked{background:linear-gradient(180deg,#d75c5c1f,#d75c5c0f)}.time-head,.time-cell{width:84px;min-width:84px}.time-cell{padding:10px 8px;color:var(--muted);font-size:12px;background:#ffffffe0}.time-cell-blocked{background:linear-gradient(180deg,#fff8e7f0,#fffcf5eb);color:#b45309}.timetable-date{display:block;margin-top:6px;color:#18211bb8;font-size:12px;letter-spacing:0}.timetable-annotation{display:block;margin-top:6px;color:#b45309;font-size:11px;letter-spacing:0}.timetable-cell{height:38px;padding:4px 6px;background:#ffffffe6}.timetable-cell.has-course{background:linear-gradient(180deg,#f8fcf8fa,#f3f9f3f5)}.timetable-cell-available{background:linear-gradient(180deg,#e8f9eefa,#dbf4e5f0)}.timetable-cell-unavailable{background:linear-gradient(180deg,#ebeeecf2,#e2e7e4eb)}.timetable-cell-blocked{background:linear-gradient(180deg,#fff4f0f2,#fff8f5eb)}.timetable-cell-slot-blocked{background:linear-gradient(180deg,#fff8e7f0,#fffcf5eb)}.timetable-rest-day{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background:#d977061f;color:#b45309;font-size:11px;font-weight:700;letter-spacing:.04em}.timetable-slot-blocked-text{display:inline-flex;align-items:center;padding:2px 6px;border-radius:999px;background:#d977061f;color:#b45309;font-size:10px;font-weight:700;letter-spacing:.02em}.availability-grid{display:grid;grid-template-columns:minmax(4.5rem,.8fr) repeat(7,minmax(4.5rem,1fr));gap:.35rem;margin-top:1rem;overflow-x:auto}.availability-corner,.availability-day,.availability-time{min-height:2.75rem;border:1px solid rgba(41,58,50,.14);background:#f6f9f4e0;color:#24352e;display:grid;place-items:center;font-size:.82rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.availability-slot{min-height:2.75rem;border:1px solid rgba(41,58,50,.14);background:#fff;color:#6b7a72;font-weight:800}.availability-slot.selected{background:#2f8f59;border-color:#2f8f59;color:#fff}.availability-slot.readonly{cursor:default}.availability-slot:disabled{cursor:default;opacity:1}.availability-panel-grid{display:grid;gap:18px}@media(min-width:64rem){.availability-panel-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.timetable-course{display:flex;align-items:center;min-width:0;padding:4px 6px;border-left:3px solid transparent;background:#ffffffe6}.timetable-course+.timetable-course{margin-top:4px}.timetable-course strong{display:block;min-width:0;font-size:11px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.timetable-course-formal{border-left-color:#cd5a4eb3;background:#cd5a4e0d}.timetable-course-trial{border-left-color:#c5a447b8;background:#c5a44714}.mini-button{min-height:34px;padding:0 12px;font-size:12px}.login-shell{min-height:100vh;display:grid;place-items:center;padding:28px}.login-card{width:min(1100px,100%);display:grid;grid-template-columns:1.12fr .88fr;overflow:hidden}.login-art{display:grid;gap:24px;padding:34px;background:linear-gradient(180deg,#f3f8f3,#ebf3eb),linear-gradient(135deg,rgba(63,153,96,.08),transparent);border-right:1px solid var(--line)}.login-logo{margin-bottom:10px}.login-art h1{max-width:100%;margin:0;font-size:clamp(30px,3.8vw,52px);line-height:1.18;letter-spacing:-.03em}.login-title{display:grid;gap:10px}.login-title-zh{display:block;color:var(--text);font-size:clamp(46px,5.2vw,72px);line-height:1.08;letter-spacing:-.04em}.login-title-en{display:block;color:var(--muted);font-size:clamp(22px,2.1vw,30px);line-height:1.45;font-weight:600;letter-spacing:.01em}.login-art p{max-width:44ch;margin:0;color:#18211bb8;line-height:1.72;display:none}.login-points{display:grid;gap:12px;margin-top:auto;display:none}.login-point{display:grid;grid-template-columns:46px 1fr;gap:12px;align-items:start;padding:12px 0;border-top:1px solid var(--line)}.point-index{color:var(--accent-dark);font-size:11px;font-weight:700;letter-spacing:.18em}.login-panel{padding:34px;background:linear-gradient(180deg,#fffffffa,#f9fcf9)}.login-panel h2{margin:12px 0 0;font-size:26px;line-height:1.3;letter-spacing:.01em}.login-panel-copy{margin:10px 0 0;color:var(--muted);line-height:1.65}.panel-chip{color:var(--accent-dark)}.role-list{display:grid;gap:10px;margin:24px 0}.role-button{width:100%;display:grid;gap:6px;padding:16px;border:1px solid var(--line);background:#fafcfafa;color:var(--text);text-align:left;cursor:pointer}.role-button strong{font-size:15px}.role-button span{color:var(--muted);font-size:13px}.empty-note{padding:16px;border:1px dashed var(--line-strong);background:#f7faf7eb;color:var(--muted);line-height:1.6}.feedback-note{padding:14px 16px;border:1px solid var(--line);background:#f7faf7f5;line-height:1.6}.section-note{padding:16px 18px;border-left:4px solid rgba(63,153,96,.42);background:#f5faf5fa;color:#18211bd1;line-height:1.7;display:none}.feedback-note.success{border-color:#4aa1763d;color:var(--accent-dark)}.feedback-note.danger,.danger-note{border-style:solid;border-color:#cd5a4e38;color:#a5473f}.vocabulary-classroom{--vocab-ink: #162016;--vocab-paper: #fffdf4;--vocab-line: rgba(47, 125, 75, .18)}.vocab-precheck-list{display:grid;gap:.75rem}.vocab-precheck-row{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:center;padding:1rem;border:1px solid var(--vocab-line);background:#ffffffe6}.vocab-precheck-row.correct{border-color:#4aa1766b;background:#4aa17614}.vocab-precheck-row.wrong{border-color:#cd5a4e5c;background:#cd5a4e12}.vocab-precheck-word{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.vocab-order{display:inline-flex;justify-content:center;align-items:center;min-width:2.25rem;min-height:2.25rem;border:1px solid var(--line);color:var(--muted)}.vocab-word-button{min-height:3rem;border:0;background:transparent;color:var(--vocab-ink);font-size:clamp(1.5rem,3vw,2.5rem);font-weight:800;cursor:pointer}.vocab-meaning{color:var(--accent-dark);font-size:1.125rem}.vocab-precheck-actions{display:flex;gap:.75rem}.vocab-mark{width:3.75rem;min-height:3.75rem;border:1px solid transparent;border-radius:999px;color:#fff;font-size:2rem;font-weight:900;cursor:pointer}.vocab-mark.correct{background:#2f7d4b}.vocab-mark.wrong{background:#cd5a4e}.vocab-class-footer{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:1rem}.vocab-counter{padding:.75rem 1rem;border:1px solid var(--line);background:#f7faf7eb;color:var(--muted);font-weight:700}.vocab-tile-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:1rem}.vocab-tile{position:relative;display:grid;align-content:center;gap:.5rem;min-height:14rem;padding:1.25rem;border:1px solid var(--line);background:radial-gradient(circle at top right,rgba(197,164,71,.12),transparent 34%),linear-gradient(180deg,#fff,#f8fbf8);cursor:pointer;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease,background .16s ease}.vocab-tile-index{position:absolute;top:.75rem;left:.75rem;display:inline-flex;justify-content:center;align-items:center;width:2rem;height:2rem;border-radius:999px;background:#2f7d4b1a;color:var(--accent-dark);font-weight:800}.vocab-tile.active{border-color:#2f7d4b80;background:radial-gradient(circle at top right,rgba(74,161,118,.2),transparent 34%),linear-gradient(180deg,#f5fff8,#fff);box-shadow:0 18px 40px #22382721;transform:translateY(-.125rem)}.vocab-tile.shadowing-current{border-color:#c5a447b8;background:radial-gradient(circle at top right,rgba(197,164,71,.24),transparent 34%),linear-gradient(180deg,#fffdf4,#fff)}.vocab-tile.dict-open{transform:translate(-1rem)}.vocab-tile-word{color:var(--vocab-ink);font-size:clamp(1.5rem,3vw,2.25rem);font-weight:900;line-height:1.1;word-break:break-word}.vocab-tile-phonetic,.vocab-tile-hint{color:var(--muted)}.vocab-tile-meaning{color:var(--accent-dark);font-size:1.125rem;line-height:1.55}.vocab-dict-button{position:absolute;right:.75rem;bottom:.75rem;min-height:2.5rem;padding:0 .75rem;border:1px solid rgba(47,125,75,.22);background:#ffffffe6;color:var(--accent-dark);cursor:pointer}.vocab-sequence{margin-bottom:1rem;padding:.875rem 1rem;border:1px dashed rgba(47,125,75,.28);background:#f7faf7db;color:var(--vocab-ink);font-weight:800;line-height:1.7}.vocab-paper-stage{display:grid;grid-template-columns:minmax(0,1fr) 5rem;gap:1.5rem;align-items:center;min-height:24rem}.vocab-paper-card{display:grid;place-items:center;gap:1rem;min-height:20rem;padding:2rem;border:2px solid rgba(197,164,71,.38);background:linear-gradient(135deg,rgba(197,164,71,.08) 25%,transparent 25%),linear-gradient(225deg,rgba(197,164,71,.08) 25%,transparent 25%),var(--vocab-paper);color:var(--vocab-ink);cursor:pointer;transition:transform .26s ease,opacity .26s ease}.vocab-paper-card.cut{transform:translate(-8rem) rotate(-5deg);opacity:0}.vocab-paper-word{font-size:clamp(3rem,8vw,7rem);font-weight:900;line-height:1}.vocab-paper-meaning{color:var(--accent-dark);font-size:clamp(1.25rem,3vw,2rem)}.vocab-scissor-button{width:5rem;min-height:5rem;border:1px solid rgba(205,90,78,.24);border-radius:999px;background:#cd5a4e1a;color:#a5473f;font-size:2.5rem;cursor:pointer}@media(max-width:900px){.vocab-tile-grid,.vocab-precheck-row,.vocab-class-footer,.vocab-paper-stage{grid-template-columns:1fr}.vocab-class-footer{align-items:stretch}.vocab-paper-stage{display:grid}.vocab-scissor-button{width:100%}}.vocabulary-review-note{margin-top:1rem}.vocab-review-card{display:grid;gap:1.25rem;padding:clamp(1.25rem,3vw,2rem);border:1px solid rgba(47,125,75,.18);background:radial-gradient(circle at top right,rgba(197,164,71,.12),transparent 32%),linear-gradient(180deg,#fff,#f8fbf8)}.vocab-review-card.revealed{border-color:#2f7d4b61;background:radial-gradient(circle at top right,rgba(74,161,118,.16),transparent 34%),linear-gradient(180deg,#f6fff8,#fff)}.vocab-review-word{color:var(--ink);font-size:clamp(3rem,9vw,7rem);font-weight:900;line-height:1;word-break:break-word}.vocab-review-word.consolidation-prompt{font-size:clamp(2rem,6vw,4rem)}.vocab-review-details{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(10rem,.8fr) minmax(12rem,1fr);gap:1rem;align-items:end}.vocab-review-meaning{margin:0;color:var(--accent-dark);font-size:clamp(1.4rem,3vw,2.25rem);font-weight:800;line-height:1.3}.vocab-review-audio{width:100%}.vocab-review-actions{display:flex;flex-wrap:wrap;gap:.75rem}.vocab-option-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.vocab-option{justify-content:flex-start;min-height:4rem;white-space:normal;text-align:left;line-height:1.5}@media(max-width:1180px){.page-shell,.login-card,.content-grid,.hero-grid,.vocab-review-details,.vocab-option-grid{grid-template-columns:1fr}.sidebar{border-right:0;border-bottom:1px solid var(--line)}}@media(max-width:900px){.dashboard-preview-grid,.stats-grid,.form-grid,.toolbar-grid,.summary-strip,.course-actions,.split-grid{grid-template-columns:1fr}.nav-group{grid-template-columns:repeat(2,minmax(0,1fr))}.nav-link{min-height:auto;padding:12px;grid-template-columns:36px 1fr}.header-bar,.header-actions{flex-direction:column;align-items:stretch}.main-area,.sidebar,.login-art,.login-panel{padding:20px}.login-art h1,.header-copy h1{max-width:none;font-size:34px}}@media(max-width:640px){body:before{display:none}.brand-title{font-size:30px}.header-copy h1,.panel h2,.hero-panel h2{font-size:28px}.summary-value{font-size:22px}.table th,.table td{padding:12px 10px;font-size:13px}.sidebar-footer,.empty-note,.feedback-note,.section-note{padding:14px}}html{font-size:16px;overflow-x:hidden;-webkit-text-size-adjust:100%}body,#root{overflow-x:hidden}body{line-height:1.5}a,button,input,select,textarea,.nav-link,.role-button{-webkit-tap-highlight-color:transparent}button,.ghost-button,.accent-button,.nav-link,.role-button{min-height:3rem}button:active,.ghost-button:active,.accent-button:active,.nav-link:active,.role-button:active{transform:scale(.98)}@media(hover:hover)and (pointer:fine){button:hover,.ghost-button:hover,.accent-button:hover,.nav-link:hover,.role-button:hover{transform:translateY(-.0625rem)}}@media(hover:none){button:hover,.ghost-button:hover,.accent-button:hover,.nav-link:hover,.role-button:hover{transform:none}}.page-shell{display:block;min-height:100dvh}.sidebar{gap:1rem;padding:max(1rem,env(safe-area-inset-top)) max(1rem,env(safe-area-inset-right)) 1rem max(1rem,env(safe-area-inset-left));border-right:0;border-bottom:1px solid var(--line)}.brand-block,.brand,.nav-group,.dashboard-grid,.section-stack,.stack-grid,.toolbar-stack,.panel-head,.preview-list,.hero-list{gap:.75rem}.main-area{padding:1rem max(1rem,env(safe-area-inset-right)) max(1rem,env(safe-area-inset-bottom)) max(1rem,env(safe-area-inset-left))}.header-bar,.header-actions,.preview-list-head,.inline-toolbar,.table-actions,.toolbar-actions{flex-direction:column;align-items:stretch}.nav-group,.dashboard-preview-grid,.split-grid,.summary-strip,.hero-grid,.stats-grid,.content-grid,.form-grid,.toolbar-grid,.course-actions{grid-template-columns:1fr}.nav-group{display:grid}.nav-link{grid-template-columns:2.75rem 1fr;gap:.75rem;padding:.5rem .75rem}.nav-tag{min-height:2rem}.main-area,.sidebar,.login-shell,.login-art,.login-panel,.panel,.hero-panel{padding-left:1rem;padding-right:1rem}.header-copy h1,.panel h2,.hero-panel h2,.login-panel h2{font-size:1.75rem}.header-copy p,.hero-panel p,.login-panel-copy,.section-note,.stat-note,.preview-list-secondary,.sidebar-footer p{font-size:1rem;line-height:1.5}.summary-item,.panel,.hero-panel,.stat-card,.sidebar-footer,.empty-note,.feedback-note,.section-note,.preview-list-row{padding:1rem}.summary-value{font-size:1.5rem}.field label,.summary-label,.stat-label,.table th{font-size:.75rem}.field input,.field select,.field textarea,.compact-input,.compact-display,.ghost-button,.accent-button{min-height:3rem;padding:.75rem .875rem;font-size:1rem}.mini-button{min-height:3rem;padding:.625rem .875rem;font-size:.875rem}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:.75rem}.mobile-stack{width:100%;border-collapse:separate;border-spacing:0}.mobile-stack thead{display:none}.mobile-stack tbody,.mobile-stack tr,.mobile-stack td{display:block;width:100%}.mobile-stack tr{margin-bottom:.75rem;border:1px solid var(--line);background:#ffffffeb}.mobile-stack td{display:grid;grid-template-columns:minmax(5.5rem,40%) 1fr;gap:.75rem;align-items:start;border-bottom:1px solid var(--line);padding:.75rem;font-size:.9375rem}.mobile-stack td:last-child{border-bottom:0}.mobile-stack td:before{content:attr(data-label);color:var(--muted);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase}.timetable-mobile-list{display:grid;gap:.75rem}.timetable-mobile-card{border:1px solid var(--line);background:#ffffffeb;padding:.875rem}.timetable-mobile-card-head{display:flex;justify-content:space-between;gap:.75rem;align-items:start;margin-bottom:.5rem}.timetable-mobile-card-time{color:var(--muted);font-size:.875rem}.timetable-mobile-empty{padding:1rem;border:1px dashed var(--line-strong);color:var(--muted)}.timetable-wrap{display:none}@media(max-width:47.9375rem){.login-shell{padding:max(1rem,env(safe-area-inset-top)) max(1rem,env(safe-area-inset-right)) max(1rem,env(safe-area-inset-bottom)) max(1rem,env(safe-area-inset-left))}.login-card{width:100%;grid-template-columns:1fr}.login-art{border-right:0;border-bottom:1px solid var(--line)}.login-title-zh{font-size:2.25rem}.login-title-en{font-size:1rem}}@media(min-width:23.4375rem){.summary-strip,.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.header-actions{flex-direction:row;flex-wrap:wrap;align-items:center}}@media(min-width:25.875rem){.nav-group,.toolbar-grid,.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.field.full{grid-column:1 / -1}}@media(min-width:48rem){.page-shell{display:grid;grid-template-columns:18rem 1fr}.sidebar{gap:1.375rem;padding:1.75rem 1.375rem 1.5rem;border-right:1px solid var(--line);border-bottom:0}.main-area{padding:1.75rem}.header-bar,.preview-list-head,.inline-toolbar{flex-direction:row;align-items:flex-start}.header-actions,.table-actions,.toolbar-actions{flex-direction:row;align-items:center}.nav-group{grid-template-columns:1fr}.dashboard-preview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.split-grid,.summary-strip,.stats-grid,.toolbar-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.hero-grid{grid-template-columns:1.2fr .8fr}.content-grid{grid-template-columns:1.35fr 1fr}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.course-actions{grid-template-columns:11rem minmax(14rem,1fr) auto}.timetable-mobile-list{display:none}.timetable-wrap{display:block}.mobile-stack thead{display:table-header-group}.mobile-stack tbody{display:table-row-group}.mobile-stack tr{display:table-row;margin:0;border:0;background:transparent}.mobile-stack td{display:table-cell;width:auto;padding:.875rem .75rem;border-bottom:1px solid var(--line);font-size:.875rem}.mobile-stack td:before{content:none}}body{background:radial-gradient(circle at 8% 0%,rgba(61,139,112,.06),transparent 18rem),linear-gradient(180deg,#fbfdfc,#f3f7f5);font-size:.875rem}body:before{opacity:.22;background-image:linear-gradient(rgba(34,71,55,.012) 1px,transparent 1px),linear-gradient(90deg,rgba(34,71,55,.012) 1px,transparent 1px);background-size:2rem 2rem;-webkit-mask-image:linear-gradient(180deg,transparent 0%,black 14%,transparent 92%);mask-image:linear-gradient(180deg,transparent 0%,black 14%,transparent 92%)}.page-shell{grid-template-columns:18rem minmax(0,1fr)}.main-area{width:min(100%,90rem);margin:0 auto;padding:2rem clamp(1rem,2.4vw,2.25rem) 3rem}.sidebar{position:sticky;top:0;height:100vh;padding:1.25rem;background:#f7fbf9eb;border-right:1px solid rgba(31,62,48,.1);box-shadow:.75rem 0 2rem #182d230a}.brand-block{gap:.875rem;padding:.5rem .5rem 1rem;border-bottom:1px solid rgba(31,62,48,.08)}.brand-logo-image{width:min(100%,12rem)}.brand-kicker,.header-kicker,.calendar-kicker{color:#6b7c73;font-size:.6875rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase}.brand-title{color:#14211a;font-size:1.55rem;letter-spacing:-.03em;text-transform:none}.nav-group{gap:.45rem}.nav-link{grid-template-columns:2.35rem 1fr;min-height:3rem;border-radius:.5rem;background:transparent;color:#32443b;font-size:.875rem;font-weight:700}.nav-link:hover{background:#1d8b6814}.nav-link.active{background:#e8f5f0;border-color:#1d8b682e;color:#0f513d;box-shadow:inset .1875rem 0 #2c9a74}.nav-tag{min-height:1.75rem;border-radius:.375rem;border-color:#1d8b681f;background:#ffffffc7;color:#547165}.sidebar-footer{border-radius:.75rem;border-color:#1f3e301a;background:#ffffffd1;box-shadow:0 .75rem 1.5rem #182d230d}.meta-chip{border-radius:999px;border-color:#2c9a742e;background:#e9f6f1;color:#17664d}.header-bar{align-items:center;min-height:4.75rem;margin-bottom:1.5rem;padding:1rem 1.125rem;border:1px solid rgba(31,62,48,.09);border-radius:.75rem;background:#ffffffe0;box-shadow:0 1rem 2rem #182d230d}.header-copy h1{margin-top:.35rem;font-size:clamp(1.5rem,2.4vw,2rem);letter-spacing:-.04em}.header-actions{gap:.65rem}.header-user-chip{display:grid;gap:.125rem;min-height:2.75rem;padding:.45rem .8rem;border:1px solid rgba(31,62,48,.1);border-radius:999px;background:#f7fbf9}.header-user-chip span{color:#6b7c73;font-size:.625rem;font-weight:800;letter-spacing:.14em}.header-user-chip strong{color:#18251f;font-size:.875rem;line-height:1}.card{border:1px solid rgba(31,62,48,.1);border-radius:.5rem;background:#fffffff0;box-shadow:0 1rem 2.5rem #182d230f}.teacher-workspace{gap:1rem}.teacher-workspace .hero-panel.hero-panel-intro{display:block}.teacher-workspace .hero-grid{grid-template-columns:minmax(0,1.35fr) minmax(20rem,.65fr)}.hero-panel{padding:1.35rem}.hero-panel h2{font-size:clamp(1.35rem,2.2vw,1.875rem);letter-spacing:-.04em}.stats-grid{gap:1rem}.stat-card{min-height:9rem;padding:1rem;border-radius:.5rem}.stat-topline,.panel-rule{width:2.25rem;height:.1875rem;border-radius:999px;background:#2c9a74}.stat-label{margin-top:.85rem;font-size:.75rem;font-weight:800;letter-spacing:.1em}.stat-value{margin:.75rem 0 .5rem;font-size:clamp(1.85rem,3.4vw,2.8rem)}.stat-note,.summary-note{display:block;color:#66776e;font-size:.8125rem}.panel{padding:1.25rem}.panel-head{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:start;gap:.75rem;margin-bottom:1.125rem}.panel-title-block{min-width:0}.panel h2{margin:0;font-size:clamp(1.125rem,1.6vw,1.45rem);letter-spacing:-.03em}.panel-subtitle{display:block;margin:.35rem 0 0;color:#687970;font-size:.875rem;line-height:1.5}.panel-back-button{margin-right:.5rem;padding:0;border:0;background:transparent;color:#17664d;cursor:pointer;font-size:inherit;font-weight:800}.ghost-button,.accent-button{display:inline-flex;align-items:center;justify-content:center;min-height:2.75rem;border-radius:.5rem;font-size:.875rem;font-weight:800;text-decoration:none}.ghost-button{border-color:#1f3e3024;background:#fff;color:#20352b}.ghost-button:hover{background:#f2f8f5;border-color:#2c9a7442}.accent-button{background:#1d8b68;border-color:#1d8b68;color:#fff;box-shadow:0 .5rem 1rem #1d8b6829}.accent-button:hover{background:#176f54;border-color:#176f54}.accent-button:disabled{cursor:not-allowed;opacity:.55;transform:none}.summary-strip{gap:.75rem}.summary-item{border-color:#1f3e3017;border-radius:.5rem;background:#f8fbfa}.summary-value{font-size:clamp(1.35rem,2.2vw,1.9rem)}.availability-summary{grid-template-columns:repeat(auto-fit,minmax(14rem,1fr))}.availability-unsaved{border-color:#c4872347;background:#fffaf0}.calendar-legend{display:flex;flex-wrap:wrap;gap:.75rem;margin:.9rem 0 1rem;color:#5f7168;font-size:.8125rem;font-weight:700}.calendar-legend span{display:inline-flex;align-items:center;gap:.375rem}.legend-dot,.availability-dot{display:inline-block;width:.55rem;height:.55rem;border-radius:999px}.legend-available,.availability-dot.available{background:#49a882}.legend-closed,.availability-dot.closed{background:#cbd5d0}.legend-unsaved{background:#d69e2e}.availability-board{min-width:0;overflow:hidden;border:1px solid rgba(31,62,48,.1);border-radius:.75rem;background:#fff}.availability-board-head{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.9rem 1rem;border-bottom:1px solid rgba(31,62,48,.08);background:#f7fbf9}.availability-board-head strong{display:block;margin-top:.25rem;font-size:1rem}.calendar-status-pill{display:inline-flex;align-items:center;min-height:1.75rem;padding:0 .65rem;border-radius:999px;background:#edf5f1;color:#25664f;font-size:.6875rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.calendar-status-pill.dirty{background:#fff3d7;color:#8a5b10}.stack-grid{grid-template-columns:1fr}.availability-grid{min-width:58rem;margin:0;padding:.75rem;gap:.25rem;overflow-x:auto;background:#fff}.availability-corner,.availability-day,.availability-time{min-height:2.45rem;border:0;border-radius:.375rem;background:#f2f6f4;color:#44594f;font-size:.75rem}.availability-slot{min-height:2.45rem;border:1px solid rgba(31,62,48,.08);border-radius:.375rem;background:#f4f7f5;color:transparent}.availability-slot.selected{background:#e5f5ee;border-color:#2c9a7447;color:transparent}.availability-slot:not(.readonly):hover{background:#d9f0e7;border-color:#2c9a7461}.availability-slot:not(.readonly):active{transform:scale(.97)}.availability-slot.readonly{background:#f7f9f8}.availability-slot.selected.readonly{background:#edf8f3}.calendar-toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;padding:.875rem 1rem;border:1px solid rgba(31,62,48,.09);border-radius:.75rem;background:#f7fbf9}.calendar-toolbar h3{margin:.2rem 0;font-size:1.25rem;letter-spacing:-.03em}.calendar-toolbar span{color:#63756c;font-size:.8125rem}.calendar-toolbar-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.5rem}.timetable-wrap{position:relative;overflow:auto;border:1px solid rgba(31,62,48,.1);border-radius:.75rem;background:#fff}.timetable-grid{min-width:66rem;border-collapse:separate;border-spacing:0;table-layout:fixed}.timetable-grid th,.timetable-grid td{border:0;border-right:1px solid rgba(31,62,48,.07);border-bottom:1px solid rgba(31,62,48,.07)}.timetable-grid thead th{position:sticky;top:0;z-index:3;background:#f7fbf9}.timetable-grid th{padding:.75rem .5rem;color:#45584f;font-size:.75rem}.timetable-head-today{background:#eaf7f2!important;color:#155f48!important}.time-head,.time-cell{position:sticky;left:0;z-index:4;width:5rem;min-width:5rem}.time-cell{padding:.55rem .5rem;background:#fbfcfb;color:#60746a;font-size:.75rem;font-weight:800}.timetable-grid tbody tr:nth-child(odd) .time-cell,.timetable-grid tbody tr:nth-child(odd) .timetable-cell{border-bottom-color:#1f3e301a}.timetable-cell{position:relative;height:3.05rem;padding:.25rem;background:#fbfcfb}.timetable-cell-available{background:#f1fbf6}.timetable-cell-unavailable,.timetable-cell-blocked,.timetable-cell-slot-blocked,.timetable-cell-cutoff{background:#f3f5f4}.timetable-cell.has-course{background:#fff}.calendar-now-line{position:absolute;right:.25rem;left:.25rem;top:50%;height:.125rem;border-radius:999px;background:#20a47a;box-shadow:0 0 0 .1875rem #20a47a1a}.calendar-empty-inline{padding:1rem;border-bottom:1px dashed rgba(31,62,48,.14);color:#66776e;font-weight:700}.calendar-course-card{position:relative;display:grid;grid-template-columns:auto minmax(0,1fr);gap:.4rem;width:100%;min-height:2.45rem;padding:.42rem .5rem .42rem .65rem;border:1px solid rgba(31,62,48,.11);border-left-width:.1875rem;border-radius:.375rem;background:#edf8f5;color:#163229;cursor:pointer;text-align:left;box-shadow:0 .35rem .85rem #182d230f}.calendar-course-card+.calendar-course-card{margin-top:.25rem}.calendar-course-card:hover{transform:translateY(-1px);box-shadow:0 .65rem 1.2rem #182d231a}.calendar-course-card.compact{grid-template-columns:auto minmax(0,1fr);min-height:2rem}.calendar-course-status-dot{width:.45rem;height:.45rem;margin-top:.28rem;border-radius:999px;background:currentColor}.calendar-course-main{display:grid;min-width:0;gap:.1rem}.calendar-course-main strong,.calendar-course-main span,.calendar-course-status{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-course-main strong{font-size:.75rem}.calendar-course-main span,.calendar-course-status{color:#5c6f66;font-size:.6875rem;line-height:1.25}.calendar-course-scheduled{border-left-color:#2c9a74;background:#e9f7f2}.calendar-course-trial{border-left-color:#4a90c2;background:#edf6fc}.calendar-course-completed{border-left-color:#7ea08e;background:#eef4f1}.calendar-course-cancelled{border-left-color:#c76f64;background:#fff0ee}.calendar-course-leave{border-left-color:#9aa8a1;background:#f1f3f2}.calendar-course-pending{border-left-color:#d8aa39;background:#fff8e6}.calendar-mobile-list{gap:.9rem}.calendar-mobile-day{border:1px solid rgba(31,62,48,.1);border-radius:.75rem;background:#fff;overflow:hidden}.calendar-mobile-day-head{display:flex;justify-content:space-between;padding:.75rem .85rem;border-bottom:1px solid rgba(31,62,48,.08);background:#f7fbf9}.calendar-mobile-day-list{display:grid;gap:.5rem;padding:.75rem}.course-detail-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:flex;justify-content:flex-end;background:#0c181247;-webkit-backdrop-filter:blur(.25rem);backdrop-filter:blur(.25rem)}.course-detail-drawer{width:min(100%,32rem);height:100%;overflow-y:auto;padding:1.25rem;background:#fff;box-shadow:-1rem 0 2.5rem #0c18122e}.course-detail-head{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;margin-bottom:1rem}.course-detail-head h3{margin:.25rem 0 0;font-size:1.5rem;letter-spacing:-.04em}.course-detail-grid{display:grid;gap:.75rem}.course-detail-grid div{display:grid;gap:.25rem;padding:.75rem;border:1px solid rgba(31,62,48,.09);border-radius:.5rem;background:#f8fbfa}.course-detail-grid span{color:#6b7c73;font-size:.6875rem;font-weight:900;letter-spacing:.11em;text-transform:uppercase}.course-detail-grid strong{color:#17251e;font-size:.9rem;line-height:1.45;word-break:break-word}.course-detail-actions{display:flex;gap:.65rem;margin-top:1rem}@media(min-width:64rem){.stack-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.teacher-workspace .timetable-wrap-compact{overflow-x:hidden;overflow-y:auto;max-height:min(58vh,42rem)}.teacher-workspace .timetable-wrap-compact .timetable-grid{width:100%;min-width:0}.teacher-workspace .timetable-wrap-compact .time-head,.teacher-workspace .timetable-wrap-compact .time-cell{width:3.75rem;min-width:3.75rem}.teacher-workspace .timetable-wrap-compact .timetable-grid th{padding:.45rem .25rem;font-size:.68rem}.teacher-workspace .timetable-wrap-compact .timetable-date{margin-top:.2rem;font-size:.66rem}.teacher-workspace .timetable-wrap-compact .time-cell{padding:.35rem .25rem;font-size:.68rem}.teacher-workspace .timetable-wrap-compact .timetable-cell{height:2.05rem;padding:.12rem}.teacher-workspace .timetable-wrap-compact .calendar-course-card{min-height:1.72rem;padding:.2rem .25rem;gap:.2rem;border-left-width:.15rem;box-shadow:none}.teacher-workspace .timetable-wrap-compact .calendar-course-status-dot{width:.34rem;height:.34rem;margin-top:.22rem}.teacher-workspace .timetable-wrap-compact .calendar-course-main strong{font-size:.64rem}.teacher-workspace .timetable-wrap-compact .calendar-course-main span,.teacher-workspace .timetable-wrap-compact .calendar-course-status{display:none}@media(max-width:63.9375rem){.page-shell{display:block}.sidebar{position:relative;height:auto}.main-area{padding:1rem}.teacher-workspace .hero-grid,.stats-grid,.summary-strip{grid-template-columns:1fr}.header-bar,.calendar-toolbar{align-items:stretch;flex-direction:column}.header-actions,.calendar-toolbar-actions{justify-content:flex-start}.header-user-chip,.brand-logo.compact{display:none}.panel-head{grid-template-columns:auto minmax(0,1fr)}.panel-head>.ghost-button{grid-column:1 / -1;width:fit-content}.course-detail-backdrop{align-items:flex-end}.course-detail-drawer{width:100%;height:min(88vh,44rem);border-radius:1rem 1rem 0 0}}@media(max-width:47.9375rem){.teacher-workspace{gap:.75rem}.teacher-workspace .hero-grid,.teacher-workspace .stats-grid{display:none}.teacher-workspace .panel{padding:.875rem}.teacher-workspace .panel-head{margin-bottom:.75rem}.teacher-workspace .panel h2{font-size:1.05rem}.teacher-workspace .panel-subtitle{font-size:.78rem}.teacher-workspace .calendar-toolbar{margin-bottom:.75rem;padding:.75rem}.teacher-workspace .calendar-toolbar h3{font-size:1.05rem}.teacher-workspace .calendar-toolbar-actions .mini-button{flex:1 1 0}.teacher-workspace .timetable-wrap{display:none}.teacher-workspace .calendar-mobile-list{display:grid;max-height:58vh;overflow-y:auto;padding-right:.125rem}.teacher-workspace .calendar-mobile-day{border-radius:.625rem}.teacher-workspace .calendar-mobile-day-head{padding:.55rem .7rem}.teacher-workspace .calendar-mobile-day-list{gap:.4rem;padding:.6rem}.teacher-workspace .calendar-course-card{min-height:2.25rem;padding:.34rem .45rem}}
