*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;width:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.login-page{width:100%;min-height:100vh;display:flex;overflow-x:hidden;overflow-y:auto;background:linear-gradient(135deg,#054653,#0b7186 70%,#0b7186);position:relative}.login-page:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.4'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");opacity:.1;z-index:0}.login-wrapper{width:100%;max-width:1200px;margin:0 auto;padding:2rem;display:flex;align-items:center;justify-content:center;z-index:1;position:relative}.login-columns{display:flex;width:100%;background:white;border-radius:16px;overflow:hidden;box-shadow:0 20px 40px rgba(0,0,0,.2)}.login-branding{flex:1;background:linear-gradient(135deg,#054653,#0b7186 70%,#0b7186);color:white;padding:3rem;position:relative;display:flex;flex-direction:column;justify-content:center}.login-branding:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.4'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");opacity:.1;z-index:0}.branding-content{position:relative;z-index:1;max-width:500px}.branding-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem;line-height:1.2}.branding-subtitle{font-size:1.25rem;margin-bottom:2.5rem;opacity:.9}.features-list{display:flex;flex-direction:column;gap:1.5rem}.feature-item{display:flex;align-items:flex-start;gap:1rem;background:rgba(255,255,255,.1);border-radius:12px;padding:1.25rem;transition:transform .3s ease,background .3s ease}.feature-item:hover{transform:translateY(-5px);background:rgba(255,255,255,.15)}.feature-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:rgba(255,255,255,.2);border-radius:12px;padding:10px}.feature-icon svg{width:24px;height:24px;color:white}.feature-text h3{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.feature-text p{font-size:.9rem;opacity:.8;margin:0}.login-form-section{width:450px;padding:3rem;display:flex;flex-direction:column;justify-content:center}.form-header{text-align:center;margin-bottom:2rem}.form-logo{display:flex;justify-content:center;margin-bottom:2rem}.form-logo img{height:80px;width:auto}.form-title{font-size:1.75rem;font-weight:700;color:#1a1a1a;margin-bottom:.5rem}.form-subtitle{color:#666;font-size:.95rem}.form-alert{padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-size:.9rem;border-left-width:4px;border-left-style:solid}.alert-success{background-color:#f0fff4;color:#38a169;border-left-color:#38a169}.alert-error{background-color:#fff5f5;color:#e53e3e;border-left-color:#e53e3e}.alert-warning{background-color:#fffbeb;color:#d97706;border-left-color:#d97706}.login-form{gap:1.25rem}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:.5rem}.label-row{display:flex;justify-content:space-between;align-items:center}.form-label{font-size:.9rem;font-weight:500;color:#4a5568}.input-container{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1rem;width:20px;height:20px;color:#718096}.form-input{width:100%;padding:.75rem 1rem .75rem 3rem;border:1px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .3s ease}.form-input:focus{outline:none;border-color:#0b7186;box-shadow:0 0 0 3px rgba(11,113,134,.15)}.form-input::placeholder{color:#a0aec0}.toggle-password{position:absolute;right:1rem;background:none;border:none;color:#718096;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.toggle-password svg{width:20px;height:20px}.forgot-password{font-size:.85rem;color:#0b7186;text-decoration:none;transition:color .3s ease}.forgot-password:hover{color:#054653;text-decoration:underline}.checkbox-container,.remember-me{display:flex;align-items:center}.checkbox-container{position:relative;padding-left:30px;cursor:pointer;font-size:.9rem;color:#4a5568;user-select:none}.checkbox-container input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkmark{position:absolute;top:0;left:0;height:20px;width:20px;background-color:#fff;border:1px solid #e2e8f0;border-radius:4px}.checkbox-container:hover input~.checkmark{border-color:#cbd5e0}.checkbox-container input:checked~.checkmark{background-color:#0b7186;border-color:#0b7186}.checkmark:after{content:"";position:absolute;display:none}.checkbox-container input:checked~.checkmark:after{display:block}.checkbox-container .checkmark:after{left:7px;top:3px;width:5px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.submit-button{background:linear-gradient(90deg,#0b7186,#054653);color:white;border:none;border-radius:8px;padding:.9rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;justify-content:center;align-items:center;margin-top:.5rem}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px rgba(11,113,134,.3)}.submit-button:active:not(:disabled){transform:translateY(0)}.submit-button:disabled{opacity:.7;cursor:not-allowed}.button-spinner{display:flex;align-items:center;justify-content:center;gap:.5rem}.spinner{width:20px;height:20px;border-radius:50%;border:2px solid rgba(255,255,255,.3);border-top-color:white;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.register-link{text-align:center;margin-top:1.5rem;font-size:.9rem;color:#4a5568}.register-link a{color:#0b7186;text-decoration:none;font-weight:500;transition:color .3s ease}.register-link a:hover{text-decoration:underline;color:#054653}@media (max-width:1024px){.login-wrapper{padding:1rem}.login-columns{flex-direction:column;max-width:600px;margin:0 auto}.login-branding{padding:2rem}.login-form-section{width:100%;padding:2rem}}@media (max-width:768px){.login-page{padding:1rem}.login-columns{box-shadow:none;background:transparent}.login-branding{display:none}.login-form-section{background:white;border-radius:16px;box-shadow:0 10px 30px rgba(0,0,0,.2);padding:2rem}}@media (max-width:480px){.login-form-section{padding:1.5rem}.form-logo img{height:60px}.form-title{font-size:1.5rem}}