.navbar{background:#fff;position:-webkit-sticky;position:sticky;top:0;transition:all .3s ease;width:100%;z-index:1000}.navbar,.navbar-shadow{box-shadow:0 6px 18px #00000026}.navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1280px;padding:.8rem 2rem}.navbar-logo a{color:#000;font-size:1.75rem;font-weight:700;letter-spacing:1px;text-decoration:none;transition:color .3s ease}.navbar-logo a:hover{color:#00317f}.navbar-links{align-items:center;display:flex;gap:1.5rem}.navbar-links a{border-radius:6px;color:#000;font-weight:500;padding:.5rem .7rem;text-decoration:none;transition:all .3s ease}.navbar-links a:hover{background:#3b82f633;color:#00165e}.logout-btn{background:#ef4444;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:.5rem 1rem;transition:all .3s ease}.logout-btn:hover{background:#dc2626;box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.hamburger{cursor:pointer;display:none;flex-direction:column;gap:5px;z-index:1100}.hamburger span{background:#000;border-radius:3px;height:3px;transition:all .3s ease;width:28px}.hamburger.open span:first-child{transform:rotate(45deg) translate(5px,5px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}@media (max-width:768px){.hamburger{display:flex}.navbar-links{align-items:center;background:#1f2937;flex-direction:column;gap:2rem;height:100vh;justify-content:center;position:fixed;right:0;top:0;transform:translateX(100%);transition:transform .3s ease;width:70%;z-index:1000}.navbar-links.active{transform:translateX(0)}.logout-btn,.navbar-links a{font-size:1.25rem;text-align:center;width:80%}.navbar-links,.navbar-links a{color:#fff}.navbar-links a:hover{background:#ffffff1a;color:#3b82f6}.logout-btn{background:#ef4444;color:#fff}.logout-btn:hover{background:#dc2626;box-shadow:0 4px 12px #0003;transform:translateY(-2px)}}.auth-container{align-items:center;background:#f4f6f9;display:flex;justify-content:center;min-height:100vh}.auth-card{background:#fff;border-radius:10px;box-shadow:0 4px 10px #0000001a;max-width:400px;padding:2rem;width:100%}.auth-title{font-size:24px;font-weight:700;margin-bottom:1.5rem;text-align:center}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-group label{display:block;font-weight:500;margin-bottom:.3rem}.form-group input,.form-group select{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:.6rem;width:100%}.form-group input:focus,.form-group select:focus{border-color:#2563eb}.error-text{color:red;margin-top:.2rem}.btn{align-items:center;background:#2563eb;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-weight:500;justify-content:center;padding:.7rem;transition:background .3s}.btn:hover{background:#1d4ed8}.auth-footer{font-size:14px;margin-top:1rem;text-align:center}.auth-link{color:#2563eb;font-weight:500;text-decoration:none}.auth-link:hover{text-decoration:underline}.dashboard-container{background:#f9fafb;color:#1f2937;font-family:Inter,sans-serif;min-height:100vh;padding:2rem 1.5rem}.dashboard-title{color:#111827;font-size:clamp(1.8rem,5vw,2.4rem);font-weight:800;margin-bottom:2rem;text-align:center}.cards-container{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:2.5rem}.card{background:#fff;border-radius:1rem;box-shadow:0 4px 12px #0000000f;padding:1.5rem;text-align:center;transition:transform .3s ease}.card:hover{transform:translateY(-4px)}.card h3{color:#6b7280;font-size:clamp(.9rem,2vw,1rem);margin-bottom:.5rem}.card p{-webkit-text-fill-color:#0000;background:linear-gradient(90deg,#6366f1,#3b82f6);-webkit-background-clip:text;font-size:clamp(1.6rem,6vw,2.4rem);font-weight:800;margin:0}.charts-container{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.chart-box{background:#fff;border-radius:1rem;box-shadow:0 4px 12px #0000000f;display:flex;flex-direction:column;justify-content:center;min-height:320px;padding:1.5rem}.chart-box h4{color:#111827;font-size:clamp(1rem,4vw,1.25rem);font-weight:600;margin-bottom:1rem;text-align:center}.chart-box .recharts-responsive-container{aspect-ratio:1.5/1;height:100%!important;min-height:250px;width:100%!important}.recharts-legend-item text{fill:#374151;font-size:14px;font-weight:500}.access-denied,.error-text,.loading{color:#ef4444;font-size:1.2rem;font-weight:700;margin-top:4rem;text-align:center}@media (max-width:480px){.dashboard-container{padding:1.5rem 1rem}.dashboard-title{font-size:1.6rem}.card{padding:1rem}.card h3{font-size:.85rem}.card p{font-size:1.8rem}.chart-box{min-height:260px;padding:1rem}.chart-box h4{font-size:1rem}.recharts-legend-item text{font-size:13px}}@media (max-width:320px){.dashboard-title{font-size:1.4rem}.card p{font-size:1.6rem}.chart-box{min-height:240px}.chart-box h4{font-size:.95rem}}.students-container{color:#1f2937;font-family:Poppins,sans-serif;margin:0 auto;max-width:1280px;padding:2rem}.students-title{-webkit-text-fill-color:#0000;background:linear-gradient(90deg,#3b82f6,#6366f1,#10b981);-webkit-background-clip:text;font-size:2.2rem;font-weight:700;letter-spacing:-.5px;margin-bottom:2rem;text-align:center}.filters-container{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.filters{display:flex;flex-wrap:wrap;gap:.8rem}.filters input{background:#f9fafb;border:1px solid #d1d5db;border-radius:.6rem;min-width:180px;outline:none;padding:.7rem 1rem;transition:all .25s}.filters input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f155}.import-btn,button{border:none;border-radius:.6rem;cursor:pointer;font-size:.95rem;font-weight:600;padding:.65rem 1.4rem;transition:all .25s ease-in-out}.export-btn{background:linear-gradient(90deg,#10b981,#34d399);color:#fff}.import-btn{background:linear-gradient(90deg,#6366f1,#3b82f6);color:#fff}.clear-btn{background:linear-gradient(90deg,#f59e0b,#fbbf24);color:#fff}.add-btn{background:linear-gradient(90deg,#2563eb,#3b82f6);color:#fff}.import-btn:hover,button:hover{box-shadow:0 6px 14px #0000001f;transform:translateY(-2px) scale(1.03)}.students-table{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffb3;border-collapse:initial;border-radius:1rem;border-spacing:0;box-shadow:0 8px 24px #00000014;overflow:hidden;width:100%}.students-table td,.students-table th{border-bottom:1px solid #e5e7eb;padding:1rem 1.2rem;text-align:center}.students-table th{background:#f3f4f6e6;color:#374151;font-size:.85rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.students-table tr:hover{background:#f3f4f699;transition:.25s}.student-photo{border:2px solid #3b82f6;border-radius:50%;box-shadow:0 2px 6px #3b82f64d;height:48px;object-fit:cover;width:48px}.action-btn{border-radius:.5rem;cursor:pointer;font-size:.85rem;font-weight:500;margin:0 .2rem;padding:.45rem .8rem;transition:.25s}.edit-btn{background:linear-gradient(90deg,#2563eb,#3b82f6);color:#fff}.delete-btn{background:linear-gradient(90deg,#ef4444,#f87171);color:#fff}.action-btn:hover{box-shadow:0 4px 10px #0000001f;transform:scale(1.08)}.pagination{align-items:center;display:flex;gap:1rem;justify-content:center;margin-top:2rem}.page-btn{background:linear-gradient(90deg,#6366f1,#3b82f6);border-radius:.5rem;color:#fff;font-weight:500;padding:.55rem 1.2rem}.page-btn:disabled{background:#9ca3af;cursor:not-allowed}.modal-overlay{align-items:center;background:#0009;display:flex;inset:0;justify-content:center;position:fixed;z-index:50}.modal{animation:fadeInUp .35s ease;background:#fff;border-radius:1rem;box-shadow:0 12px 30px #0003;max-width:480px;padding:2rem;width:100%}.modal h3{color:#111827;font-size:1.3rem;font-weight:600;margin-bottom:1.2rem}.modal form input,.modal form select{background:#f9fafb;border:1px solid #d1d5db;border-radius:.6rem;margin-bottom:1rem;padding:.7rem;transition:.2s;width:100%}.modal form input:focus,.modal form select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f655}.preview-img{border-radius:.7rem;height:90px;margin:.7rem 0;width:90px}.modal-actions{display:flex;gap:.8rem;justify-content:flex-end}.save-btn{background:linear-gradient(90deg,#10b981,#34d399)}.cancel-btn,.save-btn{border-radius:.6rem;color:#fff;padding:.6rem 1.2rem}.cancel-btn{background:linear-gradient(90deg,#ef4444,#f87171)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:900px){.students-table{display:block;overflow-x:auto;width:100%}.students-table td,.students-table th{font-size:.85rem;padding:.8rem;white-space:nowrap}.students-container .student-card{background:#fff;border-radius:.8rem;box-shadow:0 4px 10px #00000014;display:block;margin-bottom:1rem;padding:1rem}.student-card img{border:2px solid #3b82f6;border-radius:50%;height:55px;margin-bottom:.8rem;object-fit:cover;width:55px}.student-card h4{font-size:1.05rem;font-weight:600;margin-bottom:.3rem}.student-card p{color:#374151;font-size:.9rem;margin:.2rem 0}.student-card .action-btn{margin-top:.7rem}}.delete-modal-overlay{align-items:center;animation:fadeInOverlay .25s ease forwards;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#1f2937b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:100}.delete-modal{animation:scaleInModal .3s ease forwards;background:#fff;border-radius:.8rem;border-top:4px solid #ef4444;box-shadow:0 8px 20px #00000026;max-width:90%;padding:2rem;text-align:center;width:380px}.delete-modal h3{color:#ef4444;font-size:1.3rem;font-weight:600;margin-bottom:.6rem}.delete-modal p{color:#374151;font-size:1rem;line-height:1.4;margin-bottom:1.8rem}.delete-modal .modal-actions{display:flex;gap:.8rem;justify-content:center}.delete-modal .cancel-btn{background:#e5e7eb;border:1px solid #d1d5db;border-radius:.5rem;color:#374151;cursor:pointer;font-weight:500;padding:.55rem 1.2rem;transition:all .2s ease-in-out}.delete-modal .cancel-btn:hover{background:#d1d5db;box-shadow:0 4px 10px #00000014;transform:translateY(-2px)}.delete-modal .confirm-delete-btn{background:#ef4444;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-weight:500;padding:.55rem 1.2rem;transition:all .2s ease-in-out}.delete-modal .confirm-delete-btn:hover{background:#dc2626;box-shadow:0 4px 12px #ef444440;transform:translateY(-2px)}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}@keyframes scaleInModal{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}@media (max-width:500px){.delete-modal{padding:1.5rem;width:90%}.delete-modal .modal-actions{flex-direction:column}.delete-modal .modal-actions button{width:100%}}@media (max-width:425px){.filters-container{align-items:stretch;flex-direction:column}.filter-wrapper,.filters{flex-direction:column;width:100%}.filter-wrapper{gap:12px}.dropdown-wrapper,.filters input{min-width:0;min-width:auto;width:100%}.add-btn,.clear-btn,.export-btn,.import-btn,button{width:100%}}.filter-wrapper{display:flex;gap:15px;margin-bottom:20px}.dropdown-wrapper{position:relative;width:135px}.filter-dropdown{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:#fdfdfd;border:1px solid #ccc;border-radius:10px;box-shadow:0 2px 5px #0000000d;color:#333;cursor:pointer;font-size:14px;padding:10px 40px 10px 15px;transition:all .3s ease;width:100%}.filter-dropdown:hover{border-color:#4a90e2;box-shadow:0 4px 10px #4a90e233}.filter-dropdown:focus{border-color:#4a90e2;box-shadow:0 0 10px #4a90e24d;outline:none}.dropdown-wrapper:after{color:#666;content:"▼";font-size:12px;pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:transform .3s ease}.filter-dropdown:focus+.dropdown-wrapper:after{transform:translateY(-50%) rotate(180deg)}.filter-dropdown option{background-color:#fff;color:#333;padding:10px}.spinner-overlay{background-color:#00000040}.add-student-container{animation:fadeIn .6s ease-in-out;background:#fff;border-radius:15px;box-shadow:0 6px 25px #00000014;margin:40px auto;max-width:500px;padding:25px}.form-title{color:#2d3748;font-size:22px;font-weight:700;margin-bottom:20px;text-align:center}.student-form{gap:18px}.form-group,.student-form{display:flex;flex-direction:column}.form-group label{color:#374151;font-size:14px;font-weight:600;margin-bottom:6px}.form-group input,.form-group select{border:1px solid #e2e8f0;border-radius:8px;font-size:15px;padding:10px 12px;transition:border-color .3s,box-shadow .3s}.form-group input:focus,.form-group select:focus{border-color:#3b82f6;box-shadow:0 0 6px #3b82f640;outline:none}.error-text{color:#e11d48;font-size:13px;margin-top:4px}.preview-img{border:2px solid #e5e7eb;border-radius:12px;height:100px;margin-top:10px;object-fit:cover;transition:transform .3s ease;width:100px}.preview-img:hover{transform:scale(1.08)}.form-actions{display:flex;gap:10px;justify-content:space-between;margin-top:10px}.back-btn{background:#f3f4f6;border-radius:8px;color:#374151;font-size:14px;font-weight:500;padding:10px 18px;text-decoration:none;transition:background .3s,transform .2s}.back-btn:hover{background:#e5e7eb;transform:translateY(-2px)}.submit-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 18px;transition:background .4s,transform .2s}.submit-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px)}.submit-btn:disabled{background:#9ca3af;cursor:not-allowed}.not-allowed{color:#e11d48;font-size:18px;font-weight:600;margin-top:50px;text-align:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}@media (max-width:600px){.add-student-container{margin:20px}.form-actions{flex-direction:column;gap:12px}.back-btn,.submit-btn{text-align:center;width:100%}}@media (max-width:400px){.add-student-container{margin:15px}.form-title{font-size:20px}.form-group input,.form-group select{font-size:14px;padding:8px 10px}.preview-img{height:80px;width:80px}.back-btn,.submit-btn{font-size:13px;padding:8px 12px}}.spinner-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0003;display:flex;flex-direction:column;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:9999}.spinner{animation:spin 1s linear infinite;border:6px solid #fff;border-radius:50%;border-top-color:#2563eb;height:60px;width:60px}.spinner-text{color:#fff;font-size:16px;font-weight:500;margin-top:1rem;text-align:center}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.audit-container{background:#fff;border-radius:16px;box-shadow:0 6px 18px #00000014;max-width:100%;overflow-x:auto;padding:2rem}.audit-container h2{color:#333;font-size:1.8rem;font-weight:600;margin-bottom:1rem;text-align:center}.audit-table{border-collapse:collapse;font-size:.95rem;width:100%}.audit-table thead{background:linear-gradient(90deg,#4f46e5,#6366f1);color:#fff}.audit-table td,.audit-table th{border-bottom:1px solid #eee;padding:.9rem 1rem;text-align:left}.audit-table tbody tr:hover{background:#f9fafb;transition:background .2s ease-in-out}.audit-table th{font-weight:600;white-space:nowrap}.audit-table td{color:#444;vertical-align:top}.audit-table details summary{color:#4f46e5;cursor:pointer;font-weight:500}.audit-table pre{background:#f4f4f4;border-radius:8px;font-size:.85rem;margin:.5rem 0 0;max-height:200px;overflow-y:auto;padding:.8rem}.access-denied{background:#fee2e2;border-radius:12px;color:#ef4444;font-weight:600;padding:2rem;text-align:center}@media (max-width:768px){.audit-table td,.audit-table th{font-size:.85rem;padding:.6rem}.audit-container{padding:1rem}.audit-container h2{font-size:1.4rem}}.home-hero{align-items:center;background:linear-gradient(135deg,#fff,#fff);display:flex;flex-wrap:wrap-reverse;font-family:Poppins,sans-serif;gap:2rem;justify-content:space-between;padding:6rem 2rem}.hero-content{flex:1 1;max-width:600px}.hero-title{color:#000;font-size:3rem;font-weight:800;line-height:1.2;margin-bottom:1.5rem}.hero-title span{color:#ff9800}.hero-subtitle{color:#374151;font-size:1.15rem;line-height:1.6;margin-bottom:2rem}.hero-buttons{display:flex;flex-wrap:wrap;gap:1rem}.btn{border-radius:.6rem;box-shadow:0 4px 15px #0000001a;font-weight:600;padding:.75rem 1.8rem;text-decoration:none;transition:all .3s ease}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover{background:#2563eb;box-shadow:0 6px 20px #3b82f64d;transform:translateY(-3px)}.btn-secondary{background:#fbbf24;color:#fff}.btn-secondary:hover{background:#f59e0b;box-shadow:0 6px 20px #fbbf244d;transform:translateY(-3px)}.hero-image{align-items:center;display:flex;flex:1 1;justify-content:center}.hero-image img{max-width:90%;transition:transform .3s ease}.hero-image img:hover{transform:scale(1.03)}@media (max-width:1024px){.home-hero{padding:3rem 1.5rem}.hero-title{font-size:2.5rem}}@media (max-width:768px){.home-hero{flex-direction:column-reverse;gap:2rem;text-align:center}.hero-buttons{justify-content:center}}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
/*# sourceMappingURL=main.7e227799.css.map*/