.login {
  /* Figma 95:788 Login-Page */
  --login-page-bg: #e7e5dd;
  --login-card-bg: #f7f6f3;
  --login-card-w: 460px;
  --login-card-h: 370px;
  --login-field-max: 360px;
  --login-muted: #655e4c;
  --login-input-surface: #ffffff;
  --login-border: #e7e5dd;
  --login-field-gap: 21px; /* input2 top 210 − (145 + 44) */
  --login-actions-offset: 29px; /* button top 283 − pwd field bottom 254 */
  /* Forgot text top 294 vs button top 283 */
  --login-forgot-drop: 11px;
  /* Field 50–410: forgot at 65 → +15px; button right 408 vs 410 → 2px */
  --login-actions-pad-left: 15px;
  --login-actions-pad-right: 2px;
  --login-btn-h: 41.462px;
  --login-btn-w: 129.999px;
  --login-btn-radius: 4.507px;
  --login-input-fs: 12px;
  --login-input-pad-x: 15px;
  /* 95:794: padding-top = forte group top 10.22% × 370 */
  --login-card-pad-top: 37.814px;
  /* bottom = 370 − (button top 283 + btn h 41.462) */
  --login-card-pad-bottom: 45.538px;
  --login-card-pad-x: 50px;
  /* fusion bottom Y = 23.16%×370 + 5.4%×370 = 105.672px; first input top 145 */
  --login-brand-after: 39.328px;
  /* gap between forte bottom and fusion top */
  --login-wordmark-gap: 7.77px;
  --login-wordmark-forte-w: 168px;
  --login-wordmark-fusion-w: 96.324px;
  /* Inner content starts after 50px pad; forte left 31.3%×460 − 50 ≈ 93.98px */
  --login-wordmark-inset: 93.98px;
  /* Figma 95:801 / 95:798: DM Sans Regular, opsz 14 — set wght explicitly (variable font) */
  --login-dm-regular: "opsz" 14, "wght" 400;
  /* Figma 95:797: DM Sans SemiBold */
  --login-dm-semibold: "opsz" 14, "wght" 600;

  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--login-page-bg);
  padding: var(--space-20);
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-synthesis: none;
}

.login-container {
  box-sizing: border-box;
  background: var(--login-card-bg);
  width: 100%;
  max-width: var(--login-card-w);
  min-height: var(--login-card-h);
  padding: var(--login-card-pad-top) var(--login-card-pad-x) var(--login-card-pad-bottom)
    var(--login-card-pad-x);
  display: flex;
  flex-direction: column;
  align-items: center;
  border-radius: 10px;
}

/* Figma 95:819 / 95:825: same right edge (≈67.83% of card); fusion narrower — flex-end stack */
.login-brand {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  width: 100%;
  margin: 0;
}

/* Figma: fusion bottom → first input top = 39.328px (no alert between) */
.login-brand + form {
  margin-top: var(--login-brand-after);
}

.login-brand + .alert {
  margin-top: 0;
  margin-bottom: var(--space-16);
}

.login-brand + .alert + form {
  margin-top: var(--space-16);
}

.login-brand + .form-actions {
  margin-top: var(--login-brand-after);
}

.login-brand__wordmarks {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  width: var(--login-wordmark-forte-w);
  max-width: 100%;
  margin-left: var(--login-wordmark-inset);
  margin-right: auto;
  gap: var(--login-wordmark-gap);
}

.login-brand__forte-img {
  width: var(--login-wordmark-forte-w);
  max-width: 100%;
  height: auto;
  display: block;
  flex-shrink: 0;
}

.login-brand__fusion-img {
  width: var(--login-wordmark-fusion-w);
  max-width: 100%;
  height: auto;
  display: block;
  flex-shrink: 0;
}

form {
  max-width: var(--login-field-max);
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

input[type="text"],
input[type="email"],
input[type="password"] {
  display: block;
  box-sizing: border-box;
  width: 100%;
  height: 44px;
  margin: 0 0 var(--login-field-gap);
  padding: 0 var(--login-input-pad-x);
  border: 1.5px solid var(--login-border);
  border-radius: 8px;
  font-family: "DM Sans", sans-serif;
  font-size: var(--login-input-fs);
  font-weight: 400;
  font-variation-settings: var(--login-dm-regular);
  line-height: 44px;
  letter-spacing: normal;
  background: var(--login-input-surface);
  color: #222222;
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus {
  -webkit-box-shadow: 0 0 0 1000px var(--login-input-surface) inset;
  -webkit-text-fill-color: #222222;
  font-family: "DM Sans", sans-serif;
  font-size: var(--login-input-fs);
  font-weight: 400;
  font-variation-settings: var(--login-dm-regular);
  transition: background-color 5000s ease-in-out 0s;
}

.password-field-wrapper {
  position: relative;
  display: block;
  width: 100%;
  margin: 0 0 var(--login-field-gap);
  height: 44px;
}

.password-field-wrapper:last-of-type {
  margin-bottom: 0;
}

.password-field-wrapper input[type="password"],
.password-field-wrapper input[type="text"] {
  width: 100%;
  margin-bottom: 0;
  padding-right: var(--login-input-pad-x);
}

.password-field-wrapper.password-field-wrapper--has-value input[type="password"],
.password-field-wrapper.password-field-wrapper--has-value input[type="text"] {
  padding-right: 48px;
}

.password-toggle {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
  align-items: center;
  justify-content: center;
  color: var(--color-gray-light);
  transition: color 0.2s ease;
}

.password-field-wrapper.password-field-wrapper--has-value .password-toggle {
  display: flex;
}

.password-toggle:hover {
  color: var(--color-black);
}

.password-toggle:focus {
  outline: none;
  color: var(--color-black);
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus {
  outline: none;
  border-color: var(--login-border);
}

input[type="text"]::placeholder,
input[type="email"]::placeholder,
input[type="password"]::placeholder {
  color: var(--color-gray-light);
}

.form-actions {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  box-sizing: border-box;
  width: 100%;
  margin-top: var(--login-actions-offset);
  padding-left: var(--login-actions-pad-left);
  padding-right: var(--login-actions-pad-right);
  gap: 0;
}

.login .form-actions:has(> *:only-child) {
  justify-content: center;
  align-items: center;
  padding-left: 0;
  padding-right: 0;
}

.login--session-form .form-actions .forgot-password {
  margin-top: var(--login-forgot-drop);
}

.forgot-password {
  font-family: "DM Sans", sans-serif;
  font-size: 15px;
  font-weight: 400;
  font-variation-settings: var(--login-dm-regular);
  line-height: normal;
  letter-spacing: normal;
  color: var(--login-muted);
  text-decoration: none;
  flex-shrink: 0;
}

.forgot-password:hover {
  color: var(--login-muted);
}

button.login-button,
input.login-button {
  box-sizing: border-box;
  width: var(--login-btn-w);
  min-width: var(--login-btn-w);
  max-width: var(--login-btn-w);
  height: var(--login-btn-h);
  min-height: var(--login-btn-h);
  padding: 0;
  background: #222222;
  color: #e7e5dd;
  border: none;
  border-radius: var(--login-btn-radius);
  font-family: "DM Sans", sans-serif;
  font-size: 18.027px;
  font-weight: 600;
  font-variation-settings: var(--login-dm-semibold);
  line-height: normal;
  letter-spacing: normal;
  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
}

a.login-button {
  box-sizing: border-box;
  min-height: var(--login-btn-h);
  padding: 0 20px;
  width: auto;
  min-width: var(--login-btn-w);
  background: #222222;
  color: #e7e5dd;
  border: none;
  border-radius: var(--login-btn-radius);
  font-family: "DM Sans", sans-serif;
  font-size: 18.027px;
  font-weight: 600;
  font-variation-settings: var(--login-dm-semibold);
  line-height: normal;
  letter-spacing: normal;
  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  text-decoration: none;
}

button.login-button:hover,
input.login-button:hover,
a.login-button:hover {
  background: #222222;
  color: #e7e5dd;
}

button.login-button:active,
input.login-button:active,
a.login-button:active {
  opacity: 0.92;
}

button.login-button:focus,
input.login-button:focus,
a.login-button:focus {
  outline: none;
}

button.login-button:focus-visible,
input.login-button:focus-visible,
a.login-button:focus-visible {
  outline: 2px solid #222222;
  outline-offset: 2px;
}

button.login-button:disabled,
input.login-button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.alert {
  margin: 0;
  padding: var(--space-16);
  border-radius: 10px;
  font-family: "DM Sans", sans-serif;
  font-size: var(--fs-body);
  font-weight: 400;
  font-variation-settings: var(--login-dm-regular);
  width: 100%;
  max-width: var(--login-field-max);
  box-sizing: border-box;
}

.alert-danger {
  background: var(--login-border);
  color: var(--color-red);
  border: 1px solid var(--color-red);
}


.dev-info {
  margin-top: var(--space-32);
  padding: var(--space-16);
  background: var(--color-bg-tertiary);
  border-radius: 10px;
  text-align: center;
}

.dev-info small {
  font-family: "DM Sans", sans-serif;
  font-size: var(--fs-body);
  font-weight: var(--font-light);
  color: var(--color-gray-dark);
}

@media (max-width: 520px) {
  .login-container {
    min-height: 0;
    padding: 32px var(--space-24) 40px;
  }

  .login-brand + form,
  .login-brand + .form-actions,
  .login-brand + .alert + form {
    margin-top: 28px;
  }

  .login-brand__wordmarks {
    margin-left: auto;
    margin-right: auto;
    gap: 6px;
  }

  .login-brand__forte-img {
    width: min(168px, 48vw);
  }

  .login-brand__fusion-img {
    width: min(96.324px, 28vw);
  }
}

@media (max-width: 380px) {
  .login {
    padding: var(--space-16);
  }

  .form-actions {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-16);
    padding-left: 0;
    padding-right: 0;
  }

  .login--session-form .form-actions .forgot-password {
    margin-top: 0;
  }

  button.login-button,
  input.login-button,
  a.login-button {
    max-width: none;
    width: 100%;
  }

  .forgot-password {
    text-align: center;
  }
}
