/*
 * Paciente auth — alineado a web-2026
 *
 */

/* ========== layout.blade.php — todas las vistas auth ========== */
body#login.auth-paciente-oyo26 {
  padding-top: 0;
  margin: 0;
  min-height: 100vh;
  font-family: var(--font-base);
  color: var(--color-text);
  background-color: var(--color-white);
  background-image: linear-gradient(
    165deg,
    var(--color-white) 0%,
    var(--color-surface) 42%,
    #eef6fb 100%
  );
}

.auth-paciente-oyo26-wrap {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-10) var(--space-4) var(--space-12);
}

.auth-paciente-oyo26-inner {
  width: 100%;
  max-width: 460px;
}

.auth-paciente-oyo26-logo {
  display: block;
  text-align: center;
  margin-bottom: var(--space-8);
}

.auth-paciente-oyo26-logo img {
  display: inline-block;
  height: 41px;
  width: auto;
}

/* ========== Card contenedora ========== */
/* Card checkout: elevación y sin sticky de la página de pago */
.auth-paciente-oyo26-card.oyo-checkout-form-card {
  margin-left: auto;
  margin-right: auto;
  position: static;
  top: auto;
  border: 1px solid var(--color-border-soft);
  box-shadow: 0 1px 3px rgba(36, 50, 88, 0.05), 0 6px 20px rgba(36, 50, 88, 0.06);
}

/* ========== Títulos / subtítulos / enlaces superiores ========== */
.auth-paciente-oyo26-title {
  color: var(--color-navy-deep);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  text-align: center;
  margin: 0 0 var(--space-2);
  letter-spacing: -0.02em;
}

.auth-paciente-oyo26-subtitle {
  color: var(--color-text-secondary);
  font-size: var(--fs-base);
  line-height: var(--lh-base);
  text-align: center;
  margin: 0 0 var(--space-6);
}

.auth-paciente-oyo26-top-links {
  text-align: center;
  font-size: var(--fs-sm);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-5);
}

.auth-paciente-oyo26-top-links a {
  color: var(--color-teal);
  font-weight: var(--fw-semibold);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.auth-paciente-oyo26-top-links a:hover {
  color: var(--color-teal-hover);
}

/* ========== LOGIN — login.blade.php ========== */
/* Bloque “¿No tienes cuenta?” */
.auth-paciente-oyo26-card > .kt-grid__item.login-register:not(.pt-4) {
  text-align: center;
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border-soft);
  font-size: var(--fs-sm);
  color: var(--color-text-secondary);
}

.auth-paciente-oyo26-card > .kt-grid__item.login-register:not(.pt-4) .kt-login__signup-link {
  color: var(--color-teal);
  font-weight: var(--fw-semibold);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.auth-paciente-oyo26-card > .kt-grid__item.login-register:not(.pt-4) .kt-login__signup-link:hover {
  color: var(--color-teal-hover);
}

/* ========== OLVIDÉ CONTRASEÑA + RESET — passwords/email.blade.php, passwords/reset.blade.php ========== */
.auth-paciente-oyo26-card > .kt-login__form + .kt-grid__item.login-register:not(.pt-4) {
  margin-top: var(--space-6);
  padding-top: 0;
  border-top: none;
  padding-bottom: var(--space-4);
}

/* ========== Alertas y nota al pie ========== */
.auth-paciente-oyo26-alert {
  background-color: rgba(46, 167, 106, 0.12);
  border: 1px solid var(--color-success);
  color: var(--color-dark);
  font-size: var(--fs-sm);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-4);
}

.auth-paciente-oyo26-footnote {
  text-align: center;
  font-size: var(--fs-sm);
  color: var(--color-text-secondary);
  line-height: var(--lh-base);
  margin-top: var(--space-6);
}

.auth-paciente-oyo26-footnote a {
  color: var(--color-teal);
  text-decoration: underline;
}

/* ========== REGISTRO — register.blade.php ========== */
/* Fila nombre / apellido */
.auth-paciente-oyo26-form-row {
  display: flex;
  flex-direction: column;
  gap: 0;
}

@media (min-width: 480px) {
  .auth-paciente-oyo26-form-row {
    flex-direction: row;
    gap: var(--space-4);
  }

  .auth-paciente-oyo26-form-row .oyo-form-group {
    flex: 1;
    margin-bottom: var(--space-5);
  }
}

.auth-paciente-oyo26-whatsapp-grid {
  display: flex;
  flex-direction: column;
  gap: 0;
}

@media (min-width: 480px) {
  .auth-paciente-oyo26-whatsapp-grid {
    flex-direction: row;
    gap: var(--space-4);
    align-items: flex-end;
  }

  .auth-paciente-oyo26-whatsapp-grid .oyo-form-group:first-child {
    flex: 0 0 38%;
  }

  .auth-paciente-oyo26-whatsapp-grid .oyo-form-group:last-child {
    flex: 1;
  }
}

/* ========== Inputs .form-control / .select-one a nivel body ========== */
.auth-paciente-oyo26 .form-control,
.auth-paciente-oyo26 .select-one {
  background-color: var(--color-white);
  color: var(--color-text);
  font-family: var(--font-base);
  font-size: var(--fs-base);
  padding: var(--space-3) var(--space-4);
  width: 100%;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.auth-paciente-oyo26 .form-control:focus,
.auth-paciente-oyo26 .select-one:focus {
  outline: none;
  border-color: var(--color-blue);
  box-shadow: 0 0 0 3px rgba(70, 167, 222, 0.15);
}

.auth-paciente-oyo26 .form-text {
  color: var(--color-muted);
  font-size: var(--fs-xs);
  margin-top: var(--space-1);
}

/* Términos y checkbox de marketing (registro) */
.auth-paciente-oyo26-terms {
  font-size: var(--fs-sm);
  color: var(--color-text-secondary);
  line-height: var(--lh-base);
}

.auth-paciente-oyo26-terms a {
  color: var(--color-teal);
  font-weight: var(--fw-semibold);
  text-decoration: underline;
}

/* ========== LOGIN — aviso de crisis / emergencias ========== */
.auth-paciente-oyo26-card > .kt-grid__item.login-register.pt-4 {
  margin-top: var(--space-5);
  padding: var(--space-4);
  background: color-mix(in srgb, var(--color-danger) 8%, var(--color-white));
  border: 1px solid color-mix(in srgb, var(--color-danger) 22%, var(--color-white));
  border-radius: var(--radius-md);
  text-align: center;
}

.auth-paciente-oyo26-card > .kt-grid__item.login-register.pt-4 .kt-login__signup-label {
  display: block;
  margin: 0;
  color: var(--color-dark);
  font-size: var(--fs-sm);
  line-height: var(--lh-base);
}

.auth-paciente-oyo26-card > .kt-grid__item.login-register.pt-4 .text-danger {
  color: var(--color-dark);
}

.auth-paciente-oyo26-card > .kt-grid__item.login-register.pt-4 a {
  color: var(--color-danger);
  font-weight: var(--fw-semibold);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.auth-paciente-oyo26-card > .kt-grid__item.login-register.pt-4 a:hover {
  color: var(--color-dark);
}

/* ========== Botón envío checkout ========== */
.auth-paciente-oyo26-card .oyo-checkout-form-submit {
  width: 100%;
  max-width: none;
}

/* ========== Formularios dentro de la card ========== */
.auth-paciente-oyo26-card .form-group {
  margin-bottom: var(--space-5);
}

.auth-paciente-oyo26-card .kt-form br {
  display: none;
}

.auth-paciente-oyo26-card .invalid-feedback,
.auth-paciente-oyo26-card .error.invalid-feedback {
  display: block;
  color: var(--color-danger);
  font-size: var(--fs-xs);
  margin-top: var(--space-1);
}

.auth-paciente-oyo26-card .form-group input.form-control,
.auth-paciente-oyo26-card .form-group .form-control.oyo-input {
  box-sizing: border-box;
  background-color: var(--color-white);
  color: var(--color-text);
  font-family: var(--font-base);
  font-size: var(--fs-base);
  line-height: 1.25;
  padding: 0 var(--space-4);
  height: 48px;
  min-height: 48px;
  width: 100%;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

/* Misma altura que el select de al lado */
.auth-paciente-oyo26-card .form-group input[type="number"].form-control {
  -moz-appearance: textfield;
}

.auth-paciente-oyo26-card .form-group input[type="number"].form-control::-webkit-outer-spin-button,
.auth-paciente-oyo26-card .form-group input[type="number"].form-control::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.auth-paciente-oyo26-card .form-group input.form-control:focus,
.auth-paciente-oyo26-card .form-group .form-control.oyo-input:focus {
  outline: none;
  border-color: var(--color-blue);
  box-shadow: 0 0 0 3px rgba(70, 167, 222, 0.15);
}

/* Selects en la card  */
.auth-paciente-oyo26-card .form-group select.form-control,
.auth-paciente-oyo26-card .form-group select.select-one {
  box-sizing: border-box;
  height: 48px;
  min-height: 48px;
  padding: 0 var(--space-10) 0 var(--space-4);
  line-height: 1.25;
  background-color: var(--color-white);
  color: var(--color-text);
  font-family: var(--font-base);
  font-size: var(--fs-base);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' viewBox='0 0 12 7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23666' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-4) center;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.auth-paciente-oyo26-card .form-group select.form-control:focus,
.auth-paciente-oyo26-card .form-group select.select-one:focus {
  outline: none;
  border-color: var(--color-blue);
  box-shadow: 0 0 0 3px rgba(70, 167, 222, 0.15);
}

/* REGISTRO — inputs .oyo-input / .oyo-select */
.auth-paciente-oyo26-card .oyo-form-group > .oyo-input,
.auth-paciente-oyo26-card .oyo-form-group > .oyo-select {
  min-height: 48px;
}

/* ========== LOGIN + REGISTRO — .kt-login__actions (enlace olvidé + botones primarios) ========== */
.auth-paciente-oyo26-card .kt-login__actions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--space-3);
  margin-top: var(--space-6);
}

.auth-paciente-oyo26-card .kt-login__actions .kt-login__link-forgot {
  color: var(--color-teal);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-align: center;
}

.auth-paciente-oyo26-card .kt-login__actions .kt-login__link-forgot:hover {
  color: var(--color-teal-hover);
}

.auth-paciente-oyo26-card .kt-login__actions #register-button.btn.btn-primary.kt-login__btn-primary,
.auth-paciente-oyo26-card .kt-login__actions #login-button.btn.btn-primary.kt-login__btn-primary,
.auth-paciente-oyo26-card .kt-login__actions > button.g-recaptcha.btn.btn-primary.kt-login__btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: none;
  min-height: 48px;
  padding: 0 var(--space-5);
  border: none;
  border-radius: var(--radius-md);
  background: var(--color-teal);
  color: var(--color-white);
  font-family: var(--font-base);
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-image: none;
  box-shadow: none;
  text-shadow: none;
  transition: background-color var(--transition-fast), box-shadow var(--transition-fast);
}

.auth-paciente-oyo26-card .kt-login__actions #register-button.btn.btn-primary.kt-login__btn-primary:hover,
.auth-paciente-oyo26-card .kt-login__actions #login-button.btn.btn-primary.kt-login__btn-primary:hover,
.auth-paciente-oyo26-card .kt-login__actions > button.g-recaptcha.btn.btn-primary.kt-login__btn-primary:hover {
  background: var(--color-teal-hover);
  box-shadow: none;
}

.auth-paciente-oyo26-card .kt-login__actions #register-button.btn.btn-primary.kt-login__btn-primary:focus-visible,
.auth-paciente-oyo26-card .kt-login__actions #login-button.btn.btn-primary.kt-login__btn-primary:focus-visible,
.auth-paciente-oyo26-card .kt-login__actions > button.g-recaptcha.btn.btn-primary.kt-login__btn-primary:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-teal) 35%, transparent);
}

/* ========== REGISTRO — cabecera Metronic (.kt-login__title / .kt-login__desc) ========== */
.auth-paciente-oyo26-card .kt-login__title h3 {
  color: var(--color-navy-deep);
  font-size: var(--fs-xl);
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  text-align: center;
  margin: 0 0 var(--space-3);
  letter-spacing: -0.02em;
}

.auth-paciente-oyo26-card .kt-login__desc {
  text-align: center;
  color: var(--color-text-secondary);
  font-size: var(--fs-base);
  line-height: var(--lh-base);
  margin: 0 auto var(--space-6);
  max-width: 34rem;
}

.auth-paciente-oyo26-card .kt-login__form {
  padding-bottom: var(--space-4);
}

/* Alerta éxito Metronic */
.auth-paciente-oyo26-card .alert.alert-outline-success.font-up {
  background-color: rgba(46, 167, 106, 0.12);
  border: 1px solid var(--color-success);
  color: var(--color-dark);
  font-size: var(--fs-sm);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-4);
  text-align: center;
}

/* REGISTRO — botón secundario “¿Ya tienes cuenta?” → ir a login */
.auth-paciente-oyo26-card .kt-login__actions > .btn.btn-outline-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 48px;
  padding: 0 var(--space-5);
  box-sizing: border-box;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-teal);
  background-color: var(--color-white);
  color: var(--color-teal);
  font-family: var(--font-base);
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  cursor: pointer;
  text-decoration: none;
  appearance: none;
  -webkit-appearance: none;
  transition: background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);
}

.auth-paciente-oyo26-card .kt-login__actions > .btn.btn-outline-primary:hover {
  background-color: color-mix(in srgb, var(--color-teal) 10%, var(--color-white));
  color: var(--color-teal-hover);
  border-color: var(--color-teal-hover);
}

.auth-paciente-oyo26-card .kt-login__actions > .btn.btn-outline-primary:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-teal) 35%, transparent);
}

/* ========== OLVIDÉ + RESET  ========== */
.auth-paciente-oyo26-card .kt-login__form .kt-login__actions {
  gap: var(--space-2);
  margin-top: var(--space-5);
}

.auth-paciente-oyo26-card .kt-login__form .kt-login__actions > button.g-recaptcha.btn.btn-primary.kt-login__btn-primary,
.auth-paciente-oyo26-card .kt-login__form .kt-login__actions #login-button.btn.btn-primary.kt-login__btn-primary,
.auth-paciente-oyo26-card .kt-login__form .kt-login__actions #register-button.btn.btn-primary.kt-login__btn-primary {
  min-height: 42px;
  height: auto;
  padding: var(--space-2) var(--space-4);
  font-size: var(--fs-sm);
  border-radius: var(--radius-sm);
}

.auth-paciente-oyo26-card .kt-login__form .kt-login__actions > .btn.btn-outline-primary {
  min-height: 42px;
  height: auto;
  padding: var(--space-2) var(--space-4);
  font-size: var(--fs-sm);
  border-radius: var(--radius-sm);
}

/* ========== REGISTRO — bloque “¿Ya tienes cuenta?” / enlaces bajo la card ========== */
.auth-paciente-oyo26-card .login-register:not(.pt-4) {
  text-align: center;
  font-size: var(--fs-sm);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-2);
}

/* Separación del #kt-form respecto al bloque “¿Ya tienes cuenta?” (registro) */
.auth-paciente-oyo26-card #kt-form.kt-form.mt-4 {
  margin-top: var(--space-5);
}

.auth-paciente-oyo26-card .kt-login__signup-link {
  color: var(--color-teal);
  font-weight: var(--fw-semibold);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.auth-paciente-oyo26-card .kt-login__signup-link:hover {
  color: var(--color-teal-hover);
}

/* ========== REGISTRO — rejilla .row / .col-*  ========== */
.auth-paciente-oyo26-card .row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-left: 0;
  margin-right: 0;
}

.auth-paciente-oyo26-card .row > [class*="col-"] {
  position: relative;
  box-sizing: border-box;
  min-width: 0;
  padding-left: 0;
  padding-right: 0;
}

@media (max-width: 575.98px) {
  .auth-paciente-oyo26-card .row > [class*="col-"] {
    flex: 1 1 100%;
    max-width: 100%;
  }
}

@media (min-width: 576px) {
  .auth-paciente-oyo26-card .row > .col-sm-6 {
    flex: 0 0 calc((100% - var(--space-4)) / 2);
    max-width: calc((100% - var(--space-4)) / 2);
  }

  .auth-paciente-oyo26-card .row > .col-sm-4 {
    flex: 0 0 calc((100% - var(--space-4)) / 3);
    max-width: calc((100% - var(--space-4)) / 3);
  }

  .auth-paciente-oyo26-card .row > .col-sm-8 {
    flex: 0 0 calc((100% - var(--space-4)) * 2 / 3);
    max-width: calc((100% - var(--space-4)) * 2 / 3);
  }
}

/* REGISTRO / compartido — select con ambas clases */
.auth-paciente-oyo26-card .form-control.select-one {
  min-height: 48px;
}

/* REGISTRO — aceptación términos (.kt-checkbox-inline) */
.auth-paciente-oyo26-card .kt-checkbox-inline {
  font-size: var(--fs-sm);
  line-height: var(--lh-base);
  color: var(--color-text-secondary);
}

.auth-paciente-oyo26-card .kt-checkbox-inline .kt-link--brand {
  color: var(--color-teal);
  font-weight: var(--fw-semibold);
}

.auth-paciente-oyo26-card .kt-checkbox-inline .kt-link--brand:hover {
  color: var(--color-teal-hover);
}

/* REGISTRO — línea de crisis / ayuda al pie */
.auth-paciente-oyo26-card > h6.text-center {
  text-align: center;
  margin: var(--space-8) var(--space-2) 0;
  font-size: var(--fs-sm);
  font-weight: var(--fw-normal);
  line-height: var(--lh-base);
  color: var(--color-text-secondary);
}

.auth-paciente-oyo26-card > h6.text-center a {
  color: var(--color-teal);
  font-weight: var(--fw-semibold);
  text-decoration: none;
}

.auth-paciente-oyo26-card > h6.text-center a:hover {
  color: var(--color-teal-hover);
}

/* ========== REGISTRO ========== */
.auth-paciente-oyo26-card .mt-1 {
  margin-top: var(--space-1);
}

@media (min-width: 576px) {
  .auth-paciente-oyo26-card .mt-sm-0 {
    margin-top: 0 !important;
  }

  .auth-paciente-oyo26-card .pl-sm-2 {
    padding-left: var(--space-2) !important;
  }
}

.auth-paciente-oyo26-card .pl-0 {
  padding-left: 0 !important;
}

.auth-paciente-oyo26-card .pr-0 {
  padding-right: 0 !important;
}
