/* Labels negros en sección participar */
#participa label {
  color: #232627 !important;
}

/*********************** Imagen Leche Oversize ***********************/
.imgLeche-oversize {
  max-width: 1400px;
  width: 130%;
  position: absolute;
  right: -120px;
  top: -220px;
  z-index: 20;
  filter: drop-shadow(0 8px 32px rgba(0, 0, 0, 0.18));
  pointer-events: none;
}

/* Forzar icono usuario blanco y fondo negro */

:root {
  --tph-negro: #232627;
  --tph-azul: #71caf3;
  --tph-azul-oscuro: var(--tph-azul);
  --tph-gris-oscuro: #1d1d1b;
  --tph-gris-medio: var(--tph-gris-claro);
  --tph-gris-claro: #f2f2f2;
  --tph-blanco: white;
  --tph-cuenta-atras: #e8871b;
  /* En esta creatividad no hay verde/rojo de marca: se mapean a acento */
  --tph-verde: var(--tph-cuenta-atras);
  --tph-rojo: var(--tph-cuenta-atras);
  --tph-form-label: #000000;
  --tph-form-placeholder: #868686;
  --tph-form-input: #000;
  --tph-form-bg: #000000;
  --tph-font-body: 'georgia';
  --tph-font-stempel: 'stempel_garamond_pro_bold_italic';


}

.alert-error {
  border: #f70000 solid 1px !important;
  margin-bottom: 0.5rem;
}

.pie-imagen {
  position: absolute;
  font-size: 0.8rem;
  color: rgb(99, 99, 99);
  right: 10px;
  top: 0;
}

.bg-promo {
  background-color: transparent;
}

.bg-azul {
  background-color: var(--tph-azul);
}

.bg-negro {
  background-color: var(--tph-negro);
}

.bg-gris-oscuro {
  background-color: var(--tph-gris-oscuro);
}

.bg-verde {
  background-color: var(--tph-verde);
}

.bg-gris-claro {
  background-color: var(--tph-gris-claro);
}

.bg-gris-medio {
  background-color: var(--tph-gris-medio);
}

.bg-blanco {
  background-color: var(--tph-blanco);
}

.bg-promo-menu {
  background-color: rgb(255, 255, 255);
}

.color-promo {
  color: rgb(255, 255, 255);
}

.color-azul {
  color: var(--tph-azul);
}

.color-negro {
  color: var(--tph-negro);
}

.color-verde {
  color: var(--tph-verde);
}

.color-verde {
  color: var(--tph-verde);
}

.color-gris-claro {
  color: var(--tph-gris-claro);
}

.color-gris-medio {
  color: var(--tph-gris-medio);
}

.color-blanco {
  color: var(--tph-blanco);
}

.cursor-blocked {
  cursor: not-allowed;
}

.cursor-pointer {
  cursor: pointer;
}



.btn-primary {
  background-color: #1b2122;
  color: #fff;
  border: solid 1px #1b2122;
  border-radius: 5rem !important;
}

.btn-primary:hover {
  background-color: #1b2122;
  color: rgb(255, 255, 255);
  border: solid 1px #ffffff;
}

.btn-primary:focus {
  background-color: #1b2122;
  color: rgb(0, 0, 0);
}

.btn-formulario {
  background-color: var(--tph-negro);
  color: var(--tph-blanco);
  border: solid 3px var(--tph-azul);
  font-family: var(--tph-font-stempel);
  text-align: center;
  border-radius: 5rem !important;
  box-sizing: border-box;
  display: block;
  width: 100%;
  padding: 0.75rem 1.25rem;
  font-size: 2rem;
}

@media (min-width: 1024px) and (max-width: 1199.98px) {
  .btn-formulario {
    padding: 0.5rem 26rem;
  }
}

@media (min-width: 1200px) {
  .btn-formulario {

    padding: 0.5rem 26rem;
  }
}

@media (min-width: 1300px) {
  .btn-formulario {
    padding: 0.5rem 26rem;
  }
}


.btn-formulario:hover {
  background-color: #1b2122;
  color: rgb(255, 255, 255);
  border: solid 1px #ffffff;
}

.btn-formulario:focus {
  background-color: #1b2122;
  color: rgb(0, 0, 0);
}

.btn-promo {
  background-color: rgb(0, 0, 0);
  color: #fff;
}

.btn-promo:hover {
  background-color: rgb(255, 255, 255);
  color: rgb(0, 0, 0);
}

.btn-promo:focus {
  background-color: rgb(255, 255, 255);
  color: rgb(0, 0, 0);
}

.btn-round-negativo {
  border-radius: 1.3rem !important;
  background-color: rgb(255, 255, 255);
  color: rgb(0, 0, 0);
}

.font-georgia {
  font-family: Georgia, serif;
}

.txtStempel {
  font-family: 'Stempel Garamond Pro Bold Italic', serif;
}

.txtPopulaire {
  font-family: 'Populaire', sans-serif;
}

.font-arial {
  font-family: Arial, Helvetica, sans-serif;
}

.gradiente-texto {
  background-clip: text;
  -webkit-background-clip: text;
  /* Para navegadores basados en WebKit, como Chrome y Safari */
  color: transparent;
  background-image: linear-gradient(to right, #00B09F, #009295);
}

.cursor-pointer {
  cursor: pointer;
}

/********************************************************************* scrollbar css *********************************************************/
/* width */
::-webkit-scrollbar {
  width: 5px;
}

/* Track */
::-webkit-scrollbar-track {
  background: #f1f1f1;
}

/* Handle */
::-webkit-scrollbar-thumb {
  background: rgba(209, 232, 228, 1);
}

/* Handle on hover */
::-webkit-scrollbar-thumb:hover {
  background: #e3d7c6;
}

/********************************************************************* fuentes *********************************************************/


@font-face {
  font-family: 'Georgia';
  src: url('../../../fonts/georgia.woff') format('woff');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Populaire';
  src: url('../../../fonts/POPULAIRE.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Stempel Garamond Pro Bold Italic';
  src: url('../../../fonts/stempel-garamond-pro-bold-italic.woff') format('woff');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

body {
  font-family: Arial, Helvetica, sans-serif;
  color: black;
  background-color: #fff;
  overflow-x: hidden;
}

a {
  color: #1b2122;
}

.border-left {
  border-left: #009295 1px solid;
}

.border-right {
  border-right: #009295 1px solid;
}

.container-fluid {
  max-width: 1980px !important;
}

/********************************************************************************** MENU  *******************************************************************************/

#mainMenu {
  background-color: var(--tph-azul);
}

.navbar-light .navbar-nav .nav-link {
  color: #000000 !important;
}

.navbar-light .navbar-brand {
  color: #000000;
}

.active {
  text-decoration: underline;
}

.btn-menu {
  display: inline-block;
  font-weight: 400;
  line-height: 1.5;
  color: #1466b8;
  text-decoration: none;
  vertical-align: middle;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  background-color: transparent;
  border: 1px solid transparent;
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  border-radius: 0.25rem;
  transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out;
  background-color: #1b2122;
  color: #fff;
  border: solid 1px #1b2122;
  border-radius: 5rem !important;
}

.bg-menu {
  background-color: var(--tph-azul);
  color: var(--tph-gris-claro) !important;
}

.bg-menu-scroll {
  background-color: var(--tph-azul);
  color: var(--tph-gris-claro);
}

/********************************************************************************** header  *******************************************************************************/

#inicio {
  background-color: var(--tph-azul);
}

.h1Title {
  font-size: 5rem;
  line-height: 1;
}
.h2-relajate {
  font-size: 1.5rem;
}
.btnMiExperiencia {
  background-color: var(--tph-negro);
  color: var(--tph-blanco);
  font-size: 1.4rem;
  border: none;
  border-radius: 5rem;
  display: block;
  margin-left: auto;
  margin-right: auto;
  padding: 0.5rem 1rem;
  text-decoration: none;
  text-align: center;
  margin-bottom: 2rem;
}

.btnMiExperiencia a {
  text-decoration: none;

}

.img-movil {
  margin-top: 50px;
  width: 81%;
  margin-left: 21px;
}

.p-movil {
  margin-top: 20px;
  margin-left: 21px;
  font-size: 1.7rem;
  line-height: 1.15;
  text-align: center !important;
}

.lead {
  line-height: 1.15;
  text-align: center;
}

/********************************************************************************** mecánica  *******************************************************************************/

.txtComoParticipar {
  font-size: 6rem;
  margin-top: 10px;
}

.txtSigueLosPasos {
  font-size: 3rem;
}

.h3TituloPasos {
  font-size: 2.5rem;
}

.pPasos {
  font-size: 1rem;
}

/********************************************************************************** regalo  *******************************************************************************/

#regalo {
  background-color: var(--tph-azul);
  padding: auto;
  font-family: var(--tph-font-stempel);
}

.m-vbg {
  width: 100%;
  margin-top: auto;
  margin-bottom: auto;
  border-radius: 1rem;
}
.flickity-page-dots{
  display: none;
}
.btnParticipar {
  color: var(--tph-negro);
  background-color: var(--tph-verde);
  border-radius: 5rem;
  border: none;
  font-size: 1.8rem;
  padding: 0.5vh 4vh;
  font-weight: bold;
}

/********************************************************************************** countdown  *******************************************************************************/

/* Panel cuenta atrás (antes de FECHA_INICIO) */
.countdown-panel {
  background-color: rgba(255, 255, 255, 0.92);
  border: 2px solid rgba(35, 38, 39, 0.08);
  border-radius: 1.25rem;
  padding: 1.5rem;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.08);
  backdrop-filter: blur(6px);
}

@media (min-width: 768px) {
  .countdown-panel {
    padding: 2.25rem;
  }
}



.countdown-title {
  font-size: 2rem;
}

.countdown-subtitle,
.countdown-help {
  color: rgba(35, 38, 39, 0.85);
  font-size: 1.05rem;
  line-height: 1.35;
}

#countdown {
  margin-left: auto;
  margin-right: auto;
  max-width: 560px;
}


#countdown .wrapper {
  text-align: center;
}

#countdown .time {
    color: var(--tph-azul);
    font-family: var(--tph-font-stempel);
  font-size: 3.5rem;
  padding: 0.25rem;
}

#countdown .label {
  font-family: var(--tph-font-stempel);
  font-size: 1rem;
  display: block;
  color: var(--tph-azul);
  /* text-shadow     : 2px 2px #FF0620; */
}

#countdown svg {
  font: bold 5rem;
  width: 100%;
  height: 120px;
}

#countdown text {
  fill: none;
  stroke: var(--tph-azul);
  stroke-width: 6px;
  stroke-linejoin: round;
  /* text-shadow     : 2px 2px #FF0620; */
  animation: 2s pulsate infinite;
}

@keyframes pulsate {
  50% {
    text-shadow: 4px 4px var(--tph-azul);
  }
}

/* Badge icono usuario en menú */
.menu-user-badge {
  width: 20px;
  height: 20px;
}

/********************************************************************************** participa  *******************************************************************************/

.pastilla-round {
  border-radius: 0rem 5rem 5rem 0rem;
}

form#formReg_l label {
  display: block;
  color: #fff;
}


form#formReg_l .form-control {
  color: rgb(255, 255, 255)!important;
  background-color: #000000 !important;
  border-radius: 5rem;

  font-size: 1rem;
}

form#formReg_l .form-select {
  color: rgb(255, 255, 255)!important;
  background-color: #000000 !important;
  border-radius: 5rem;

  font-size: 1rem;
}

form#formReg_l label.custom-control-label {
  display: block !important;
  color: var(--tph-negro) !important;
  font-size: 1rem;
}

form#formReg_l .form-control::placeholder {
  /* Chrome, Firefox, Opera, Safari 10.1+ */
  color: rgb(255, 255, 255);
  opacity: 1;
  /* Firefox */
}

form#formReg_l .form-control:-ms-input-placeholder {
  /* Internet Explorer 10-11 */
  color: rgb(0, 0, 0);
}

form#formReg_l .form-control::-ms-input-placeholder {
  /* Microsoft Edge */
  color: rgb(0, 0, 0);
}

form#formReg_l .form-select::placeholder {
  /* Chrome, Firefox, Opera, Safari 10.1+ */
  color: rgb(0, 0, 0);
  opacity: 1;
  /* Firefox */
}

form#formReg_l .form-select:-ms-input-placeholder {
  /* Internet Explorer 10-11 */
  color: rgb(0, 0, 0);
}

form#formReg_l .form-select::-ms-input-placeholder {
  /* Microsoft Edge */
  color: rgb(0, 0, 0);
}

form#formReg_l a {
  color: #000000;
}

form option {
  color: #ffffff;
  font-size: 1rem;
}

form option:hover {
  background-color: #ffffff;
}

form .input-group-text {
  background: #fff;
  border: none;
  border-radius: 10rem !important;
}

form .form-check-input:checked {
  background-color: #1b2122;
  border-color: #1b2122;
}

/********************************************************************************** contacto  *******************************************************************************/

.franja-decorativa {
  width: 100%;
  height: 28px;
  background-image: url('../../../../assets/img/template/leche-celta-regalo-26/franja.avif');
  background-repeat: repeat-x;
  background-size: auto 120%;
  background-position: top center;
  overflow: hidden;
  margin-top: 1.5rem;
}

.tel_promo a {
  text-decoration: none;
}

.email_contacto a {
  text-decoration: none;
}

.pText {
  color: var(--tph-negro);
  font-family: Georgia, 'Times New Roman', Times, serif;
}

/********************************************************************************** footer  *******************************************************************************/

footer {
  background-color: var(--tph-negro);
}

footer ul {
  list-style: none;
}

footer a {
  color: rgb(255, 255, 255);
  font-size: 0.8rem;
}

footer a:hover {
  text-decoration: underline;
  color: rgb(255, 255, 255)
}

footer .small {
  color: rgb(255, 255, 255);
  font-size: 0.7rem;
}

footer img .small {
  max-width: 1.5rem;
}

.logoBonduellPie {
  max-width: 8rem;
}

.pull-right {
  float: right;
}

.xs-d-flex {
  flex-direction: column;
}

/********************************************************************************** Modal Área Personal  *******************************************************************************/

.modal-area-personal {
  background-color: var(--tph-negro);
  border: none;
  border-radius: 1.5rem;
  color: var(--tph-blanco);
  overflow: hidden;
}

.modal-area-personal .modal-header {
  padding: 1rem 1.5rem 0;
}

.btn-close-custom {
  filter: invert(1) grayscale(100%) brightness(200%);
  opacity: 0.7;
  transition: opacity 0.2s ease;
}

.btn-close-custom:hover {
  opacity: 1;
}

.modal-icon-wrapper {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--tph-negro) !important;
  color: var(--tph-blanco) !important;
  font-size: 1.6rem;
  margin: 0 auto;
}

.modal-title-custom {
  font-family: 'Hisense Medium', Arial, Helvetica, sans-serif;
  font-size: 1.5rem;
  color: var(--tph-blanco);
  margin-bottom: 0.25rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.modal-subtitle {
  font-family: 'Hisense Light', Arial, Helvetica, sans-serif;
  font-size: 0.9rem;
  color: rgba(255, 255, 255, 0.65);
  margin-bottom: 0;
}

.form-label-custom {
  display: block;
  font-family: 'Hisense Regular', Arial, Helvetica, sans-serif;
  font-size: 0.85rem;
  color: rgba(255, 255, 255, 0.8);
  margin-bottom: 0.4rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.form-control-custom {
  background-color: var(--tph-form-bg) !important;
  color: var(--tph-form-input) !important;
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 5rem !important;
  padding: 0.6rem 1.25rem;
  font-size: 0.95rem;
  font-family: 'Hisense Regular', Arial, Helvetica, sans-serif;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.form-control-custom:focus {
  border-color: var(--tph-azul);
  box-shadow: 0 0 0 3px rgba(9, 169, 175, 0.25);
  outline: none;
}

.form-control-custom::placeholder {
  color: var(--tph-form-placeholder);
  opacity: 1;
}

.password-wrapper {
  position: relative;
}

.password-wrapper .form-control-custom {
  padding-right: 3rem;
}

.password-toggle {
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  cursor: pointer;
  color: var(--tph-form-placeholder);
  font-size: 0.95rem;
  transition: color 0.2s ease;
  z-index: 5;
}

.password-toggle:hover {
  color: var(--tph-azul);
}

.recuperar-pass-link {
  font-family: 'Hisense Light', Arial, Helvetica, sans-serif;
  color: var(--tph-verde) !important;
  font-size: 0.85rem;
  text-decoration: none;
  transition: color 0.2s ease, text-decoration 0.2s ease;
}

.recuperar-pass-link:hover {
  color: var(--tph-azul) !important;
  text-decoration: underline;
}

.btn-acceso-custom {
  font-family: 'Hisense Medium', Arial, Helvetica, sans-serif;
  background: linear-gradient(135deg, var(--tph-azul), var(--tph-verde));
  color: var(--tph-negro);
  border: none;
  border-radius: 5rem;
  padding: 0.7rem 1.5rem;
  font-size: 1rem;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transition: opacity 0.2s ease, transform 0.15s ease;
}

.btn-acceso-custom:hover {
  opacity: 0.9;
  color: var(--tph-negro);
  transform: translateY(-1px);
}

.btn-acceso-custom:focus {
  box-shadow: 0 0 0 3px rgba(0, 254, 193, 0.3);
  color: var(--tph-negro);
}

.btn-acceso-custom:disabled {
  opacity: 0.65;
  transform: none;
}

.btn-acceso-custom .btn-text {
  display: inline;
}

.btn-cancelar-custom {
  font-family: 'Hisense Regular', Arial, Helvetica, sans-serif;
  background-color: transparent;
  color: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(255, 255, 255, 0.25);
  border-radius: 5rem;
  padding: 0.6rem 1.5rem;
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.btn-cancelar-custom:hover {
  background-color: rgba(255, 255, 255, 0.08);
  color: var(--tph-blanco);
  border-color: rgba(255, 255, 255, 0.45);
}

.alert-custom {
  background-color: rgba(247, 0, 0, 0.12);
  border: 1px solid rgba(247, 0, 0, 0.5);
  color: #ff6b6b;
  border-radius: 0.75rem;
  font-family: 'Hisense Light', Arial, Helvetica, sans-serif;
  font-size: 0.85rem;
}

/* Decorative gradient line at top of modal */
.modal-area-personal::before {
  content: '';
  display: block;
  height: 3px;
  background: linear-gradient(to right, var(--tph-azul), var(--tph-verde));
  border-radius: 1.5rem 1.5rem 0 0;
}

/* Modal backdrop */
.modal-backdrop.show {
  opacity: 0.7;
}

/* Responsive */
@media (max-width: 575.98px) {
  .modal-area-personal {
    border-radius: 1rem;
    margin: 0.5rem;
  }

  .modal-title-custom {
    font-size: 1.25rem;
  }

  .modal-icon-wrapper {
    width: 52px;
    height: 52px;
    font-size: 1.3rem;
  }

  .modal-area-personal .modal-body {
    padding-left: 1.25rem !important;
    padding-right: 1.25rem !important;
  }

  .modal-area-personal .modal-footer {
    padding-left: 1.25rem !important;
    padding-right: 1.25rem !important;
  }
}

/********************************************************************************** Area personal  *******************************************************************************/
.card-width {
  min-width: 10rem;
}

.flex-adapt {
  flex-direction: column !important;
}

/********************************************************************************** textos  *******************************************************************************/

/********************************************************************************** media query  *******************************************************************************/
@media (min-width: 768px) {}

@media (min-width: 992px) {}

@media (min-width: 1024px) {}

@media (min-width: 1200px) {
  .h1Title {
    font-size: 5rem;
    line-height: 1;
  }
.h2-relajate {
  font-size: 2rem;
  text-align: center;
}
  .btnMiExperiencia {
    margin-bottom: 0rem;
    font-size: 2rem;
  }

  .txtComoParticipar {
  font-size: 6rem;
  margin-top: 180px;
}
}
@media (min-width: 1400px) {
  .h1Title {
    font-size: 8rem;
    line-height: 1;
  }
.h2-relajate {
  font-size: 3rem;
  text-align: left;
}
  .btnMiExperiencia {
    margin-bottom: 0rem;
    font-size: 2rem;
  }
}

@media (min-width: 1600px) {}

.imgFranja {
  height: 28px;
  background-repeat: repeat-x;
  background-size: auto 120%;
  background-position: top center;
  overflow: hidden;
}