/**
 * Login corporativo
 */

.login-corporate-page {
  margin: 0;
  font-family: var(--font-family-base);
  font-size: var(--type-body-l-size);
  font-weight: var(--type-body-l-weight);
  line-height: var(--type-body-l-line);
  color: var(--kl-text);
  background: var(--kl-bg);
  -webkit-font-smoothing: antialiased;
}

.login-corporate {
  --login-card-max-width: 440px;
  --login-logo-width: 13.75rem;
  --login-card-radius: 2rem;
  --login-card-shadow:
    0 28px 56px -10px color-mix(in srgb, var(--kl-primary) 11%, transparent),
    0 10px 24px -6px color-mix(in srgb, var(--gray-900) 5%, transparent);

  position: relative;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-3xl) var(--space-lg) var(--space-2xl);
  background: color-mix(in srgb, var(--klinea-50) 42%, var(--kl-bg));
  overflow: hidden;
}

.login-corporate::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(40rem, 90vw);
  height: min(32rem, 70vh);
  transform: translate(-50%, -50%);
  border-radius: var(--radius-full);
  background: radial-gradient(
    circle,
    color-mix(in srgb, var(--kl-primary) 9%, transparent) 0%,
    color-mix(in srgb, var(--kl-primary) 3%, transparent) 50%,
    transparent 72%
  );
  pointer-events: none;
  z-index: 0;
}

.login-corporate__panel {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: var(--login-card-max-width);
}

.login-corporate__eyebrow-wrap {
  width: 100%;
  margin: 0 0 var(--space-md);
  text-align: center;
}

.login-corporate__eyebrow {
  margin: 0;
  font-size: var(--type-caption-size);
  font-weight: var(--kl-font-weight-bold);
  line-height: var(--type-caption-line);
  letter-spacing: var(--kl-letter-spacing-wide);
  text-transform: uppercase;
  color: var(--kl-primary);
}

.login-corporate__eyebrow-short,
.login-corporate__support-short {
  display: none;
}

.login-corporate__card {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: var(--login-card-max-width);
  min-height: 480px;
  padding: var(--space-3xl) var(--space-xl) var(--space-2xl);
  background: var(--kl-surface);
  border: none;
  border-radius: var(--login-card-radius);
  box-shadow: var(--login-card-shadow);
  text-align: center;
}

.login-corporate__stack {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  text-align: center;
}

.login-corporate__logo {
  display: block;
  width: min(var(--login-logo-width), 88%);
  max-width: 100%;
  height: auto;
  margin: 0 auto var(--space-lg);
}

.login-corporate__title {
  margin: 0 0 var(--space-xs);
  width: 100%;
  font-size: var(--type-h3-size);
  font-weight: var(--kl-font-weight-bold);
  line-height: var(--type-h3-line);
  letter-spacing: var(--kl-letter-spacing-tight);
  color: var(--kl-text);
}

.login-corporate__lead {
  margin: 0 0 var(--space-xl);
  width: 100%;
  max-width: 22rem;
  font-size: var(--type-body-m-size);
  font-weight: var(--type-body-m-weight);
  line-height: var(--kl-line-height-relaxed);
  color: var(--kl-muted);
}

.login-corporate__actions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  width: 100%;
  gap: var(--space-sm);
}

.login-corporate__btn-microsoft {
  appearance: none;
  -webkit-appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  width: 100%;
  margin: 0;
  padding: var(--space-md) var(--space-lg);
  font-family: inherit;
  font-size: var(--type-body-m-size);
  font-weight: var(--kl-font-weight-semibold);
  line-height: var(--kl-line-height-tight);
  color: var(--kl-text);
  background-color: var(--kl-surface);
  border: 1px solid var(--kl-border);
  border-radius: var(--radius-md);
  box-shadow: none;
  cursor: pointer;
  transition:
    background-color var(--kl-transition-fast),
    border-color var(--kl-transition-fast),
    box-shadow var(--kl-transition-fast);
}

.login-corporate__btn-microsoft:hover:not(:disabled) {
  background-color: var(--gray-50);
  border-color: var(--gray-300);
  box-shadow: var(--shadow-sm);
  color: var(--kl-text);
}

.login-corporate__btn-microsoft:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}

.login-corporate__btn-microsoft:disabled {
  opacity: 0.65;
  cursor: wait;
}

.login-corporate__btn-microsoft img {
  width: 21px;
  height: 21px;
  flex-shrink: 0;
}

.login-corporate__policy {
  margin: var(--space-2xl) 0 0;
  width: 100%;
  font-size: var(--type-body-s-size);
  font-weight: var(--type-body-s-weight);
  line-height: var(--type-body-s-line);
  color: var(--kl-text-disabled);
}

.login-corporate__status {
  box-sizing: border-box;
  width: 100%;
  margin: 0;
  padding: var(--space-sm) var(--space-md);
  min-height: 2.75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--type-body-s-size);
  font-weight: var(--type-body-s-weight);
  line-height: var(--type-body-s-line);
  text-align: center;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--kl-muted);
}

.login-corporate__status[hidden] {
  display: none;
}

.login-corporate__status--loading {
  border-color: var(--kl-border);
  background: var(--gray-50);
  color: var(--kl-text-secondary);
}

.login-corporate__status--loading::before {
  content: "";
  flex-shrink: 0;
  width: 0.875rem;
  height: 0.875rem;
  margin-right: var(--space-sm);
  border: 2px solid var(--gray-300);
  border-top-color: var(--kl-primary);
  border-radius: var(--radius-full);
  animation: login-status-spin 0.7s linear infinite;
}

.login-corporate__status--error {
  border-color: color-mix(in srgb, var(--error) 28%, var(--kl-border));
  background: var(--error-bg);
  color: var(--kl-text-secondary);
}

@keyframes login-status-spin {
  to {
    transform: rotate(360deg);
  }
}

.login-corporate__support {
  position: relative;
  z-index: 1;
  margin: var(--space-2xl) 0 0;
  max-width: var(--login-card-max-width);
  font-size: var(--type-body-s-size);
  font-weight: var(--type-body-s-weight);
  line-height: var(--type-body-s-line);
  color: var(--kl-muted);
  text-align: center;
}

.login-corporate__support a {
  color: inherit;
  font-weight: var(--kl-font-weight-medium);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.login-corporate__support a:hover {
  color: var(--kl-primary-hover);
}

/* Mobile ~360px — mockup §3 */
@media (max-width: 480px) {
  .login-corporate {
    --login-card-radius: 2.5rem;
    --login-card-shadow:
      0 24px 48px -8px color-mix(in srgb, var(--kl-primary) 14%, transparent),
      0 8px 20px -4px color-mix(in srgb, var(--gray-900) 6%, transparent);

    justify-content: center;
    gap: var(--space-2xl);
    padding: var(--space-xl) var(--space-md) var(--space-xl);
    background: linear-gradient(
      180deg,
      color-mix(in srgb, var(--klinea-50) 65%, var(--kl-bg)) 0%,
      var(--kl-bg) 55%
    );
  }

  .login-corporate::before {
    width: 100%;
    height: 50vh;
    top: 38%;
  }

  .login-corporate__panel {
    max-width: none;
    width: 92%;
  }

  .login-corporate__eyebrow {
    font-size: var(--type-body-m-size);
    letter-spacing: var(--kl-letter-spacing-wide);
  }

  .login-corporate__eyebrow-full,
  .login-corporate__support-full {
    display: none;
  }

  .login-corporate__eyebrow-short,
  .login-corporate__support-short {
    display: inline;
  }

  .login-corporate__card {
    width: 100%;
    max-width: none;
    min-height: auto;
    padding: var(--space-2xl) var(--space-md) var(--space-xl);
    border-radius: var(--login-card-radius);
    box-shadow: var(--login-card-shadow);
  }

  .login-corporate__logo {
    width: min(var(--login-logo-width), 80%);
    margin-bottom: var(--space-md);
  }

  .login-corporate__title {
    font-size: var(--type-h4-size);
  }

  .login-corporate__lead {
    margin-bottom: var(--space-xl);
    max-width: none;
    padding: 0 var(--space-xs);
  }

  .login-corporate__policy {
    margin-top: var(--space-xl);
    padding: 0 var(--space-xs);
  }

  .login-corporate__support {
    margin-top: 0;
    max-width: none;
    font-size: var(--type-caption-size);
    color: var(--kl-text-disabled);
  }
}
