/* ── Main centered area ── */
.login-main {
  flex:            1;
  display:         flex;
  align-items:     center;
  justify-content: center;
  padding:         var(--space-6) var(--space-4);
}

.login-wrapper {
  width:           100%;
  max-width:       440px;
  display:         flex;
  flex-direction:  column;
  gap:             var(--space-5);
}

/* ── Branding header ── */
.login-header-link {
  display:        flex;
  flex-direction: column;
  align-items:    center;
  gap:            var(--space-3);
  text-decoration: none;
  transition:     opacity 0.15s ease;
}

.login-header-link:hover {
  opacity: 0.85;
}

.login-header {
  display:         flex;
  flex-direction:  column;
  align-items:     center;
  gap:             var(--space-3);
  text-align:      center;
}

.login-logo {
  max-height:  64px;
  max-width:   200px;
  object-fit:  contain;
}

.login-company {
  font-size:   var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color:       var(--color-accent);
  margin:      0;
}

/* ── Card ── */
.login-card {
  padding: var(--space-6);
}

/* ── Form layout ── */
.login-form {
  display:        flex;
  flex-direction: column;
  gap:            var(--space-4);
}

.login-form .form-pill {
  min-height:  48px;
  font-size:   var(--font-size-base);
}

.input-flex {
  display: flex;
  width:   100%;
}

/* ── Validation error — only visible when ASP.NET adds validation-summary-errors ── */
/*.login-error.validation-summary-valid {
  display: block;
}*/

.login-error.validation-summary-errors {
    background: #FFEBEE;
    border: 1px solid var(--color-error);
    border-radius: var(--radius-sm);
    padding: var(--space-3) var(--space-4);
    color: #C62828;
    font-size: var(--font-size-sm);
}

/* ── Forgot password link ── */
.login-links {
  display:         flex;
  justify-content: flex-end;
  margin-top:      calc(var(--space-1) * -1);
}

.login-links a {
  font-size:   var(--font-size-sm);
  color:       var(--color-accent);
  font-weight: var(--font-weight-medium);
}

.login-links a:hover {
  color:           var(--color-accent-dark);
  text-decoration: underline;
}

/* ── Submit button ── */
.login-submit {
  width:           100%;
  justify-content: center;
  min-height:      48px;
  font-size:       var(--font-size-base);
  font-weight:     var(--font-weight-semibold);
}

/* ── Sign-up note ── */
.login-note {
  margin-top:  var(--space-5);
  padding-top: var(--space-4);
  border-top:  1px solid var(--color-border);
  text-align:  center;
  font-size:   var(--font-size-sm);
  color:       var(--color-text-secondary);
}

.login-note a {
  color:       var(--color-accent);
  font-weight: var(--font-weight-medium);
}

.login-note a:hover {
  color:           var(--color-accent-dark);
  text-decoration: underline;
}

/* ── Password toggle ── */
.toggle-password {
  color: var(--color-text-secondary);
}

.toggle-password:hover,
.toggle-password:focus {
  color:   var(--color-accent);
  outline: none;
}

/* ── Footer ── */
.login-footer {
  display:        flex;
  flex-direction: column;
  align-items:    center;
  gap:            var(--space-2);
  padding:        var(--space-4) var(--space-4) var(--space-6);
  text-align:     center;
  font-size:      var(--font-size-xs);
  color:          var(--color-text-muted);
}

.login-footer-links {
  display: flex;
  gap:     var(--space-4);
}

.login-footer-links a {
  color:     var(--color-text-muted);
  font-size: var(--font-size-xs);
}

.login-footer-links a:hover {
  color: var(--color-accent);
}

/* ── Responsive ── */
@media (max-width: 480px) {
  .login-card {
    padding: var(--space-5) var(--space-4);
  }

  .login-footer-links {
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-2) var(--space-3);
  }
}
