*{box-sizing:border-box}body{margin:0;min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:#f0ede6;font-family:DM Sans,sans-serif;padding:24px}.login-card{display:flex;width:100%;max-width:860px;min-height:540px;border-radius:20px;overflow:hidden;box-shadow:0 20px 60px #0000001a,0 4px 16px #0000000f}.login-left{width:40%;background:#1c3a2f;display:flex;flex-direction:column;justify-content:space-between;padding:40px 36px;position:relative;overflow:hidden}.login-left:before{content:"";position:absolute;width:300px;height:300px;border-radius:50%;border:1px solid rgba(255,255,255,.06);top:-100px;right:-100px;pointer-events:none}.login-left:after{content:"";position:absolute;width:200px;height:200px;border-radius:50%;border:1px solid rgba(255,255,255,.04);bottom:30px;left:-70px;pointer-events:none}.brand-mark{display:flex;align-items:center;gap:10px;z-index:1}.brand-logo-box{width:38px;height:38px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:10px;display:flex;align-items:center;justify-content:center}.brand-logo-box img{width:70px;height:70px;-o-object-fit:contain;object-fit:contain}.brand-name{font-size:15px;font-weight:600;color:#fffffff2;letter-spacing:-.3px}.left-body{z-index:1}.left-tagline{font-family:Playfair Display,serif;font-style:italic;font-size:27px;color:#ffffffe0;line-height:1.38;margin:0 0 14px;font-weight:400}.left-tagline strong{font-style:normal;font-weight:500;color:#7ec8a0}.left-desc{font-size:13px;color:#ffffff6b;line-height:1.65;margin:0}.left-footer{font-size:11px;color:#ffffff38;z-index:1}.login-right{flex:1;background:#fff;display:flex;flex-direction:column;justify-content:center;padding:52px 48px}.login-heading{font-size:24px;font-weight:600;color:#111;margin:0 0 4px;letter-spacing:-.5px}.login-sub{font-size:14px;color:#6b7280;margin:0 0 32px}.error-alert{background:#fef2f2;border:1px solid #FECACA;color:#b91c1c;font-size:13px;padding:10px 14px;border-radius:10px;margin-bottom:20px}.field-group{margin-bottom:18px}.field-label{display:block;font-size:11px;font-weight:500;color:#6b7280;letter-spacing:.6px;text-transform:uppercase;margin-bottom:7px}.input-wrap{position:relative}.field-input{width:100%;padding:11px 14px;font-size:14px;font-family:DM Sans,sans-serif;color:#111;background:#f9fafb;border:1px solid #E5E7EB;border-radius:10px;outline:none;transition:border-color .15s,box-shadow .15s}.field-input:focus{border-color:#3a6b52;box-shadow:0 0 0 3px #3a6b521a;background:#fff}.toggle-pw{position:absolute;right:13px;top:50%;transform:translateY(-50%);font-size:11px;color:#9ca3af;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.meta-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.remember-label{display:flex;align-items:center;gap:7px;font-size:13px;color:#6b7280;cursor:pointer}.remember-label input[type=checkbox]{accent-color:#3A6B52;width:14px;height:14px}.forgot-link{font-size:13px;color:#3a6b52;font-weight:500;text-decoration:none}.forgot-link:hover{text-decoration:underline}.btn-login{width:100%;padding:13px;background:#1c3a2f;color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;font-family:DM Sans,sans-serif;cursor:pointer;letter-spacing:.2px;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .15s,transform .1s}.btn-login:hover{background:#243f35}.btn-login:active{transform:scale(.99)}.right-footer{margin-top:28px;font-size:12px;color:#9ca3af;text-align:center}@media(max-width:640px){.login-left{display:none}.login-right{padding:40px 28px}.login-card{max-width:420px}}
