html{overflow-x:hidden}:root{--primary-color:#4361ee;--secondary-color:#3f37c9;--success-color:#4cc9f0;--danger-color:#f72585;--warning-color:#f8961e;--dark-color:#1e1e2f;--light-color:#f8f9fa;--gray-color:#6c757d}body{color:#333;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow-x:hidden}#root{flex-direction:column;min-height:100vh;display:flex}.container{max-width:auto;margin:0 auto;padding:0 20px}.btn{cursor:pointer;border:none;border-radius:5px;padding:10px 20px;font-size:16px;font-weight:500;transition:all .3s}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:var(--secondary-color);transform:translateY(-2px);box-shadow:0 5px 15px #4361ee4d}.btn-danger{background:var(--danger-color);color:#fff}.btn-danger:hover{background:#d1146b;transform:translateY(-2px);box-shadow:0 5px 15px #f725854d}.error{color:var(--danger-color);margin-top:5px;font-size:14px}.loading{text-align:center;color:var(--primary-color);padding:40px;font-size:18px}.success-message{color:#155724;background:#d4edda;border:1px solid #c3e6cb;border-radius:5px;margin-bottom:20px;padding:12px}.error-message{color:#721c24;background:#f8d7da;border:1px solid #f5c6cb;border-radius:5px;margin-bottom:20px;padding:12px}.app{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:20px}@media (width<=768px){.main-content{padding:15px}}.add-student{background:#fff;border-radius:20px;max-width:600px;margin:0 auto;padding:40px;animation:.5s slideUp;box-shadow:0 10px 30px #0000001a}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.form-header{text-align:center;margin-bottom:30px}.form-icon{color:var(--primary-color);margin-bottom:15px;font-size:3rem}.form-title{color:var(--dark-color);margin-bottom:10px;font-size:2rem}.form-subtitle{color:var(--gray-color);font-size:1rem}.student-form{flex-direction:column;gap:20px;display:flex}.form-group{margin-bottom:0}.form-group label{color:var(--dark-color);margin-bottom:8px;font-weight:600;display:block}.form-group input{border:2px solid #e0e0e0;border-radius:10px;width:100%;padding:12px 15px;font-size:16px;transition:all .3s}.form-group input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #4361ee1a}.form-group input.error{border-color:var(--danger-color)}.error-text{color:var(--danger-color);margin-top:5px;font-size:14px;display:block}.form-actions{gap:15px;margin-top:20px;display:flex}.btn-cancel,.btn-submit{cursor:pointer;border:none;border-radius:10px;flex:1;padding:14px;font-size:16px;font-weight:600;transition:all .3s}.btn-cancel:hover:not(:disabled){background:#d0d0d0;transform:translateY(-2px)}.btn-submit{background:linear-gradient(135deg, var(--primary-color) 0%, var(--secondary-color) 100%);color:#fff;justify-content:center;align-items:center;gap:10px;display:flex}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #4361ee4d}.btn-submit:disabled,.btn-cancel:disabled{opacity:.6;cursor:not-allowed}.spinner-icon{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (width<=768px){.add-student{padding:20px}.form-title{font-size:1.5rem}.form-actions{flex-direction:column}.btn-cancel,.btn-submit{width:100%}}*{box-sizing:border-box;margin:0;padding:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}body{background:#f4f7fb}.login-page{background:linear-gradient(135deg,#0f172a,#1e3a8a,#2563eb);justify-content:center;align-items:center;width:100%;min-height:100vh;padding:20px;display:flex;position:relative;overflow:hidden}.login-overlay{z-index:1;background:radial-gradient(circle at 100% 0,#ffffff14,#0000 35%),radial-gradient(circle at 0 100%,#ffffff0f,#0000 30%);width:100%;height:100%;position:absolute}.login-container{z-index:2;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff14;border-radius:24px;width:100%;max-width:1100px;min-height:600px;display:flex;position:relative;overflow:hidden;box-shadow:0 20px 50px #00000040}.login-left{color:#fff;background:#ffffff0a;flex-direction:column;flex:1;justify-content:center;padding:60px 50px;display:flex}.login-left h1{margin-bottom:20px;font-size:2.8rem;font-weight:700;line-height:1.2}.login-left p{color:#dbeafe;max-width:450px;font-size:1.1rem;line-height:1.7}.login-badge{color:#fff;background:#ffffff2e;border:1px solid #ffffff40;border-radius:30px;width:fit-content;margin-top:30px;padding:12px 22px;font-size:.95rem;font-weight:600;display:inline-block}.login-right{background:#ffffff1f;flex:1;justify-content:center;align-items:center;padding:40px;display:flex}.login-card{background:#fff;border-radius:22px;width:100%;max-width:420px;padding:40px 35px;box-shadow:0 15px 40px #0f172a2e}.login-card h2{color:#0f172a;text-align:center;margin-bottom:8px;font-size:2rem}.login-subtitle{text-align:center;color:#64748b;margin-bottom:30px;font-size:.95rem}.input-group{margin-bottom:22px}.input-group label{color:#1e293b;margin-bottom:8px;font-size:.95rem;font-weight:600;display:block}.input-group input{background:#f8fafc;border:1.5px solid #dbe3ef;border-radius:12px;outline:none;width:100%;padding:14px 16px;font-size:1rem;transition:all .3s}.input-group input:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 4px #2563eb1f}.password-wrapper{position:relative}.toggle-password{cursor:pointer;color:#2563eb;-webkit-user-select:none;user-select:none;font-size:.9rem;font-weight:600;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.login-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;border-radius:12px;width:100%;margin-top:8px;padding:14px;font-size:1rem;font-weight:700;transition:all .3s}.login-btn:hover{transform:translateY(-2px);box-shadow:0 10px 20px #2563eb40}.login-footer-text{text-align:center;color:#64748b;margin-top:18px;font-size:.85rem}@media (width<=992px){.login-container{flex-direction:column;min-height:auto}.login-left{text-align:center;align-items:center;padding:40px 30px}.login-left h1{font-size:2.2rem}.login-left p{max-width:100%}.login-right{padding:30px 20px 40px}}@media (width<=576px){.login-page{padding:15px}.login-left{padding:30px 20px}.login-left h1{font-size:1.8rem}.login-left p{font-size:.95rem}.login-card{border-radius:18px;padding:30px 22px}.login-card h2{font-size:1.6rem}.input-group input{padding:12px 14px}.login-btn{padding:12px}}.change-password-page{box-sizing:border-box;background:linear-gradient(135deg,#eef2ff,#dbeafe,#f0f9ff);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.change-password-card{background:#fff;border-radius:18px;width:100%;max-width:420px;padding:30px 25px;animation:.4s ease-in-out fadeIn;box-shadow:0 8px 25px #0000001f}.change-password-card h2{text-align:center;color:#1e3a8a;margin:0;font-size:28px;font-weight:700}.subtitle{text-align:center;color:#6b7280;margin:8px 0 20px;font-size:14px}.change-password-form{flex-direction:column;gap:16px;display:flex}.form-group{flex-direction:column;display:flex}.form-group label{color:#374151;margin-bottom:6px;font-size:14px;font-weight:600}.form-group input{border:1px solid #cbd5e1;border-radius:10px;outline:none;padding:12px 14px;font-size:15px;transition:all .3s}.form-group input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.change-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;border-radius:10px;margin-top:10px;padding:13px;font-size:16px;font-weight:600;transition:all .3s}.change-btn:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-2px)}.message{text-align:center;border-radius:10px;margin-bottom:15px;padding:12px;font-size:14px;font-weight:500}.message.success{color:#166534;background:#dcfce7;border:1px solid #86efac}.message.error{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (width<=480px){.change-password-card{border-radius:14px;padding:22px 18px}.change-password-card h2{font-size:24px}.form-group input{padding:11px 12px;font-size:14px}.change-btn{padding:12px;font-size:15px}}.edit-student{background:#fff;border-radius:20px;max-width:600px;margin:0 auto;padding:40px;animation:.5s slideUp;box-shadow:0 10px 30px #0000001a}.edit-student .form-header{text-align:center;margin-bottom:30px}.edit-student .form-icon{color:var(--warning-color);margin-bottom:15px;font-size:3rem}.edit-student .form-title{color:var(--dark-color);margin-bottom:10px;font-size:2rem}.edit-student .form-subtitle{color:var(--gray-color);font-size:1rem}.edit-student .student-form{flex-direction:column;gap:20px;display:flex}.edit-student .form-group{margin-bottom:0}.edit-student .form-group label{color:var(--dark-color);margin-bottom:8px;font-weight:600;display:block}.edit-student .form-group input{border:2px solid #e0e0e0;border-radius:10px;width:100%;padding:12px 15px;font-size:16px;transition:all .3s}.edit-student .form-group input:focus{border-color:var(--warning-color);outline:none;box-shadow:0 0 0 3px #f8961e1a}.edit-student .form-group input.error{border-color:var(--danger-color)}.edit-student .error-text{color:var(--danger-color);margin-top:5px;font-size:14px;display:block}.edit-student .form-actions{gap:15px;margin-top:20px;display:flex}.edit-student .btn-cancel,.edit-student .btn-submit{cursor:pointer;border:none;border-radius:10px;flex:1;padding:14px;font-size:16px;font-weight:600;transition:all .3s}.edit-student .btn-cancel{color:var(--gray-color);background:#e0e0e0}.edit-student .btn-cancel:hover:not(:disabled){background:#d0d0d0;transform:translateY(-2px)}.edit-student .btn-submit{background:linear-gradient(135deg, var(--warning-color) 0%, #e07c0c 100%);color:#fff;justify-content:center;align-items:center;gap:10px;display:flex}.edit-student .btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #f8961e4d}.edit-student .btn-submit:disabled,.edit-student .btn-cancel:disabled{opacity:.6;cursor:not-allowed}.edit-student .spinner-icon{animation:1s linear infinite spin}@media (width<=768px){.edit-student{padding:20px}.edit-student .form-title{font-size:1.5rem}.edit-student .form-actions{flex-direction:column}.edit-student .btn-cancel,.edit-student .btn-submit{width:100%}}.footer{background:var(--dark-color);color:#fff;margin-top:auto;padding:20px 0;box-shadow:0 -2px 10px #0000001a}.footer-container{text-align:center;max-width:1200px;margin:0 auto;padding:0 20px}.footer-text{justify-content:center;align-items:center;gap:5px;font-size:1rem;display:flex}.footer-heart{color:var(--danger-color);animation:1.5s infinite heartbeat}@keyframes heartbeat{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}@media (width<=768px){.footer-text{flex-wrap:wrap;font-size:.9rem}}.home{animation:.5s fadeIn}.home-header{text-align:center;margin-bottom:40px}.home-title{color:var(--dark-color);justify-content:center;align-items:center;gap:10px;margin-bottom:10px;font-size:2.5rem;display:flex}.home-title-icon{color:var(--primary-color)}.home-subtitle{color:var(--gray-color);font-size:1.2rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:40px;display:grid}.stat-card{background:#fff;border-radius:15px;align-items:center;gap:20px;padding:25px;transition:transform .3s,box-shadow .3s;display:flex;box-shadow:0 4px 6px #0000001a}.stat-card:hover{transform:translateY(-5px);box-shadow:0 8px 15px #00000026}.stat-icon-wrapper{border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;display:flex}.stat-icon-wrapper.total-students{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.stat-icon-wrapper.total-courses{background:linear-gradient(135deg,#f093fb 0%,#f5576c 100%)}.stat-icon-wrapper.total-cities{background:linear-gradient(135deg,#4facfe 0%,#00f2fe 100%)}.stat-icon{color:#fff;font-size:30px}.stat-details{flex:1}.stat-value{color:var(--dark-color);margin-bottom:5px;font-size:2rem;font-weight:700}.stat-label{color:var(--gray-color);font-size:1rem}.action-cards{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;display:grid}.action-card{text-align:center;background:#fff;border-radius:15px;padding:30px;transition:all .3s;box-shadow:0 4px 6px #0000001a}.action-card:hover{transform:translateY(-5px);box-shadow:0 8px 20px #00000026}.action-card-title{color:var(--dark-color);margin-bottom:15px;font-size:1.5rem}.action-card-description{color:var(--gray-color);margin-bottom:25px;line-height:1.6}.action-button{background:var(--primary-color);color:#fff;border-radius:50px;align-items:center;gap:10px;padding:12px 30px;font-weight:500;text-decoration:none;transition:all .3s;display:inline-flex}.action-button:hover{background:var(--secondary-color);transform:scale(1.05);box-shadow:0 5px 15px #4361ee4d}@media (width<=768px){.home-title{font-size:2rem}.home-subtitle{font-size:1rem}.stat-card{padding:20px}.stat-value{font-size:1.5rem}.action-card{padding:20px}}.action-cards{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-top:30px;display:grid}.button-icon{margin-right:8px}*{box-sizing:border-box;margin:0;padding:0}.navbar{z-index:1000;background:linear-gradient(135deg,#0f172a,#1e3a8a,#2563eb);width:100%;position:sticky;top:0;box-shadow:0 6px 20px #0f172a26}.navbar-container{justify-content:space-between;align-items:center;max-width:1250px;height:72px;margin:auto;padding:0 24px;display:flex}.navbar-logo{color:#fff;letter-spacing:.5px;align-items:center;gap:10px;font-size:1.6rem;font-weight:700;text-decoration:none;display:flex}.logo-icon{color:#bfdbfe;font-size:1.8rem}.logo-highlight{color:#93c5fd}.nav-menu{align-items:center;gap:12px;list-style:none;display:flex}.nav-item{align-items:center;display:flex}.nav-link{color:#e2e8f0;cursor:pointer;background:0 0;border:none;border-radius:12px;align-items:center;gap:8px;padding:10px 16px;font-size:.98rem;font-weight:500;text-decoration:none;transition:all .3s;display:flex}.nav-link:hover{color:#fff;background:#ffffff1f}.nav-icon{font-size:.95rem}.logout-btn{color:#fff;background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:12px;padding:10px 18px;font-weight:600}.logout-btn:hover{color:#fff;background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-1px)}.menu-icon{color:#fff;cursor:pointer;font-size:1.8rem;display:none}@media (width<=992px){.navbar-container{height:70px;padding:0 18px}.menu-icon{display:block}.nav-menu{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f172afa;flex-direction:column;align-items:stretch;gap:0;width:100%;padding:18px;transition:all .4s;position:absolute;top:70px;left:-100%;box-shadow:0 10px 25px #0003}.nav-menu.active{left:0}.nav-item{width:100%;margin-bottom:10px}.nav-link{border-radius:12px;justify-content:flex-start;width:100%;padding:14px 16px;font-size:1rem}.logout-btn{justify-content:center;width:100%}}@media (width<=576px){.navbar-logo{font-size:1.35rem}.logo-icon{font-size:1.5rem}.menu-icon{font-size:1.6rem}.nav-menu{padding:15px;top:68px}.nav-link{padding:12px 14px;font-size:.95rem}}.not-found{text-align:center;justify-content:center;align-items:center;min-height:60vh;animation:.5s fadeIn;display:flex}.not-found-content{background:#fff;border-radius:20px;max-width:500px;padding:40px;box-shadow:0 10px 30px #0000001a}.not-found-icon{color:var(--warning-color);margin-bottom:20px;font-size:5rem;animation:2s infinite bounce}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-30px)}60%{transform:translateY(-15px)}}.not-found-title{color:var(--dark-color);text-shadow:2px 2px 0 var(--primary-color);margin-bottom:10px;font-size:6rem;font-weight:700;line-height:1}.not-found-subtitle{color:var(--gray-color);margin-bottom:20px;font-size:2rem}.not-found-message{color:var(--gray-color);margin-bottom:30px;line-height:1.6}.not-found-button{background:linear-gradient(135deg, var(--primary-color) 0%, var(--secondary-color) 100%);color:#fff;border-radius:50px;align-items:center;gap:10px;padding:12px 30px;font-weight:500;text-decoration:none;transition:all .3s;display:inline-flex}.not-found-button:hover{transform:translateY(-2px);box-shadow:0 5px 20px #4361ee4d}.button-icon{font-size:1.2rem}@media (width<=768px){.not-found-content{margin:20px;padding:30px}.not-found-title{font-size:4rem}.not-found-subtitle{font-size:1.5rem}}.student-list{animation:.5s fadeIn}.list-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;margin-bottom:30px;display:flex}.list-title{color:var(--dark-color);font-size:2rem}.btn-add{background:var(--success-color);color:#fff;border-radius:50px;align-items:center;gap:8px;padding:12px 24px;font-weight:500;text-decoration:none;transition:all .3s;display:flex}.btn-add:hover{background:#3aa8d8;transform:translateY(-2px);box-shadow:0 5px 15px #4cc9f04d}.loading-container{text-align:center;padding:60px}.spinner{color:var(--primary-color);margin-bottom:20px;font-size:3rem;animation:1s linear infinite spin}.table-container{background:#fff;border-radius:15px;overflow-x:auto;box-shadow:0 4px 6px #0000001a}.students-table{border-collapse:collapse;width:100%;min-width:800px}.students-table thead{background:linear-gradient(135deg, var(--primary-color) 0%, var(--secondary-color) 100%);color:#fff}.students-table th{text-align:left;padding:15px;font-weight:600}.students-table td{border-bottom:1px solid #e0e0e0;padding:15px}.students-table tbody tr:hover{background:#f8f9fa}.action-buttons{gap:10px;display:flex}.btn-edit,.btn-delete{cursor:pointer;border:none;border-radius:5px;justify-content:center;align-items:center;padding:8px 12px;transition:all .3s;display:inline-flex}.btn-edit{background:var(--warning-color);color:#fff;text-decoration:none}.btn-edit:hover{background:#e07c0c;transform:translateY(-2px)}.btn-delete{background:var(--danger-color);color:#fff}.btn-delete:hover{background:#d1146b;transform:translateY(-2px)}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:15px;width:90%;max-width:400px;padding:30px;animation:.3s slideIn}@keyframes slideIn{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}.modal-title{color:var(--dark-color);margin-bottom:15px;font-size:1.5rem}.modal-message{color:var(--gray-color);margin-bottom:25px;line-height:1.6}.modal-actions{justify-content:flex-end;gap:10px;display:flex}.btn-cancel,.btn-confirm-delete{cursor:pointer;border:none;border-radius:5px;padding:10px 20px;font-weight:500;transition:all .3s}.btn-cancel{color:var(--gray-color);background:#e0e0e0}.btn-cancel:hover{background:#d0d0d0}.btn-confirm-delete{background:var(--danger-color);color:#fff}.btn-confirm-delete:hover{background:#d1146b;transform:translateY(-2px);box-shadow:0 5px 15px #f725854d}.no-results{text-align:center;background:#fff;border-radius:15px;padding:60px;box-shadow:0 4px 6px #0000001a}.no-results p{color:var(--gray-color);font-size:1.2rem}@media (width<=768px){.list-header{text-align:center;flex-direction:column}.list-title{font-size:1.5rem}.btn-add{justify-content:center;width:100%}.table-container{-webkit-overflow-scrolling:touch;border-radius:15px;overflow-x:auto}.students-table{min-width:650px}.students-table th,.students-table td{white-space:nowrap;padding:10px 12px;font-size:.85rem}.btn-edit,.btn-delete{padding:6px 10px;font-size:.8rem}.modal{padding:20px}.modal-actions{flex-direction:column}.btn-cancel,.btn-confirm-delete{text-align:center;width:100%}}.search-bar{width:100%;max-width:600px;margin:20px auto}.search-input-wrapper{gap:10px;display:flex;position:relative}.search-input{border:2px solid #e0e0e0;border-radius:50px;flex:1;padding:15px 50px 15px 20px;font-size:16px;transition:all .3s}.search-input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #4361ee1a}.search-button{background:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:45px;height:45px;transition:all .3s;display:flex;position:absolute;top:5px;right:5px}.search-button:hover{background:var(--secondary-color);transform:scale(1.05)}@media (width<=768px){.search-bar{padding:0 10px}.search-input{padding:12px 45px 12px 15px}.search-button{width:40px;height:40px}}
