.login-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-light) 100%);
  padding: var(--sp-4);
}

.login-card {
  width: 100%;
  max-width: 380px;
  background: var(--c-surface);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: var(--sp-6);
}

.login-brand {
  text-align: center;
  margin-bottom: var(--sp-6);
}

.login-logo {
  font-size: 22px;
  font-weight: var(--fw-semibold);
  color: var(--c-primary);
  letter-spacing: -0.01em;
}

.login-sub {
  font-size: var(--fs-small);
  color: var(--c-text-muted);
  margin-top: var(--sp-1);
}

.login-form {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}

.field {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}

.field-label {
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  color: var(--c-text-secondary);
}

.field-input {
  padding: 10px 12px;
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  font-size: var(--fs-body);
  font-family: var(--font-sans);
  color: var(--c-text);
  background: var(--c-surface);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  min-height: 44px;
}

.field-input:focus {
  outline: none;
  border-color: var(--c-accent);
  box-shadow: 0 0 0 3px var(--c-accent-light);
}

.login-error {
  background: var(--c-danger-bg);
  color: var(--c-danger);
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--radius-md);
  font-size: var(--fs-small);
  border: 1px solid rgba(185, 28, 28, 0.15);
}

.login-button {
  background: var(--c-accent);
  color: white;
  border: none;
  border-radius: var(--radius-md);
  padding: 12px 16px;
  font-size: var(--fs-body);
  font-weight: var(--fw-medium);
  cursor: pointer;
  transition: background var(--transition-fast);
  min-height: 44px;
}

.login-button:hover {
  background: var(--c-accent-hover);
}

.login-button:active {
  transform: translateY(1px);
}

.login-footnote {
  text-align: center;
  margin-top: var(--sp-5);
  font-size: var(--fs-caption);
  color: var(--c-text-placeholder);
}
