@import url(https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap);:root{--primary:#4f46e5;--primary-dark:#4338ca;--primary-light:#6366f1;--primary-bg:#eef2ff;--secondary:#7c6bed;--success:#10b981;--success-bg:#d1fae5;--warning:#f59e0b;--warning-bg:#fef3c7;--danger:#ef4444;--danger-bg:#fee2e2;--info:#3b82f6;--info-bg:#dbeafe;--sidebar-bg:#1a2338;--sidebar-hover:#4f46e51f;--sidebar-active:#4f46e5;--sidebar-text:#94a3b8;--sidebar-white:#fff;--sidebar-width:240px;--bg-page:#f1f5f9;--bg-card:#fff;--text-dark:#1e293b;--text-mid:#64748b;--text-light:#94a3b8;--border:#e2e8f0;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 24px #0000001a;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--transition:all .2s ease}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:#f1f5f9;background:var(--bg-page);color:#1e293b;color:var(--text-dark);font-family:Poppins,sans-serif;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer}button,input,select,textarea{font-family:inherit}.app-layout,.main-wrapper{display:flex;min-height:100vh}.main-wrapper{flex:1 1;flex-direction:column;margin-left:240px;margin-left:var(--sidebar-width)}.page-content{flex:1 1;overflow-y:auto;padding:28px}.sidebar{background:#1a2338;background:var(--sidebar-bg);display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;transition:all .2s ease;transition:var(--transition);width:240px;width:var(--sidebar-width);z-index:1000}.sidebar-logo{align-items:center;border-bottom:1px solid #ffffff12;display:flex;gap:10px;padding:20px 20px 16px}.sidebar-logo-icon{align-items:center;background:#4f46e5;background:var(--primary);border-radius:10px;border-radius:var(--radius-md);display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.sidebar-logo-icon svg{fill:#fff;height:20px;width:20px}.sidebar-logo-text{color:#fff;font-size:13px;font-weight:700;letter-spacing:.5px;line-height:1.2;text-transform:uppercase}.sidebar-logo-text span{color:#94a3b8;color:var(--sidebar-text);display:block;font-size:10px;font-weight:400;letter-spacing:0;text-transform:none}.sidebar-nav{flex:1 1;overflow-y:auto;padding:12px 0}.sidebar-nav-section{font-size:10px;font-weight:600;letter-spacing:1px;padding:8px 16px 4px;text-transform:uppercase}.sidebar-nav a,.sidebar-nav-section{color:#94a3b8;color:var(--sidebar-text)}.sidebar-nav a{align-items:center;border-radius:0;display:flex;font-size:13.5px;font-weight:500;gap:12px;margin:2px 0;padding:10px 20px;position:relative;transition:all .2s ease;transition:var(--transition)}.sidebar-nav a:hover{background:#4f46e51f;background:var(--sidebar-hover);color:#fff}.sidebar-nav a.active{background:#4f46e5;background:var(--sidebar-active);border-radius:0 6px 6px 0;border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:#fff;margin-right:12px}.sidebar-nav a.active:before{background:#fff;border-radius:0 2px 2px 0;bottom:0;content:"";left:0;position:absolute;top:0;width:3px}.sidebar-nav a svg{flex-shrink:0;height:18px;width:18px}.sidebar-footer{align-items:center;border-top:1px solid #ffffff12;display:flex;gap:10px;padding:16px 20px}.sidebar-user-avatar{align-items:center;background:#4f46e5;background:var(--primary);border-radius:9999px;border-radius:var(--radius-full);color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:36px;justify-content:center;width:36px}.sidebar-user-info{flex:1 1;overflow:hidden}.sidebar-user-name{color:#fff;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-role{font-size:11px}.sidebar-logout-btn,.sidebar-user-role{color:#94a3b8;color:var(--sidebar-text)}.sidebar-logout-btn{background:none;border:none;border-radius:6px;border-radius:var(--radius-sm);padding:4px;transition:all .2s ease;transition:var(--transition)}.sidebar-logout-btn:hover{background:#ef44441a;color:#ef4444;color:var(--danger)}.sidebar-logout-btn svg{display:block;height:16px;width:16px}.navbar{align-items:center;background:#fff;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);box-shadow:0 1px 3px #00000014;box-shadow:var(--shadow-sm);display:flex;gap:16px;height:64px;padding:0 28px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.navbar-breadcrumb{flex:1 1}.navbar-page-title{color:#1e293b;color:var(--text-dark);font-size:18px;font-weight:600}.navbar-crumbs{align-items:center;color:#94a3b8;color:var(--text-light);display:flex;font-size:12px;gap:4px}.navbar-crumbs span.sep{color:#e2e8f0;color:var(--border)}.navbar-crumbs span.current{color:#4f46e5;color:var(--primary)}.navbar-actions{align-items:center;display:flex;gap:10px}.navbar-icon-btn{align-items:center;background:#f1f5f9;background:var(--bg-page);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#64748b;color:var(--text-mid);display:flex;height:38px;justify-content:center;position:relative;transition:all .2s ease;transition:var(--transition);width:38px}.navbar-icon-btn:hover{background:#eef2ff;background:var(--primary-bg);border-color:#4f46e5;border-color:var(--primary);color:#4f46e5;color:var(--primary)}.navbar-icon-btn svg{height:18px;width:18px}.navbar-notification-dot{background:#ef4444;background:var(--danger);border:1.5px solid #fff;border-radius:9999px;border-radius:var(--radius-full);height:7px;position:absolute;right:7px;top:7px;width:7px}.navbar-user{align-items:center;background:#f1f5f9;background:var(--bg-page);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);cursor:pointer;display:flex;gap:8px;padding:6px 12px 6px 6px;transition:all .2s ease;transition:var(--transition)}.navbar-user:hover{border-color:#4f46e5;border-color:var(--primary)}.navbar-user-avatar{align-items:center;background:#4f46e5;background:var(--primary);border-radius:9999px;border-radius:var(--radius-full);color:#fff;display:flex;font-size:12px;font-weight:700;height:30px;justify-content:center;width:30px}.navbar-user-name{font-size:13px;font-weight:500}.navbar-user svg{color:#94a3b8;color:var(--text-light);height:14px;width:14px}.card{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #00000014;box-shadow:var(--shadow-sm)}.card-header{align-items:center;display:flex;justify-content:space-between;padding:20px 24px 0}.card-title{color:#1e293b;color:var(--text-dark);font-size:15px;font-weight:600}.card-subtitle{color:#94a3b8;color:var(--text-light);font-size:12px;margin-top:2px}.card-body{padding:20px 24px}.stat-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}.stat-card{align-items:flex-start;background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #00000014;box-shadow:var(--shadow-sm);display:flex;gap:12px;justify-content:space-between;padding:20px;transition:all .2s ease;transition:var(--transition)}.stat-card:hover{box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-card-info{flex:1 1}.stat-card-label{color:#94a3b8;color:var(--text-light);font-size:12px;font-weight:500;margin-bottom:6px}.stat-card-value{color:#1e293b;color:var(--text-dark);font-size:28px;font-weight:700;line-height:1}.stat-card-change{align-items:center;display:flex;font-size:11px;gap:3px;margin-top:6px}.stat-card-change.up{color:#10b981;color:var(--success)}.stat-card-change.down{color:#ef4444;color:var(--danger)}.stat-card-icon{align-items:center;border-radius:10px;border-radius:var(--radius-md);display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.stat-card-icon svg{height:24px;width:24px}.icon-blue{background:#dbeafe;color:#2563eb}.icon-purple{background:#ede9fe;color:#7c3aed}.icon-green{background:#d1fae5;color:#059669}.icon-orange{background:#fef3c7;color:#d97706}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.page-header-left h1{color:#1e293b;color:var(--text-dark);font-size:20px;font-weight:700}.page-header-left .breadcrumb{align-items:center;color:#94a3b8;color:var(--text-light);display:flex;font-size:12px;gap:4px;margin-top:2px}.page-header-left .breadcrumb span{color:#4f46e5;color:var(--primary)}.btn{align-items:center;border:1.5px solid #0000;border-radius:6px;border-radius:var(--radius-sm);display:inline-flex;font-size:13px;font-weight:500;gap:6px;padding:9px 18px;transition:all .2s ease;transition:var(--transition);white-space:nowrap}.btn svg{height:16px;width:16px}.btn-primary{background:#4f46e5;background:var(--primary);border-color:#4f46e5;border-color:var(--primary);color:#fff}.btn-primary:hover{background:#4338ca;background:var(--primary-dark);border-color:#4338ca;border-color:var(--primary-dark)}.btn-secondary{background:#fff;border-color:#e2e8f0;border-color:var(--border);color:#1e293b;color:var(--text-dark)}.btn-secondary:hover{background:#eef2ff;background:var(--primary-bg);border-color:#4f46e5;border-color:var(--primary);color:#4f46e5;color:var(--primary)}.btn-danger{background:#ef4444;background:var(--danger);border-color:#ef4444;border-color:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626;border-color:#dc2626}.btn-sm{font-size:12px;padding:6px 12px}.btn-icon{border-radius:6px;border-radius:var(--radius-sm);padding:7px}.btn-icon svg{display:block;height:16px;width:16px}.table-toolbar{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:16px 24px}.table-toolbar-left,.table-toolbar-right{align-items:center;display:flex;gap:10px}.search-box{align-items:center;display:flex;position:relative}.search-box input{background:#f1f5f9;background:var(--bg-page);border:1.5px solid #e2e8f0;border:1.5px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#1e293b;color:var(--text-dark);font-size:13px;padding:8px 12px 8px 36px;transition:all .2s ease;transition:var(--transition);width:240px}.search-box input:focus{background:#fff;border-color:#4f46e5;border-color:var(--primary);box-shadow:0 0 0 3px #eef2ff;box-shadow:0 0 0 3px var(--primary-bg);outline:none}.search-box input::placeholder,.search-box svg{color:#94a3b8;color:var(--text-light)}.search-box svg{height:16px;left:10px;pointer-events:none;position:absolute;width:16px}.table-wrapper{overflow-x:auto}table{border-collapse:collapse;width:100%}thead tr{background:#f1f5f9;background:var(--bg-page)}th{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);color:#94a3b8;color:var(--text-light);cursor:pointer;font-size:12px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase;transition:all .2s ease;transition:var(--transition);-webkit-user-select:none;user-select:none;white-space:nowrap}th:hover{color:#4f46e5;color:var(--primary)}td{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);color:#1e293b;color:var(--text-dark);font-size:13.5px;padding:14px 16px;vertical-align:middle}tbody tr{transition:all .2s ease;transition:var(--transition)}tbody tr:hover{background:#eef2ff;background:var(--primary-bg)}tbody tr:last-child td{border-bottom:none}.td-name{font-weight:500}.td-id{background:#f1f5f9;background:var(--bg-page);border-radius:6px;border-radius:var(--radius-sm);color:#64748b;color:var(--text-mid);display:inline-block;font-family:monospace;font-size:12px;padding:2px 8px}.td-actions{gap:6px}.action-btn,.td-actions{align-items:center;display:flex}.action-btn{border:none;border-radius:6px;border-radius:var(--radius-sm);height:32px;justify-content:center;transition:all .2s ease;transition:var(--transition);width:32px}.action-btn svg{height:15px;width:15px}.action-btn.view{background:#dbeafe;background:var(--info-bg);color:#3b82f6;color:var(--info)}.action-btn.edit{background:#fef3c7;background:var(--warning-bg);color:#f59e0b;color:var(--warning)}.action-btn.delete{background:#fee2e2;background:var(--danger-bg);color:#ef4444;color:var(--danger)}.action-btn.view:hover{background:#3b82f6;background:var(--info);color:#fff}.action-btn.edit:hover{background:#f59e0b;background:var(--warning);color:#fff}.action-btn.delete:hover{background:#ef4444;background:var(--danger);color:#fff}.badge{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-size:11.5px;font-weight:600;gap:4px;padding:3px 10px}.badge:before{background:currentColor;border-radius:50%;content:"";height:6px;width:6px}.badge-success{background:#d1fae5;background:var(--success-bg);color:#10b981;color:var(--success)}.badge-danger{background:#fee2e2;background:var(--danger-bg);color:#ef4444;color:var(--danger)}.badge-warning{background:#fef3c7;background:var(--warning-bg);color:#f59e0b;color:var(--warning)}.badge-info{background:#dbeafe;background:var(--info-bg);color:#3b82f6;color:var(--info)}.badge-secondary{background:#f1f5f9;color:#64748b;color:var(--text-mid)}.pagination{align-items:center;border-top:1px solid #e2e8f0;border-top:1px solid var(--border);display:flex;justify-content:space-between;padding:14px 24px}.pagination-info{color:#94a3b8;color:var(--text-light);font-size:12px}.pagination-controls{align-items:center;display:flex;gap:4px}.pagination-btn{align-items:center;background:#fff;border:1.5px solid #e2e8f0;border:1.5px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#64748b;color:var(--text-mid);display:flex;font-size:13px;height:32px;justify-content:center;transition:all .2s ease;transition:var(--transition);width:32px}.pagination-btn:hover:not(:disabled){background:#eef2ff;background:var(--primary-bg);border-color:#4f46e5;border-color:var(--primary);color:#4f46e5;color:var(--primary)}.pagination-btn.active{background:#4f46e5;background:var(--primary);border-color:#4f46e5;border-color:var(--primary);color:#fff;font-weight:600}.pagination-btn:disabled{cursor:not-allowed;opacity:.4}.pagination-btn svg{height:14px;width:14px}.modal-overlay{align-items:center;animation:fadeIn .15s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a80;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:2000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal{animation:slideUp .2s ease;background:#fff;border-radius:24px;border-radius:var(--radius-xl);box-shadow:0 8px 24px #0000001a;box-shadow:var(--shadow-lg);max-height:90vh;max-width:640px;overflow-y:auto;width:100%}.modal-header{align-items:center;display:flex;justify-content:space-between;padding:24px 28px 0}.modal-title{font-size:18px;font-weight:700}.modal-subtitle{color:#94a3b8;color:var(--text-light);font-size:13px;margin-top:2px}.modal-close-btn{align-items:center;background:#f1f5f9;background:var(--bg-page);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#64748b;color:var(--text-mid);display:flex;height:32px;justify-content:center;transition:all .2s ease;transition:var(--transition);width:32px}.modal-close-btn:hover{background:#fee2e2;background:var(--danger-bg);border-color:#ef4444;border-color:var(--danger);color:#ef4444;color:var(--danger)}.modal-close-btn svg{height:16px;width:16px}.modal-body{padding:24px 28px}.modal-footer{border-top:1px solid #e2e8f0;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;margin-top:8px;padding:16px 28px 24px}.form-section-title{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);color:#64748b;color:var(--text-mid);font-size:13px;font-weight:600;letter-spacing:.5px;margin-bottom:14px;padding-bottom:8px;text-transform:uppercase}.form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr;margin-bottom:20px}.form-grid.single{grid-template-columns:1fr}.form-col-full{grid-column:1/-1}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{color:#64748b;color:var(--text-mid);font-size:12.5px;font-weight:500}.form-input,.form-select{background:#f1f5f9;background:var(--bg-page);border:1.5px solid #e2e8f0;border:1.5px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#1e293b;color:var(--text-dark);font-size:13.5px;padding:9px 12px;transition:all .2s ease;transition:var(--transition);width:100%}.form-input:focus,.form-select:focus{background:#fff;border-color:#4f46e5;border-color:var(--primary);box-shadow:0 0 0 3px #eef2ff;box-shadow:0 0 0 3px var(--primary-bg);outline:none}.form-input::placeholder{color:#94a3b8;color:var(--text-light)}.form-input.error,.form-select.error{border-color:#ef4444;border-color:var(--danger)}.form-error{align-items:center;color:#ef4444;color:var(--danger);display:flex;font-size:11.5px;gap:4px}.dashboard-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 360px;margin-top:20px}.chart-card{padding:24px}.chart-card .card-title{margin-bottom:4px}.recent-enrollments-list{padding:0 24px 16px}.recent-enrollment-item{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;gap:12px;padding:12px 0}.recent-enrollment-item:last-child{border-bottom:none}.rei-avatar{align-items:center;background:#eef2ff;background:var(--primary-bg);border-radius:9999px;border-radius:var(--radius-full);color:#4f46e5;color:var(--primary);display:flex;flex-shrink:0;font-size:13px;font-weight:700;height:36px;justify-content:center;width:36px}.rei-info{flex:1 1}.rei-name{font-size:13.5px;font-weight:600}.rei-course{font-size:12px}.rei-course,.rei-date{color:#94a3b8;color:var(--text-light)}.rei-date{font-size:11.5px}.login-page{display:flex;min-height:100vh}.login-left{align-items:center;background:linear-gradient(150deg,#0f0c29,#302b63 55%,#1e1b4b);display:flex;flex-shrink:0;justify-content:center;overflow:hidden;padding:60px 56px;position:relative;width:46%}.login-grid-overlay{background-image:linear-gradient(#ffffff08 1px,#0000 0),linear-gradient(90deg,#ffffff08 1px,#0000 0);background-size:48px 48px;inset:0}.login-grid-overlay,.login-orb{pointer-events:none;position:absolute}.login-orb{border-radius:50%;filter:blur(72px)}.orb-1{animation:orbFloat 7s ease-in-out infinite;background:radial-gradient(circle,#7c3aed99,#4f46e54d);height:360px;left:-100px;top:-120px;width:360px}.orb-2{animation:orbFloat 9s ease-in-out infinite reverse;background:radial-gradient(circle,#6366f180,#8b5cf64d);bottom:60px;height:240px;right:-80px;width:240px}.orb-3{animation:orbFloat 11s ease-in-out infinite;background:radial-gradient(circle,#a78bfa66,#c4b5fd33);bottom:-60px;height:180px;left:35%;width:180px}@keyframes orbFloat{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-28px) scale(1.04)}}.login-left-content{max-width:400px;position:relative;width:100%;z-index:2}.login-logo-wrap{align-items:center;display:flex;gap:10px;margin-bottom:52px}.login-logo-icon{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1f;border:1px solid #fff3;border-radius:12px;color:#fff;display:flex;height:42px;justify-content:center;width:42px}.login-logo-icon svg{height:22px;width:22px}.login-logo-text{color:#fff;font-size:17px;font-weight:700;letter-spacing:.4px}.login-hero-title{color:#fff;font-size:38px;font-weight:800;letter-spacing:-.6px;line-height:1.18;margin-bottom:18px}.login-hero-sub{color:#fff9;font-size:14px;line-height:1.75;margin-bottom:40px}.login-features{list-style:none;margin-bottom:44px}.login-feature-item{align-items:center;color:#ffffffd1;display:flex;font-size:13.5px;gap:12px;margin-bottom:14px}.login-feature-check{align-items:center;background:#a5f3fc26;border:1px solid #a5f3fc40;border-radius:50%;color:#a5f3fc;display:flex;flex-shrink:0;height:22px;justify-content:center;width:22px}.login-feature-check svg{height:11px;width:11px}.login-stats-card{align-items:center;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff12;border:1px solid #ffffff1f;border-radius:18px;display:flex;padding:22px 28px}.login-stat{flex:1 1;text-align:center}.login-stat-num{color:#fff;display:block;font-size:24px;font-weight:800;letter-spacing:-.5px;line-height:1;margin-bottom:5px}.login-stat-lbl{color:#ffffff80;display:block;font-size:11px;font-weight:500;letter-spacing:.8px;text-transform:uppercase}.login-stat-divider{background:#ffffff1f;height:38px;width:1px}.login-right{align-items:center;background:#fff;display:flex;flex:1 1;justify-content:center;overflow-y:auto;padding:48px 40px}.login-form-box{animation:fadeInUp .4s ease;max-width:420px;width:100%}@keyframes fadeInUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.login-form-header{align-items:center;display:flex;gap:14px;margin-bottom:28px}.login-form-logo{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:14px;box-shadow:0 6px 16px #4f46e559;color:#fff;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.login-form-logo svg{height:26px;width:26px}.login-form-header h2{color:#1e293b;color:var(--text-dark);font-size:22px;font-weight:700;margin-bottom:3px}.login-subtitle{color:#94a3b8;color:var(--text-light);font-size:13px}.login-guest-section{background:linear-gradient(135deg,#faf5ff,#eff6ff);border:1.5px solid #ddd6fe;border-radius:18px;margin-bottom:22px;padding:20px}.login-guest-top{margin-bottom:14px}.login-guest-badge{align-items:center;background:#fff;border:1px solid #ddd6fe;border-radius:999px;color:#4f46e5;color:var(--primary);display:inline-flex;font-size:11.5px;font-weight:600;gap:7px;margin-bottom:8px;padding:4px 12px 4px 8px}.login-demo-dot{animation:demoPulse 2s ease-in-out infinite;background:#10b981;background:var(--success);border-radius:50%;height:7px;width:7px}@keyframes demoPulse{0%,to{box-shadow:0 0 0 0 #10b98166;opacity:1}50%{box-shadow:0 0 0 4px #10b98100;opacity:.7}}.login-guest-desc{color:#64748b;color:var(--text-mid);font-size:12.5px;margin:0}.login-guest-btns{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.login-guest-btn{align-items:center;border:1.5px solid #0000;border-radius:13px;cursor:pointer;display:flex;font-family:inherit;gap:10px;padding:13px 14px;position:relative;text-align:left;transition:all .2s ease}.login-guest-btn:disabled{box-shadow:none!important;cursor:not-allowed;opacity:.55;transform:none!important}.login-guest-btn.admin{background:linear-gradient(135deg,#4f46e5,#7c3aed);box-shadow:0 4px 14px #4f46e547;color:#fff}.login-guest-btn.admin:not(:disabled):hover{box-shadow:0 8px 22px #4f46e566;transform:translateY(-2px)}.login-guest-btn.registrar{background:#fff;border-color:#ddd6fe;color:#1e293b;color:var(--text-dark)}.login-guest-btn.registrar:not(:disabled):hover{background:#eef2ff;background:var(--primary-bg);border-color:#4f46e5;border-color:var(--primary);box-shadow:0 4px 12px #4f46e51f;transform:translateY(-2px)}.login-guest-btn-icon{align-items:center;border-radius:8px;display:flex;flex-shrink:0;height:30px;justify-content:center;width:30px}.login-guest-btn.admin .login-guest-btn-icon{background:#fff3;color:#fff}.login-guest-btn.registrar .login-guest-btn-icon{background:#eef2ff;background:var(--primary-bg);color:#4f46e5;color:var(--primary)}.login-guest-btn-icon svg{height:14px;width:14px}.login-guest-btn-info{flex:1 1}.login-guest-btn-info strong{display:block;font-size:12.5px;font-weight:600;line-height:1;margin-bottom:3px}.login-guest-btn-info small{font-size:11px;opacity:.72}.login-guest-arrow{opacity:.65}.login-guest-arrow svg{display:block;height:14px;width:14px}.login-guest-spinner{animation:spin .7s linear infinite;border:2px solid #ffffff59;border-radius:50%;border-top-color:#fff;flex-shrink:0;height:14px;width:14px}.login-guest-spinner.reg{border-color:#4f46e5 #4f46e533 #4f46e533;border-top-color:var(--primary)}.login-divider{align-items:center;color:#94a3b8;color:var(--text-light);display:flex;font-size:12px;gap:12px;margin-bottom:22px}.login-divider:after,.login-divider:before{background:#e2e8f0;background:var(--border);content:"";flex:1 1;height:1px}.login-input-group{margin-bottom:16px}.login-input-label{color:#64748b;color:var(--text-mid);display:block;font-size:12.5px;font-weight:500;margin-bottom:6px}.login-input-wrap{align-items:center;display:flex;position:relative}.login-input-icon{align-items:center;color:#94a3b8;color:var(--text-light);display:flex;left:12px;pointer-events:none;position:absolute;z-index:1}.login-input-icon svg{height:16px;width:16px}.login-input{background:#f1f5f9;background:var(--bg-page);border:1.5px solid #e2e8f0;border:1.5px solid var(--border);border-radius:10px;color:#1e293b;color:var(--text-dark);font-family:inherit;font-size:13.5px;padding:11px 42px 11px 40px;transition:all .2s ease;width:100%}.login-input:focus{background:#fff;border-color:#4f46e5;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a;outline:none}.login-input-toggle,.login-input::placeholder{color:#94a3b8;color:var(--text-light)}.login-input-toggle{align-items:center;background:none;border:none;display:flex;padding:4px;position:absolute;right:10px;transition:color .2s}.login-input-toggle:hover{color:#4f46e5;color:var(--primary)}.login-input-toggle svg{height:16px;width:16px}.login-btn{align-items:center;background:linear-gradient(135deg,#4f46e5,#7c3aed);border:none;border-radius:10px;box-shadow:0 4px 14px #4f46e559;color:#fff;display:flex;font-family:inherit;font-size:14px;font-weight:600;gap:8px;justify-content:center;letter-spacing:.3px;margin-top:6px;padding:13px;transition:all .2s ease;width:100%}.login-btn:not(:disabled):hover{box-shadow:0 8px 24px #4f46e573;transform:translateY(-2px)}.login-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.login-btn-spinner{animation:spin .7s linear infinite;border:2px solid #ffffff59;border-radius:50%;border-top-color:#fff;height:16px;width:16px}.login-alert{align-items:center;background:#fee2e2;background:var(--danger-bg);border:1px solid #fca5a5;border-radius:10px;color:#ef4444;color:var(--danger);display:flex;font-size:13px;gap:8px;margin-bottom:16px;padding:11px 14px}.login-alert svg{flex-shrink:0;height:16px;width:16px}.login-footer{color:#94a3b8;color:var(--text-light);font-size:13px;margin-top:22px;text-align:center}.login-footer a{color:#4f46e5;color:var(--primary);font-weight:500}.login-footer a:hover{text-decoration:underline}.modal-wide{max-width:700px}.savatar-section{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:8px;margin-bottom:4px;padding-bottom:22px}.savatar-wrap{border-radius:9999px;border-radius:var(--radius-full);cursor:pointer;height:90px;position:relative;width:90px}.savatar-wrap .student-avatar-fallback,.savatar-wrap .student-avatar-img{border:3px solid #e2e8f0;border:3px solid var(--border)}.savatar-overlay{align-items:center;background:#00000085;border-radius:9999px;border-radius:var(--radius-full);color:#fff;display:flex;flex-direction:column;gap:4px;inset:0;justify-content:center;opacity:0;position:absolute;transition:opacity .2s ease}.savatar-wrap:hover .savatar-overlay{opacity:1}.savatar-overlay svg{height:20px;width:20px}.savatar-overlay span{font-size:10px;font-weight:600;letter-spacing:.3px}.savatar-hint{color:#94a3b8;color:var(--text-light);font-size:12px}.student-avatar-img{display:block;object-fit:cover}.student-avatar-fallback,.student-avatar-img{border-radius:9999px;border-radius:var(--radius-full);flex-shrink:0}.student-avatar-fallback{align-items:center;color:#fff;display:flex;font-weight:700;justify-content:center;letter-spacing:-.5px}.sdetail{display:flex;flex-direction:column;gap:0}.sdetail-hero{align-items:flex-start;border-radius:16px;border-radius:var(--radius-lg);display:flex;gap:18px;margin-bottom:20px;overflow:hidden;padding:24px 24px 20px;position:relative}.sdetail-hero:before{background:#ffffff14;border-radius:50%;content:"";height:200px;pointer-events:none;position:absolute;right:-60px;top:-80px;width:200px}.sdetail-hero .student-avatar-fallback,.sdetail-hero .student-avatar-img{border:3px solid #ffffff80;box-shadow:0 4px 16px #00000040}.sdetail-hero-info{flex:1 1}.sdetail-name{color:#fff;font-size:20px;font-weight:700;line-height:1;margin-bottom:8px}.sdetail-hero-meta{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:6px}.sdetail-id-badge{background:#fff3;border:1px solid #ffffff4d;border-radius:9999px;border-radius:var(--radius-full);color:#fff;font-family:monospace;font-size:11.5px;font-weight:600;padding:3px 10px}.sdetail-meta-pill{background:#ffffff26;border:1px solid #fff3;border-radius:9999px;border-radius:var(--radius-full);color:#ffffffe6;font-size:11.5px;font-weight:500;padding:3px 10px}.sdetail-hero-sub{color:#ffffffa6;font-size:12px;margin-top:2px}.sdetail-gpa-badge{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff26;border:1.5px solid #ffffff40;border-radius:10px;border-radius:var(--radius-md);display:flex;flex-direction:column;flex-shrink:0;min-width:60px;padding:10px 14px;text-align:center}.sdetail-gpa-num{color:#fff;font-size:18px;font-weight:800;line-height:1;margin-bottom:3px}.sdetail-gpa-lbl{color:#ffffffa6;font-size:9px;font-weight:600;letter-spacing:1px;text-transform:uppercase}.sdetail-section{margin-bottom:20px}.sdetail-section-title{align-items:center;border-bottom:1.5px solid #e2e8f0;border-bottom:1.5px solid var(--border);color:#64748b;color:var(--text-mid);display:flex;font-size:11.5px;font-weight:700;gap:8px;letter-spacing:.8px;margin-bottom:12px;padding-bottom:8px;text-transform:uppercase}.sdetail-section-title svg{color:#4f46e5;color:var(--primary);height:14px;width:14px}.sdetail-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.sdetail-cell{align-items:flex-start;background:#f1f5f9;background:var(--bg-page);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius-md);display:flex;gap:10px;padding:12px 14px}.sdetail-cell.wide{grid-column:1/-1}.sdetail-cell-icon{align-items:center;background:#eef2ff;background:var(--primary-bg);border-radius:6px;border-radius:var(--radius-sm);color:#4f46e5;color:var(--primary);display:flex;flex-shrink:0;height:30px;justify-content:center;width:30px}.sdetail-cell-icon svg{height:14px;width:14px}.sdetail-cell-body{display:flex;flex-direction:column;gap:2px;min-width:0}.sdetail-cell-label{color:#94a3b8;color:var(--text-light);font-size:11px;font-weight:500;letter-spacing:.4px;text-transform:uppercase}.sdetail-cell-value{color:#1e293b;color:var(--text-dark);font-size:13.5px;font-weight:500;word-break:break-word}.toast-container{bottom:24px;display:flex;flex-direction:column;gap:8px;position:fixed;right:24px;z-index:9999}.toast{align-items:center;animation:slideUp .25s ease;background:#fff;border-left:4px solid;border-radius:10px;border-radius:var(--radius-md);box-shadow:0 8px 24px #0000001a;box-shadow:var(--shadow-lg);display:flex;font-size:13.5px;gap:10px;max-width:360px;min-width:280px;padding:12px 16px}.toast svg{flex-shrink:0;height:18px;width:18px}.toast-message{flex:1 1}.toast.success{border-color:#10b981;border-color:var(--success)}.toast.success svg{color:#10b981;color:var(--success)}.toast.error{border-color:#ef4444;border-color:var(--danger)}.toast.error svg{color:#ef4444;color:var(--danger)}.toast.info{border-color:#4f46e5;border-color:var(--primary)}.toast.info svg{color:#4f46e5;color:var(--primary)}.loading-wrapper{align-items:center;color:#94a3b8;color:var(--text-light);display:flex;flex-direction:column;font-size:13px;gap:12px;justify-content:center;padding:60px 20px}.spinner{animation:spin .7s linear infinite;border:3px solid #e2e8f0;border-top-color:#4f46e5;border:3px solid var(--border);border-radius:50%;border-top-color:var(--primary);height:36px;width:36px}@keyframes spin{to{transform:rotate(1turn)}}.empty-state{color:#94a3b8;color:var(--text-light);padding:60px 20px;text-align:center}.empty-state svg{height:48px;margin-bottom:12px;opacity:.4;width:48px}.empty-state h3{color:#64748b;color:var(--text-mid);font-size:15px;font-weight:600;margin-bottom:6px}.empty-state p{font-size:13px}@media (max-width:1200px){.stat-cards{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}}@media (max-width:960px){.sidebar{transform:translateX(-100%)}.main-wrapper{margin-left:0}.login-left{display:none}.login-right{padding:40px 24px}}@media (max-width:640px){.stat-cards{grid-template-columns:1fr}.page-content{padding:16px}.form-grid{grid-template-columns:1fr}}
/*# sourceMappingURL=main.8d3ccf4f.css.map*/