html,
body {
  height: 100%;
}

body {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100%;
  padding: clamp(24px, 6vh, 56px) 16px;
  overflow-x: hidden;
  color: var(--golfoticket-color-text-primary);
  font-family: "Geist", "Aptos", "Segoe UI", system-ui, -apple-system, sans-serif;
  background-color: var(--golfoticket-color-canvas);
  background-image:
    linear-gradient(var(--golfoticket-grid-line-blue) 1px, transparent 1px),
    linear-gradient(90deg, var(--golfoticket-grid-line-sky) 1px, transparent 1px),
    linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(232, 246, 255, 0.92) 58%, rgba(247, 251, 255, 0.96));
  background-size: 72px 72px, 72px 72px, auto;
}

.form-signin {
  width: 100%;
  max-width: 380px;
  padding: 30px;
  margin: auto;
  border: 1px solid rgba(20, 123, 209, 0.18);
  border-radius: var(--golfoticket-radius-base);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: var(--golfoticket-shadow-card);
  backdrop-filter: blur(16px);
}

.login-brand-mark {
  display: block;
  width: min(300px, 100%);
  max-height: 72px;
  height: auto;
  margin-right: auto;
  margin-left: auto;
  object-fit: contain;
}

.form-signin .checkbox {
  font-weight: 400;
}

.form-signin .form-floating:focus-within {
  z-index: 2;
}

.form-signin h1 {
  margin-top: 0;
  color: var(--golfoticket-color-text-primary);
  font-size: 1.55rem;
  font-weight: 700;
  letter-spacing: 0;
}

.form-signin .form-floating {
  margin-bottom: 10px;
}

.form-signin .form-control {
  min-height: 58px;
  border: 1px solid var(--golfoticket-color-border);
  border-radius: var(--golfoticket-radius-base);
  color: var(--golfoticket-color-text-primary);
  background-color: rgba(255, 255, 255, 0.96);
  box-shadow: 0 10px 24px rgba(20, 123, 209, 0.06);
}

.form-signin .form-control:focus {
  border-color: var(--golfoticket-color-blue);
  box-shadow: var(--golfoticket-focus-ring);
}

.form-signin .form-floating > label {
  color: var(--golfoticket-color-text-muted);
}

.form-signin input[type="email"] {
  margin-bottom: -1px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}

.form-signin input[type="password"] {
  margin-bottom: 10px;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

.form-signin input[name="email"],
.form-signin input[type="password"] {
  margin-bottom: 0;
  border-radius: var(--golfoticket-radius-base);
}

.form-signin .btn {
  min-height: 48px;
  border-radius: var(--golfoticket-radius-base);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0;
  transition: transform 180ms ease, box-shadow 180ms ease, background-color 180ms ease, border-color 180ms ease;
}

.form-signin .btn:hover,
.form-signin .btn:focus-visible {
  transform: translateY(-1px);
}

.form-signin .btn-secondary {
  border: 0;
  color: #ffffff;
  background: linear-gradient(135deg, #023059, var(--golfoticket-color-blue) 58%, var(--golfoticket-color-sky));
  box-shadow: var(--golfoticket-shadow-action);
}

.form-signin .btn-secondary:hover,
.form-signin .btn-secondary:focus-visible {
  color: #ffffff;
  background: linear-gradient(135deg, #012442, var(--golfoticket-color-blue-dark) 58%, var(--golfoticket-color-blue));
}

.form-signin .btn-outline-primary {
  border-color: rgba(20, 123, 209, 0.62);
  color: var(--golfoticket-color-blue-dark);
  background-color: rgba(255, 255, 255, 0.74);
}

.form-signin .btn-outline-primary:hover,
.form-signin .btn-outline-primary:focus-visible {
  border-color: var(--golfoticket-color-blue);
  color: #ffffff;
  background-color: var(--golfoticket-color-blue);
  box-shadow: var(--golfoticket-shadow-header);
}

.form-signin a {
  color: var(--golfoticket-color-blue-dark);
  font-weight: 600;
}

.form-signin a:hover,
.form-signin a:focus-visible {
  color: var(--golfoticket-color-blue);
}

.form-signin .text-muted {
  color: var(--golfoticket-color-text-muted) !important;
}

.login-trust-logo {
  width: auto;
  height: 42px;
  filter: saturate(0.94) contrast(1.03);
}

.login-tech-logo {
  width: auto;
  height: 25px;
}

@media (max-width: 420px) {
  .form-signin {
    padding: 24px;
  }

  .login-brand-mark {
    width: min(272px, 100%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .form-signin .btn {
    transition: none;
  }

  .form-signin .btn:hover,
  .form-signin .btn:focus-visible {
    transform: none;
  }
}

/*=== Form Recuperar contraseña ===*/
.form-rc-signin {
  width: 100%;
  max-width: 330px;
  padding: 15px;
  margin: auto;
}

.form-rc-signin .checkbox {
  font-weight: 400;
}

.form-rc-signin .form-rc-floating:focus-within {
  z-index: 2;
}

.form-rc-signin input[type="email"] {
  margin-bottom: 5px;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}

.form-rc-signin input[type="password"] {
  margin-bottom: 10px;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
