*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0f0f1a;--bg-secondary:#161625;--bg-card:#1c1c2e;--bg-card-hover:#22223a;--bg-surface:#1e1e3299;--glass-bg:#1e1e38;--glass-border:#ffffff14;--glass-shadow:0 8px 32px #00000059;--text-primary:#eaeaf0;--text-secondary:#9d9db5;--text-muted:#5e5e7a;--indigo:#6366f1;--indigo-soft:#6366f126;--violet:#8b5cf6;--emerald:#10b981;--emerald-soft:#10b98126;--amber:#f59e0b;--amber-soft:#f59e0b26;--rose:#f43f5e;--rose-soft:#f43f5e26;--cyan:#06b6d4;--sky:#38bdf8;--border:1px solid #ffffff0f;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--ease:cubic-bezier(.4,0,.2,1);--duration:.25s;--sidebar-width:260px;--sidebar-collapsed:72px;--font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}html{scroll-behavior:smooth;font-size:15px}body{font-family:var(--font);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden}.hidden{display:none!important}.login-page{background:var(--bg-primary);place-items:center;min-height:100vh;display:none;position:relative;overflow:hidden}.login-page.active{display:grid}.login-bg-shapes{pointer-events:none;position:absolute;inset:0;overflow:hidden}.shape{filter:blur(80px);opacity:.4;border-radius:50%;animation:20s ease-in-out infinite float;position:absolute}.shape-1{background:var(--indigo);width:500px;height:500px;animation-delay:0s;top:-100px;left:-100px}.shape-2{background:var(--violet);width:400px;height:400px;animation-delay:-7s;bottom:-80px;right:-80px}.shape-3{background:var(--emerald);width:300px;height:300px;animation-delay:-14s;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes float{0%,to{transform:translate(0)scale(1)}33%{transform:translate(30px,-40px)scale(1.05)}66%{transform:translate(-20px,30px)scale(.95)}}.login-container{z-index:2;width:100%;max-width:420px;padding:1.5rem;position:relative}.login-card{padding:2.5rem}.login-logo{text-align:center;margin-bottom:2rem}.logo-icon{animation:logoIn .8s var(--ease)both;margin-bottom:1rem;display:inline-block}@keyframes logoIn{0%{opacity:0;transform:scale(.5)rotate(-10deg)}to{opacity:1;transform:scale(1)rotate(0)}}.login-title{background:linear-gradient(135deg,var(--indigo),var(--violet),var(--cyan));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.8rem;font-weight:800}.login-subtitle{color:var(--text-secondary);margin-top:.25rem;font-size:.88rem}.auth-tabs{grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1.25rem;display:grid}.auth-tab{color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration)var(--ease);background:#ffffff08;border:1px solid #ffffff1a;padding:.55rem .75rem;font-size:.82rem;font-weight:600}.auth-tab:hover{color:var(--text-primary);border-color:var(--indigo)}.auth-tab.active{color:#fff;border-color:var(--indigo);background:linear-gradient(135deg,#6366f140,#8b5cf640)}.login-hint{text-align:center;color:var(--text-muted);margin-top:1.25rem;font-size:.8rem}.auth-status{text-align:center;margin-top:.9rem;font-size:.82rem;font-weight:600}.auth-status.info{color:var(--amber)}.auth-status.success{color:var(--emerald)}.auth-status.error{color:var(--rose)}.glass-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--glass-shadow)}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-secondary);letter-spacing:.02em;margin-bottom:.4rem;font-size:.82rem;font-weight:600;display:block}.form-group input,.form-group select{border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font);transition:border-color var(--duration)var(--ease),box-shadow var(--duration)var(--ease);background:#14142a;border:1px solid #ffffff1a;outline:none;padding:.7rem 1rem;font-size:.92rem}.form-group input::placeholder{color:var(--text-muted)}.form-group input:focus,.form-group select:focus{border-color:var(--indigo);box-shadow:0 0 0 3px var(--indigo-soft)}.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%239d9db5' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;padding-right:2.25rem}.form-group select option{background:var(--bg-card);color:var(--text-primary)}.form-group input[readonly]{color:var(--text-secondary);cursor:not-allowed;background:#0f0f1e;border-color:#ffffff0f}.form-hint{color:var(--text-muted);margin-top:.4rem;font-size:.75rem}.modal-form-status{margin-top:-.35rem;margin-bottom:.45rem;font-size:.8rem;font-weight:600}.modal-form-status.info{color:var(--amber)}.modal-form-status.success{color:var(--emerald)}.modal-form-status.error{color:var(--rose)}.input-sm{border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font);transition:border-color var(--duration)var(--ease);background:#ffffff0a;border:1px solid #ffffff14;outline:none;padding:.45rem .75rem;font-size:.82rem}.input-sm:focus{border-color:var(--indigo)}.btn{border-radius:var(--radius-sm);font-family:var(--font);cursor:pointer;transition:all var(--duration)var(--ease);letter-spacing:.01em;border:none;align-items:center;gap:.5rem;padding:.65rem 1.4rem;font-size:.88rem;font-weight:600;display:inline-flex}.btn-primary{background:linear-gradient(135deg,var(--indigo),var(--violet));color:#fff;box-shadow:0 4px 15px #6366f14d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #6366f173}.btn-primary:active{transform:translateY(0)}.btn-outline{color:var(--text-primary);background:0 0;border:1px solid #ffffff1f}.btn-outline:hover{border-color:var(--indigo);color:var(--indigo);background:#ffffff0d}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{color:var(--text-primary);background:#ffffff0a}.btn-sm{padding:.45rem 1rem;font-size:.8rem}.btn-xs{border-radius:6px;padding:.3rem .65rem;font-size:.74rem}.btn-full{justify-content:center;width:100%}.btn-danger{background:var(--rose);color:#fff}.btn-danger:hover{background:#e11d48}.btn-success{background:var(--emerald);color:#fff}.badge{border-radius:var(--radius-full);letter-spacing:.04em;text-transform:uppercase;align-items:center;padding:.2rem .65rem;font-size:.72rem;font-weight:600;display:inline-flex}.badge-success{background:var(--emerald-soft);color:var(--emerald)}.badge-warning{background:var(--amber-soft);color:var(--amber)}.badge-danger{background:var(--rose-soft);color:var(--rose)}.badge-info{background:var(--indigo-soft);color:var(--indigo)}.badge-neutral{color:var(--text-secondary);background:#ffffff0f}.app-shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:var(--border);z-index:100;transition:transform .35s var(--ease);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{padding:1.5rem 1.25rem 1rem}.sidebar-logo{align-items:center;gap:.75rem;display:flex}.sidebar-brand{background:linear-gradient(135deg,var(--indigo),var(--violet));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.2rem;font-weight:800}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;padding:.5rem .75rem;display:flex}.nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--duration)var(--ease);cursor:pointer;text-align:left;width:100%;font-size:.88rem;font-weight:500;font-family:var(--font);background:0 0;border:none;align-items:center;gap:.75rem;padding:.7rem 1rem;text-decoration:none;display:flex}.nav-item:hover{color:var(--text-primary);background:#ffffff0a}.nav-item.active{background:var(--indigo-soft);color:var(--indigo)}.nav-item.active svg{stroke:var(--indigo)}.sidebar-footer{border-top:var(--border);padding:.75rem}.logout-item:hover{background:var(--rose-soft)!important;color:var(--rose)!important}.logout-item:hover svg{stroke:var(--rose)}.main-content{margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left .35s var(--ease);flex-direction:column;flex:1;display:flex}.topbar{border-bottom:var(--border);-webkit-backdrop-filter:blur(12px);z-index:50;background:#0f0f1ab3;align-items:center;gap:1rem;padding:1rem 2rem;display:flex;position:sticky;top:0}.menu-toggle{color:var(--text-primary);cursor:pointer;background:0 0;border:none;padding:.25rem;display:none}.page-heading{flex:1;font-size:1.2rem;font-weight:700}.topbar-right{align-items:center;gap:1rem;display:flex}.search-box{border-radius:var(--radius-full);transition:border-color var(--duration)var(--ease);background:#ffffff0a;border:1px solid #ffffff0f;align-items:center;gap:.5rem;padding:.4rem 1rem;display:flex}.search-box:focus-within{border-color:var(--indigo)}.search-box svg{color:var(--text-muted);flex-shrink:0}.search-box input{color:var(--text-primary);font-family:var(--font);background:0 0;border:none;outline:none;width:180px;font-size:.85rem}.search-box input::placeholder{color:var(--text-muted)}.user-avatar{background:linear-gradient(135deg,var(--indigo),var(--violet));color:#fff;cursor:pointer;width:36px;height:36px;transition:transform var(--duration)var(--ease);border-radius:50%;place-items:center;font-size:.82rem;font-weight:700;display:grid}.user-avatar:hover{transform:scale(1.08)}.page-section{animation:fadeInUp .35s var(--ease)both;padding:2rem;display:none}.page-section.active{display:block}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.section-header h3{font-size:1.05rem;font-weight:700}.section-actions{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.filter-group{align-items:center;gap:.5rem;display:flex}.filter-group label{color:var(--text-secondary);font-size:.82rem;font-weight:500}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem;margin-bottom:1.5rem;display:grid}.stat-card{background:var(--bg-card);border:var(--border);border-radius:var(--radius-lg);transition:transform var(--duration)var(--ease),box-shadow var(--duration)var(--ease);align-items:center;gap:1rem;padding:1.5rem;display:flex}.stat-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #00000040}.stat-icon{border-radius:var(--radius-md);place-items:center;width:48px;height:48px;display:grid}.stat-indigo .stat-icon{background:var(--indigo-soft);color:var(--indigo)}.stat-indigo .stat-icon svg{stroke:var(--indigo)}.stat-emerald .stat-icon{background:var(--emerald-soft);color:var(--emerald)}.stat-emerald .stat-icon svg{stroke:var(--emerald)}.stat-amber .stat-icon{background:var(--amber-soft);color:var(--amber)}.stat-amber .stat-icon svg{stroke:var(--amber)}.stat-rose .stat-icon{background:var(--rose-soft);color:var(--rose)}.stat-rose .stat-icon svg{stroke:var(--rose)}.stat-info{flex-direction:column;display:flex}.stat-value{font-size:1.6rem;font-weight:800;line-height:1.2}.stat-label{color:var(--text-secondary);margin-top:.15rem;font-size:.78rem;font-weight:500}.dashboard-grid{grid-template-columns:1.5fr 1fr;gap:1.25rem;display:grid}.card{background:var(--bg-card);border:var(--border);border-radius:var(--radius-lg);overflow:hidden}.card-header{border-bottom:var(--border);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.card-header h3{font-size:.92rem;font-weight:600}.card-body{padding:1rem 1.25rem}.health-items{flex-direction:column;gap:.75rem;display:flex}.health-item{align-items:center;gap:.6rem;font-size:.85rem;display:flex}.health-dot{background:var(--text-muted);width:8px;height:8px;transition:background var(--duration)var(--ease);border-radius:50%;flex-shrink:0}.health-dot.online{background:var(--emerald);box-shadow:0 0 6px #10b98166}.health-dot.offline{background:var(--rose);box-shadow:0 0 6px #f43f5e66}.health-status{color:var(--text-muted);margin-left:auto;font-size:.78rem}.list-items{flex-direction:column;gap:.6rem;display:flex}.list-item{border-radius:var(--radius-sm);transition:background var(--duration)var(--ease);background:#ffffff05;border:1px solid #ffffff08;justify-content:space-between;align-items:center;padding:.7rem .75rem;display:flex}.list-item:hover{background:#ffffff0a}.list-item-info{flex-direction:column;gap:.15rem;display:flex}.list-item-title{font-size:.85rem;font-weight:600}.list-item-sub{color:var(--text-muted);font-size:.75rem}.empty-state,.empty-state-sm{text-align:center;color:var(--text-muted);padding:2rem;font-size:.88rem}.empty-state-sm{padding:1.5rem;font-size:.82rem}.table-wrapper{overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:var(--border);background:#ffffff05;padding:.75rem 1rem;font-size:.76rem;font-weight:600}.data-table td{vertical-align:middle;border-bottom:1px solid #ffffff08;padding:.75rem 1rem;font-size:.85rem}.data-table tbody tr{transition:background var(--duration)var(--ease)}.data-table tbody tr:hover{background:#ffffff05}.data-table .actions-cell{gap:.4rem;display:flex}.courses-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;display:grid}.course-card{background:var(--bg-card);border:var(--border);border-radius:var(--radius-lg);transition:transform var(--duration)var(--ease),box-shadow var(--duration)var(--ease);padding:1.5rem;position:relative;overflow:hidden}.course-card:before{content:"";background:linear-gradient(90deg,var(--indigo),var(--violet),var(--cyan));height:3px;position:absolute;top:0;left:0;right:0}.course-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #0000004d}.course-card h4{margin-bottom:.4rem;font-size:1rem;font-weight:700}.course-card p{color:var(--text-secondary);margin-bottom:.25rem;font-size:.82rem}.course-card-footer{border-top:var(--border);justify-content:space-between;align-items:center;margin-top:1rem;padding-top:.75rem;display:flex}.course-credits{color:var(--text-muted);font-size:.78rem}.gpa-summary{margin-bottom:1.25rem}.gpa-card{justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.gpa-label{color:var(--text-secondary);font-size:.92rem;font-weight:600}.gpa-value{background:linear-gradient(135deg,var(--emerald),var(--cyan));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2.4rem;font-weight:800}.modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:1000;background:#0009;place-items:center;display:none;position:fixed;inset:0}.modal-overlay.show{animation:overlayIn .2s var(--ease)both;display:grid}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.modal{width:90%;max-width:440px;animation:modalIn .35s var(--ease)both;padding:2rem}@keyframes modalIn{0%{opacity:0;transform:scale(.92)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.modal-header h3{font-size:1.1rem;font-weight:700}.modal-close{color:var(--text-muted);cursor:pointer;transition:color var(--duration)var(--ease);background:0 0;border:none;padding:.25rem;font-size:1.5rem;line-height:1}.modal-close:hover{color:var(--text-primary)}.modal-actions{justify-content:flex-end;gap:.75rem;margin-top:1.5rem;display:flex}.modal-delete{max-width:460px}.delete-copy{color:var(--text-secondary);margin:0;line-height:1.55}.delete-warning{color:#fecaca;border-radius:var(--radius-sm);background:#f43f5e24;border:1px solid #f43f5e59;margin:.8rem 0 0;padding:.65rem .8rem;font-weight:600}.delete-student-pill{border-radius:var(--radius-full);color:#c7d2fe;letter-spacing:.02em;background:#6366f124;border:1px solid #818cf873;align-items:center;max-width:max-content;margin-top:.9rem;padding:.38rem .7rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.78rem;font-weight:700;display:inline-flex}.profile-details{flex-direction:column;gap:.75rem;display:flex}.profile-row{border-radius:var(--radius-sm);background:#ffffff08;border:1px solid #ffffff0f;justify-content:space-between;align-items:center;gap:1rem;padding:.7rem .85rem;display:flex}.profile-row span{color:var(--text-secondary);font-size:.82rem}.profile-row strong{color:var(--text-primary);overflow-wrap:anywhere;text-align:right;font-size:.88rem;font-weight:600}.toast{background:var(--bg-card);border:var(--border);border-radius:var(--radius-md);animation:toastIn .35s var(--ease)both;pointer-events:auto;align-items:center;gap:.6rem;min-width:280px;max-width:400px;padding:.85rem 1.25rem;font-size:.85rem;display:flex;box-shadow:0 8px 24px #00000059}@keyframes toastIn{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}@keyframes toastOut{to{opacity:0;transform:translate(50px)}}@media (max-width:900px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.menu-toggle{display:block}.dashboard-grid{grid-template-columns:1fr}.topbar{padding:.75rem 1rem}.page-section{padding:1.25rem}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.stats-grid{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start}.section-actions{width:100%}.filter-group{flex-wrap:wrap;width:100%}.filter-group .input-sm{flex:1}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff2e}.skeleton{border-radius:var(--radius-sm);background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14 50%,#ffffff0a 75%) 0 0/200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.sidebar-overlay{z-index:99;background:#00000080;display:none;position:fixed;inset:0}.sidebar-overlay.show{display:block}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:.75rem;display:flex;position:fixed;top:1.5rem;right:1.5rem}.toast{background:var(--bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:auto;min-width:280px;max-width:400px;animation:toastIn .4s var(--ease)both;align-items:center;gap:.75rem;padding:1rem 1.25rem;font-size:.9rem;display:flex;box-shadow:0 10px 25px #0006}.toast.hide{animation:toastOut .3s var(--ease)forwards}.toast-success{border-left:4px solid var(--emerald)}.toast-error{border-left:4px solid var(--rose)}.toast-warning{border-left:4px solid var(--amber)}.toast-info{border-left:4px solid var(--indigo)}.loading-spinner{border:2px solid #fff3;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}button:disabled{opacity:.7;cursor:not-allowed}
