@import "https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@400;500;600;700;800&display=swap";:root{color:#14213d;font-synthesis:none;text-rendering:optimizelegibility;background:#f4f7fb;font-family:Noto Sans SC,system-ui,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input,select{font:inherit}button,a{-webkit-tap-highlight-color:transparent}button{cursor:pointer}a{color:inherit;text-decoration:none}:root{--navy:#10233f;--blue:#2368d9;--line:#e3e9f2;--muted:#697891;--panel:#fff}.eyebrow{color:#527099;letter-spacing:.14em;text-transform:uppercase;margin:0 0 8px;font-size:11px;font-weight:800}.muted{color:var(--muted);line-height:1.7}.icon-button{color:inherit;background:0 0;border:0;border-radius:10px;place-items:center;padding:8px;display:grid}.icon-button:hover{background:#6978911a}.login-page{background:#fff;grid-template-columns:1.1fr .9fr;min-height:100vh;display:grid}.login-intro{color:#fff;background:linear-gradient(145deg,#0a2244fa,#1b57a4eb),radial-gradient(circle at 10% 10%,#5ea3ff,#0000 50%);flex-direction:column;justify-content:center;padding:9vw;display:flex;position:relative;overflow:hidden}.login-intro:after{content:"";border:1px solid #ffffff26;border-radius:50%;width:520px;height:520px;position:absolute;bottom:-220px;right:-180px;box-shadow:0 0 0 80px #ffffff09,0 0 0 160px #ffffff06}.brand-mark{background:#ffffff1a;border:1px solid #fff3;border-radius:18px;place-items:center;width:58px;height:58px;margin-bottom:48px;display:grid}.login-intro .eyebrow{color:#9fc6ff}.login-intro h1{letter-spacing:-.05em;max-width:680px;margin:0;font-size:clamp(38px,4.5vw,68px);line-height:1.2}.login-copy{color:#c9d8ed;max-width:540px;margin:26px 0 42px;font-size:17px;line-height:1.8}.intro-features{color:#e8f1ff;flex-wrap:wrap;gap:22px;font-size:13px;display:flex}.intro-features span{align-items:center;gap:7px;display:flex}.login-panel{place-items:center;padding:32px;display:grid}.login-card{width:min(100%,390px)}.login-card h2{color:var(--navy);letter-spacing:-.04em;margin:0;font-size:34px}.login-card label{color:#34435b;gap:8px;margin-top:22px;font-size:13px;font-weight:700;display:grid}.login-card input,.filters input,.filters select{width:100%;color:var(--navy);background:#fff;border:1px solid #d9e1ec;border-radius:11px;outline:none;padding:13px 14px}.login-card input:focus,.filters input:focus,.filters select:focus{border-color:#5b91e4;box-shadow:0 0 0 3px #2368d91a}.primary-button{color:#fff;background:var(--blue);border:0;border-radius:11px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:26px;padding:14px;font-weight:700;display:flex;box-shadow:0 12px 24px #2368d933}.primary-button:disabled{opacity:.65}.form-error{color:#c73d4c;margin:14px 0 0;font-size:13px}.mobile-brand{display:none}.app-shell{min-height:100vh;display:flex}.sidebar{z-index:20;color:#dce8f8;background:var(--navy);flex-direction:column;width:245px;padding:24px 16px 18px;display:flex;position:fixed;inset:0 auto 0 0}.sidebar-brand{align-items:center;gap:11px;padding:0 8px 24px;display:flex}.sidebar-brand>span{color:#fff;background:var(--blue);border-radius:12px;place-items:center;width:39px;height:39px;display:grid}.sidebar-brand div{display:grid}.sidebar-brand small,.sidebar-user small{color:#8fa4bf;letter-spacing:.08em;font-size:10px}.sidebar nav{gap:4px;display:grid}.sidebar nav a{color:#aebed2;border-radius:9px;align-items:center;gap:11px;padding:11px 12px;font-size:13px;font-weight:600;display:flex}.sidebar nav a:hover,.sidebar nav a.active{color:#fff;background:#ffffff17}.sidebar nav a.active{box-shadow:inset 3px 0 #65a3ff}.sidebar-user{border-top:1px solid #ffffff1a;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;margin-top:auto;padding:14px 8px 0;display:grid}.sidebar-user>div:nth-child(2){font-size:12px;display:grid}.avatar{color:#fff;background:#356ba9;border-radius:50%;place-items:center;width:34px;height:34px;font-weight:800;display:grid}.close-nav,.menu-button{display:none}.main-column{width:calc(100% - 245px);margin-left:245px}.topbar{border-bottom:1px solid var(--line);background:#ffffffeb;align-items:center;gap:14px;height:72px;padding:0 32px;display:flex}.topbar div:nth-child(2){display:grid}.topbar .eyebrow{margin:0;font-size:9px}.topbar strong{font-size:14px}.role-pill,.date-chip{color:#47617f;background:#f7faff;border:1px solid #dbe5f2;border-radius:20px;margin-left:auto;padding:7px 11px;font-size:11px;font-weight:700}.heading-actions{justify-content:flex-end;align-items:center;gap:10px;margin-left:auto;display:flex}.heading-actions .date-chip{margin-left:0}.primary-link,.secondary-link{border-radius:10px;justify-content:center;align-items:center;gap:7px;padding:9px 13px;font-size:11px;font-weight:800;display:inline-flex}.primary-link{color:#fff;background:var(--blue);box-shadow:0 8px 18px #2368d929}.secondary-link{color:#4b617e;background:#fff;border:1px solid #dbe3ee}.primary-link:hover{background:#1c5bbc}.secondary-link:hover{color:var(--blue);border-color:#a8c3eb}.content{max-width:1450px;margin:auto;padding:36px 36px 60px}.page-heading{justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:28px;display:flex}.page-heading h1,.placeholder h1{color:var(--navy);letter-spacing:-.035em;margin:0;font-size:30px}.page-heading .muted{margin:7px 0 0;font-size:13px}.metric-grid{grid-template-columns:repeat(3,1fr);gap:18px;display:grid}.metric-card{border:1px solid var(--line);background:var(--panel);border-radius:15px;align-items:center;gap:16px;padding:23px;display:flex;box-shadow:0 6px 20px #19325a09}.metric-card p{color:var(--muted);margin:0 0 4px;font-size:11px;font-weight:700}.metric-card strong{color:var(--navy);font-size:25px}.metric-icon{border-radius:13px;place-items:center;width:46px;height:46px;display:grid}.metric-icon.blue{color:#2368d9;background:#edf4ff}.metric-icon.violet{color:#7257c7;background:#f2efff}.metric-icon.green{color:#20836b;background:#ebf8f4}.dashboard-grid{grid-template-columns:1.7fr 1fr;gap:18px;margin-top:18px;display:grid}.panel{border:1px solid var(--line);background:var(--panel);border-radius:15px;box-shadow:0 6px 20px #19325a09}.panel-heading{justify-content:space-between;align-items:center;gap:12px;padding:22px 24px 10px;display:flex}.panel h2{color:var(--navy);margin:0;font-size:18px}.quick-grid{grid-template-columns:repeat(2,1fr);gap:1px;padding:12px 16px 20px;display:grid}.quick-grid a{color:#435772;border-radius:10px;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:14px;font-size:12px;font-weight:700;display:grid}.quick-grid a:hover{color:var(--blue);background:#f4f8fe}.notice-panel{background:linear-gradient(160deg,#fff,#f1f6fd);padding:24px}.notice-panel .muted{font-size:12px}.status-line{color:#347461;align-items:center;gap:8px;margin-top:25px;font-size:11px;font-weight:800;display:flex}.status-dot{background:#35a47f;border-radius:50%;width:8px;height:8px;box-shadow:0 0 0 5px #35a47f1a}.filters{border-bottom:1px solid var(--line);gap:12px;padding:20px;display:flex}.search-box{color:#7d8ca1;background:#fff;border:1px solid #d9e1ec;border-radius:11px;align-items:center;gap:8px;min-width:300px;padding-left:12px;display:flex}.search-box input{border:0;box-shadow:none!important}.filters select{width:160px}.filter-action{white-space:nowrap;border:0;margin-left:auto}.year-filter{width:160px;color:var(--navy);background:#fff;border:1px solid #d9e1ec;border-radius:11px;outline:none;padding:13px 14px}.table-wrap{overflow-x:auto}table{border-collapse:collapse;text-align:left;width:100%}th{color:#718099;letter-spacing:.07em;background:#f8fafc;padding:12px 20px;font-size:10px}td{color:#43536b;border-top:1px solid #edf1f6;padding:16px 20px;font-size:12px}td:first-child{gap:3px;display:grid}td small{color:#8a98aa;font-size:10px}.row-link{color:var(--blue);white-space:nowrap;align-items:center;gap:3px;font-size:11px;font-weight:800;display:inline-flex}.status-badge{border-radius:20px;padding:4px 9px;font-size:10px;font-weight:800;display:inline-flex}.status-badge.active{color:#24765e;background:#e9f7f2}.status-badge.suspended{color:#a26a15;background:#fff4dc}.status-badge.graduated{color:#4169a9;background:#edf3fd}.status-badge.withdrawn{color:#9a5260;background:#fbedf0}.empty-state{color:var(--muted);text-align:center;padding:60px 20px;font-size:13px}.placeholder{text-align:center;justify-items:center;max-width:720px;margin:8vh auto;padding:65px 30px;display:grid}.placeholder-icon{width:64px;height:64px;color:var(--blue);background:#edf4ff;border-radius:20px;place-items:center;margin-bottom:24px;display:grid}.placeholder .muted{max-width:440px}.next-note{color:#547092;background:#f5f8fc;border-radius:8px;margin-top:25px;padding:10px 14px;font-size:11px}.student-form{overflow:hidden}.form-section{border-bottom:1px solid var(--line);grid-template-columns:190px 1fr;gap:32px;padding:28px;display:grid}.form-section h2,.profile-card h2,.detail-card h2{color:var(--navy);margin:0;font-size:17px}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;display:grid}.form-grid label{color:#485b76;gap:8px;font-size:11px;font-weight:800;display:grid}.form-grid label span{color:#c74655}.form-grid label.wide{grid-column:1/-1}.form-grid input,.form-grid select{width:100%;color:var(--navy);background:#fff;border:1px solid #d9e1ec;border-radius:9px;outline:none;padding:11px 12px}.form-grid input:focus,.form-grid select:focus{border-color:#5b91e4;box-shadow:0 0 0 3px #2368d91a}.form-actions{background:#fafbfd;justify-content:flex-end;gap:10px;padding:20px 28px;display:flex}.primary-button.compact{width:auto;box-shadow:none;margin:0;padding:10px 15px;font-size:11px}.form-message{margin:20px 28px 0}.student-profile{grid-template-columns:280px 1fr;gap:18px;display:grid}.profile-card{text-align:center;flex-direction:column;align-items:center;padding:30px 24px;display:flex}.profile-avatar{width:78px;height:78px;color:var(--blue);background:#edf4ff;border-radius:24px;place-items:center;margin-bottom:15px;display:grid}.profile-card .status-badge{margin-top:10px}.profile-card dl{text-align:left;width:100%;margin:28px 0 0}.profile-card dl div{border-top:1px solid #edf1f6;justify-content:space-between;gap:12px;padding:12px 0;font-size:11px;display:flex}.profile-card dt{color:#7a899e}.profile-card dd{color:#334760;text-align:right;margin:0;font-weight:700}.profile-details{align-content:start;gap:18px;display:grid}.detail-card{padding:25px}.detail-lines{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:20px;display:grid}.detail-lines>div{color:#6380a4;background:#f7f9fc;border-radius:11px;align-items:center;gap:12px;padding:15px;display:flex}.detail-lines span{color:#354a65;overflow-wrap:anywhere;gap:4px;font-size:11px;font-weight:700;display:grid}.detail-lines small{color:#8996a8;font-size:9px;font-weight:700}.field-help{color:#8491a3;font-size:9px;font-weight:500;line-height:1.5}.class-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;padding:20px;display:grid}.class-card{color:#71839a;border:1px solid #e5ebf3;border-radius:12px;grid-template-columns:auto 1fr auto;align-items:center;gap:13px;padding:18px;transition:border-color .18s,transform .18s;display:grid}.class-card:hover{border-color:#abc6ed;transform:translateY(-2px)}.class-card>span{width:43px;height:43px;color:var(--blue);background:#edf4ff;border-radius:12px;place-items:center;display:grid}.class-card div{gap:3px;display:grid}.class-card small{color:#7e8da1;font-size:9px;font-weight:800}.class-card h3{color:var(--navy);margin:0;font-size:14px}.class-card p{color:#78889d;margin:0;font-size:10px}.tab-bar{border:1px solid var(--line);background:#fff;border-radius:11px;gap:5px;width:fit-content;margin-bottom:16px;padding:4px;display:flex}.tab-bar button{color:#718098;background:0 0;border:0;border-radius:8px;align-items:center;gap:7px;padding:9px 13px;font-size:11px;font-weight:800;display:flex}.tab-bar button.active{color:var(--blue);background:#edf4ff}.inline-create{border-bottom:1px solid var(--line);background:#f8fafc;grid-template-columns:2fr 1fr 1fr auto;align-items:end;gap:12px;padding:18px 20px;display:grid}.inline-create label{color:#5b6d85;gap:6px;font-size:9px;font-weight:800;display:grid}.inline-create input,.inline-create select{width:100%;min-width:0;color:var(--navy);background:#fff;border:1px solid #d9e1ec;border-radius:8px;padding:9px 10px;font-size:10px}.inline-create button{border:0}.offering-create{grid-template-columns:repeat(5,minmax(110px,1fr)) auto}.offering-filters select{min-width:130px}.course-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;padding:20px;display:grid}.course-card{border:1px solid #e5ebf3;border-radius:12px;grid-template-columns:auto 1fr auto;align-items:center;gap:13px;padding:18px;transition:border-color .18s,transform .18s;display:grid}.course-card:hover{border-color:#abc6ed;transform:translateY(-2px)}.course-card>span:first-child{color:#7257c7;background:#f2efff;border-radius:12px;place-items:center;width:43px;height:43px;display:grid}.course-card div{gap:3px;display:grid}.course-card small{color:#7e8da1;font-size:9px;font-weight:800}.course-card h3{color:var(--navy);margin:0;font-size:14px}.course-card p{color:#78889d;margin:0;font-size:10px}.class-detail-grid{grid-template-columns:1.7fr 1fr;gap:18px;display:grid}.class-detail-grid .notice-panel .secondary-link{margin-top:18px}.roster-panel{overflow:hidden}.roster-panel .panel-heading{border-bottom:1px solid var(--line);padding-bottom:18px}.roster-list{display:grid}.roster-list>a{color:#73839a;border-top:1px solid #edf1f6;grid-template-columns:auto 1fr auto auto;align-items:center;gap:10px;padding:13px 20px;display:grid}.roster-list>a:first-child{border-top:0}.roster-list>a:hover{background:#f8fafc}.roster-list>a>div{gap:3px;display:grid}.roster-list strong{color:#3e526d;font-size:11px}.roster-list small{color:#8996a8;font-size:9px}.assignment-card{overflow:hidden}.current-class{color:var(--blue);background:#f2f7fe;border-radius:11px;align-items:center;gap:12px;margin-top:18px;padding:16px;display:flex}.current-class span{color:var(--navy);gap:4px;font-size:12px;font-weight:800;display:grid}.current-class small{color:#7690b2;font-size:9px}.assignment-actions{grid-template-columns:minmax(150px,1fr) 145px auto auto;gap:8px;margin-top:14px;display:grid}.assignment-actions select,.assignment-actions input{min-width:0;color:var(--navy);background:#fff;border:1px solid #d9e1ec;border-radius:9px;padding:9px 10px;font-size:10px}.assignment-actions button{border:0}.assignment-actions button:disabled{cursor:not-allowed;opacity:.55}.danger-link{color:#a64453;background:#fcedf0;border-radius:9px;justify-content:center;align-items:center;gap:6px;padding:9px 12px;font-size:10px;font-weight:800;display:inline-flex}.history-list{margin-top:20px;display:grid}.history-list>div{border-top:1px solid #edf1f6;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:12px 0;display:grid}.history-list>div>div{gap:4px;display:grid}.history-list strong{color:#415570;font-size:11px}.history-list small{color:#8492a5;font-size:9px}.history-dot{border:2px solid #9facbc;border-radius:50%;width:9px;height:9px}.history-dot.current{background:#2e8b70;border-color:#2e8b70;box-shadow:0 0 0 4px #2e8b701a}.nav-overlay{display:none}@media (width<=900px){.login-page{background:#f4f7fb;grid-template-columns:1fr}.login-intro{display:none}.login-panel{min-height:100vh}.mobile-brand{color:var(--blue);align-items:center;gap:8px;margin-bottom:54px;font-weight:800;display:flex}.sidebar{transition:transform .22s;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.close-nav{color:#fff;margin-left:auto;display:grid}.nav-overlay{z-index:15;background:#08142773;border:0;display:block;position:fixed;inset:0}.main-column{width:100%;margin-left:0}.menu-button{display:grid}.content{padding:28px 20px 50px}.topbar{padding:0 18px}}@media (width<=680px){.metric-grid,.dashboard-grid,.quick-grid{grid-template-columns:1fr}.page-heading{display:grid}.date-chip{justify-self:start;margin-left:0}.filters{display:grid}.search-box{min-width:0}.filters select{width:100%}.heading-actions{flex-wrap:wrap;justify-content:flex-start;margin-left:0}.form-section{grid-template-columns:1fr;gap:18px;padding:22px}.form-grid{grid-template-columns:1fr}.form-grid label.wide{grid-column:auto}.student-profile,.detail-lines{grid-template-columns:1fr}.form-actions{padding:18px 22px}.class-grid,.class-detail-grid,.assignment-actions{grid-template-columns:1fr}.year-filter{width:100%}.course-grid,.inline-create,.offering-create{grid-template-columns:1fr}.offering-filters select{width:100%}.filter-action{margin-left:0}.topbar .eyebrow{display:none}.content{padding-inline:14px}.login-panel{padding:22px}}
