.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:20px;background:var(--bg)}.login-bg{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.bg-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.12}.b1{width:500px;height:500px;background:var(--primary);top:-150px;left:-100px}.b2{width:400px;height:400px;background:var(--accent);bottom:-100px;right:-80px}.bg-grid-lines{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:48px 48px;opacity:.3}.login-card{position:relative;z-index:1;display:flex;width:100%;max-width:960px;min-height:560px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}.login-panel-left{width:380px;flex-shrink:0;background:linear-gradient(160deg,#0d1a36,#080c14);border-right:1px solid var(--border);position:relative;overflow:hidden}.login-panel-left:before{content:"";position:absolute;top:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(59,130,246,.15) 0%,transparent 70%)}.panel-inner{position:relative;z-index:1;padding:48px 40px;height:100%;display:flex;flex-direction:column}.panel-logo{display:flex;align-items:center;gap:10px;margin-bottom:40px}.panel-logo-icon{font-size:24px;color:var(--primary)}.panel-logo-text{font-family:Syne,sans-serif;font-size:20px;font-weight:800;letter-spacing:3px;color:var(--text)}.panel-heading{font-family:Syne,sans-serif;font-size:36px;font-weight:800;line-height:1.1;color:var(--text);margin-bottom:16px;letter-spacing:-.5px}.panel-desc{font-size:14px;color:var(--text-3);line-height:1.7;margin-bottom:36px}.panel-features{display:flex;flex-direction:column;gap:14px;margin-top:auto}.feature-row{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--text-2)}.feature-icon{font-size:16px}.login-panel-right{flex:1;padding:48px 44px;display:flex;flex-direction:column;justify-content:center}.tabs{display:flex;gap:4px;margin-bottom:32px;background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:4px;width:fit-content}.tab{padding:8px 24px;border:none;border-radius:7px;background:transparent;color:var(--text-3);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.tab.active{background:var(--surface-2);color:var(--text);font-weight:600;box-shadow:0 1px 4px #0003}.form-heading{font-family:Syne,sans-serif;font-size:26px;font-weight:700;color:var(--text);margin-bottom:6px}.form-sub{font-size:14px;color:var(--text-3);margin-bottom:28px}.login-alert{padding:11px 14px;border-radius:8px;font-size:13px;margin-bottom:18px;font-weight:500}.login-alert.error{background:var(--danger-glow);border:1px solid rgba(239,68,68,.3);color:#fca5a5}.login-alert.success{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:#6ee7b7}.lf{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.lf label{font-size:12px;font-weight:600;color:var(--text-2);letter-spacing:.3px}.lf input{background:var(--bg-2);border:1px solid var(--border);border-radius:8px;padding:11px 14px;color:var(--text);font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s}.lf input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.lf.err input{border-color:var(--danger)}.lf span{font-size:11px;color:var(--danger);font-weight:500}.hint-box{background:#06b6d40f;border:1px solid rgba(6,182,212,.2);border-radius:8px;padding:10px 14px;font-size:12px;color:var(--text-3);margin-bottom:18px}.hint-box strong{color:var(--accent)}.login-btn{width:100%;padding:13px;background:var(--primary);border:none;border-radius:8px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;margin-top:6px;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;letter-spacing:.3px}.login-btn:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 6px 20px #3b82f666}.login-btn:disabled{opacity:.65;cursor:not-allowed;transform:none}@media (max-width: 768px){.login-panel-left{display:none}.login-panel-right{padding:36px 28px}}.navbar{display:flex;align-items:center;gap:32px;padding:0 32px;height:62px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;box-shadow:0 1px 20px #0000004d}.navbar-brand{display:flex;align-items:center;gap:8px;flex-shrink:0}.brand-icon{font-size:22px;color:var(--primary);line-height:1}.brand-name{font-family:Syne,sans-serif;font-size:18px;font-weight:800;color:var(--text);letter-spacing:2px}.brand-sub{font-size:11px;color:var(--text-3);font-weight:400;letter-spacing:1px;margin-top:2px}.nav-links{display:flex;list-style:none;gap:4px;flex:1}.nav-link{display:flex;align-items:center;gap:7px;padding:7px 14px;border-radius:8px;font-size:14px;font-weight:500;color:var(--text-2);text-decoration:none;transition:all .2s;letter-spacing:.3px}.nav-link:hover{background:var(--surface-2);color:var(--text)}.nav-link.active{background:var(--primary-glow);color:var(--primary);font-weight:600}.nav-icon{font-size:15px}.nav-right{display:flex;align-items:center;gap:12px;margin-left:auto}.user-chip{display:flex;align-items:center;gap:10px;padding:6px 14px 6px 6px;background:var(--surface-2);border:1px solid var(--border);border-radius:100px}.user-avatar{width:30px;height:30px;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.user-info{display:flex;flex-direction:column;line-height:1.2}.user-name{font-size:13px;font-weight:600;color:var(--text)}.user-role{font-size:10px;color:var(--text-3);text-transform:capitalize;letter-spacing:.5px}.logout-btn{width:36px;height:36px;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text-3);font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.logout-btn:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-glow)}@media (max-width: 768px){.navbar{padding:0 16px;gap:16px}.brand-sub,.user-info{display:none}.user-chip{padding:4px}}.dashboard-page{min-height:100vh;background:var(--bg);display:flex;flex-direction:column}.dashboard-main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:36px 32px}.page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:32px;gap:16px}.page-title{font-family:Syne,sans-serif;font-size:30px;font-weight:800;color:var(--text);letter-spacing:-.5px;margin-bottom:6px}.page-sub strong{color:var(--text-2)}.dash-error{background:var(--danger-glow);border:1px solid rgba(239,68,68,.3);border-radius:var(--radius);padding:14px 18px;color:#fca5a5;font-size:14px;margin-bottom:24px}.dash-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:16px;color:var(--text-3)}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px 20px;display:flex;align-items:center;gap:16px;transition:transform .2s,border-color .2s}.stat-card:hover{transform:translateY(-2px)}.stat-blue:hover{border-color:var(--primary)}.stat-green:hover{border-color:var(--success)}.stat-amber:hover{border-color:var(--warning)}.stat-cyan:hover{border-color:var(--accent)}.stat-icon{font-size:28px;flex-shrink:0}.stat-body{display:flex;flex-direction:column}.stat-value{font-family:Syne,sans-serif;font-size:26px;font-weight:800;color:var(--text);line-height:1;margin-bottom:4px}.stat-label{font-size:13px;font-weight:600;color:var(--text-2)}.stat-sub{font-size:11px;color:var(--text-3);margin-top:2px}.dash-grid{display:grid;grid-template-columns:1fr 380px;gap:20px}.dash-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.card-title{font-family:Syne,sans-serif;font-size:15px;font-weight:700;color:var(--text)}.card-link{background:none;border:none;color:var(--primary);font-size:13px;cursor:pointer;font-weight:500;transition:opacity .2s}.card-link:hover{opacity:.7}.card-empty{font-size:14px;color:var(--text-3);text-align:center;padding:20px}.dept-list{display:flex;flex-direction:column;gap:14px}.dept-row{display:flex;align-items:center;gap:12px}.dept-name{font-size:13px;color:var(--text-2);width:150px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dept-bar-wrap{flex:1;height:6px;background:var(--bg-2);border-radius:100px;overflow:hidden}.dept-bar{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:100px;transition:width .6s ease}.dept-count{font-size:12px;font-weight:700;color:var(--text-2);width:24px;text-align:right}.quick-actions{display:flex;flex-direction:column;gap:10px}.quick-action-btn{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg-2);border:1px solid var(--border);border-radius:10px;cursor:pointer;text-align:left;transition:all .2s;width:100%}.quick-action-btn:hover{border-color:var(--primary);background:var(--primary-glow)}.qa-icon{font-size:20px;flex-shrink:0}.qa-label{font-size:14px;font-weight:600;color:var(--text)}.qa-desc{font-size:12px;color:var(--text-3);margin-top:2px}.qa-arrow{margin-left:auto;color:var(--text-3);font-size:16px}@media (max-width: 1100px){.stats-row{grid-template-columns:repeat(2,1fr)}.dash-grid{grid-template-columns:1fr}}@media (max-width: 600px){.dashboard-main{padding:24px 16px}.stats-row{grid-template-columns:1fr 1fr}.page-header{flex-direction:column;align-items:flex-start}}.table-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.table-toolbar{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border);flex-wrap:wrap}.search-box{position:relative;flex:1;min-width:220px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:18px;pointer-events:none}.search-box input{width:100%;background:var(--bg-2);border:1px solid var(--border);border-radius:8px;padding:9px 36px 9px 38px;color:var(--text);font-size:14px;outline:none;transition:border-color .2s}.search-box input:focus{border-color:var(--primary)}.search-box input::placeholder{color:var(--text-3)}.clear-search{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-3);cursor:pointer;font-size:12px;padding:2px 4px}.filters{display:flex;gap:8px;flex-wrap:wrap}.filters select{background:var(--bg-2);border:1px solid var(--border);border-radius:8px;padding:8px 12px;color:var(--text);font-size:13px;outline:none;cursor:pointer;transition:border-color .2s}.filters select:focus{border-color:var(--primary)}.filters select option{background:var(--surface)}.table-meta{padding:8px 20px;font-size:12px;color:var(--text-3);border-bottom:1px solid var(--border);background:var(--bg-2)}.table-loading,.table-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:12px;color:var(--text-3)}.empty-icon{font-size:40px;opacity:.5}.table-empty p{font-size:16px;font-weight:600;color:var(--text-2)}.table-empty span{font-size:13px}.table-scroll{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;min-width:700px}.data-table thead tr{background:var(--bg-2)}.data-table th{padding:12px 16px;text-align:left;font-family:Syne,sans-serif;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-3);white-space:nowrap;border-bottom:1px solid var(--border)}.table-row td{padding:14px 16px;font-size:14px;color:var(--text);border-bottom:1px solid var(--border);vertical-align:middle}.table-row:last-child td{border-bottom:none}.table-row:hover td{background:#ffffff05}.student-id-badge{font-family:Syne,sans-serif;font-size:12px;font-weight:700;color:var(--accent);background:#06b6d41a;padding:3px 10px;border-radius:6px;letter-spacing:.5px}.student-name-cell{display:flex;align-items:center;gap:10px}.mini-avatar{width:32px;height:32px;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.name-text{font-weight:500;color:var(--text);font-size:14px}.email-text{font-size:12px;color:var(--text-3);margin-top:1px}.dept-tag{font-size:12px;background:var(--surface-2);border:1px solid var(--border);padding:3px 10px;border-radius:6px;color:var(--text-2);white-space:nowrap}.cgpa-badge{font-weight:700;font-size:13px;padding:3px 10px;border-radius:6px}.cgpa-high{color:var(--success);background:#10b9811a}.cgpa-mid{color:var(--warning);background:#f59e0b1a}.cgpa-low{color:var(--danger);background:var(--danger-glow)}.status-badge{font-size:11px;font-weight:600;padding:4px 10px;border-radius:100px;letter-spacing:.5px;white-space:nowrap}.status-active{background:#10b98126;color:var(--success)}.status-inactive{background:#64748b26;color:var(--text-3)}.status-graduated{background:#3b82f626;color:var(--primary)}.status-dropped{background:var(--danger-glow);color:var(--danger)}.action-btns{display:flex;gap:6px}.btn-edit,.btn-delete{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:transparent;font-size:15px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-edit{color:var(--text-2)}.btn-edit:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-glow)}.btn-delete{color:var(--text-3)}.btn-delete:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-glow)}.pagination{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px 20px;border-top:1px solid var(--border)}.page-btn{padding:7px 16px;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text-2);font-size:13px;cursor:pointer;transition:all .2s}.page-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-numbers{display:flex;gap:4px}.page-num{width:34px;height:34px;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text-2);font-size:13px;cursor:pointer;transition:all .2s}.page-num:hover{border-color:var(--primary);color:var(--primary)}.page-num.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:700}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:700px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:28px 32px 20px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:1}.modal-title{font-family:Syne,sans-serif;font-size:20px;font-weight:700;color:var(--text)}.modal-sub{font-size:13px;color:var(--text-3);margin-top:3px}.modal-close{background:none;border:1px solid var(--border);color:var(--text-3);width:32px;height:32px;border-radius:8px;cursor:pointer;font-size:13px;transition:all .2s;flex-shrink:0}.modal-close:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-glow)}.student-form{padding:24px 32px 28px}.form-section-title{font-family:Syne,sans-serif;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--primary);margin:20px 0 16px}.form-section-title:first-of-type{margin-top:0}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field{display:flex;flex-direction:column;gap:6px}.field.full-width{margin-top:14px}.field label{font-size:12px;font-weight:600;color:var(--text-2);letter-spacing:.3px}.field input,.field select,.field textarea{background:var(--bg-2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text);font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s;width:100%}.field textarea{resize:vertical}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.field.error input,.field.error select{border-color:var(--danger)}.field input:disabled{opacity:.5;cursor:not-allowed}.field select option{background:var(--surface)}.field-error{font-size:11px;color:var(--danger);font-weight:500}.modal-actions{display:flex;gap:12px;margin-top:24px;justify-content:flex-end;border-top:1px solid var(--border);padding-top:20px}.btn-cancel{padding:10px 24px;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text-2);font-size:14px;font-weight:500;transition:all .2s}.btn-cancel:hover:not(:disabled){border-color:var(--text-3);color:var(--text)}.btn-submit{padding:10px 28px;background:var(--primary);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px;transition:all .2s}.btn-submit:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 16px #3b82f666}.btn-submit:disabled,.btn-cancel:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 600px){.form-grid{grid-template-columns:1fr}.modal-box{max-height:95vh}.modal-header,.student-form{padding-left:20px;padding-right:20px}}.students-page{min-height:100vh;background:var(--bg);display:flex;flex-direction:column}.students-main{flex:1;max-width:1300px;width:100%;margin:0 auto;padding:36px 32px}.page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;gap:16px}.page-label{font-family:Syne,sans-serif;font-size:11px;font-weight:700;letter-spacing:3px;color:var(--primary);margin-bottom:6px}.page-title{font-family:Syne,sans-serif;font-size:30px;font-weight:800;color:var(--text);letter-spacing:-.5px;margin-bottom:4px}.page-sub{font-size:14px;color:var(--text-3)}.btn-primary{padding:10px 22px;background:var(--primary);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s;flex-shrink:0}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 16px #3b82f659}.page-alert{padding:12px 16px;border-radius:8px;font-size:13px;font-weight:500;margin-bottom:16px}.page-alert.success{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:#6ee7b7}.page-alert.error{background:var(--danger-glow);border:1px solid rgba(239,68,68,.3);color:#fca5a5}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.delete-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px 36px;max-width:420px;width:100%;text-align:center;box-shadow:var(--shadow-lg);margin:20px}.delete-icon{font-size:40px;color:var(--danger);margin-bottom:16px}.delete-modal h3{font-family:Syne,sans-serif;font-size:20px;font-weight:700;color:var(--text);margin-bottom:12px}.delete-modal p{font-size:14px;color:var(--text-3);line-height:1.6;margin-bottom:28px}.delete-modal p strong{color:var(--text-2)}.delete-actions{display:flex;gap:12px;justify-content:center}.btn-cancel-del{padding:10px 28px;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text-2);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel-del:hover{border-color:var(--text-3);color:var(--text)}.btn-confirm-del{padding:10px 28px;background:var(--danger);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-confirm-del:hover{background:#dc2626;box-shadow:0 4px 16px #ef444466}@media (max-width: 600px){.students-main{padding:24px 16px}.page-header{flex-direction:column;align-items:flex-start}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #080c14;--bg-2: #0d1220;--surface: #111827;--surface-2: #1a2235;--border: #1e2d45;--border-light: #243352;--primary: #3b82f6;--primary-dark: #2563eb;--primary-glow: rgba(59,130,246,.15);--accent: #06b6d4;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--danger-glow: rgba(239,68,68,.15);--text: #e2e8f0;--text-2: #94a3b8;--text-3: #64748b;--radius: 10px;--radius-lg: 16px;--shadow: 0 4px 24px rgba(0,0,0,.4);--shadow-lg: 0 8px 48px rgba(0,0,0,.6)}html,body,#root{height:100%;width:100%}body{background:var(--bg);color:var(--text);font-family:DM Sans,sans-serif;font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}button{cursor:pointer;font-family:DM Sans,sans-serif}input,select,textarea{font-family:DM Sans,sans-serif}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.fade-in{animation:fadeInUp .4s ease both}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}
