*{margin:0;padding:0;box-sizing:border-box}:root{--primary:hsl(217, 89%, 35%);--primary-dark:hsl(217, 89%, 25%);--primary-light:hsl(210, 100%, 97%);--gold:hsl(45, 95%, 55%);--gold-dark:hsl(40, 90%, 45%);--foreground:hsl(220, 25%, 15%);--muted:hsl(220, 15%, 45%);--background:hsl(210, 20%, 98%);--card:hsl(0, 0%, 100%);--border:hsl(210, 25%, 90%);--success:hsl(142, 70%, 45%);--gradient-hero:linear-gradient(135deg, hsl(217, 89%, 35%) 0%, hsl(217, 80%, 45%) 50%, hsl(210, 70%, 50%) 100%);--gradient-gold:linear-gradient(135deg, hsl(45, 95%, 55%) 0%, hsl(40, 90%, 45%) 100%);--shadow-card:0 4px 20px -2px hsla(217, 89%, 35%, 0.08);--shadow-card-hover:0 12px 30px -4px hsla(217, 89%, 35%, 0.15)}html{scroll-behavior:smooth}body{font-family:'Inter',system-ui,-apple-system,sans-serif;background-color:var(--background);color:var(--foreground);line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:'Playfair Display',Georgia,serif;font-weight:600}img{max-width:100%;height:auto}a{color:inherit;text-decoration:none}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.75rem;border-radius:.75rem;font-weight:600;font-size:.9rem;cursor:pointer;transition:all 0.3s ease;border:none;text-decoration:none}.btn-primary{background:var(--gradient-hero);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px hsl(217 89% 35% / .3)}.btn-gold{background:var(--gradient-gold);color:var(--foreground)}.btn-gold:hover{transform:translateY(-2px);box-shadow:0 8px 25px hsl(45 95% 55% / .4)}.btn-outline{background:#fff0;border:2px solid var(--primary);color:var(--primary)}.btn-outline:hover{background:var(--primary);color:#fff}.btn-white{background:#fff;color:var(--primary)}.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgb(255 255 255 / .3)}.form-group{margin-bottom:1.5rem}.form-label{display:block;font-weight:500;color:var(--foreground);margin-bottom:.5rem;font-size:.9rem}.form-input,.form-textarea,.form-select{width:100%;padding:.875rem 1rem;border:1px solid var(--border);border-radius:.75rem;font-size:1rem;font-family:inherit;background:var(--card);color:var(--foreground);transition:all 0.3s ease}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px hsl(217 89% 35% / .1)}.form-input::placeholder,.form-textarea::placeholder{color:var(--muted)}.form-textarea{resize:vertical;min-height:120px}.fade-up{opacity:0;transform:translateY(30px);transition:all 0.6s ease-out}.fade-up.visible{opacity:1;transform:translateY(0)}.slide-left{opacity:0;transform:translateX(-30px);transition:all 0.6s ease-out}.slide-left.visible{opacity:1;transform:translateX(0)}.slide-right{opacity:0;transform:translateX(30px);transition:all 0.6s ease-out}.slide-right.visible{opacity:1;transform:translateX(0)}.zoom-in{opacity:0;transform:scale(.9);transition:all 0.6s ease-out}.zoom-in.visible{opacity:1;transform:scale(1)}.delay-1{transition-delay:0.1s}.delay-2{transition-delay:0.2s}.delay-3{transition-delay:0.3s}.delay-4{transition-delay:0.4s}.delay-5{transition-delay:0.5s}.delay-6{transition-delay:0.6s}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:var(--primary)}.text-gold{color:var(--gold)}.text-muted{color:var(--muted)}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mb-5{margin-bottom:3rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mt-5{margin-top:3rem}.d-flex{display:flex}.align-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.w-100{width:100%}.auth-section{min-height:calc(100vh - 80px);display:flex;align-items:center;justify-content:center;padding:4rem 1rem;background:linear-gradient(135deg,var(--primary-light) 0%,var(--background) 50%,hsl(45 95% 55% / .08) 100%)}.auth-section-admin{background:linear-gradient(135deg,hsl(220 25% 12%) 0%,hsl(220 25% 18%) 50%,hsl(217 89% 25%) 100%)}.auth-container{display:grid;grid-template-columns:1fr 1fr;gap:3rem;max-width:1000px;width:100%;align-items:center}.auth-container-centered{grid-template-columns:1fr;max-width:480px}.auth-card{background:var(--card);border-radius:1.5rem;padding:2.5rem;box-shadow:var(--shadow-card-hover);border:1px solid var(--border)}.auth-card-admin{border-top:4px solid var(--primary);position:relative}.admin-badge{position:absolute;top:-1px;left:50%;transform:translateX(-50%) translateY(-50%);background:var(--gradient-hero);color:#fff;padding:.5rem 1.25rem;border-radius:50px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.auth-header{text-align:center;margin-bottom:2rem}.auth-icon{width:80px;height:80px;background:var(--primary-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;color:var(--primary);font-size:2rem}.auth-icon-admin{background:var(--gradient-hero);color:#fff}.auth-icon-warning{background:hsl(45 95% 55% / .15);color:var(--gold-dark)}.auth-icon-success{background:hsl(142 70% 45% / .15);color:var(--success)}.auth-header h1{font-size:1.75rem;color:var(--foreground);margin-bottom:.5rem}.auth-header p{color:var(--muted);font-size:.95rem}.auth-form{margin-bottom:2rem;width:100%}.input-wrapper{position:relative}.input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--muted);font-size:1rem}.form-input-icon{padding-left:2.75rem;padding-right:3rem}.password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--muted);cursor:pointer;padding:.5rem;transition:color 0.3s ease}.password-toggle:hover{color:var(--primary)}.form-options{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:.5rem}.checkbox-wrapper{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;color:var(--foreground)}.checkbox-wrapper input{display:none}.checkmark{width:18px;height:18px;border:2px solid var(--border);border-radius:4px;position:relative;transition:all 0.3s ease}.checkbox-wrapper input:checked+.checkmark{background:var(--primary);border-color:var(--primary)}.checkbox-wrapper input:checked+.checkmark::after{content:'';position:absolute;left:5px;top:2px;width:5px;height:9px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.forgot-link{color:var(--primary);font-size:.9rem;font-weight:500;transition:color 0.3s ease}.forgot-link:hover{color:var(--primary-dark);text-decoration:underline}.btn-admin{background:var(--gradient-hero);color:#fff}.btn-admin:hover{transform:translateY(-2px);box-shadow:0 8px 25px hsl(217 89% 35% / .4)}.auth-footer{text-align:center;padding-top:1.5rem;border-top:1px solid var(--border)}.auth-footer p{color:var(--muted);font-size:.9rem}.auth-footer a{color:var(--primary);font-weight:500}.auth-footer a:hover{text-decoration:underline}.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.25rem 0}.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}.auth-divider span{color:var(--muted);font-size:.8rem;text-transform:uppercase}.admin-link,.student-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.9rem;padding:.75rem 1.5rem;border:1px solid var(--border);border-radius:.75rem;transition:all 0.3s ease}.admin-link:hover,.student-link:hover{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}.security-notice{margin-top:1.5rem;padding:1rem;background:hsl(45 95% 55% / .1);border-radius:.75rem;display:flex;align-items:center;gap:.75rem;font-size:.8rem;color:var(--gold-dark)}.auth-info{display:flex;flex-direction:column;gap:1.5rem}.info-card{background:var(--gradient-hero);color:#fff;padding:2rem;border-radius:1.25rem}.info-card h3{font-size:1.25rem;margin-bottom:1.25rem;display:flex;align-items:center;gap:.5rem}.benefits-list{list-style:none;display:flex;flex-direction:column;gap:.875rem}.benefits-list li{display:flex;align-items:center;gap:.75rem;font-size:.95rem}.benefits-list li i{color:var(--gold)}.help-text{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;background:var(--card);border-radius:.75rem;border:1px solid var(--border);font-size:.9rem;color:var(--muted)}.help-text i{color:var(--primary);font-size:1.25rem}.help-text a{color:var(--primary);font-weight:600}.process-steps{background:var(--primary-light);border-radius:1rem;padding:1.5rem;margin-bottom:2rem}.process-steps h4{font-family:'Inter',sans-serif;font-size:.9rem;font-weight:600;color:var(--primary);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.step{display:flex;align-items:center;gap:1rem;padding:.75rem 0;border-bottom:1px dashed hsl(217 89% 35% / .2)}.step:last-child{border-bottom:none;padding-bottom:0}.step-number{width:28px;height:28px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;flex-shrink:0}.step-text{font-size:.9rem;color:var(--foreground)}.help-links{display:flex;justify-content:center;gap:1.5rem;flex-wrap:wrap}.help-links a{display:flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.9rem;transition:color 0.3s ease}.help-links a:hover{color:var(--primary)}.password-strength{margin-top:.75rem}.strength-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-bottom:.5rem}.strength-fill{height:100%;width:0%;border-radius:3px;transition:all 0.3s ease}.strength-fill.weak{width:25%;background:hsl(0 70% 50%)}.strength-fill.fair{width:50%;background:hsl(30 90% 50%)}.strength-fill.good{width:75%;background:hsl(60 70% 45%)}.strength-fill.strong{width:100%;background:var(--success)}.strength-text{font-size:.8rem;color:var(--muted)}.strength-text.weak{color:hsl(0 70% 50%)}.strength-text.fair{color:hsl(30 90% 50%)}.strength-text.good{color:hsl(60 70% 45%)}.strength-text.strong{color:var(--success)}.password-match{margin-top:.5rem;font-size:.8rem}.password-match.match{color:var(--success)}.password-match.no-match{color:hsl(0 70% 50%)}.password-requirements{background:var(--primary-light);border-radius:.75rem;padding:1.25rem;margin-bottom:1.5rem}.password-requirements h4{font-family:'Inter',sans-serif;font-size:.85rem;font-weight:600;color:var(--primary);margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.requirements-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.requirements-list li{font-size:.8rem;color:var(--muted);display:flex;align-items:center;gap:.5rem}.requirements-list li i{font-size:.5rem}.requirements-list li.valid{color:var(--success)}.requirements-list li.valid i{font-size:.8rem}.requirements-list li.valid i::before{content:'\f058'}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width:576px){.form-row{grid-template-columns:1fr;gap:0}}.requirements-title{font-family:'Inter',sans-serif;font-size:.85rem;font-weight:600;color:var(--primary);margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.form-select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 8.825L.35 3.175 1.175 2.35 6 7.175l4.825-4.825.825.825z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:12px;padding-right:2.5rem;cursor:pointer}.form-select option{font-family:'Inter',sans-serif;padding:.5rem}.form-select option:disabled{color:var(--muted)}#registerForm .form-group{margin-bottom:1.25rem}#registerForm .form-options{justify-content:flex-start}#registerForm .checkbox-wrapper span:last-child{font-size:.85rem;color:var(--muted)}#registerForm .checkbox-wrapper span:last-child a{color:var(--primary);font-weight:500}#registerForm .checkbox-wrapper span:last-child a:hover{text-decoration:underline}@media (min-width:992px){.auth-section{padding:2rem 1rem}.auth-card{padding:2rem}}.forgot-section{min-height:100vh;padding:6rem 1rem 4rem;background:linear-gradient(135deg,var(--primary-light) 0%,var(--background) 50%,hsl(45 95% 55% / .08) 100%)}.forgot-container{max-width:480px;margin:0 auto}.forgot-card{background:var(--card);border-radius:1.5rem;padding:2.5rem;box-shadow:0 20px 50px rgb(0 0 0 / .08);border:1px solid var(--border)}.forgot-header{text-align:center;margin-bottom:2rem}.forgot-icon{width:80px;height:80px;background:hsl(45 95% 55% / .15);color:var(--gold-dark);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;font-size:2rem}.forgot-header h1{font-size:1.75rem;margin-bottom:.5rem}.forgot-header p{color:var(--muted);font-size:.95rem}.forgot-form{margin-bottom:2rem}.forgot-footer{text-align:center;padding-top:1.5rem;border-top:1px solid var(--border)}.forgot-footer a{color:var(--primary);font-weight:500}.forgot-footer a:hover{text-decoration:underline}.forgot-message{padding:.9rem 1rem;border-radius:.75rem;margin-bottom:1.25rem;font-size:.9rem;display:flex;align-items:center;gap:.5rem}.forgot-error{background:hsl(0 70% 50% / .1);color:hsl(0 70% 45%)}.forgot-success{background:hsl(142 70% 45% / .1);color:var(--success)}@media (max-width:992px){.auth-container{grid-template-columns:1fr;gap:2rem}.auth-info{order:2}.auth-card{order:1}}@media (max-width:576px){.auth-section{padding:2rem 1rem}.auth-card{padding:1.75rem;border-radius:1.25rem}.auth-header h1{font-size:1.4rem}.auth-icon{width:65px;height:65px;font-size:1.6rem}.form-options{flex-direction:column;align-items:flex-start;gap:.75rem}.btn{padding:.8rem 1.25rem;font-size:.85rem}.info-card{padding:1.5rem}.benefits-list li{font-size:.85rem}.help-text{font-size:.8rem;padding:.75rem}}@media (max-width:576px){.auth-card,.info-card{box-shadow:0 8px 25px rgb(0 0 0 / .06)}}.field-error{color:#e53935;font-size:13px;margin-top:6px;display:block}