.login-container{box-sizing:border-box;align-items:center;justify-content:center;padding:0}.login-container,.login-wrapper{height:100%;background-color:white;display:flex}.login-wrapper{width:100%;flex-direction:row}.image-container{flex:1.2;position:relative;height:92vh;width:100%;background-size:contain;background-position:50%;margin-left:30px;margin-top:auto;margin-bottom:auto}.form-container{box-sizing:border-box;flex:1;display:flex;align-items:center;justify-content:center;background-color:white;padding:clamp(1.5rem,3vw,3rem) clamp(1rem,2vw,2rem)}.form-wrapper{width:100%;max-width:clamp(320px,50vw,520px)}@media (max-width:768px){.form-wrapper{height:100%}}.form-header{text-align:left;margin-bottom:.5rem}.form-title{font-size:2rem;line-height:1.2;font-weight:700;color:var(--color-gray-700);margin-bottom:.75rem}.form-subtitle{font-size:.875rem;line-height:1.5;color:#6b7280;margin:0}.form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:block}.form-label{font-size:.875rem;line-height:1.25rem;font-weight:600;color:var(--color-gray-700);margin-bottom:.5rem}.form-label,.input-wrapper{display:flex;align-items:center}.input-wrapper{position:relative}.password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:.25rem;color:#6b7280;transition:color .2s;display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:#374151}.password-toggle:focus{outline:none;color:#000000}.form-input{width:100%;padding:.875rem 1rem;background-color:white;border:1px solid var(--color-black);border-radius:.5rem;font-size:1rem;color:#1e293b;transition:all .2s;outline:none}.form-input:focus{border-color:var(--color-black);box-shadow:0 0 0 1px var(--color-black)}.form-input.error{border-color:#ef4444;box-shadow:0 0 0 2px rgba(239,68,68,.1)}.form-input.error:focus{border-color:#ef4444;box-shadow:0 0 0 2px rgba(239,68,68,.2)}.form-input::placeholder{color:#94a3b8}.input-wrapper:has(.password-toggle) .form-input{padding-right:3rem}.error-message{display:block;color:#ef4444;font-size:.75rem;margin-top:.25rem;font-weight:500}.general-error{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:.75rem;border-radius:.5rem;font-size:.875rem;margin-bottom:1rem;text-align:center;font-weight:500}.btn-primary{width:100%;padding:.875rem 1rem;border-radius:.5rem;font-weight:600;border:none;cursor:pointer;transition:all .2s;background-color:var(--color-primary);color:var(--color-black);display:flex;align-items:center;justify-content:center;gap:.5rem;position:relative}.btn-primary:hover:not(:disabled){background-color:var(--color-primary);transform:translateY(-1px)}.btn-primary:focus{outline:none;box-shadow:0 0 0 3px var(--color-focus-ring);transform:translateY(-1px);background-color:var(--color-primary-dark)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-primary.loading{background-color:var(--color-primary);cursor:wait}.btn-primary.loading:hover{transform:none}.btn-spinner{width:16px;height:16px;border:2px solid transparent;border-top-color:#000000;border-radius:50%;animation:buttonSpin 1s linear infinite}@keyframes buttonSpin{to{transform:rotate(1turn)}}.logo-container{width:100%;display:flex;justify-content:center;margin-bottom:2rem}.logo-container img{width:100%;height:auto;max-width:clamp(160px,50vw,400px)}@media (max-width:768px){.login-wrapper{flex-direction:column;width:100vw;height:100%}.logo-container{margin-bottom:4px}.image-container{height:45%;flex:none;margin-left:0;width:100vw;background-size:cover;background-position:50%}.form-container{flex:1;padding:18px}.form-wrapper{max-width:100%}.form-title{font-size:1.5rem}}@media (max-width:480px){.image-container{height:40%;width:100vw;background-size:cover}}