.login-page { min-height: calc(100vh - 190px); }
.login-shell { display: grid; grid-template-columns: minmax(320px, 520px) minmax(260px, 1fr); gap: 18px; align-items: stretch; }
.login-card h1 { margin: 0; font-size: 24px; line-height: 1.15; color: #0f2942; }
.login-card-header { align-items: flex-start; gap: 12px; }
.login-health { display: inline-flex; align-items: center; min-height: 26px; padding: 4px 10px; border: 1px solid var(--line); border-radius: 999px; background: var(--panel-strong); color: var(--muted); font-size: 12px; font-weight: 700; white-space: nowrap; }
.login-health.ok { border-color: rgba(22,128,79,.35); color: var(--green); background: #eef9f3; }
.login-health.warn { border-color: rgba(244,189,47,.55); color: #8a6200; background: #fff8df; }
.login-health.error { border-color: rgba(179,38,30,.35); color: var(--red); background: #fff0ee; }
.login-form { display: grid; gap: 10px; }
.field-label { font-weight: 800; color: var(--text); }
.login-form input { width: 100%; min-height: 46px; border: 1px solid var(--line-strong); border-radius: 6px; padding: 0 12px; outline: none; background: #fff; }
.login-form input:focus { border-color: var(--blue); box-shadow: 0 0 0 3px rgba(21,101,192,.12); }
.password-row { display: grid; grid-template-columns: minmax(0, 1fr) 108px; gap: 8px; }
.login-submit { min-height: 46px; margin-top: 8px; font-weight: 800; }
.login-benefits { display: grid; gap: 10px; }
.login-benefits div { padding: 12px; border: 1px solid var(--line); border-radius: 6px; background: var(--panel-strong); }
.login-benefits strong { display: block; color: var(--text); margin-bottom: 2px; }
.login-benefits span { color: var(--muted); }
.forgot-password-area,
.register-area { margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--line); }
.forgot-password-area input,
.register-form input { width: 100%; min-height: 42px; border: 1px solid var(--line-strong); border-radius: 6px; padding: 0 12px; background: #fff; }
.forgot-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 10px; }
.register-form { gap: 12px; margin-top: 10px; }
.register-form .span-2 { grid-column: 1 / -1; }
@media (max-width: 860px) { .login-shell { grid-template-columns: 1fr; } .login-card-header { flex-direction: column; } }
@media (max-width: 620px) { .register-form .form-grid.cols-2 { grid-template-columns: 1fr; } .register-form .span-2 { grid-column: auto; } }
