:root{--accent:#1d4ed8;--ink:#0f172a;--muted:#64748b;--line:#dfe6ef;--shadow:0 16px 42px #0f172a14;color:var(--ink);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f4f7fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input,select,textarea{letter-spacing:0}button{-webkit-tap-highlight-color:transparent}p,h1,h2,h3{overflow-wrap:anywhere}.app-shell{background:radial-gradient(circle at 86% 12%,#facc152e,#0000 28%),radial-gradient(circle at 42% 5%,#14b8a621,#0000 26%),linear-gradient(#ffffffd1,#f2f6fac7),#f4f7fb;grid-template-columns:280px minmax(0,1fr);min-height:100vh;display:grid}.auth-page{background:radial-gradient(circle at 20% 18%,#2563eb26,#0000 30%),radial-gradient(circle at 88% 78%,#0f766e29,#0000 30%),#f4f7fb;place-items:center;min-height:100vh;padding:28px;display:grid}.auth-shell{grid-template-columns:minmax(0,1fr) 420px;gap:18px;width:min(1040px,100%);display:grid}.auth-visual{color:#dbeafe;min-height:540px;box-shadow:var(--shadow);background:linear-gradient(135deg,#0f172af5,#1e40afe6 58%,#0f766ee0),#172554;border-radius:8px;flex-direction:column;justify-content:center;padding:34px;display:flex}.auth-visual h1{color:#fff;letter-spacing:0;max-width:620px;margin:0;font-size:clamp(34px,6vw,58px);line-height:1.02}.auth-visual p{color:#c7d2fe;max-width:580px;margin:18px 0 0;font-size:18px}.feature-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:28px;display:grid}.feature-grid span{color:#fff;overflow-wrap:anywhere;background:#ffffff1a;border:1px solid #ffffff2e;border-radius:8px;min-width:0;padding:12px}.sidebar{border-right:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffdb;flex-direction:column;gap:24px;height:100vh;padding:24px;display:flex;position:sticky;top:0}.brand,.nav-item,.table-card{font:inherit}.brand{width:100%;color:var(--ink);text-align:left;cursor:pointer;background:0 0;border:0;align-items:center;gap:12px;padding:0;display:flex}.brand-mark{color:#fff;background:linear-gradient(135deg,#2563eb,#0f766e);border-radius:8px;place-items:center;width:44px;height:44px;font-weight:800;display:grid;box-shadow:0 16px 34px #0f766e3d}.brand strong,.user-chip strong,.sidebar-card strong{color:var(--ink);display:block}.brand small,.user-chip small,.sidebar-card small{color:var(--muted)}.nav-list{gap:8px;display:grid}.nav-item{min-height:42px;color:var(--muted);text-align:left;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;transition:background .2s,border-color .2s,color .2s;display:flex}.nav-item:hover,.nav-item.active{color:var(--ink);border-color:var(--line);background:#fff}.icon{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.9px;flex:none;width:18px;height:18px}.sidebar-card,.auth-card,.security-panel,.edit-panel,.schedule-table-wrap,.notice,.empty-state,.filter-grid,.directory-card,.directory-tabs,.insight-band{border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;border-radius:8px}.sidebar-card{margin-top:auto;padding:16px}.eyebrow{color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px;font-size:12px;font-weight:800;display:block}.mini-progress{background:#e8edf5;border-radius:999px;height:7px;margin:14px 0 8px;overflow:hidden}.mini-progress span{border-radius:inherit;background:var(--table-accent,#2563eb);height:100%;display:block}.workspace{min-width:0;padding:24px 28px}.notice{color:#92400e;background:#fffbeb;align-items:center;gap:10px;margin-bottom:14px;padding:12px 14px;display:flex}.topbar{justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:18px;display:flex}.topbar h1{color:var(--ink);letter-spacing:0;margin:0;font-size:clamp(28px,4vw,46px);line-height:1.02}.user-chip{border:1px solid var(--line);background:#fff;border-radius:8px;align-items:center;gap:10px;min-width:220px;padding:10px 12px;display:flex}.avatar{color:#0f172a;background:#dbeafe;border-radius:8px;place-items:center;width:38px;height:38px;font-size:13px;font-weight:800;display:grid}.start-grid{gap:18px;display:grid}.intro-panel{border:1px solid var(--line);color:#dbeafe;min-height:340px;box-shadow:var(--shadow);background:linear-gradient(120deg,#0f172aeb,#1e40afe0),#172554;border-radius:8px;grid-template-columns:minmax(0,1.12fr) minmax(340px,.88fr);gap:24px;padding:28px 32px;display:grid}.school-hero{background:linear-gradient(120deg,#0f172af2,#1e40afd6 58%,#0f766ee0),#172554;position:relative;overflow:hidden}.school-hero:after{content:"";border:44px solid #facc152e;border-radius:50%;width:360px;height:360px;position:absolute;bottom:-130px;right:-80px}.intro-copy{z-index:1;flex-direction:column;justify-content:center;max-width:720px;display:flex;position:relative}.intro-copy .eyebrow{color:#93c5fd}.intro-copy h2{color:#fff;letter-spacing:0;margin:0;font-size:clamp(27px,3.4vw,38px);line-height:1.06}.intro-copy p{color:#c7d2fe;max-width:620px;margin:14px 0 0;font-size:16px}.actions{flex-wrap:wrap;gap:12px;margin-top:20px;display:flex}.primary-button,.ghost-button{color:#fff;min-height:42px;font:inherit;cursor:pointer;background:#1d4ed8;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:9px;padding:10px 16px;font-weight:750;transition:transform .2s,box-shadow .2s,background .2s;display:inline-flex}.primary-button:hover,.ghost-button:hover{transform:translateY(-1px);box-shadow:0 14px 28px #0f172a24}.primary-button:disabled{cursor:progress;opacity:.72;transform:none}.danger-button{color:#b91c1c;background:#fff;border-color:#fecaca}.ghost-button{color:var(--ink);border-color:var(--line);background:#fff}.intro-panel .ghost-button{color:#fff;background:#ffffff1f;border-color:#ffffff47}.wide{width:100%}.icon-only{width:42px;padding:0}.school-preview{z-index:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1a;border:1px solid #ffffff2e;border-radius:8px;align-self:center;gap:14px;padding:14px;display:grid;position:relative}.week-board{background:#ffffffeb;border-radius:8px;grid-template-columns:repeat(5,1fr);gap:8px;padding:10px;display:grid}.week-board span{color:var(--muted);text-align:center;font-size:12px;font-weight:900}.week-cell{background:linear-gradient(135deg, color-mix(in srgb, var(--subject-color) 86%, white), var(--subject-color));border-radius:7px;min-height:42px;box-shadow:inset 0 -10px 18px #00000014}.preview-stack{gap:10px;display:grid}.preview-row{min-height:56px;color:var(--ink);background:#ffffffeb;border-radius:8px;grid-template-columns:70px 76px 1fr;align-items:center;gap:12px;padding:12px 14px;display:grid}.preview-row span{color:var(--muted);font-weight:700}.preview-row small{color:var(--muted)}.visual-strip{grid-template-columns:250px minmax(0,1fr);gap:12px;display:grid}.bell-card,.subject-palette{border:1px solid var(--line);min-width:0;box-shadow:var(--shadow);background:#fff;border-radius:8px;padding:14px}.bell-card{align-items:center;gap:12px;display:flex}.bell-card .icon{color:#c2410c;width:34px;height:34px}.bell-card span{color:var(--muted);font-size:13px;font-weight:800;display:block}.bell-card strong{color:var(--ink)}.subject-palette{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.subject-palette span{min-height:34px;color:color-mix(in srgb, var(--subject-color) 70%, #0f172a);background:color-mix(in srgb, var(--subject-color) 13%, white);border-radius:999px;align-items:center;padding:6px 12px;font-size:13px;font-weight:850;display:inline-flex}.stats-strip,.metrics-row{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.metric{border:1px solid var(--line);background:#fff;border-radius:8px;min-width:0;padding:16px}.metric span{color:var(--muted);margin-bottom:8px;font-size:13px;font-weight:700;display:block}.metric strong{overflow-wrap:anywhere;color:var(--ink);font-size:22px;line-height:1.12;display:block}.login-layout{grid-template-columns:minmax(320px,440px) minmax(0,1fr);align-items:stretch;gap:18px;display:grid}.segmented{border:1px solid var(--line);background:#f8fafc;border-radius:8px;grid-template-columns:1fr 1fr;gap:6px;padding:4px;display:grid}.segmented button,.directory-tabs button{min-height:38px;color:var(--muted);font:inherit;cursor:pointer;background:0 0;border:0;border-radius:7px;font-weight:800}.segmented button.active,.directory-tabs button.active{color:var(--ink);background:#fff;box-shadow:0 8px 18px #0f172a14}.form-alert{color:#1d4ed8;background:#eff6ff;border-radius:8px;padding:11px 12px}.auth-card,.security-panel{flex-direction:column;gap:18px;padding:24px;display:flex}.auth-card h2,.section-heading h2,.edit-panel h2,.security-panel h3{color:var(--ink);letter-spacing:0;margin:0;font-size:28px}.auth-card p,.security-panel p,.table-card p{color:var(--muted);margin:8px 0 0}.security-panel{background:linear-gradient(135deg,#dbeafecc,#ecfdf5db),#fff;justify-content:center;min-height:420px}.school-panel{background:linear-gradient(135deg,#fef9c3c2,#dbeafec7),#fff}.security-panel>.icon{color:#0f766e;width:46px;height:46px}.role-list{flex-wrap:wrap;gap:10px;display:flex}.role-list span,.status-pill,.group-badge,.load-chip{white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;min-height:28px;padding:4px 10px;font-size:12px;font-weight:800;display:inline-flex}.role-list span{color:#0f766e;background:#ccfbf1}.field{color:var(--muted);gap:8px;font-size:13px;font-weight:800;display:grid}input,select,textarea{box-sizing:border-box;width:100%;min-height:42px;color:var(--ink);font:inherit;background:#fff;border:1px solid #d8dee8;border-radius:8px}input,select{padding:0 12px}textarea{resize:vertical;padding:12px}input:focus,select:focus,textarea:focus,button:focus-visible{outline-offset:2px;border-color:#2563eb;outline:3px solid #2563eb2e}.check-row{color:var(--ink);align-items:center;gap:10px;font-weight:700;display:flex}.check-row input{width:18px;min-height:18px}.tables-view{gap:18px;display:grid}.section-heading{justify-content:space-between;align-items:end;gap:18px;display:flex}.table-cards{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.table-card{min-height:292px;color:var(--ink);text-align:left;border:1px solid var(--line);cursor:pointer;box-shadow:var(--shadow);background:#fff;border-radius:8px;flex-direction:column;align-items:stretch;padding:18px;display:flex;position:relative}.table-card:before{content:"";background:var(--table-accent);border-radius:8px 8px 0 0;height:4px;position:absolute;inset:0 0 auto}.table-card.selected{border-color:var(--table-accent);box-shadow:0 18px 44px #0f172a24}.table-card h3{color:var(--ink);letter-spacing:0;margin:18px 0 0;font-size:24px;line-height:1.12}.status-pill{color:var(--table-accent);background:color-mix(in srgb, var(--table-accent) 12%, white);align-self:flex-start}.card-metrics{color:var(--muted);gap:8px;margin:22px 0;font-size:14px;font-weight:700;display:grid}.school-card-visual{background:color-mix(in srgb, var(--table-accent) 8%, white);border-radius:8px;gap:10px;margin-top:18px;padding:12px;display:grid}.school-card-visual span{color:var(--table-accent);font-size:13px;font-weight:900}.school-card-visual div{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.school-card-visual i{background:linear-gradient(180deg, color-mix(in srgb, var(--table-accent) 28%, white), #fff);border:1px solid color-mix(in srgb, var(--table-accent) 24%, white);border-radius:7px;height:38px}.quality-row{align-items:baseline;gap:8px;margin-top:auto;display:flex}.quality-row strong{color:var(--ink);font-size:30px;line-height:1}.quality-row span,.table-card small{color:var(--muted)}.editor-layout{align-items:start;gap:18px;display:grid}.editor-main{gap:14px;min-width:0;display:grid}.insight-band{background:linear-gradient(135deg,#ffffffeb,#ecfdf5db),#fff;grid-template-columns:repeat(3,minmax(120px,1fr)) 180px;gap:12px;padding:14px;display:grid}.insight-band span{color:var(--muted);text-transform:uppercase;margin-bottom:6px;font-size:12px;font-weight:850;display:block}.insight-band strong{color:var(--ink);font-size:24px}.load-wave{justify-content:end;align-items:end;gap:7px;min-height:52px;display:flex}.load-wave i{background:linear-gradient(#facc15,#0f766e);border-radius:999px 999px 4px 4px;width:16px}.editor-toolbar{grid-template-columns:minmax(260px,1fr) 180px 42px auto auto;align-items:center;gap:10px;display:grid}.filter-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;padding:14px;display:grid}.search-field{position:relative}.search-field .icon{color:var(--muted);position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-field input{padding-left:40px}.schedule-table-wrap{overflow:auto}.schedule-table{border-collapse:collapse;text-align:left;width:100%;min-width:1080px}.schedule-table th,.schedule-table td{border-bottom:1px solid var(--line);padding:14px 12px}.schedule-table th{z-index:1;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;background:#f8fafc;font-size:12px;position:sticky;top:0}.schedule-table tr{cursor:pointer}.schedule-table tbody tr{border-left:4px solid #0000}.schedule-table tbody tr.selected-row{border-left-color:var(--subject-color)}.load-chip.danger{color:#b91c1c;background:#fee2e2}.subject-chip{align-items:center;gap:8px;font-weight:850;display:inline-flex}.subject-chip:before{content:"";background:var(--subject-color);width:10px;height:10px;box-shadow:0 0 0 4px color-mix(in srgb, var(--subject-color) 14%, transparent);border-radius:50%}.edit-panel{gap:16px;padding:18px;display:grid;position:sticky;top:28px}.edit-panel form{gap:16px;display:grid}.panel-title h2{font-size:24px}.subject-banner{color:#fff;background:linear-gradient(135deg, color-mix(in srgb, var(--subject-color) 92%, #111827), var(--subject-color)), var(--subject-color);box-shadow:0 16px 30px color-mix(in srgb, var(--subject-color) 22%, transparent);border-radius:8px;align-items:center;gap:12px;padding:14px;display:flex}.subject-banner .icon{width:32px;height:32px}.subject-banner span{color:#ffffffc7;text-transform:uppercase;font-size:12px;font-weight:900;display:block}.subject-banner strong{color:#fff;font-size:20px;display:block}.form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}input[type=range]{accent-color:#1d4ed8;padding:0}.warning-box{color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;gap:10px;padding:12px;display:flex}.panel-actions{gap:10px;display:grid}.empty-state{min-height:280px;color:var(--muted);text-align:center;align-content:center;place-items:center;gap:10px;padding:24px;display:grid}.empty-state .icon{color:#1d4ed8;width:42px;height:42px}.empty-state strong{color:var(--ink);font-size:22px}.directories,.access-page{gap:16px;display:grid}.access-card{border:1px solid var(--line);min-height:220px;box-shadow:var(--shadow);background:linear-gradient(135deg,#fffffff0,#eff6ffe6),#fff;border-radius:8px;grid-template-columns:72px minmax(0,1fr);align-items:center;gap:18px;padding:24px;display:grid}.access-card h2{color:var(--ink);letter-spacing:0;margin:0;font-size:32px}.access-card p{max-width:640px;color:var(--muted);margin:10px 0 0;font-size:17px}.access-mark{color:#1d4ed8;background:#dbeafe;border-radius:8px;place-items:center;width:72px;height:72px;display:grid}.access-mark.active{color:#0f766e;background:#ccfbf1}.access-mark .icon{width:34px;height:34px}.access-details{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.directory-tabs{flex-wrap:wrap;gap:8px;padding:8px;display:flex}.directory-tabs button{align-items:center;gap:8px;padding:8px 12px;display:inline-flex}.directory-tabs span{color:#1d4ed8;background:#dbeafe;border-radius:999px;place-items:center;min-width:24px;height:24px;font-size:12px;display:inline-grid}.directory-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.directory-card{align-content:start;gap:14px;min-height:230px;padding:16px;display:grid}.directory-card h3{color:var(--ink);margin:0;font-size:22px;line-height:1.1}.directory-fields{gap:8px;display:grid}.directory-fields span{color:var(--muted);overflow-wrap:anywhere;gap:2px;display:grid}.directory-fields strong{color:var(--ink);text-transform:uppercase;font-size:12px}@media (width<=1160px){.app-shell{grid-template-columns:88px minmax(0,1fr)}.sidebar{padding:18px 12px}.brand{justify-content:center}.brand span:not(.brand-mark),.nav-item:not(.active):after,.nav-item{font-size:0}.nav-item{justify-content:center}.sidebar-card{display:none}.intro-panel,.login-layout,.auth-shell,.visual-strip{grid-template-columns:1fr}}@media (width<=1360px){.editor-layout{grid-template-columns:1fr}.edit-panel{position:static}}@media (width<=820px){.app-shell{display:block}.sidebar{border-right:0;border-bottom:1px solid var(--line);flex-direction:row;align-items:center;height:auto;position:static;overflow-x:auto}.brand span:not(.brand-mark){display:none}.nav-list{min-width:max-content;display:flex}.workspace{padding:18px}.topbar,.section-heading{display:grid}.user-chip{min-width:0}.intro-panel{min-height:0;padding:22px}.schedule-preview,.school-preview{display:none}.stats-strip,.metrics-row,.insight-band,.table-cards,.editor-toolbar,.filter-grid,.access-card,.access-details,.directory-grid{grid-template-columns:1fr}.icon-only{width:100%}.form-grid{grid-template-columns:1fr}}.view-panel{background:linear-gradient(135deg,#f8fafcfa,#f1f5f9f5)}.view-mode-card{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:32px 24px;display:flex}.lock-icon{background:#f1f5f9;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:8px;display:flex}.lock-icon .icon{color:#64748b;stroke-width:1.8px;width:32px;height:32px}.view-mode-card h3{color:#0f172a;margin:0;font-size:20px;font-weight:700}.view-mode-card p{color:#64748b;margin:0;font-size:14px;line-height:1.5}.info-message{color:#92400e;text-align:left;background:#fffbeb;border:1px solid #fde68a;border-radius:12px;align-items:center;gap:10px;width:100%;margin-top:16px;padding:12px 16px;font-size:13px;display:flex}.info-message .icon{color:#f59e0b;flex-shrink:0;width:18px;height:18px}@media (width<=820px){.view-mode-card{padding:24px 20px}.info-message{font-size:12px}}@keyframes wave{0%,to{opacity:.5;transform:scaleY(.4)}50%{opacity:1;transform:scaleY(1)}}@keyframes wave-pulse{0%,to{opacity:.4}50%{opacity:.8}}.loading-wave{align-items:flex-end;gap:6px;height:60px;display:flex}.loading-wave-bar{background:linear-gradient(#2563eb,#0f766e);border-radius:4px;width:4px;animation:.8s ease-in-out infinite wave}.loading-wave-bar:first-child{height:20px;animation-delay:0s}.loading-wave-bar:nth-child(2){height:35px;animation-delay:.1s}.loading-wave-bar:nth-child(3){height:28px;animation-delay:.2s}.loading-wave-bar:nth-child(4){height:45px;animation-delay:.3s}.loading-wave-bar:nth-child(5){height:32px;animation-delay:.4s}.loading-wave-bar:nth-child(6){height:22px;animation-delay:.5s}.loading-wave-bar:nth-child(7){height:38px;animation-delay:.6s}.skeleton{background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9 50%,#e2e8f0 75%) 0 0/200% 100%;border-radius:8px;animation:1.5s ease-in-out infinite wave-pulse}.week-calendar{background:var(--bg-card,#fff);border:1px solid var(--border-color,#dfe6ef);box-shadow:var(--shadow-md,0 4px 6px -1px #0000001a);border-radius:16px;overflow-x:auto}.week-calendar-grid{grid-template-columns:80px repeat(7,minmax(120px,1fr));min-width:1000px;display:grid}.week-calendar-time{color:#64748b;background:#f8fafc;border-right:1px solid #e2e8f0;font-size:13px;font-weight:600}.week-calendar-day{text-align:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;border-right:1px solid #e2e8f0;padding:12px 8px;font-weight:700}.week-calendar-day-name{color:#64748b;font-size:14px}.week-calendar-day-date{color:#0f172a;font-size:20px}.week-calendar-cell{background:#fff;border-bottom:1px solid #e2e8f0;border-right:1px solid #e2e8f0;min-height:90px;padding:6px;transition:all .2s}.week-calendar-cell:hover{z-index:1;background:#f1f5f9;transform:scale(1.02);box-shadow:0 4px 12px #00000014}.calendar-lesson{cursor:pointer;background:linear-gradient(135deg,#2563eb1f,#0f766e14);border-left:3px solid #2563eb;border-radius:8px;margin-bottom:4px;padding:6px 8px;font-size:11px;transition:all .2s}.calendar-lesson-subject{color:#2563eb;white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:700;overflow:hidden}.calendar-lesson-room{color:#64748b;font-size:10px}.progress-year-card{color:#fff;background:linear-gradient(135deg,#1e293b,#0f172a);border-radius:20px;margin-bottom:20px;padding:20px}.progress-year-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;display:flex}.progress-year-title{opacity:.8;font-size:14px;font-weight:500}.progress-year-percent{font-size:28px;font-weight:800}.progress-bar-container{background:#fff3;border-radius:100px;height:8px;margin:16px 0;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg,#facc15,#22c55e);border-radius:100px;width:0%;height:100%;transition:width .8s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.progress-bar-fill:after{content:"";background:linear-gradient(90deg,#0000,#ffffff4d,#0000);animation:1.5s infinite shimmer;position:absolute;inset:0}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-stats{opacity:.8;justify-content:space-between;margin-top:16px;font-size:13px;display:flex}.donut-chart{background:conic-gradient(#22c55e 0deg 280deg,#ef4444 280deg 360deg);border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;display:flex;position:relative}.donut-chart-inner{background:#1e293b;border-radius:50%;justify-content:center;align-items:center;width:70px;height:70px;font-size:18px;font-weight:700;display:flex}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 #2563eb66}50%{box-shadow:0 0 0 8px #2563eb00}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-3px)}75%{transform:translate(3px)}}.fade-in-up{animation:.4s ease-out forwards fadeInUp}.fade-in-scale{animation:.3s ease-out forwards fadeInScale}.slide-in-right{animation:.4s ease-out forwards slideInRight}.pulse-glow{animation:1.5s infinite pulse-glow}.shake{animation:.3s ease-in-out shake}.hover-lift{transition:all .2s cubic-bezier(.4,0,.2,1)}.hover-lift:hover{box-shadow:var(--shadow-lg,0 10px 15px -3px #0000001a);transform:translateY(-2px)}.hover-grow{transition:transform .2s}.hover-grow:hover{transform:scale(1.02)}.toast-notification{z-index:1000;animation:.3s ease-out slideInRight,.3s ease-out 2.7s forwards fadeOut;position:fixed;bottom:24px;right:24px}@keyframes fadeOut{to{opacity:0;visibility:hidden}}.widgets-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:24px;display:grid}.widget-card{background:var(--bg-card,#fff);border:1px solid var(--border-color,#dfe6ef);box-shadow:var(--shadow-sm,0 1px 2px #0000000d);border-radius:20px;padding:18px;transition:all .2s}.widget-card:hover{box-shadow:var(--shadow-md,0 4px 6px -1px #0000001a);transform:translateY(-2px)}.widget-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.widget-icon{background:linear-gradient(135deg,#2563eb14,#0f766e14);border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.widget-icon .icon{color:#2563eb;width:20px;height:20px}.widget-title{color:var(--text-secondary,#64748b);font-size:14px;font-weight:600}.widget-value{color:var(--text-primary,#0f172a);font-size:28px;font-weight:800}.current-lesson-widget{color:#fff;background:linear-gradient(135deg,#2563eb,#0f766e)}.current-lesson-widget .widget-icon .icon,.current-lesson-widget .widget-title{color:#fffc}.current-lesson-widget .widget-value{color:#fff}.countdown-timer{margin-top:8px;font-family:monospace;font-size:24px;font-weight:700}.week-stats-chart{align-items:flex-end;gap:8px;height:80px;margin-top:12px;display:flex}.chart-bar{background:linear-gradient(#2563eb,#0f766e);border-radius:6px 6px 4px 4px;flex:1;min-height:4px;transition:height .5s}.chart-bar:hover{opacity:.8}.chart-label{text-align:center;color:var(--text-secondary,#64748b);margin-top:6px;font-size:10px}.schedule-table tbody tr{animation:.3s ease-out backwards fadeInUp}.schedule-table tbody tr:first-child{animation-delay:20ms}.schedule-table tbody tr:nth-child(2){animation-delay:40ms}.schedule-table tbody tr:nth-child(3){animation-delay:60ms}.schedule-table tbody tr:nth-child(4){animation-delay:80ms}.schedule-table tbody tr:nth-child(5){animation-delay:.1s}.schedule-table tbody tr:nth-child(6){animation-delay:.12s}.schedule-table tbody tr:nth-child(7){animation-delay:.14s}.schedule-table tbody tr:nth-child(8){animation-delay:.16s}@media (width<=768px){.week-calendar-grid{min-width:800px}.widgets-grid{grid-template-columns:1fr}.progress-year-card{padding:16px}.progress-year-percent{font-size:22px}}.school-hero:after{display:none}.app-shell{background:#eef1f5;grid-template-columns:264px minmax(0,1fr)}.auth-page{background:linear-gradient(90deg,#0e749014,#0000 34%),linear-gradient(#f7f8fa,#edf1f5)}.sidebar{color:#d6dde8;background:#18212f;border-right:1px solid #cfd6df;gap:18px;padding:20px 16px;box-shadow:10px 0 32px #0f172a1f}.brand{color:#f8fafc;padding:8px}.brand-mark{color:#101827;width:40px;height:40px;box-shadow:none;background:#f4c542}.brand strong,.sidebar-card strong{color:#fff}.brand small,.sidebar-card small{color:#aeb8c6}.nav-list{gap:4px}.nav-item{color:#b9c3d0;border:1px solid #0000;border-radius:6px;min-height:44px;padding:10px 12px}.nav-item:hover,.nav-item.active{color:#fff;background:#ffffff14;border-color:#ffffff14}.sidebar-card{color:#cbd5e1;box-shadow:none;background:#ffffff0f;border-color:#ffffff17}.workspace{padding:22px 26px 32px}.topbar{border-bottom:1px solid #d9e0e8;align-items:center;padding-bottom:16px}.topbar h1{font-size:clamp(25px,3vw,36px);line-height:1.12}.eyebrow{color:#0f766e;letter-spacing:.04em}.user-chip,.metric,.filter-grid,.schedule-table-wrap,.edit-panel,.directory-card,.directory-tabs,.notice,.empty-state,.access-card,.auth-card,.security-panel,.bell-card,.subject-palette,.widget-card,.week-calendar,.insight-band{background:#fff;border-color:#d5dde7;border-radius:6px;box-shadow:0 8px 22px #0f172a0f}.auth-shell{grid-template-columns:minmax(0,1.1fr) 400px;width:min(1120px,100%)}.auth-visual,.intro-panel{background:linear-gradient(90deg,#18212feb,#18212fc7),url(/assets/hero-CLDdwZDr.png) 50%/cover;border-radius:6px;box-shadow:0 18px 44px #0f172a29}.auth-visual h1,.intro-copy h2{font-size:clamp(30px,4.8vw,48px)}.feature-grid span{background:#ffffff14;border-radius:6px;position:relative}.feature-grid span:before{content:"";background:#f4c542;border-radius:2px;width:8px;height:8px;margin-right:10px;display:inline-block}.editor-layout{gap:16px}.editor-main,.tables-view,.directories,.access-page{gap:14px}.widgets-grid{grid-template-columns:repeat(6,minmax(150px,1fr));gap:10px;margin-bottom:0}.widget-card{min-height:126px;padding:14px}.widget-header{gap:8px;margin-bottom:12px}.widget-icon{border-radius:6px;width:34px;height:34px}.widget-icon .icon{color:#0f766e}.widget-title{color:#5f6f82;font-size:12px;line-height:1.25}.widget-value{font-size:22px;line-height:1.12}.current-lesson-widget{background:#0f766e}.countdown-timer{font-size:18px}.insight-band{background:#fff;grid-template-columns:minmax(180px,1.2fr) minmax(180px,1.1fr) 130px 150px;padding:12px}.insight-band strong{font-size:19px}.load-wave i{background:#f4c542}.filter-grid{box-shadow:none;grid-template-columns:repeat(4,minmax(150px,1fr));padding:12px}.editor-toolbar{background:#fff;border:1px solid #d5dde7;border-radius:6px;grid-template-columns:minmax(260px,1fr) 180px 42px 42px 42px auto;padding:10px}.primary-button,.ghost-button{min-height:40px;box-shadow:none;border-radius:6px}.primary-button{background:#0f766e}.primary-button:hover,.ghost-button:hover{box-shadow:none;transform:none}.primary-button:disabled{background:#78938f}.generate-button{background:#b45309;min-width:168px}.ghost-button.active{color:#0f766e;background:#edf7f5;border-color:#99d8cf}input,select,textarea{border-color:#cfd8e3;border-radius:6px;min-height:40px}input:focus,select:focus,textarea:focus,button:focus-visible{border-color:#0f766e;outline-color:#0f766e2e}.metrics-row{grid-template-columns:repeat(4,minmax(120px,1fr));gap:10px}.metric{box-shadow:none;padding:13px 14px}.metric strong{font-size:20px}.schedule-table-wrap{box-shadow:none}.schedule-table th{color:#526173;background:#f1f4f7}.schedule-table th,.schedule-table td{padding:12px 11px}.schedule-table tbody tr:hover,.schedule-table tbody tr.selected-row{background:#f4faf9}.group-badge{color:#1f4f7a;background:#e4eef8}.load-chip{color:#0f766e;background:#dff3ef}.subject-chip:before{box-shadow:none;border-radius:3px}.edit-panel{box-shadow:none;padding:16px;top:22px}.subject-banner{box-shadow:none;background:#18212f;border-radius:6px}.week-calendar{box-shadow:none;border-radius:6px}.week-calendar-day,.week-calendar-time{background:#f1f4f7}.week-calendar-cell:hover{transform:none;box-shadow:inset 0 0 0 1px #0f766e}.calendar-lesson{background:#edf7f5;border-left-color:#0f766e}.calendar-lesson:hover{background:#dff3ef;transform:none}.directory-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.directory-card{min-height:210px;box-shadow:none}.directory-card h3{font-size:20px}.access-card{background:#fff}.access-mark,.avatar{border-radius:6px}.hover-lift:hover,.hover-grow:hover{transform:none}.fade-in-up,.fade-in-scale,.slide-in-right,.schedule-table tbody tr{animation:none}@media (width<=1460px){.widgets-grid{grid-template-columns:repeat(3,minmax(180px,1fr))}.directory-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=1160px){.app-shell{grid-template-columns:84px minmax(0,1fr)}.editor-toolbar{grid-template-columns:minmax(220px,1fr) 170px 42px 42px 42px}.generate-button{grid-column:1/-1}}@media (width<=820px){.sidebar{background:#18212f}.widgets-grid,.filter-grid,.metrics-row,.insight-band,.directory-grid,.editor-toolbar{grid-template-columns:1fr}}
