.elementor-225 .elementor-element.elementor-element-2c9834f3{--display:flex;}.elementor-widget-text-editor{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}.elementor-225 .elementor-element.elementor-element-8d0d97a{--display:flex;}body.elementor-page-225:not(.elementor-motion-effects-element-type-background), body.elementor-page-225 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#FFFFFF;}/* Start custom CSS for container, class: .elementor-element-8d0d97a *//* ======================================
   VISTA INICIAR SESIÓN / CREAR CUENTA
   Página: /iniciar-sesion/
====================================== */

/* Contenedor general de las 2 tarjetas */
.zsvbe-auth-grid:has(.swpm-login-widget-form) {
  display: grid !important;
  grid-template-columns: 1.1fr 0.9fr !important;
  gap: 42px !important;
  max-width: 1050px !important;
  margin: 55px auto 90px !important;
  padding: 0 24px !important;
  align-items: stretch !important;
}

/* Tarjetas */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .zsvbe-auth-card {
  background: #ffffff !important;
  border-radius: 18px !important;
  padding: 42px 44px !important;
  border: 1px solid #eeeeee !important;
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.08) !important;
  color: #303047 !important;
  min-height: auto !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
}

/* Primera tarjeta: login */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .zsvbe-auth-card:first-child {
  border-top: 5px solid #269d95 !important;
}

/* Segunda tarjeta: registro */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .zsvbe-auth-card:last-child {
  border-top: 5px solid #bdd719 !important;
  justify-content: center !important;
  text-align: center !important;
}

/* Texto introductorio login */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .zsvbe-auth-card:first-child > p {
  color: #4c4c63 !important;
  font-size: 16px !important;
  line-height: 1.55 !important;
  margin: 0 0 30px !important;
  max-width: 420px !important;
}

/* Agregar título visual al login */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .zsvbe-auth-card:first-child::before {
  content: "Iniciar sesión";
  display: block;
  color: #269d95;
  font-size: 34px;
  font-weight: 800;
  line-height: 1.15;
  margin-bottom: 14px;
}

/* Agregar pequeño texto superior */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .zsvbe-auth-card:first-child::after {
  content: "";
  display: block;
  width: 80px;
  height: 2px;
  background: #269d95;
  margin: 0 0 26px;
  order: -1;
}

/* Título de la segunda tarjeta */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .zsvbe-auth-card:last-child h3 {
  color: #44127a !important;
  font-size: 34px !important;
  font-weight: 800 !important;
  line-height: 1.15 !important;
  margin: 0 0 18px !important;
}

/* Icono visual segunda tarjeta */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .zsvbe-auth-card:last-child::before {
  content: "✦";
  width: 78px;
  height: 78px;
  border-radius: 50%;
  background: #44127a;
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 38px;
  font-weight: 700;
  margin: 0 auto 28px;
}

/* Texto segunda tarjeta */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .zsvbe-auth-card:last-child p {
  color: #4c4c63 !important;
  font-size: 16px !important;
  line-height: 1.55 !important;
  margin: 0 auto 30px !important;
  max-width: 310px !important;
}

/* Contenedor del formulario */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-login-widget-form,
.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-login-form-inner {
  width: 100% !important;
}

/* Labels */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-label,
.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-rememberme-label {
  color: #303047 !important;
  font-size: 15px !important;
  font-weight: 700 !important;
}

/* Espaciado labels */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-username-label,
.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-password-label {
  margin-bottom: 8px !important;
}

/* Inputs */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-text-field {
  width: 100% !important;
  height: 52px !important;
  border: 1px solid #dddddd !important;
  border-radius: 12px !important;
  background: #ffffff !important;
  color: #303047 !important;
  font-size: 15px !important;
  padding: 0 16px !important;
  outline: none !important;
  box-sizing: border-box !important;
  transition: all 0.2s ease !important;
}

/* Focus inputs */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-text-field:focus {
  border-color: #269d95 !important;
  box-shadow: 0 0 0 3px rgba(38, 157, 149, 0.14) !important;
}

/* Separación entre campos */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-username-input {
  margin-bottom: 20px !important;
}

.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-password-input {
  margin-bottom: 16px !important;
}

/* Recuérdame */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-remember-me {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin: 8px 0 24px !important;
}

.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-remember-checkbox input {
  width: 16px !important;
  height: 16px !important;
  accent-color: #269d95 !important;
}

.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-rember-label {
  color: #4c4c63 !important;
  font-weight: 500 !important;
}

/* Botón Acceder */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-login-submit {
  margin-top: 8px !important;
}

.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-login-form-submit {
  width: 100% !important;
  height: 50px !important;
  border: none !important;
  border-radius: 10px !important;
  background: #269d95 !important;
  color: #ffffff !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
}

.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-login-form-submit:hover {
  background: #1f867f !important;
  transform: translateY(-1px) !important;
}

/* Links inferiores */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-forgot-pass-link,
.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-join-us-link {
  text-align: center !important;
  margin-top: 14px !important;
}

.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-forgot-pass-link a,
.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-join-us-link a {
  color: #269d95 !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  text-decoration: none !important;
}

.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-forgot-pass-link a:hover,
.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-join-us-link a:hover {
  text-decoration: underline !important;
}

/* Botón Ir al registro */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .zsvbe-auth-actions {
  display: flex !important;
  justify-content: center !important;
  width: 100% !important;
  margin-top: 0 !important;
}

.zsvbe-auth-grid:has(.swpm-login-widget-form) .zsvbe-auth-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 190px !important;
  height: 48px !important;
  padding: 0 26px !important;
  border-radius: 10px !important;
  background: #bdd719 !important;
  color: #ffffff !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  transition: all 0.2s ease !important;
}

.zsvbe-auth-grid:has(.swpm-login-widget-form) .zsvbe-auth-btn:hover {
  background: #aeca14 !important;
  transform: translateY(-1px) !important;
}

/* Mensaje de error / acción */
.zsvbe-auth-grid:has(.swpm-login-widget-form) .swpm-login-action-msg {
  margin-top: 14px !important;
  text-align: center !important;
  color: #cc0000 !important;
  font-size: 14px !important;
}

/* Responsive tablet */
@media (max-width: 900px) {
  .zsvbe-auth-grid:has(.swpm-login-widget-form) {
    grid-template-columns: 1fr !important;
    max-width: 620px !important;
    gap: 28px !important;
  }

  .zsvbe-auth-grid:has(.swpm-login-widget-form) .zsvbe-auth-card:last-child {
    min-height: auto !important;
  }
}

/* Responsive móvil */
@media (max-width: 600px) {
  .zsvbe-auth-grid:has(.swpm-login-widget-form) {
    margin: 35px auto 70px !important;
    padding: 0 18px !important;
  }

  .zsvbe-auth-grid:has(.swpm-login-widget-form) .zsvbe-auth-card {
    padding: 32px 24px !important;
    border-radius: 16px !important;
  }

  .zsvbe-auth-grid:has(.swpm-login-widget-form) .zsvbe-auth-card:first-child::before,
  .zsvbe-auth-grid:has(.swpm-login-widget-form) .zsvbe-auth-card:last-child h3 {
    font-size: 29px !important;
  }

  .zsvbe-auth-grid:has(.swpm-login-widget-form) .zsvbe-auth-card:first-child > p,
  .zsvbe-auth-grid:has(.swpm-login-widget-form) .zsvbe-auth-card:last-child p {
    font-size: 15px !important;
  }
}/* End custom CSS */