.student-form-wrapper{background-color:#fff;display:flex;flex-direction:column;height:100%;overflow:hidden}.modal-header{background-color:#f9fafb;border-bottom:1px solid #e5e7eb;flex-shrink:0;padding:20px 32px}.modal-title{color:#111827;font-size:1.25rem}.modal-close{background:#0000;border-radius:6px;color:#6b7280;height:32px;line-height:1;padding:4px;transition:all .2s;width:32px}.modal-close:hover{background-color:#e5e7eb;color:#1f2937}.student-form-grid{flex:1 1;overflow-y:auto}.form-group label{color:#374151;font-size:.875rem}.form-group input,.form-group select,.form-group textarea{background-color:#fff;border:1px solid #d1d5db;border-radius:8px;color:#111827;transition:border-color .15s,box-shadow .15s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled,.input-readonly{background-color:#f3f4f6;color:#6b7280;cursor:not-allowed}.required{color:#ef4444;margin-left:4px}.field-error{font-size:.8rem;margin-top:4px}.payment-plan-details,.selected-seat-details{align-items:center;background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;color:#1e40af;cursor:pointer;display:flex;font-size:.95rem;justify-content:space-between;padding:12px 16px;transition:background-color .2s}.selected-seat-details:hover{background-color:#dbeafe}.seat-selection-prompt{display:flex;gap:12px}.seat-selection-input{background-color:#f9fafb!important;cursor:pointer;flex:1 1}.select-seat-button{white-space:nowrap}.form-footer{align-items:center;border-top:1px solid #e5e7eb;gap:12px;margin-top:8px;padding-top:24px}.form-error-message{color:#d32f2f;font-size:.9rem;font-weight:500;margin-right:auto}@media (max-width:768px){.student-form-grid{gap:20px;grid-template-columns:1fr;padding:20px}.modal-header{padding:16px 20px}}.popup-overlay{align-items:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:3000}.popup-content{animation:slideUpFade .3s ease-out;background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;max-width:400px;padding:32px;text-align:center;width:90%}.popup-icon{display:block;font-size:48px;margin-bottom:16px}.popup-message{color:#111827;font-size:1.25rem;font-weight:700;line-height:1.4;margin:0}@keyframes slideUpFade{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.form-group label{font-size:.9rem;line-height:1.4;margin-bottom:6px}.form-group input,.form-group select{box-sizing:border-box;height:44px;padding:10px 12px}:root{--sidebar-width:260px;--sidebar-width-collapsed:80px;--sidebar-bg:#fff;--sidebar-color:#4b5563;--sidebar-color-hover:#111827;--sidebar-bg-hover:#f3f4f6;--sidebar-color-active:#2563eb;--sidebar-bg-active:#eff6ff;--sidebar-border:#e5e7eb;--sidebar-shadow:4px 0 24px #00000005;--navbar-height:64px;--text-color:#374151}.dark,.dark-mode,[data-theme=dark]{--sidebar-bg:#1f2937;--sidebar-color:#9ca3af;--sidebar-color-hover:#f3f4f6;--sidebar-bg-hover:#374151;--sidebar-color-active:#60a5fa;--sidebar-bg-active:#2563eb33;--sidebar-border:#374151;--sidebar-shadow:4px 0 24px #0006;--bg-elevated:#1f2937;--text-color:#f3f4f6;--border-color:#374151}.sidebar{background-color:#fff;background-color:var(--sidebar-bg,#fff);border-right:1px solid var(--sidebar-border);box-shadow:4px 0 24px #00000005;box-shadow:var(--sidebar-shadow);display:flex;flex-direction:column;font-family:Inter,system-ui,-apple-system,sans-serif;height:100dvh;overflow-x:hidden;transition:width .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1);z-index:1000}.sidebar-header{flex-shrink:0}.sidebar.expanded{min-width:260px;min-width:var(--sidebar-width);width:260px;width:var(--sidebar-width)}.sidebar.collapsed{min-width:80px;min-width:var(--sidebar-width-collapsed);width:80px;width:var(--sidebar-width-collapsed)}.sidebar.expanded~*{margin-left:260px;margin-left:var(--sidebar-width)}.sidebar.collapsed~*,.sidebar.expanded~*{transition:margin-left .3s cubic-bezier(.4,0,.2,1);width:auto}.sidebar.collapsed~*{margin-left:80px;margin-left:var(--sidebar-width-collapsed)}.sidebar-header{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--sidebar-border);gap:.75rem;height:64px;height:var(--navbar-height);justify-content:flex-start;margin-bottom:0;padding:0 1.5rem;white-space:nowrap}.sidebar-header,.sidebar-logo{align-items:center;display:flex;transition:all .3s ease}.sidebar-logo{background:linear-gradient(135deg,#2563eb,#1d4ed8);background:linear-gradient(135deg,var(--sidebar-color-active) 0,#1d4ed8 100%);border-radius:6px;box-shadow:0 2px 4px #2563eb1a;color:#fff;flex-shrink:0;height:32px;justify-content:center;width:32px}.sidebar-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#4f46e5,#9333ea);-webkit-background-clip:text;background-clip:text;color:#111827;font-size:1.15rem;font-weight:800;letter-spacing:-.5px;line-height:1;margin-left:0;max-width:200px;opacity:1;overflow:hidden;transition:opacity .3s ease,max-width .3s ease}[data-theme=dark] .sidebar-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#818cf8,#c084fc);-webkit-background-clip:text;background-clip:text}.sidebar.collapsed .sidebar-header{justify-content:center;padding:0}.sidebar.collapsed .sidebar-header>span,.sidebar.collapsed .sidebar-title{display:none}.sidebar.collapsed .sidebar-logo{margin:0}.sidebar-toggle{align-items:center;background:#0000;border:1px solid #0000;border-radius:8px;color:#6b7280;display:flex;font-size:1.2rem;height:36px;justify-content:center;transition:all .2s;width:36px}.sidebar-toggle:hover{background-color:#f3f4f6;background-color:var(--sidebar-bg-hover);color:#111827;color:var(--sidebar-color-hover)}.sidebar.collapsed .sidebar-toggle{margin:0 auto}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:.5rem;overflow-y:auto;padding:1rem;scrollbar-width:none}.sidebar-nav::-webkit-scrollbar{display:none}.sidebar-nav::-webkit-scrollbar-thumb{background-color:#e5e7eb;border-radius:4px}.sidebar-link{align-items:center;border-radius:8px;color:#4b5563;color:var(--sidebar-color);cursor:pointer;display:flex;font-size:.95rem;font-weight:500;margin-bottom:2px;overflow:hidden;padding:.75rem;position:relative;text-decoration:none;transition:all .2s ease;white-space:nowrap}.sidebar-link:hover{background-color:#f3f4f6;background-color:var(--sidebar-bg-hover);color:#111827;color:var(--sidebar-color-hover)}.sidebar-link.active{background-color:#eff6ff;background-color:var(--sidebar-bg-active);color:#2563eb;color:var(--sidebar-color-active);font-weight:600}.sidebar-link.active:before{background-color:#2563eb;background-color:var(--sidebar-color-active);border-radius:0 4px 4px 0;bottom:0;content:"";left:-1rem;position:absolute;top:0;width:4px}.sidebar-link .icon{align-items:center;display:inline-flex;flex-shrink:0;font-size:1.25rem;height:24px;justify-content:center;margin-right:12px;min-width:24px;transition:color .2s;width:24px}.sidebar.collapsed .sidebar-link{border-radius:10px;justify-content:center;margin:0 0 4px;padding:12px 0;width:100%}.sidebar.collapsed .sidebar-link .icon{font-size:1.5rem;margin-right:0}.sidebar-link .label{max-width:150px;opacity:1;transition:opacity .2s ease,max-width .2s ease}.sidebar.collapsed .label{display:none}.sidebar-divider{border-top:1px solid #e5e7eb;border-top:1px solid var(--sidebar-border);margin:1rem 0}.sidebar-divider-title{color:#9ca3af;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:.5rem;padding:0 1rem;text-transform:uppercase;transition:opacity .3s ease;white-space:nowrap}.sidebar.collapsed .sidebar-divider-title{display:none}.sidebar-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--sidebar-border);flex-shrink:0;padding:1rem}button.sidebar-link{background:none;border:none;cursor:pointer;font-family:inherit;font-size:inherit;text-align:left;width:100%}@media (max-width:768px){.sidebar{background-color:#fff;background-color:var(--sidebar-bg,#fff);box-shadow:none;height:100vh;position:fixed;top:0;transform:translateX(-100%);transition:transform .3s ease-in-out;width:260px!important;width:var(--sidebar-width)!important;z-index:1200}.sidebar.expanded{box-shadow:4px 0 15px #0000001a;transform:translateX(0)}.sidebar.collapsed{min-width:0;overflow:hidden;width:0}.sidebar.collapsed~*,.sidebar.expanded~*{margin-left:0!important}}.top-navbar{background-color:#fff;background-color:var(--bg-elevated);height:64px;height:var(--navbar-height);padding:0 1rem;transition:background-color .3s ease,border-color .3s ease;z-index:900}.top-navbar.glass-effect{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background-color:#ffffffd9;border-bottom:1px solid #e5e7eb80}.top-left,.top-right{align-items:center;display:flex;gap:1rem}.app-name{color:#374151;font-size:1.25rem}.notify-dropdown{box-shadow:0 4px 12px #00000026;margin-top:.5rem;overflow:hidden;top:100%;width:300px;z-index:1002}.notify-header{background:#f3f4f6;background:var(--sidebar-bg-hover);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);padding:12px 16px}.notify-empty{font-size:.9rem;padding:16px;text-align:center}[data-theme=dark] .top-navbar.glass-effect{background-color:#1f2937d9;border-bottom:1px solid #37415180}:root{--bg-color:#f1f5f9;--bg-elevated:#fff;--text-color:#0f172a;--muted-text:#6b7280;--border-color:#e5e7eb;--border-soft:#c4e4e9;--primary-color:#0ea5a4;--primary-strong:#0891b2;--primary-alt:#22c55e;--accent-blue:#6366f1;--danger-color:#ef4444;--danger-soft:#f97373;--sidebar-bg:linear-gradient(180deg,#e0f7f7,#f0fbff);--navbar-bg:#fff;--main-bg-soft:#f8fafc;--card-soft-ac:#ecfeff;--card-soft-nonac:#eef2ff;--table-row:#f9fafb;--table-row-alt:#fff;--table-row-hover:#e5e7eb;--avatar-bg:#0ea5a4;--overlay-bg:#0f172a80;--shadow-soft:#0f172a2e;--shadow-strong:#0f172a33;--shadow-navbar:#94a3b82e;--shadow-dropdown:#0f172a26;--btn-ghost-border:#94a3b899}[data-theme=dark]{--bg-color:#020617;--bg-elevated:#020617;--text-color:#e5e7eb;--muted-text:#9ca3af;--border-color:#374151;--border-soft:#1f2937;--primary-color:#22c55e;--primary-strong:#16a34a;--primary-alt:#06b6d4;--accent-blue:#6366f1;--danger-color:#f97373;--danger-soft:#fecaca;--sidebar-bg:linear-gradient(180deg,#020617,#111827);--navbar-bg:#020617;--main-bg-soft:#020617;--card-soft-ac:#22c55e14;--card-soft-nonac:#6366f114;--table-row:#020617;--table-row-alt:#111827;--table-row-hover:#1f2937;--avatar-bg:#22c55e;--overlay-bg:#0f172abf;--shadow-soft:#00000073;--shadow-strong:#0009;--shadow-navbar:#00000080;--shadow-dropdown:#00000080;--btn-ghost-border:#94a3b8cc}*,:after,:before{box-sizing:border-box}body,html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;background:#f1f5f9;background:var(--bg-color);color:#0f172a;color:var(--text-color);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;margin:0;max-width:100%;overflow-x:hidden}:root{--space-xxs:4px;--space-xs:8px;--space-sm:12px;--space-md:18px;--space-lg:24px;--space-xl:32px}.btn,.btn-danger,.btn-ghost,.btn-primary{min-height:38px}:focus{outline:none}:focus-visible{outline:3px solid #22c55e2e;outline-offset:3px}@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}.container{padding:0 18px;padding:0 var(--space-md)}.container-sm{max-width:720px}.container-md{max-width:960px}.container-lg{max-width:1400px}.row{display:flex;flex-wrap:wrap;gap:18px;gap:var(--space-md)}.col{flex:1 1;min-width:0}.col-1{flex:0 0 8.33%}.col-2{flex:0 0 16.66%}.col-3{flex:0 0 25%}.col-4{flex:0 0 33.333%}.col-6{flex:0 0 50%}.col-auto{flex:0 0 auto}@media (max-width:768px){body{font-size:15px}.row{gap:12px;gap:var(--space-sm)}.col-1,.col-2,.col-3,.col-4{flex-basis:100%}.container{padding:0 12px;padding:0 var(--space-sm)}.btn{justify-content:center;width:100%}.table{min-width:640px}}@supports (-ms-ime-align:auto){body,html{font-family:Segoe UI,Inter,system-ui,-apple-system,BlinkMacSystemFont,Roboto,Arial,sans-serif}}.btn-report-generate{align-items:center;background:linear-gradient(135deg,#0ea5a4,#22c55e);background:linear-gradient(135deg,var(--primary-color),var(--primary-alt));border:none;border-radius:10px;box-shadow:0 6px 20px #0f172a2e;box-shadow:0 6px 20px var(--shadow-soft);color:#fff;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:600;gap:10px;justify-content:center;min-height:42px;overflow:hidden;padding:10px 18px;position:relative;transition:transform .2s ease,box-shadow .2s ease,filter .2s ease;width:100%}.btn-report-generate:hover:not(:disabled){box-shadow:0 10px 30px #0f172a33;box-shadow:0 10px 30px var(--shadow-strong);filter:saturate(1.05);transform:translateY(-2px)}.btn-report-generate:active:not(:disabled){box-shadow:0 6px 18px #0f172a2e;box-shadow:0 6px 18px var(--shadow-soft);transform:translateY(0)}.btn-report-generate:disabled{background:#e5e7eb;background:var(--border-color);box-shadow:none;color:#6b7280;color:var(--muted-text);cursor:not-allowed;opacity:.7;transform:none}[data-theme=dark] .btn-report-generate{box-shadow:0 6px 20px #94a3b82e;box-shadow:0 6px 20px var(--shadow-navbar)}[data-theme=dark] .btn-report-generate:hover:not(:disabled){box-shadow:0 10px 30px #0f172a26;box-shadow:0 10px 30px var(--shadow-dropdown)}.btn-report-generate .btn-spinner,.btn-spinner{animation:spin .8s linear infinite;border:2px solid #ffffff59;border-radius:50%;border-top-color:#fff;display:inline-block;height:18px;width:18px}@keyframes spin{to{transform:rotate(1turn)}}.container{margin:0 auto;max-width:1200px;padding:0 20px;width:100%}.page{padding:16px 0}.page-header{gap:16px;margin-bottom:16px}.page-title{font-size:1.25rem;font-weight:700;margin:0}.page-actions{align-items:center;display:flex;gap:12px}.card{border-radius:10px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;padding:16px}.card-title{font-size:1rem;font-weight:600;margin-bottom:8px}.card-body{padding-top:6px}.btn{align-items:center;background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:10px;color:#0f172a;color:var(--text-color);cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:8px;padding:8px 12px;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,opacity .12s ease}.btn:focus{box-shadow:0 0 0 4px #0ea5a40f;outline:none}.btn:active{transform:translateY(0)}.btn-primary{background:linear-gradient(135deg,#0ea5a4,#22c55e);background:linear-gradient(135deg,var(--primary-color),var(--primary-alt));border-color:#0000;box-shadow:0 8px 24px #0f172a2e;box-shadow:0 8px 24px var(--shadow-soft)}.btn-primary:hover{box-shadow:0 12px 36px #0f172a33;box-shadow:0 12px 36px var(--shadow-strong);transform:translateY(-2px)}.btn-refresh{align-items:center;border-radius:10px;display:inline-flex;font-size:.875rem;gap:8px;height:44px;min-width:110px;padding:10px 20px}.btn-refresh:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-danger{background:#ef4444;background:var(--danger-color);border-color:#0000;color:#fff}.btn-link{background:#0000;border:none;color:#0ea5a4;color:var(--primary-color);font-weight:600;padding:0}.btn:disabled,.btn[disabled]{cursor:not-allowed;opacity:.6}.form-row{align-items:center;display:flex;gap:12px}.form-label{color:#6b7280;color:var(--muted-text);display:block;font-size:.9rem;margin-bottom:6px}.form-control,input[type=email],input[type=password],input[type=text],select,textarea{background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;color:#0f172a;color:var(--text-color);height:38px;padding:8px 12px;transition:box-shadow .12s ease,border-color .12s ease;width:100%}.form-control:focus,input:focus,select:focus,textarea:focus{border-color:#0891b2;border-color:var(--primary-strong);box-shadow:0 6px 18px #0ea5a414;outline:none}.input-inline{align-items:center;display:inline-flex;gap:8px}.table-responsive{border-radius:8px}.table{background:#fff;background:var(--bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-collapse:collapse;border-radius:8px;min-width:720px;overflow:hidden;width:100%}.table thead{background:linear-gradient(180deg,#00000005,#0000)}.table td,.table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);padding:12px 14px;text-align:left}.table tbody tr:nth-child(odd){background:#f9fafb;background:var(--table-row)}.table tbody tr:hover{background:#e5e7eb;background:var(--table-row-hover)}.modal-backdrop{background:#0f172a80;background:var(--overlay-bg);display:none;inset:0;position:fixed;z-index:999}.modal{animation:slideIn .3s cubic-bezier(.25,.46,.45,.94);background:#fff;background:var(--bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 20px 40px #0f172a33;box-shadow:0 20px 40px var(--shadow-strong);left:50%;max-width:600px;padding:18px;position:fixed;top:10%;transform:translateX(-50%);width:calc(100% - 40px);z-index:1000}.badge{align-items:center;background:#0ea5a4;background:var(--primary-color);gap:6px;padding:6px 10px}.avatar,.badge{display:inline-flex;font-weight:700}.avatar{height:36px;width:36px}.notification-container{align-items:center;cursor:pointer;display:inline-flex;gap:8px;position:relative}.notification-container .badge{background:#ef4444;background:var(--danger-color);border-radius:999px;box-shadow:0 6px 16px #0f172a2e;box-shadow:0 6px 16px var(--shadow-soft);color:#fff;font-size:12px;font-weight:700;min-width:20px;padding:4px 6px;position:absolute;right:-6px;text-align:center;top:-6px}.notification-container .dropdown{background:#fff;background:var(--bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 12px 30px #0f172a2e;box-shadow:0 12px 30px var(--shadow-soft);display:none;max-width:calc(100vw - 32px);overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:320px;z-index:1200}.notification-container.open .dropdown,.notification-container:focus-within .dropdown{display:block}.notification-container .dropdown .item{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:12px}.notification-container .dropdown .item:last-child{border-bottom:none}.notification-container .dropdown .item .meta{color:#6b7280;color:var(--muted-text);font-size:.9rem}.notification-container .dropdown .item button{min-width:80px}@media (max-width:480px){.notification-container .dropdown{left:10px;right:10px;top:calc(100% + 6px);width:auto}}.text-muted{color:#6b7280;color:var(--muted-text)}.text-right{text-align:right}.small{font-size:.85rem}.mt-1{margin-top:6px}.mt-2{margin-top:12px}.mb-1{margin-bottom:6px}@media (max-width:768px){.page-header{align-items:stretch;flex-direction:column;gap:12px}.page-actions{justify-content:flex-end}.form-row{flex-direction:column}}.app-shell{background:#f1f5f9;background:var(--bg-color);color:#0f172a;color:var(--text-color);display:flex;min-height:100vh}.sidebar{background:linear-gradient(180deg,#e0f7f7,#f0fbff);background:var(--sidebar-bg);border-right:1px solid #e5e7eb;border-right:1px solid var(--border-color);height:100vh;left:0;overflow-y:auto;position:fixed;top:0;transition:transform .3s ease,width .3s ease;width:260px;z-index:1200}.sidebar.collapsed{width:70px}.main-column{display:flex;flex:1 1;flex-direction:column;height:100vh;overflow:hidden}.sidebar-open .main-column{margin-left:260px}@media (max-width:768px){.app-shell.sidebar-open .main-column,.main-column{margin-left:0}.sidebar{transform:translateX(-100%)}.sidebar.expanded{transform:translateX(0)}.modal{width:90%}}.auth-shell{align-items:center;background:linear-gradient(135deg,#0ea5a4,#22c55e 50%,#6366f1);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-alt) 50%,var(--accent-blue) 100%);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.auth-card{background:#fff;background:var(--bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;box-shadow:0 18px 45px #0f172a2e;box-shadow:0 18px 45px var(--shadow-soft);max-width:420px;padding:24px 28px;width:100%}.auth-header{gap:14px;margin-bottom:20px}.auth-header,.auth-logo-circle{align-items:center;display:flex}.auth-logo-circle{background:linear-gradient(135deg,#0ea5a4,#22c55e);background:linear-gradient(135deg,var(--primary-color),var(--primary-alt));border-radius:999px;color:#fff;font-size:1.1rem;font-weight:700;height:40px;justify-content:center;width:40px}.auth-title{color:#0f172a;color:var(--text-color);font-size:1.25rem;font-weight:600;margin:0}.auth-subtitle{color:#6b7280;color:var(--muted-text);font-size:.85rem;margin:2px 0 0}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-error{color:#f97373;color:var(--danger-soft);font-size:.8rem;margin-top:4px}.auth-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:10px}.login-redirect{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);margin-top:24px;padding-top:20px;text-align:center}.login-button{align-items:center;background:linear-gradient(135deg,#0ea5a4,#22c55e);background:linear-gradient(135deg,var(--primary-color),var(--primary-alt));border:none;border-radius:8px;box-shadow:0 4px 12px #0f172a2e;box-shadow:0 4px 12px var(--shadow-soft);color:#fff;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:500;gap:8px;padding:12px 28px;text-decoration:none;transition:all .2s ease}.login-button:hover{background:linear-gradient(135deg,#0891b2,#0ea5a4);background:linear-gradient(135deg,var(--primary-strong),var(--primary-color));box-shadow:0 6px 16px #0f172a33;box-shadow:0 6px 16px var(--shadow-strong);transform:translateY(-1px)}.login-button:active{transform:translateY(0)}[data-theme=dark] .login-button{box-shadow:0 4px 12px #94a3b82e;box-shadow:0 4px 12px var(--shadow-navbar)}[data-theme=dark] .login-button:hover{box-shadow:0 6px 16px #0f172a26;box-shadow:0 6px 16px var(--shadow-dropdown)}.top-navbar{align-items:center;background:#fff;background:var(--navbar-bg);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);box-shadow:0 4px 10px #94a3b82e;box-shadow:0 4px 10px var(--shadow-navbar);display:flex;justify-content:space-between;padding:8px 16px;position:-webkit-sticky;position:sticky;top:0;z-index:1100}.app-name{color:#0f172a;color:var(--text-color);font-size:1rem;font-weight:700;letter-spacing:.05em;margin:0;text-transform:uppercase}.top-right{gap:14px}.navbar-brand-group,.top-right{align-items:center;display:flex}.navbar-brand-group{gap:12px}.icon-button,.nav-notify{position:relative}.icon-button{background:#0000;border:none;color:#0f172a;color:var(--text-color);cursor:pointer;font-size:1.2rem;transition:color .2s ease;z-index:1200}.icon-button:hover{color:#0ea5a4}.badge{background:#ef4444;background:var(--danger-color);border-radius:999px;color:#fff;font-size:.65rem;min-width:16px;padding:1px 5px;position:absolute;right:-8px;text-align:center;top:-4px}.notify-dropdown{background:#fff;background:var(--bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 10px 25px #0f172a26;box-shadow:0 10px 25px var(--shadow-dropdown);font-size:.8rem;margin-top:8px;max-width:260px;min-width:220px;padding:8px 10px;position:absolute;right:0;z-index:50}.notify-header{font-weight:600;margin-bottom:4px}.notify-dropdown ul{list-style:none;margin:4px 0 0;max-height:200px;overflow-y:auto;padding:0}.notify-dropdown li{margin-top:4px}.notify-empty{color:#6b7280;color:var(--muted-text);font-size:.78rem;padding:12px 8px}.nav-profile{gap:8px}.avatar,.nav-profile{align-items:center;display:flex}.avatar{background:#0ea5a4;background:var(--avatar-bg);border-radius:999px;color:#fff;font-size:.85rem;font-weight:600;height:32px;justify-content:center;width:32px}.profile-info{display:flex;flex-direction:column}.profile-name{font-size:.85rem;font-weight:500}.link-button{background:none;border:none;color:#ef4444;color:var(--danger-color);cursor:pointer;font-size:.75rem;margin:0;padding:0;transition:opacity .2s ease}.link-button:hover{opacity:.8}.profile-dropdown{background:#fff;background:var(--bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 15px 30px #0f172a26;box-shadow:0 15px 30px var(--shadow-dropdown);display:flex;flex-direction:column;overflow:hidden;position:absolute;right:0;top:55px;width:220px;z-index:999}.profile-dropdown-header{background:#f1f5f9;background:var(--bg-color);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:4px;padding:14px}.profile-dropdown button{background:none;border:none;color:#0f172a;color:var(--text-color);cursor:pointer;font-size:14px;padding:12px 14px;text-align:left;transition:background .2s;width:100%}.nav-library-selector{margin-right:8px;position:relative}.library-btn{align-items:center;background:#fff;background:var(--bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#0f172a;color:var(--text-color);cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:8px;height:36px;padding:6px 12px;transition:all .2s ease}.library-btn:hover{background:#e5e7eb;background:var(--table-row-hover);border-color:#0ea5a4;border-color:var(--primary-color)}.library-dropdown{background:#fff;background:var(--bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 10px 25px #0f172a26;box-shadow:0 10px 25px var(--shadow-dropdown);display:flex;flex-direction:column;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:200px;z-index:1002}.library-dropdown-item{background:none;border:none;color:#0f172a;color:var(--text-color);cursor:pointer;font-size:.85rem;padding:10px 14px;text-align:left;transition:background .2s}.profile-dropdown button:hover{background:#e5e7eb;background:var(--table-row-hover)}.profile-dropdown .danger{color:#ef4444;font-weight:600}.library-dropdown-item:hover{background:#e5e7eb;background:var(--table-row-hover);color:#0ea5a4;color:var(--primary-color)}.library-dropdown-item.active{background:#ecfeff;background:var(--card-soft-ac);color:#0ea5a4;color:var(--primary-color);font-weight:600}.dashboard-header{gap:16px;justify-content:space-between;margin-bottom:16px}.dashboard-actions,.dashboard-header{align-items:center;display:flex;flex-wrap:wrap}.dashboard-actions{gap:12px}.main-content{background:#f8fafc;background:var(--main-bg-soft);color:#0f172a;color:var(--text-color);flex:1 1;overflow-y:auto;padding:16px 20px}.page{display:flex;flex-direction:column;gap:16px;margin:0 auto;max-width:1100px}.page-header{align-items:center;display:flex;justify-content:space-between}.page-header h1{font-size:1.4rem;font-weight:600;margin:0}.card{background:#fff;background:var(--bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 30px #0f172a2e;box-shadow:0 10px 30px var(--shadow-soft);padding:18px 16px}.cards-container{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.card h3{color:#0f172a;color:var(--text-color);font-size:.95rem;margin:0 0 4px}.card span{color:#6b7280;color:var(--muted-text);font-size:.8rem}.card-number{font-size:2.4rem;font-weight:700;margin:4px 0 2px}.card-ac{background:#ecfeff;background:var(--card-soft-ac);border-left:4px solid #0ea5a4;border-left:4px solid var(--primary-color)}.card-nonac{background:#eef2ff;background:var(--card-soft-nonac);border-left:4px solid #6366f1;border-left:4px solid var(--accent-blue)}.btn-primary{background:#0ea5a4;background:var(--primary-color);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 18px;transition:all .2s ease}.btn-primary:hover:not(:disabled){background:#0891b2;background:var(--primary-strong);box-shadow:0 4px 12px #0f172a2e;box-shadow:0 4px 12px var(--shadow-soft);transform:translateY(-1px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-ghost{background:#0000;border:1px solid #94a3b899;border:1px solid var(--btn-ghost-border);border-radius:8px;color:#0f172a;color:var(--text-color);cursor:pointer;font-size:.9rem;padding:8px 14px;transition:all .2s ease}.btn-ghost:hover:not(:disabled){background:#fff;background:var(--bg-elevated);border-color:#0ea5a4;border-color:var(--primary-color);color:#0ea5a4;color:var(--primary-color)}.btn-ghost:disabled{cursor:not-allowed;opacity:.5}.student-form-wrapper{background:#f8fafc;background:var(--main-bg-soft);max-height:85vh;overflow-y:auto;padding:0}.modal-header{background:linear-gradient(135deg,#0ea5a4,#22c55e);background:linear-gradient(135deg,var(--primary-color),var(--primary-alt));box-shadow:0 4px 20px #0000001a;justify-content:space-between;padding:28px 32px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.modal-header,.modal-title{align-items:center;color:#fff;display:flex}.modal-title{font-size:1.5rem;font-weight:700;gap:12px;letter-spacing:-.02em;margin:0}.modal-title:before{content:"";font-size:1.8rem}.modal-close{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:40px;justify-content:center;padding:8px;transition:all .2s ease;width:40px}.modal-close:hover{background:#ffffff4d;transform:rotate(90deg)}.student-form-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(2,1fr);padding:32px}.form-section{grid-column:1/-1;margin-bottom:8px;margin-top:16px}.form-section-title{align-items:center;border-bottom:2px solid #0ea5a4;border-bottom:2px solid var(--primary-color);color:#0f172a;color:var(--text-color);display:flex;font-size:1.1rem;font-weight:600;gap:10px;margin:0 0 20px;padding-bottom:12px}.form-section-title:before{background:linear-gradient(180deg,#0ea5a4,#22c55e);background:linear-gradient(180deg,var(--primary-color),var(--primary-alt));border-radius:2px;content:"";height:24px;width:4px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group-full{grid-column:1/-1}.form-group label{align-items:center;color:#0f172a;color:var(--text-color);display:flex;font-size:.88rem;font-weight:600;gap:6px}.form-group label .required{color:#ef4444;color:var(--danger-color);font-size:.9rem}.form-group input,.form-group select,.form-group textarea{background:#fff;background:var(--bg-elevated);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:10px;color:#0f172a;color:var(--text-color);font-family:inherit;font-size:.95rem;padding:10px 12px;transition:all .3s cubic-bezier(.4,0,.2,1)}.form-group input:hover,.form-group select:hover,.form-group textarea:hover{border-color:#0ea5a4;border-color:var(--primary-color)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#0ea5a4;border-color:var(--primary-color);box-shadow:0 0 0 4px #0ea5a41f;outline:none;transform:translateY(-1px)}.form-group input[readonly]{background:#f9fafb;background:var(--table-row);cursor:default}.form-group input[readonly]:hover{border-color:#e5e7eb;border-color:var(--border-color)}.form-group textarea{min-height:100px;resize:vertical}.input-error{animation:shake .3s ease;border-color:#ef4444!important;border-color:var(--danger-color)!important;box-shadow:0 0 0 4px #ef44441f!important}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}.field-error{align-items:center;animation:slideDown .2s ease;color:#ef4444;color:var(--danger-color);display:flex;font-size:.82rem;gap:4px;margin-top:2px}.field-error:before{content:"";font-size:.9rem}@keyframes slideDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.form-footer{border-top:2px solid #e5e7eb;border-top:2px solid var(--border-color);display:flex;gap:14px;grid-column:1/-1;justify-content:flex-end;margin-top:32px;padding-top:28px}.table-responsive{-webkit-overflow-scrolling:touch;border-radius:12px;max-width:100%;overflow-x:auto;width:100%}.students-table{background:#fff;background:var(--bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-collapse:collapse;border-radius:10px;box-shadow:0 10px 30px #0f172a2e;box-shadow:0 10px 30px var(--shadow-soft);overflow:hidden;width:100%}.students-table thead{background:linear-gradient(90deg,#0ea5a4,#22c55e);background:linear-gradient(90deg,var(--primary-color),var(--primary-alt));color:#f9fafb}.students-table td,.students-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);font-size:.9rem;padding:12px 14px;text-align:left}.students-table th{font-weight:600;letter-spacing:.02em}.students-table tbody tr{background:#f9fafb;background:var(--table-row);color:#0f172a;color:var(--text-color);transition:background-color .2s ease}.students-table tbody tr:nth-child(2n){background:#fff;background:var(--table-row-alt)}.students-table tbody tr:hover{background:#e5e7eb;background:var(--table-row-hover)}.students-table .actions{align-items:center;display:flex;flex-wrap:nowrap;gap:8px}.action-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:500;gap:4px;height:36px;justify-content:center;min-width:36px;padding:8px 12px;transition:all .2s ease;white-space:nowrap}.action-btn.save-btn{background:#0ea5a4;background:var(--primary-color);color:#fff}.action-btn.save-btn:hover{background:#0891b2;background:var(--primary-strong);box-shadow:0 2px 8px #0f172a2e;box-shadow:0 2px 8px var(--shadow-soft);transform:translateY(-1px)}.action-btn.cancel-btn{background:#6b7280;background:var(--muted-text);color:#fff}.action-btn.cancel-btn:hover{background:#0f172a;background:var(--text-color);box-shadow:0 2px 8px #0f172a2e;box-shadow:0 2px 8px var(--shadow-soft);transform:translateY(-1px)}.action-btn.edit-btn{background:#f59e0b;color:#fff}.action-btn.edit-btn:hover{background:#d97706;box-shadow:0 2px 8px #f59e0b4d;transform:translateY(-1px)}.action-btn.full-edit-btn{background:#6366f1;background:var(--accent-blue);color:#fff}.action-btn.full-edit-btn:hover{background:#4f46e5;box-shadow:0 2px 8px #6366f14d;transform:translateY(-1px)}.action-btn.details-btn{background:#0ea5a4;background:var(--primary-color);color:#fff}.action-btn.details-btn:hover{background:#0891b2;background:var(--primary-strong);box-shadow:0 2px 8px #0f172a2e;box-shadow:0 2px 8px var(--shadow-soft);transform:translateY(-1px)}.action-btn.delete-btn{background:#ef4444;background:var(--danger-color);color:#fff}.action-btn.delete-btn:hover{background:#dc2626;box-shadow:0 2px 8px #ef44444d;transform:translateY(-1px)}.table-input,.table-select{background:#fff;background:var(--bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:4px;color:#0f172a;color:var(--text-color);font-size:.85rem;min-width:100px;padding:6px 10px;width:100%}.table-input:focus,.table-select:focus{border-color:#0ea5a4;border-color:var(--primary-color);box-shadow:0 0 0 2px #0ea5a41a;outline:none}.status-badge{border-radius:6px;display:inline-block;font-size:.8rem;font-weight:500;padding:4px 10px;text-transform:capitalize}.status-badge.active{background:#22c55e26;color:#16a34a}.status-badge.inactive{background:#6b728026;color:#6b7280;color:var(--muted-text)}[data-theme=dark] .status-badge.active{background:#22c55e33;color:#4ade80}[data-theme=dark] .status-badge.inactive{background:#6b728033;color:#9ca3af}.students-table .action-icon{align-items:center;background:#0000;border:none;border-radius:6px;color:#0f172a;color:var(--text-color);cursor:pointer;display:inline-flex;font-size:.9rem;height:32px;justify-content:center;line-height:1;min-width:32px;padding:6px 10px;transition:all .2s ease}.students-table .action-icon:hover{background:#0ea5a4;background:var(--primary-color);color:#fff}.modal-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a80;background:var(--overlay-bg);display:flex;inset:0;justify-content:center;position:fixed;z-index:2000}.modal-container{animation:slideIn .3s cubic-bezier(.25,.46,.45,.94);max-height:95vh;max-width:90vw;width:700px}.modal-content{background:#fff;background:var(--bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;box-shadow:0 25px 50px -12px #0f172a33;box-shadow:0 25px 50px -12px var(--shadow-strong);max-height:90vh;opacity:0;overflow:hidden;transform:scale(.7) translateY(30px);transition:all .2s ease-out}.modal-content.modal-visible{opacity:1;transform:scale(1) translateY(0)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.filter-card{background:#fff;background:var(--bg-elevated);margin-bottom:16px;padding:20px}.filter-grid{grid-gap:16px;align-items:end;display:grid;gap:16px;grid-template-columns:2fr 1fr 1fr auto}.filter-item{display:flex;flex-direction:column;gap:6px}.filter-label{color:#0f172a;color:var(--text-color);font-size:.85rem;font-weight:500}.filter-input,.filter-select{background:#fff;background:var(--bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#0f172a;color:var(--text-color);font-size:.9rem;padding:10px 14px;transition:all .2s ease}.filter-input:focus,.filter-select:focus{border-color:#0ea5a4;border-color:var(--primary-color);box-shadow:0 0 0 3px #0ea5a41a;outline:none}.filter-actions{justify-content:flex-end}.filter-results{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);color:#6b7280;color:var(--muted-text);font-size:.85rem;margin-top:12px;padding-top:12px}.sortable{cursor:pointer;position:relative;transition:all .2s ease;-webkit-user-select:none;user-select:none}.sortable:hover{background:#0ea5a41a}.section-title{color:#0f172a;color:var(--text-color);font-size:1.2rem;font-weight:600;margin:20px 0 10px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:20px}.stat-card{align-items:center;background:#fff;background:var(--bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 30px #0f172a2e;box-shadow:0 10px 30px var(--shadow-soft);display:flex;gap:16px;padding:16px;transition:all .3s ease}.stat-card:hover{box-shadow:0 15px 40px #0f172a33;box-shadow:0 15px 40px var(--shadow-strong);transform:translateY(-4px)}.stat-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;font-size:1.8rem;height:60px;justify-content:center;width:60px}.stat-primary .stat-icon{background:#0ea5a41a;color:#0ea5a4;color:var(--primary-color)}.stat-success .stat-icon{background:#22c55e1a;color:#22c55e}.stat-warning .stat-icon{background:#f59e0b1a;color:#f59e0b}.stat-info .stat-icon{background:#6366f11a;color:#6366f1;color:var(--accent-blue)}.stat-content{flex:1 1}.stat-label{color:#6b7280;color:var(--muted-text);font-size:.85rem;margin-bottom:4px}.stat-value{color:#0f172a;color:var(--text-color);font-size:2rem;font-weight:700}.stat-link{background:none;border:none;color:#0ea5a4;color:var(--primary-color);cursor:pointer;font-size:.8rem;margin-top:8px;padding:0;transition:opacity .2s ease}.stat-link:hover{opacity:.7}.card-divider{background:#e5e7eb;background:var(--border-color);height:1px;margin:12px 0}.card-stats{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.card-stat-item{display:flex;font-size:.85rem;justify-content:space-between}.card-stat-label{color:#6b7280;color:var(--muted-text)}.card-stat-value{color:#0f172a;color:var(--text-color);font-weight:600}.progress-bar{background:#e5e7eb;background:var(--border-color);border-radius:999px;height:6px;overflow:hidden}.progress-fill{border-radius:999px;height:100%;transition:width .3s ease}.progress-ac{background:linear-gradient(90deg,#0ea5a4,#22c55e);background:linear-gradient(90deg,var(--primary-color),var(--primary-alt))}.progress-nonac{background:linear-gradient(90deg,#6366f1,#818cf8);background:linear-gradient(90deg,var(--accent-blue),#818cf8)}.subscription-badge{background:#0ea5a41a;border-radius:6px;color:#0ea5a4;color:var(--primary-color);font-size:.75rem;font-weight:500;padding:4px 10px;text-transform:capitalize}@media (max-width:768px){.modal-container{margin:16px;width:95vw}.student-form-grid{gap:16px;grid-template-columns:1fr}.modal-content{border-radius:12px}.action-btn{font-size:.8rem;height:30px;min-width:30px;padding:6px 8px}.students-table .actions{gap:4px}.dashboard-header{align-items:flex-start;flex-direction:column}}@media (max-width:600px){.top-navbar{padding:6px 10px}.app-name{font-size:.9rem}.profile-info{display:none}.cards-container{grid-template-columns:1fr}.students-table{min-width:650px}.students-table td,.students-table th{font-size:.85rem;padding:8px 10px;white-space:nowrap}.student-form-wrapper{padding:16px}.action-btn{font-size:.75rem;height:30px;min-width:30px;padding:6px 8px}}.unified-auth-container{align-items:center;background:linear-gradient(135deg,#0ea5a4,#22c55e 50%,#6366f1);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-alt) 50%,var(--accent-blue) 100%);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.unified-auth-container:before{animation:bgPulse 8s ease-in-out infinite;background:radial-gradient(circle at 20% 50%,#ffffff1a 0,#0000 50%),radial-gradient(circle at 80% 80%,#ffffff1a 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}@keyframes bgPulse{0%,to{opacity:.5}50%{opacity:1}}.unified-auth-card{animation:slideUpAuth .5s cubic-bezier(.25,.46,.45,.94);background:#fff;background:var(--bg-elevated);border-radius:20px;box-shadow:0 25px 50px -12px #00000040;max-width:480px;overflow:hidden;position:relative;width:100%;z-index:1}@keyframes slideUpAuth{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.unified-auth-header{background:linear-gradient(135deg,#0ea5a4,#22c55e);background:linear-gradient(135deg,var(--primary-color),var(--primary-alt));color:#fff;overflow:hidden;padding:32px 40px;position:relative;text-align:center}.unified-auth-header:after{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#ffffff80,#0000);bottom:0;content:"";height:4px;left:0;position:absolute;right:0}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.unified-auth-logo{animation:bounce 2s infinite;font-size:3rem;margin-bottom:12px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.unified-auth-title{font-size:1.8rem;font-weight:700;letter-spacing:-.02em;margin:0}.unified-auth-subtitle{font-size:.95rem;margin:8px 0 0;opacity:.9}.auth-tab-switcher{background:#fff;background:var(--bg-elevated);border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--border-color);display:flex}.auth-tab-button{background:#0000;border:none;color:#6b7280;color:var(--muted-text);cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:16px;position:relative;transition:all .3s ease}.auth-tab-button:hover{background:#f9fafb;background:var(--table-row);color:#0f172a;color:var(--text-color)}.auth-tab-button.active{background:#ecfeff;background:var(--card-soft-ac);color:#0ea5a4;color:var(--primary-color)}.auth-tab-button.active:after{animation:slideInTab .3s ease;background:#0ea5a4;background:var(--primary-color);bottom:-2px;content:"";height:2px;left:0;position:absolute;right:0}@keyframes slideInTab{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.user-type-selector{display:flex;gap:12px;padding:24px 40px 16px}.user-type-button{background:#fff;background:var(--bg-elevated);border:2px solid #e5e7eb;border:2px solid var(--border-color);border-radius:12px;cursor:pointer;flex:1 1;padding:20px 16px;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1)}.user-type-button:hover{box-shadow:0 8px 20px #0f172a2e;box-shadow:0 8px 20px var(--shadow-soft);transform:translateY(-4px)}.user-type-button.active,.user-type-button:hover{border-color:#0ea5a4;border-color:var(--primary-color)}.user-type-button.active{background:#ecfeff;background:var(--card-soft-ac);box-shadow:0 10px 25px #0f172a33;box-shadow:0 10px 25px var(--shadow-strong);transform:translateY(-2px)}.user-type-button.admin.active{background:linear-gradient(135deg,#0ea5a426,#22c55e26)}.user-type-button.staff.active{background:linear-gradient(135deg,#22c55e26,#06b6d426)}.user-type-icon{display:block;font-size:2.5rem;margin-bottom:8px}.user-type-label{color:#0f172a;color:var(--text-color);display:block;font-size:.9rem;font-weight:600}.user-type-description{color:#6b7280;color:var(--muted-text);display:block;font-size:.75rem;margin-top:4px}.toast-container{display:flex;flex-direction:column;gap:10px;pointer-events:none;position:fixed;right:20px;top:20px;z-index:5000}@media (max-width:480px){.toast-container{left:10px;right:10px;width:auto}.toast{min-width:0;width:100%}}.toast{align-items:center;animation:slideInToast .3s ease-out forwards;border:1px solid #0000;border-radius:8px;box-shadow:0 4px 12px #00000026;color:#fff;display:flex;font-size:.95rem;font-weight:500;gap:12px;max-width:350px;min-width:250px;opacity:0;padding:12px 18px;pointer-events:all;transform:translateX(100%)}.toast-icon{font-size:1.2rem;line-height:1}.toast-message{flex-grow:1}.toast-close{background:none;border:none;color:#ffffffb3;cursor:pointer;font-size:1.2rem;padding:0 4px;transition:color .2s ease}.toast-close:hover{color:#fff}.toast-success{background:linear-gradient(135deg,#22c55e,#10b981);border-color:#10b981}.toast-error{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#dc2626}.toast-info{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#2563eb}.toast-warning{background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#d97706}.toast-confirm{align-items:flex-start;background:#fff;background:var(--bg-elevated);border-color:#e5e7eb;border-color:var(--border-color);box-shadow:0 10px 30px #0f172a33;box-shadow:0 10px 30px var(--shadow-strong);color:#0f172a;color:var(--text-color);flex-direction:column;gap:8px;opacity:1;padding:18px;transform:translateX(0)}.toast-confirm .toast-icon{color:#6366f1;color:var(--accent-blue)}.toast-confirm .toast-message{font-weight:600;margin-bottom:8px}.toast-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:5px;width:100%}.toast-cancel-btn,.toast-confirm-btn{border:1px solid #0000;border-radius:8px;cursor:pointer;flex:1 1;font-weight:600;padding:8px 15px;text-align:center;transition:all .2s ease}.toast-confirm-btn{background:#ef4444;background:var(--danger-color);border-color:#ef4444;border-color:var(--danger-color);color:#fff}.toast-confirm-btn:hover{background:#dc2626;box-shadow:0 2px 8px #ef44444d;transform:translateY(-1px)}.toast-cancel-btn{background:#0000;border-color:#94a3b899;border-color:var(--btn-ghost-border);color:#0f172a;color:var(--text-color)}.toast-cancel-btn:hover{background:#fff;background:var(--bg-elevated);border-color:#0f172a;border-color:var(--text-color)}@keyframes slideInToast{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes slideOutToast{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(100%)}}.app-container{display:flex;min-height:100vh;position:relative}.main-column{flex-grow:1;margin-left:70px;transition:margin-left .3s ease}.app-container.sidebar-open .main-column{margin-left:260px}.main-content{background:var(--bg-color);flex-grow:1;padding:20px}.sidebar-toggle{background:none;border:none;color:var(--primary-color);cursor:pointer;font-size:1.5em;padding:5px;z-index:1001}.icon-button{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:12px;font-size:clamp(16px,2vw,20px);height:clamp(36px,6vw,44px);padding:0;width:clamp(36px,6vw,44px)}.icon-button:hover{background:var(--card-soft-ac);color:var(--primary-color)}.icon-button:active{transform:scale(.95)}.top-left{align-items:center;display:flex;gap:12px}@media (max-width:768px){.main-column{width:100%}.app-container.sidebar-open .main-column,.main-column{margin-left:0}}
/*# sourceMappingURL=main.f8903aab.css.map*/