*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:Poppins,sans-serif;line-height:1.6;background-color:#fff;color:#333;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.login-container{display:flex;min-height:100vh}.left-panel{width:60%;background-color:#1e3a8a;color:#fff;display:flex;flex-direction:column;justify-content:space-between;align-items:center;padding:4rem 2rem;text-align:center}.brand-container{display:flex;flex-direction:column;align-items:center;gap:1rem}.brand-container .logo svg{width:60px;height:60px}.brand-text h1{font-size:2rem;font-weight:600;margin-bottom:.25rem}.brand-text p{font-size:1.25rem;font-weight:400}.illustration{width:80%;max-width:350px}.illustration img{width:100%;height:auto}.right-panel{width:60%;display:flex;justify-content:center;align-items:center;padding:2rem}.login-form-container{width:100%;max-width:400px}.login-form-container h2{font-family:Poppins,sans-serif;font-weight:700;font-size:2.5rem;color:#000;margin-bottom:2.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:600;margin-bottom:.5rem;color:#555}.form-control{width:100%;padding:.75rem 1rem;border:1px solid #ccc;border-radius:8px;font-size:1rem;transition:border-color .2s}.form-control:focus{outline:none;border-color:#2c3e50;box-shadow:0 0 0 2px #2c3e501a}.password-wrapper{position:relative}.toggle-password{position:absolute;top:50%;right:1rem;transform:translateY(-50%);cursor:pointer;color:#888}.btn-login{width:100%;padding:1rem;border:none;background-color:#2c3e50;color:#fff;font-size:1rem;font-weight:600;border-radius:12px;cursor:pointer;transition:background-color .2s,transform .1s;margin-top:1rem;box-shadow:0 4px 15px #0000001a}.btn-login:hover{background-color:#34495e}.btn-login:active{transform:scale(.98)}.invalid-feedback{color:#e3342f;font-size:.875em;margin-top:.25rem;display:block}.is-invalid{border-color:#e3342f}
