.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#f4f5f7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.login-bg{position:fixed;inset:0;z-index:0}.login-bg-gradient{position:absolute;inset:0;background:#f4f5f7}.login-bg-pattern{position:absolute;inset:0;background-image:radial-gradient(ellipse at 20% 50%,rgba(59,130,246,.04) 0,transparent 50%),radial-gradient(ellipse at 80% 50%,rgba(29,78,216,.03) 0,transparent 50%)}.login-container{position:relative;z-index:1;width:100%;max-width:400px;padding:20px}.login-card{background:#fff;border-radius:10px;padding:36px 32px 32px;border:1px solid #e5e7eb}.login-card:focus{outline:none}.login-header{text-align:center;margin-bottom:32px}.login-logo{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:6px}.login-logo-icon{width:32px;height:32px}.login-title{font-size:22px;font-weight:700;color:#111827;letter-spacing:-.01em}.login-subtitle{font-size:14px;color:#6b7280;margin-top:4px}.login-error{display:flex;align-items:center;gap:10px;padding:12px 14px;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;font-size:13px;margin-bottom:20px;animation:login-shake .35s ease-in-out}.login-error:focus{outline:2px solid var(--focus-ring-color,#1d4ed8);outline-offset:2px}@keyframes login-shake{0%,to{transform:translateX(0)}25%{transform:translateX(-3px)}75%{transform:translateX(3px)}}.login-form{gap:18px}.login-field,.login-form{display:flex;flex-direction:column}.login-field{gap:6px}.login-label{font-size:13px;font-weight:600;color:#374151}.login-required{color:#dc2626;font-weight:600}.login-input-wrapper{position:relative;display:flex;align-items:center}.login-input-icon{position:absolute;left:12px;color:#9ca3af;pointer-events:none;transition:color .15s}.login-input-wrapper:focus-within .login-input-icon{color:#3b82f6}.login-input{width:100%;padding:10px 12px 10px 40px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;color:#111827;font-size:14px;font-family:inherit;min-height:44px;transition:all .15s}.login-input-password{padding-right:44px}.login-input::-moz-placeholder{color:#9ca3af}.login-input::placeholder{color:#9ca3af}.login-input:focus-visible{border-color:#3b82f6;box-shadow:0 0 0 2px rgba(59,130,246,.15);background:#fff;outline:none}.login-input:hover:not(:focus){border-color:#d1d5db}.login-input[aria-invalid=true]{border-color:#dc2626}.login-input[aria-invalid=true]:focus-visible{box-shadow:0 0 0 2px rgba(220,38,38,.15)}.login-password-toggle{position:absolute;right:6px;display:flex;align-items:center;justify-content:center;width:32px;height:32px;min-width:24px;min-height:24px;padding:0;background:transparent;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;transition:all .15s}.login-password-toggle:hover{color:#374151;background:#f3f4f6}.login-password-toggle:focus-visible{outline:2px solid var(--focus-ring-color,#1d4ed8);outline-offset:1px}.login-button{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;margin-top:4px;background:#1d4ed8;color:#fff;font-size:14px;font-weight:600;font-family:inherit;border:none;border-radius:6px;cursor:pointer;transition:all .15s;min-height:44px}.login-button:hover:not(:disabled){background:#1a44c2;box-shadow:0 1px 3px rgba(29,78,216,.2)}.login-button:active:not(:disabled){background:#1e3fb8}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-button:focus-visible{outline:2px solid #1d4ed8;outline-offset:2px}.login-spinner{width:16px;height:16px;border:2px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;animation:login-spin .6s linear infinite}@keyframes login-spin{to{transform:rotate(1turn)}}.login-footer{margin-top:20px;text-align:center;padding-top:16px;border-top:1px solid #e5e7eb}.login-footer-text{font-size:13px;color:#6b7280}.login-link{color:#1d4ed8;text-decoration:none;font-weight:600;transition:color .15s;display:inline-block;min-height:24px;line-height:24px}.login-link:hover{color:#1a44c2;text-decoration:underline}.login-link:focus-visible{outline:2px solid var(--focus-ring-color,#1d4ed8);outline-offset:2px;border-radius:2px}.login-info{margin-top:20px;text-align:center}.login-info p{font-size:13px;color:#9ca3af}.login-info-detail{margin-top:2px;font-size:12px;color:#9ca3af}