.login-body { font-family: 'Inter', sans-serif; background: #f1f5f9; color: #0f172a; margin: 0; min-height: 100vh; display: flex; flex-direction: column; position: relative; overflow: hidden; }
.login-body::before { content: ""; position: fixed; inset: 0; background: center/520px no-repeat var(--login-logo); opacity: 0.16; pointer-events: none; z-index: 0; }
.login-main { flex: 1 0 auto; width: 100%; display: flex; align-items: flex-start; justify-content: center; gap: 120px; padding: 24px 16px 18px; position: relative; z-index: 1; flex-wrap: wrap; }
.login-card { background: #ffffff; border-radius: 20px; border: 1px solid rgba(15, 23, 42, 0.08); box-shadow: 0 18px 32px rgba(15, 23, 42, 0.08); padding: 24px; display: grid; gap: 16px; width: min(360px, 100%); }
.login-card--secondary { width: min(360px, 100%); align-self: flex-start; display: grid; gap: 12px; }
.login-card--secondary h2 { margin: 0; font-size: 1.6rem; }
.login-card--secondary p { margin: 0; line-height: 1.55; color: #1f2937; }
.login-card h1 { font-size: 2rem; margin: 0; }
.login-form { display: grid; gap: 18px; }
.login-field { display: grid; gap: 8px; }
.login-field label { font-size: 0.95rem; font-weight: 600; }
.login-field input { padding: 12px 16px; border-radius: 12px; border: 1px solid rgba(15, 23, 42, 0.18); background: #ffffff; color: #0f172a; transition: border-color 0.3s ease, box-shadow 0.3s ease; }
.login-field input:focus { border-color: #0ea5e9; box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.18); outline: none; }
.login-errors { border-radius: 12px; border: 1px solid rgba(220, 38, 38, 0.25); background: rgba(248, 113, 113, 0.12); color: #b91c1c; padding: 12px 16px; font-size: 0.9rem; }
.login-errors p { margin: 0; }
.field-error { color: #b91c1c; font-size: 0.85rem; }
.login-button { padding: 14px 18px; border-radius: 12px; border: none; background: linear-gradient(135deg, #0ea5e9, #38bdf8); color: #ffffff; font-weight: 700; cursor: pointer; transition: transform 0.2s ease, box-shadow 0.2s ease; }
.login-button:hover { transform: translateY(-2px); box-shadow: 0 12px 20px rgba(14, 165, 233, 0.25); }
.login-body .site-header { padding: 20px 24px; }
.login-body .header-content { max-width: 1080px; gap: 28px; }
.login-body .site-footer { margin-top: 16px; padding: 22px 18px 16px; }
.login-body .footer-content { margin-bottom: 2px; gap: 10px; }
.login-body .footer-column--brand p { margin: 0 0 4px; }
.login-body .footer-meta { padding-top: 6px; margin-top: 0; border-top: none; gap: 6px; }
@media (max-width: 768px) {
  .login-main { padding: 20px 16px 16px; gap: 24px; }
  .login-card { padding: 20px; }
  .login-body .site-header { padding: 16px 18px; }
  .login-body .header-content { max-width: 100%; flex-wrap: nowrap; gap: 16px; }
  .login-body .brand { flex: 1 1 auto; padding-left: 58px; font-size: 1.08rem; }
  .login-body .brand-logo { width: 50px; height: 50px; }
  .login-body .nav-toggle { flex: 0 0 auto; margin-left: auto; }
  .login-body .site-footer { margin-top: 16px; padding: 20px 16px 14px; }
  .login-body .footer-content { margin-bottom: 1px; gap: 8px; }
  .login-body .footer-meta { padding-top: 6px; }
}
@media (max-width: 560px) {
  .login-body .brand { padding-left: 50px; font-size: 1rem; }
  .login-body .brand-logo { width: 42px; height: 42px; }
  .login-body .nav-toggle { padding: 10px 14px; }
}
