*{box-sizing:border-box;margin:0;padding:0}body,html{width:100%;height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.login-page{background:linear-gradient(135deg,#054653 0%,#0b7186 70% 100%);width:100%;min-height:100vh;display:flex;position:relative;overflow:hidden auto}.login-page:before{content:"";opacity:.1;z-index: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");position:absolute;inset:0}.login-wrapper{z-index:1;justify-content:center;align-items:center;width:100%;max-width:1200px;margin:0 auto;padding:2rem;display:flex;position:relative}.login-columns{background:#fff;border-radius:16px;width:100%;display:flex;overflow:hidden;box-shadow:0 20px 40px #0003}.login-branding{color:#fff;background:linear-gradient(135deg,#054653 0%,#0b7186 70% 100%);flex-direction:column;flex:1;justify-content:center;padding:3rem;display:flex;position:relative}.login-branding:before{content:"";opacity:.1;z-index: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");position:absolute;inset:0}.branding-content{z-index:1;max-width:500px;position:relative}.branding-title{margin-bottom:1rem;font-size:2.5rem;font-weight:700;line-height:1.2}.branding-subtitle{opacity:.9;margin-bottom:2.5rem;font-size:1.25rem}.features-list{flex-direction:column;gap:1.5rem;display:flex}.feature-item{background:#ffffff1a;border-radius:12px;align-items:flex-start;gap:1rem;padding:1.25rem;transition:transform .3s,background .3s;display:flex}.feature-item:hover{background:#ffffff26;transform:translateY(-5px)}.feature-icon{background:#fff3;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;padding:10px;display:flex}.feature-icon svg{color:#fff;width:24px;height:24px}.feature-text h3{margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.feature-text p{opacity:.8;margin:0;font-size:.9rem}.login-form-section{flex-direction:column;justify-content:center;width:450px;padding:3rem;display:flex}.form-header{text-align:center;margin-bottom:2rem}.form-logo{justify-content:center;margin-bottom:2rem;display:flex}.form-logo img{width:auto;height:80px}.form-title{color:#1a1a1a;margin-bottom:.5rem;font-size:1.75rem;font-weight:700}.form-subtitle{color:#666;font-size:.95rem}.form-alert{border-left-style:solid;border-left-width:4px;border-radius:8px;margin-bottom:1.5rem;padding:1rem;font-size:.9rem}.alert-success{color:#38a169;background-color:#f0fff4;border-left-color:#38a169}.alert-error{color:#e53e3e;background-color:#fff5f5;border-left-color:#e53e3e}.alert-warning{color:#d97706;background-color:#fffbeb;border-left-color:#d97706}.login-form{flex-direction:column;gap:1.25rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.label-row{justify-content:space-between;align-items:center;display:flex}.form-label{color:#4a5568;font-size:.9rem;font-weight:500}.input-container{align-items:center;display:flex;position:relative}.input-icon{color:#718096;width:20px;height:20px;position:absolute;left:1rem}.form-input{border:1px solid #e2e8f0;border-radius:8px;width:100%;padding:.75rem 1rem .75rem 3rem;font-size:1rem;transition:all .3s}.form-input:focus{border-color:#0b7186;outline:none;box-shadow:0 0 0 3px #0b718626}.form-input::placeholder{color:#a0aec0}.toggle-password{color:#718096;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex;position:absolute;right:1rem}.toggle-password svg{width:20px;height:20px}.forgot-password{color:#0b7186;font-size:.85rem;text-decoration:none;transition:color .3s}.forgot-password:hover{color:#054653;text-decoration:underline}.remember-me{align-items:center;display:flex}.checkbox-container{cursor:pointer;color:#4a5568;-webkit-user-select:none;user-select:none;align-items:center;padding-left:30px;font-size:.9rem;display:flex;position:relative}.checkbox-container input{opacity:0;cursor:pointer;width:0;height:0;position:absolute}.checkmark{background-color:#fff;border:1px solid #e2e8f0;border-radius:4px;width:20px;height:20px;position:absolute;top:0;left:0}.checkbox-container:hover input~.checkmark{border-color:#cbd5e0}.checkbox-container input:checked~.checkmark{background-color:#0b7186;border-color:#0b7186}.checkmark:after{content:"";display:none;position:absolute}.checkbox-container input:checked~.checkmark:after{display:block}.checkbox-container .checkmark:after{border:2px solid #fff;border-width:0 2px 2px 0;width:5px;height:10px;top:3px;left:7px;transform:rotate(45deg)}.submit-button{color:#fff;cursor:pointer;background:linear-gradient(90deg,#0b7186,#054653);border:none;border-radius:8px;justify-content:center;align-items:center;margin-top:.5rem;padding:.9rem;font-size:1rem;font-weight:600;transition:all .3s;display:flex}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0b71864d}.submit-button:active:not(:disabled){transform:translateY(0)}.submit-button:disabled{opacity:.7;cursor:not-allowed}.button-spinner{justify-content:center;align-items:center;gap:.5rem;display:flex}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.register-link{text-align:center;color:#4a5568;margin-top:1.5rem;font-size:.9rem}.register-link a{color:#0b7186;font-weight:500;text-decoration:none;transition:color .3s}.register-link a:hover{color:#054653;text-decoration:underline}@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:0 0}.login-branding{display:none}.login-form-section{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 10px 30px #0003}}@media (max-width:480px){.login-form-section{padding:1.5rem}.form-logo img{height:60px}.form-title{font-size:1.5rem}}
