/* ============================================================
   /admin/login.css
   Shared by /admin/login, /admin/forgot-password, /admin/reset-password.
   Cream surface, Forest text, Gold submit. Brand-pure.
   All values pulled from tokens.css — no hardcoded fallbacks.
   ============================================================ */

.login-page {
  background-color: var(--color-cream);
  min-height: 100vh;
  min-height: 100dvh;
}

.login {
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6) var(--gutter-mobile);
}

.login__inner {
  width: 100%;
  max-width: var(--max-width-narrow);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.login__logo {
  align-self: flex-start;
  margin-bottom: var(--space-6);
  text-decoration: none;
}

.login__logo img {
  display: block;
  height: auto;
  width: 180px;
}

/* Eyebrow micro-label */
.login__label {
  font-family: var(--font-sans);
  font-size: var(--text-micro);
  font-weight: var(--font-weight-medium);
  letter-spacing: var(--tracking-micro);
  text-transform: uppercase;
  color: var(--color-sage);
  margin: 0;
}

.login__heading {
  font-family: var(--font-display);
  font-size: var(--text-display-lg);
  font-weight: var(--font-weight-regular);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-display);
  color: var(--color-forest);
  margin: 0 0 var(--space-5) 0;
}

/* Form layout */
.login__form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.login__field {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.login__label-input {
  font-family: var(--font-sans);
  font-size: var(--text-micro);
  font-weight: var(--font-weight-medium);
  letter-spacing: var(--tracking-micro);
  text-transform: uppercase;
  color: var(--color-sage);
}

.login__input {
  width: 100%;
  font-family: var(--font-sans);
  font-size: var(--text-body-md);
  font-weight: var(--font-weight-regular);
  line-height: var(--leading-snug);
  color: var(--color-forest);
  background-color: transparent;
  border: none;
  border-bottom: 1px solid color-mix(in srgb, var(--color-sage) 40%, transparent);
  padding: var(--space-2) 0;
  border-radius: 0;
  outline: none;
  transition: border-color var(--transition-hover);
  -webkit-appearance: none;
  appearance: none;
}

.login__input::placeholder {
  color: color-mix(in srgb, var(--color-sage) 60%, transparent);
}

.login__input:focus {
  border-bottom-color: var(--color-gold);
}

.login__input:autofill {
  -webkit-text-fill-color: var(--color-forest);
  box-shadow: 0 0 0px 1000px var(--color-cream) inset;
}

/* Submit */
.login__submit {
  margin-top: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--text-micro);
  font-weight: var(--font-weight-medium);
  letter-spacing: var(--tracking-micro);
  text-transform: uppercase;
  color: var(--color-forest);
  background-color: var(--color-gold);
  border: none;
  padding: var(--space-3) var(--space-5);
  cursor: pointer;
  transition: background-color var(--transition-hover), opacity var(--transition-hover);
  border-radius: var(--border-radius);
  -webkit-appearance: none;
  appearance: none;
}

.login__submit:hover:not(:disabled) {
  background-color: color-mix(in srgb, var(--color-gold) 88%, var(--color-forest));
}

.login__submit:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* Error state — Gold left border, never red */
.login__error {
  font-family: var(--font-sans);
  font-size: var(--text-body-sm);
  line-height: var(--leading-body);
  color: var(--color-forest);
  background-color: color-mix(in srgb, var(--color-gold) 12%, transparent);
  border-left: 2px solid var(--color-gold);
  padding: var(--space-2) var(--space-3);
  margin: 0;
}

.login__error[hidden] {
  display: none !important;
}

/* ============================================================
   Shared by /admin/forgot-password and /admin/reset-password
   ============================================================ */

.login__body {
  font-family: var(--font-sans);
  font-size: var(--text-body-md);
  font-weight: var(--font-weight-regular);
  line-height: var(--leading-body);
  color: var(--color-forest);
  margin: 0 0 var(--space-3) 0;
}

.login__hint {
  font-family: var(--font-sans);
  font-size: var(--text-micro);
  font-weight: var(--font-weight-regular);
  letter-spacing: var(--tracking-normal);
  color: var(--color-sage);
  margin: var(--space-1) 0 0 0;
}

.login__success {
  font-family: var(--font-sans);
  font-size: var(--text-body-sm);
  line-height: var(--leading-body);
  color: var(--color-forest);
  background-color: color-mix(in srgb, var(--color-sage) 12%, transparent);
  border-left: 2px solid var(--color-sage);
  padding: var(--space-3) var(--space-4);
  margin: 0;
}

.login__success[hidden] {
  display: none !important;
}

.login__error-state[hidden] {
  display: none !important;
}

.login__footer {
  margin-top: var(--space-4);
  font-family: var(--font-sans);
  font-size: var(--text-micro);
  font-weight: var(--font-weight-medium);
  letter-spacing: var(--tracking-micro);
  text-transform: uppercase;
  color: var(--color-sage);
}

.login__link {
  color: var(--color-sage);
  text-decoration: none;
  border-bottom: 1px solid color-mix(in srgb, var(--color-sage) 40%, transparent);
  padding-bottom: 1px;
  transition: color var(--transition-hover), border-color var(--transition-hover);
}

.login__link:hover {
  color: var(--color-gold);
  border-bottom-color: var(--color-gold);
}
