:root{--ink:#0b1220;--muted:#586575;--line:#d7e2ea;--paper:#f7fafc;--panel:#fff;--panel-soft:#eaf2f8;--green:#22c55e;--amber:#f59e0b;--red:#ef4444;--cyan:#0e7490;--shadow:0 22px 60px #0b12201f;--font-body:"Avenir Next", "Noto Sans SC", sans-serif;--font-data:"DIN Alternate", "Avenir Next", sans-serif;color:var(--ink);background:var(--paper);font-family:var(--font-body);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.58}.teacher-shell{background:linear-gradient(90deg, #0b1220f5 0 280px, transparent 280px), repeating-linear-gradient(135deg, #0e74900f 0 1px, transparent 1px 18px), var(--paper);grid-template-columns:280px minmax(0,1fr);min-height:100vh;display:grid}.side-rail{color:#f8fafc;flex-direction:column;gap:24px;height:100vh;padding:28px 22px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:14px;display:flex}.brand>span{color:#07111f;width:52px;height:52px;font-family:var(--font-data);background:#22c55e;border:1px solid #ffffff47;border-radius:16px 4px;place-items:center;font-weight:800;display:grid}.brand p,.kicker{color:var(--cyan);font-family:var(--font-data);letter-spacing:0;text-transform:uppercase;margin:0;font-size:12px;font-weight:800}.brand p{color:#7dd3fc}.brand h1,.topbar h2,.login-panel h3,.empty-state h3,.editor-panel h3{letter-spacing:0;margin:0}.brand h1{margin-top:4px;font-size:24px}.env-pill,.teacher-card{background:#ffffff0f;border:1px solid #ffffff29;border-radius:8px}.env-pill{color:#cbd5e1;font-family:var(--font-data);overflow-wrap:anywhere;padding:10px 12px;font-size:12px}.teacher-card{margin-top:auto;padding:16px}.teacher-card small,.teacher-card span{color:#94a3b8;display:block}.teacher-card strong{margin:8px 0;font-size:22px;display:block}.rail-button,.toolbar button,.form-actions button,.panel-title button,.editor-panel>button,.day-head,.mini-list button{border:1px solid var(--line);background:var(--panel);color:var(--ink);border-radius:8px}.rail-button{color:#f8fafc;background:0 0;border-color:#ffffff47;padding:12px}.workspace{min-width:0;padding:28px}.topbar{border:1px solid var(--line);box-shadow:var(--shadow);background:#ffffffdb;border-radius:12px;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:18px;padding:22px;display:flex}.topbar h2{margin:4px 0;font-size:32px}.topbar p{color:var(--muted);margin:0}.toolbar{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.toolbar button,.form-actions button,.panel-title button,.editor-panel>button{min-height:42px;padding:0 16px;font-weight:800}.notice{border:1px solid;border-radius:8px;margin-bottom:14px;padding:14px 16px;font-weight:700}.notice.error{color:#991b1b;background:#fef2f2;border-color:#fecaca}.notice.success{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.login-panel,.empty-state,.editor-panel{background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:12px}.login-panel,.empty-state{gap:18px;max-width:760px;padding:28px;display:grid}.login-panel h3,.empty-state h3,.editor-panel h3{font-size:24px}.login-panel p,.empty-state p{color:var(--muted);margin:6px 0 0}label{color:var(--ink);gap:8px;font-weight:800;display:grid}input,select,textarea{border:1px solid var(--line);width:100%;color:var(--ink);background:#fff;border-radius:8px;outline:none;min-height:44px;padding:10px 12px}textarea{resize:vertical}input:focus,select:focus,textarea:focus{border-color:var(--cyan);box-shadow:0 0 0 3px #0e74901f}.form-actions{flex-wrap:wrap;gap:10px;display:flex}.primary{background:var(--ink)!important;color:#fff!important;border-color:var(--ink)!important}.danger{color:var(--red)!important;background:#fff!important;border-color:#fecaca!important}.calendar-grid{grid-template-columns:repeat(7,minmax(132px,1fr));gap:10px;padding-bottom:12px;display:grid;overflow-x:auto}.day-column{border:1px solid var(--line);background:#eaf2f8b8;border-radius:12px;min-height:440px;padding:10px}.day-head{text-align:left;width:100%;margin-bottom:10px;padding:12px}.day-head span,.event-block span,.event-block small,.mini-list small{color:var(--muted);font-size:12px}.day-head strong{font-family:var(--font-data);margin-top:4px;font-size:24px;display:block}.event-block{border:1px solid #bae6fd;border-left:5px solid var(--green);width:100%;color:var(--ink);text-align:left;background:#fff;border-radius:8px;gap:5px;margin-bottom:8px;padding:12px;display:grid}.event-block.active{border-color:var(--amber);border-left-color:var(--amber)}.event-block strong{font-size:16px}.side-panels{grid-template-columns:minmax(320px,1.1fr) minmax(260px,.8fr) minmax(260px,.8fr);align-items:start;gap:16px;margin-top:16px;display:grid}.editor-panel{gap:14px;padding:18px;display:grid}.panel-title{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.two-col{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.checkline{grid-template-columns:none;align-items:center;gap:10px;font-weight:700;display:flex}.checkline input{width:18px;min-height:18px}.mini-list{gap:8px;max-height:280px;display:grid;overflow:auto}.mini-list button{text-align:left;grid-template-columns:minmax(0,1fr) auto;gap:4px 8px;padding:10px;display:grid}.mini-list span{font-weight:800}.mini-list small{grid-column:1/2}.mini-list b{color:var(--red);grid-area:1/2/3;align-self:center;font-size:12px}@media (width<=1180px){.teacher-shell{background:var(--paper);display:block}.side-rail{background:var(--ink);height:auto;position:static}.side-panels{grid-template-columns:1fr}}@media (width<=720px){.workspace{padding:14px}.topbar{padding:16px;display:grid}.topbar h2{font-size:26px}.login-panel,.empty-state{padding:18px}.two-col{grid-template-columns:1fr}}
