:root{--ink:#0b1220;--muted:#586575;--line:#d9e1e7;--paper:#f3f7f6;--panel:#fff;--panel-soft:#e8f1ef;--green:#1f8a70;--amber:#c46a2b;--red:#c2413a;--cyan:#0e7490;--cream:#fffaf1;--shadow:0 22px 60px #0b12201f;--shadow-soft:0 12px 36px #0b122014;--glow:0 0 28px #0e74902e;--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, #0b1220fa 0 280px, transparent 280px), radial-gradient(circle at 74% 8%, #0e749024, transparent 34%), radial-gradient(circle at 40% 96%, #1f8a701f, transparent 32%), repeating-linear-gradient(135deg, #1f8a7012 0 1px, transparent 1px 22px), 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{background:var(--green);color:#07111f;width:52px;height:52px;font-family:var(--font-data);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}.module-nav{gap:10px;display:grid}.module-nav button{color:#e5eef6;text-align:left;background:linear-gradient(135deg,#1f8a701f,#0e749014),#ffffff0a;border:1px solid #ffffff24;border-radius:16px;gap:4px;min-height:70px;padding:12px 14px;transition:border-color .16s,background-color .16s,transform .16s,box-shadow .16s;display:grid}.module-nav button:hover,.module-nav button.active{background:linear-gradient(135deg,#1f8a7047,#0e749029),#ffffff14;border-color:#7dd3fc8c;transform:translate(3px);box-shadow:0 0 0 1px #7dd3fc1f,0 18px 36px #0000002e}.module-nav span{color:#7dd3fc;font-family:var(--font-data);text-transform:uppercase;font-size:11px;font-weight:800}.module-nav strong{font-size:15px}.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}.teacher-card__meta{border-top:1px solid #ffffff29;margin-top:16px;padding-top:14px}.teacher-card__meta b{color:#fff;font-family:var(--font-data);font-size:36px;line-height:1;display:block}.teacher-card__meta em{color:#94a3b8;margin-top:4px;font-size:12px;font-style:normal;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-soft), var(--glow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffe6;border-radius:18px;grid-template-columns:minmax(260px,1fr) auto auto;align-items:center;gap:20px;margin-bottom:18px;padding:24px;display:grid}.topbar h2{margin:4px 0;font-size:clamp(28px,4vw,42px);line-height:1.08}.topbar p{color:var(--muted);margin:0}.toolbar{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.summary-strip{grid-template-columns:repeat(3,minmax(82px,1fr));gap:8px;min-width:300px;display:grid}.summary-strip div{background:var(--cream);border:1px solid #0b12201a;border-radius:14px;padding:12px 14px}.summary-strip strong{color:var(--ink);font-family:var(--font-data);font-size:28px;line-height:1;display:block}.summary-strip span{color:var(--muted);margin-top:5px;font-size:12px;display:block}.toolbar button,.form-actions button,.panel-title button,.editor-panel>button{min-height:42px;padding:0 16px;font-weight:800;transition:border-color .16s,background-color .16s,color .16s,box-shadow .16s}.toolbar button:hover,.panel-title button:hover,.editor-panel>button:hover{background:#1f8a7014;border-color:#1f8a7073}.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);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;background:#fff;border-radius:12px;outline:none;min-height:44px;padding:10px 12px}input[type=color]{min-height:44px;padding:6px}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{box-shadow:0 10px 24px #1f8a7033;background:var(--green)!important;color:#fff!important;border-color:var(--green)!important}.danger{color:var(--red)!important;background:#fff!important;border-color:#fecaca!important}.calendar-section{border:1px solid var(--line);box-shadow:var(--shadow-soft);background:linear-gradient(135deg,#ffffffe0,#e8f1efb3),#ffffffc2;border-radius:18px;padding:18px}.section-caption{justify-content:space-between;align-items:end;gap:16px;margin-bottom:16px;display:flex}.section-caption h3{color:var(--ink);margin:4px 0 0;font-size:24px}.section-caption p{color:var(--muted);margin:0}.calendar-grid{grid-template-columns:repeat(7,minmax(148px,1fr));gap:12px;padding-bottom:12px;display:grid;overflow-x:auto}.day-column{border:1px solid var(--line);background:#e8f1efc7;border-radius:16px;min-height:470px;padding:10px}.day-column.today{background:#eff8f5;border-color:#1f8a7080}.day-column.empty{background:#fffaf1b8}.day-head{text-align:left;background:#ffffffdb;width:100%;min-height:82px;margin-bottom:10px;padding:13px;position:relative}.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}.day-head em{color:var(--green);background:#1f8a701f;border-radius:999px;padding:3px 8px;font-size:11px;font-style:normal;font-weight:800;position:absolute;top:10px;right:10px}.event-block{border:1px solid #1f8a7033;border-left:5px solid var(--green);width:100%;color:var(--ink);text-align:left;background:#fff;border-radius:14px;gap:6px;margin-bottom:10px;padding:13px;transition:border-color .16s,box-shadow .16s,transform .16s;display:grid;box-shadow:0 10px 24px #0b12200f}.event-block:hover{border-color:#1f8a707a;box-shadow:0 16px 34px #0b12201a}.event-block.active{border-color:var(--amber);border-left-color:var(--amber);box-shadow:0 0 0 3px #c46a2b21}.event-block strong{font-size:16px}.event-time{font-family:var(--font-data);font-weight:800}.event-student{font-weight:800;color:var(--ink)!important}.event-type{background:#0e74901a;border-radius:999px;justify-self:start;padding:3px 8px;font-weight:900;color:var(--cyan)!important}.event-block i{color:var(--muted);background:#0b12200f;border-radius:999px;justify-self:start;padding:3px 8px;font-size:11px;font-style:normal;font-weight:800}.empty-slot{width:100%;min-height:120px;color:var(--muted);background:#ffffff8a;border:1px dashed #58657559;border-radius:14px;font-weight:800}.empty-slot:hover{color:var(--green);background:#1f8a700f;border-color:#1f8a7085}.module-layout{gap:18px;display:grid}.schedule-layout{grid-template-columns:minmax(0,1fr) minmax(340px,.34fr);align-items:start}.side-panels{grid-template-columns:minmax(340px,1.08fr) minmax(280px,.74fr) minmax(280px,.74fr);align-items:start;gap:16px;margin-top:16px;display:grid}.editor-panel{background:linear-gradient(180deg, #fffffff2, #fffaf1b8), var(--panel);box-shadow:var(--shadow-soft);border-radius:18px;gap:14px;padding:20px;display:grid}.schedule-editor{position:sticky;top:20px}.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;background:var(--cream);grid-template-columns:minmax(0,1fr) auto;gap:4px 8px;padding:12px;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}.resource-module{grid-template-columns:minmax(320px,.36fr) minmax(0,1fr);align-items:start;gap:18px;display:grid}.resource-editor{position:sticky;top:20px}.resource-list-panel{border:1px solid var(--line);background:linear-gradient(135deg, #ffffffe6, #e8f1ef9e), var(--panel);min-height:520px;box-shadow:var(--shadow-soft);border-radius:18px;padding:20px}.resource-list{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px;margin-top:16px;display:grid}.resource-list button{min-height:124px;color:var(--ink);text-align:left;background:linear-gradient(135deg,#fffaf1,#fff);border:1px solid #1f8a702e;border-radius:16px;grid-template-columns:minmax(0,1fr) auto;gap:6px 10px;padding:16px;display:grid;box-shadow:0 12px 28px #0b12200f}.resource-list button:hover{border-color:#1f8a707a;box-shadow:0 18px 38px #0b12201a}.resource-list span{align-items:center;gap:8px;font-size:18px;font-weight:900;display:flex}.course-type-list i{border-radius:999px;flex:none;width:12px;height:12px;box-shadow:0 0 0 3px #0e74901a}.resource-list small{color:var(--cyan);background:#0e74901a;border-radius:999px;justify-self:end;padding:3px 8px;font-size:12px;font-weight:800}.resource-list em{color:var(--muted);grid-column:1/3;font-style:normal;line-height:1.6}.resource-list b{color:var(--red);place-self:end start;font-size:12px}.resource-empty{min-height:220px;color:var(--muted);border:1px dashed #58657559;border-radius:18px;grid-column:1/-1;place-items:center;font-weight:800;display:grid}@media (width<=1180px){.teacher-shell{background:var(--paper);display:block}.side-rail{background:var(--ink);height:auto;position:static}.side-panels,.schedule-layout,.resource-module,.topbar{grid-template-columns:1fr}.summary-strip{min-width:0}.schedule-editor,.resource-editor{position:static}}@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}.section-caption{align-items:start;display:grid}.calendar-grid{grid-template-columns:1fr;display:grid;overflow-x:visible}.day-column{min-height:auto}.summary-strip{grid-template-columns:1fr}}
