@import url('https://fonts.googleapis.com/css2?family=Slackey&display=swap');

:root {
    --ancho-caja: 1512px;
    --padding: 2.5rem;
    --padding-x2: 5rem;
    --padding-x3: 7.5rem;
    --verde: #DCE7D1;
    --negro: #3a362e;
    --gris-suave: #fsf3f1;
    --font-xxs: 12px;
    --font-xs: 14px;
    --font-s: 18px;
    --font-m: 22px;
    --font-l: 28px;
    --font-xl: 36px;
    --margin-m: 50px;
    --gap: 7rem;
}

* {
    box-sizing: border-box !important;
    color: var(--negro)
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: 'Roboto', sans-serif;
  margin: 0px !important;
  line-height: 1.4
}

h1, h2, h3 {
    font-family: 'Slackey', cursive;
}

.versalitas {  
  font-family: 'Montserrat', sans-serif;
}


.hs_cos_wrapper {
    max-width: var(--ancho-caja);
    margin-left: auto;
    margin-right: auto;
}

.titulo {
  font-family: 'Montserrat', sans-serif;
  font-size: var(--font-s);
  font-weight: 500;   
  text-transform: uppercase;
  color: var(--negro);
  margin-bottom: 32px;
}

.eslogan {
  font-family: 'Slackey', serif;
  font-size: var(--font-xl) !important;
  font-weight: 600;
  color: var(--negro);
  margin-bottom: 40px;
}

.contenido {
  font-family: 'Roboto', sans-serif;
  font-size: var(--font-m);
  font-weight: 400;
  line-height: 1.3;
  color: var(--negro);
  list-style: none;
  padding: 0;
  margin: 0;
}








/* form */

.hs-opportunity {
    padding: var(--padding-x3) var(--padding-x2);
}
  .hs-opportunity__wrap{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--gap);
    align-items: start;
  }
.hs-opportunity__title {
  margin-bottom: 50px;
}
  .hs-opportunity__media{ 
      margin: 70px 0 0; 
}
  .hs-opportunity__img{ 
      width: 100%;
      height: auto;
}

  @media (max-width: 900px){
    .hs-opportunity__wrap{
        grid-template-columns: 1fr; gap: 28px;
    }
  }

/* ============================
   HUBSPOT FORMS (sin wrapper)
   ============================ */

/* Asegura que pillas el form real */
.hbspt-form form.hs-form {
  font-family: inherit !important;
  color: var(--negro) !important;
}

/* Separación entre campos */
.hbspt-form form.hs-form .hs-form-field {
  margin: 0 0 22px !important;
}

/* Label */
.hbspt-form form.hs-form label {
  display: block !important;
  margin: 0 0 10px !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  color:  var(--negro) !important;
}

/* Asterisco */
.hbspt-form form.hs-form .hs-form-required {
  margin-left: 2px !important;
  color:  var(--negro) !important;
}

/* Inputs / selects / textarea (estilo “caja gris” de la captura) */
.hbspt-form form.hs-form .input input.hs-input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]),
.hbspt-form form.hs-form .input select.hs-input,
.hbspt-form form.hs-form .input textarea.hs-input {
  width: 100% !important;
  box-sizing: border-box !important;
  background: #f3f3f3 !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 14px 16px !important;
  height: 52px !important;
  font-size: 15px !important;
  line-height: 1.2 !important;
  color:  var(--negro) !important;
  outline: none !important;
  box-shadow: none !important;
}

/* Placeholder */
.hbspt-form form.hs-form .input .hs-input::placeholder {
  color: #7a7a7a !important;
  opacity: 1 !important;
}

/* Textarea */
.hbspt-form form.hs-form .input textarea.hs-input {
  height: auto !important;
  min-height: 120px !important;
  resize: vertical !important;
}

/* --- Teléfono (select + input en línea) --- */
.hbspt-form form.hs-form .hs-fieldtype-intl-phone {
  display: flex !important;
  gap: 10px !important;
  align-items: stretch !important;
}

.hbspt-form form.hs-form .hs-fieldtype-intl-phone select.hs-input {
  width: 110px !important;
  flex: 0 0 110px !important;
}

.hbspt-form form.hs-form .hs-fieldtype-intl-phone input[type="tel"].hs-input {
  flex: 1 1 auto !important;
  width: auto !important;
}
.hbspt-form form.hs-form  .hs-field-desc {
    margin-bottom: 10px;
}

/* --- Checkboxes --- */
.hbspt-form form.hs-form .hs-form-booleancheckbox-display {
  display: flex !important;
  gap: 10px !important;
  align-items: flex-start !important;
  font-size: 13px !important;
  line-height: 1.3 !important;
  color:  var(--negro) !important;
}
.hbspt-form form.hs-form ul {
    list-style-type: none;
    padding-left: 0px;
}

.hbspt-form form.hs-form ul li span {
    margin-left: 0px !important;
}

.hbspt-form form.hs-form input[type="checkbox"].hs-input {
  width: 14px !important;
  height: 14px !important;
  margin-top: 3px !important;
}

/* Footer legal */
.hbspt-form form.hs-form .hs-form__field__footer {
  margin-top: 8px !important;
  font-size: 13px !important;
  color:  var(--negro) !important;
}

/* --- Botón: borde, fondo transparente --- */
.hbspt-form form.hs-form .actions {
  margin-top: 14px !important;
}

.hbspt-form form.hs-form input[type="submit"].hs-button {
  appearance: none !important;
  background: var(--verde) !important;
  border: 1px solid  var(--negro) !important;
  color:  var(--negro) !important;
  padding: 14px 18px !important;
  min-width: 260px !important;
  height: auto !important;
  font-size: 14px !important;
  letter-spacing: .03em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
}

.hbspt-form form.hs-form input[type="submit"].hs-button:hover {
  background:  var(--negro) !important;
  color: #fff !important;
}

/* Errores */
.hbspt-form form.hs-form .hs-error-msg,
.hbspt-form form.hs-form .hs-error-msgs label {
  color: #b00020 !important;
  font-size: 12px !important;
  margin-top: 6px !important;
}














/* banner alto */
.banner_tagline {
    margin-top: 0px;
}

.banner_icon_grid {
    margin-top: var(--margin-m)
}

.banner_icon_grid_item {
    font-size: var(--font-s);
}

.banner_icon_grid_item p {
    margin-top: 0px;
    margin-bottom: 0px;
}


.banner_container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 930px;
  width: 100%;
  
  background-image: url("https://2875686.fs1.hubspotusercontent-na1.net/hubfs/2875686/Kora%20Volta/Landing%20captaci%C3%B3n%20-%20Kora%20Volta/drapper%20largo.png");
 background-size: cover;
background-position: center;
  background-repeat: no-repeat;
}

/* Columna imagen */
.banner_col_derecha {
  display: flex;
  justify-content: center;  /* centra horizontal */
  align-items: center;      /* centra vertical */
}

.banner_col_derecha img {
  width: 70%;   
  height: auto;  
}

/* Columna contenido */
.banner_col_izquierda {
  padding: var(--padding) var(--padding-x2) !important;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.banner_col_izquierda .eslogan {
  color: #788E66;
}

/* Grid de iconos */
.banner_icon_grid {
  list-style: none;
  padding: 0;
  margin: 0px 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem 2rem;
}

.banner_icon_grid_item {
  display: flex;
  align-items: center;
  gap: 20px;
  font-size: var(--font-s);
  line-height: 1.4;
}

.banner_icon_grid_item img {
  width: 32px;
  height: 32px;
  object-fit: contain;
  flex-shrink: 0;
}

/* Texto destacado */
.banner_text {
  margin-bottom: 20px;
  padding: 0.75rem 0.75rem;
  border: 1px solid var(--negro);
  font-size: var(--font-s);
  text-transform: uppercase;
  width: fit-content;
}

/* Icono final */
.banner_icon_final {
  display: flex;
  align-items: center;
  gap: 1rem;
  font-size: var(--font-xs);
}

.banner_icon_final img {
  width: 60px;
  height: auto;
}
.banner_icon_final img[src=""],
.banner_icon_final img:not([src]) {
  display: none;
}

/* Responsive */
@media (max-width: 800px) {
  .banner_container {
    grid-template-columns: 1fr;
    padding: 2rem 0;
    margin-bottom: 2rem;

    min-height: 110vh; /* modifica alto */
    align-self: start;
  }

  .banner_col_izquierda {
    padding: 2rem 0rem;
  }

  .banner_tagline {
    font-size: 0rem;
  }
}




/* banner simple */
.banner_simple {
  padding: var(--padding-x2);
  text-align: center;
}

.texto_banner_simple {
  max-width: 1000px;
  margin: 0 auto var(--padding);
  font-size: var(--font-m);
}

/* Botón */
.boton_form {
  display: inline-flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.3rem;
  border: 1px solid var(--negro);
  text-decoration: none;
  color: var(--negro);
  text-transform: uppercase;
  font-size: var(--font-m);
  background-color: var(--verde);
  transition: background-color 0.2s ease, color 0.2s ease;
}

.boton_form img {
  width: 29px;
  height: auto;
  object-fit: contain;
}

/* Responsive */
@media (max-width: 768px) {
  .banner_simple {
    padding: 3rem 1.5rem;
  }

  .texto_banner_simple {
    font-size: 0.95rem;
  }
}





/* iconos ventajas */

.ventajas_container{
  padding: var(--padding-x2);
  text-align: center;
}

/* Headline */
.ventajas_eslogan{
  margin: var(--margin-m);
}

/* mapa */
/* mapa */
.mapa_container img {
        max-width: 100%;
  background-color:#DCE7D1
}


/* Grid */
.grid_ventajas{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 60px;
  margin: 100px auto 50px auto;
}


.ventaja_icono{
  height: auto;
  object-fit: contain;
  margin-bottom: 1rem;
  background-color: #fff;
  margin-top: -65px;
  padding: 20px;
  max-width: 99px;
}

.ventaja_titulo{
  font-family: 'Libre Baskerville', serif;
  font-size: 32px;
  font-weight: 600;
  margin: 0px;
  margin-bottom: 5px;
}

/* si quieres “tono verde” del ejemplo */
.ventaja_titulo{
  color: #000000;
}

.ventaja_descripcion{
    font-size: var(--font-m)
}

/* Texto inferior */
.ventajas_contenido{
  max-width: 1000px;
  margin: 0 auto var(--margin-m) auto;
}


/* Responsive */
@media (max-width: 980px){
  .grid_ventajas{
    grid-template-columns: 1fr;
    max-width: 520px;
  }

  .ventajas_eslogan{
    font-size: 2rem;
    margin-bottom: 2.5rem;
  }

  .ventaja_item{
    padding: 2rem 1.5rem 1.75rem;
  }
}




/* grid cifras */
.cifras_cajas_container{
  background: var(--verde);
  padding: var(--padding-x2);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--gap);
  align-items: start;
}

.cifras_cajas_logo_kategora{
  
  margin: 100px 0 30px;
}

.cifras_cajas_imagen_final{
  width: 110%;
  height: auto;
  display: block;
  margin-top: 1.5rem;
  transform: translate(-30px);
  margin-bottom: -200px;
}

/* Grid derecha */
.grid_cifras_cajas{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.75rem 2rem;
  align-content: start;
}

/* Caja individual */
.cifras_caja_individual{
  border: 1px solid var(--negro);
  background: rgba(255,255,255,.5);
  min-height: 120px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
}

.cifras_caja_descripcion{
  margin: auto;
  padding: .8rem 1rem .65rem;
  font-size: var(--font-xxs);
  letter-spacing: .08em;
  text-transform: uppercase;
}

.cifras_caja_individual hr{
  width: 100%;
  margin: 0;
  border: 0;
  border-top: 1px solid var(--negro);
}

.cifras_caja_valor{
  font-family: 'Libre Baskerville', serif;
  margin: 0;
  padding: 2rem 1rem 2rem;
  font-size: 2.2rem;
  line-height: 1;
  font-weight: 600;
}

/* Responsive */
@media (max-width: 980px){
  .cifras_cajas_container{
    grid-template-columns: 1fr;
    gap: 2.5rem;
    padding: 4rem 1.5rem;
  }

  .cifras_cajas_eslogan{
    font-size: 2.1rem;
  }

  .grid_cifras_cajas{
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }

  .cifras_caja_valor{
    font-size: 2rem;
  }
}


/* dossier */
.dossier_container{
  background: #fff;
  padding: 200px var(--padding-x2) var(--padding-x2);
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 4rem;
  align-items: center;
}

/* Col izquierda */
.dossier_col_izquierda{
  text-align: left;
  max-width: 560px;
}

.dossier_contenido {
    margin-bottom: var(--margin-m);
}


/* Col derecha */
.dossier_col_derecha{
  display: flex;
  justify-content: center;
  align-items: center;
}

.dossier_imagen{
  width: 100%;
  margin-bottom: -150px;
}

/* Responsive */
@media (max-width: 980px){
  .dossier_container{
    grid-template-columns: 1fr;
    padding: 4rem 1.5rem;
    gap: 2.5rem;
  }

  .dossier_eslogan{
    font-size: 2.2rem;
  }

  .dossier_col_izquierda{
    max-width: 100%;
  }

  .dossier_col_derecha{
    order: 2;
  }
}

/* faqs */
.faqs-kora {
    background-color: #DCE7D1;
    color: #fff;
    padding: var(--padding-x2);
    margin-bottom: 0px;
}

.faqs-kora svg *  {
    stroke: #fff
}

.caja-faq {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.font-big.mayus {
  color: var(--negro);    
}

.faq-kora img {
fill: #fff;
}

.caja-faq ul {
  padding-left: 0px !important;
}
/* FAQS */
.faq-icon {
    margin-right: .5rem;
    position: relative;
}
.faq-icon img {
    transition: transform .3s;
    position: absolute;
    top: 15px;
}

.faq-kora.abierto .respuesta-faq {
    display: block !important;
}
.faq-icon-giratorio {
    transform: rotate(90deg);
}
.faq-kora.abierto .faq-icon-giratorio {
    transform: rotate(0deg);
}

.pregunta-faq {
    color: var(--negro);
     font-family: 'Roboto', sans-serif;
    text-transform: none;
    font-size: var(--font-m) !important;
}

.respuesta-faq {
    font-size: var(--negro);
    color: var(--negro) !important;
  font-family: Roboto', serif;
    font-weight: 300 !important;
    font-stretch: 100%;
    margin-bottom: 1.5rem;
    margin-top: .5rem
}

.faq-kora {
    border-top: 1px solid white;
    padding: .5rem 0 .6rem;
    display: flex;
    cursor: pointer;
    user-select: none;
    /*padding: 1rem 0;*/    
    gap: 1rem;
    width: 100%;
    > img {
        position: relative;
    }
    > div {
        align-self: start;
    }
}

.pregunta-faq.font-mid {
    font-size: 18px;
}
.respuesta-faq {
    display: none;
}


@media (max-width: 1280px) {
    /*faq*/
    .pregunta-faq.font-mid {
        font-size: 18px !important;
    }

}

@media (max-width: 780px) {

  /*faqs*/
  .caja-faq {
    gap: 0 !important;
  }
}


/* footer */
.footer_nav {
  padding: var(--padding) var(--padding-x2);
  gap: 70px;
}

.footer_nav * {
  color: #000 !important;
  font-family: "Poppins", sans-serif;
}

.footer_nav img {
  width: 80px;
}

.footer_contacto {
  font-size: var(--font-s);
  font-weight: 300;
}

.footer_politicas {
  font-size: var(--font-xs);
  font-weight: 300;
}


/* mapa */

.mapa_container {
    position: relative;
    height: 1300px;
    padding-bottom: 5px;
    background-color: #DCE7D1;
    text-align: center;
}
.mapa_texto {
    max-width: 60%;
    margin: 0 auto; /* centra horizontalmente */
    transform: translateY(-30px); /* 🔼 sube */
    text-align: center;
}
.mapa_image.mobile {
  display: none;
}




/* SLIDER */

.slider_kategora {
    margin: var(--padding-x2);
    position: relative;
}
.slider_text {
    text-align: center;
}

.slider_container {
  overflow: hidden;
  width: 100%;
    max-width: 1121px;
    margin: 0 auto;
}

.slider_track {
  display: flex;
  transition: transform 0.3s ease;
  max-width: 100%;
}

.slider_slide {
  flex: 0 0 100%;
  width: 100%;
  object-fit: cover;
}

/* Miniaturas */
.slider_miniaturas {
  display: flex;
  gap: 8px;
  margin-top: 16px;
  justify-content: center;
  flex-wrap: wrap;
}
.slider_miniaturas img {
    width: 150px
}

.slider_miniatura {
  cursor: pointer;
  opacity: 0.5;
}

.slider_miniatura.is-active {
  opacity: 1;
  outline: 2px solid var(--negro);
}

/* flechas */
.slider_flechas {
  position: absolute;
  inset: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  pointer-events: none;
  z-index: 5;
}

.slider_flechas a {
  pointer-events: auto;
  width: 48px;
  height: 48px;
  background: var(--verde); /* verde */
  color: var(--negro);
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  line-height: 1;
  transition: background 0.2s ease;
}

/* separación lateral */
.slider_flechas a.control_prev {
  margin-left: 16px;
}

.slider_flechas a.control_next {
  margin-right: 16px;
}

.slider_flechas a:hover {
  background: #e6d6be;
}


@media (max-width: 767px) {
  .slider_kategora {
    margin-top: 60px;
}
  .slider_miniaturas {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;

    -ms-overflow-style: none;  /* IE / Edge */
    scrollbar-width: none;     /* Firefox */
  }

  .slider_miniaturas::-webkit-scrollbar {
    display: none;             /* Chrome / Safari */
  }
    .slider_flechas a {
        width: 36px;
        height: 36px;
    }
    
    
    
}









@media (max-width: 1250px) {
    
    .cta-hero li:before {
        content: "";
    }
    .cifras_cajas_imagen_final {
        margin-bottom: 0px;
        max-width: 100%;
        transform: translateX(0px);
    }
    .dossier_col_izquierda {
        text-align: center;
    }
    .faqs-kora .dos-columnas {
        gap: 20px !important;
    }
    
  .mapa_container img {
    width: 100%;
    height: auto;
    display: block;
    }
    .mapa_texto {
        position: static;
        max-width: 100%;
        text-align: center;
        max-width: 700px;
        margin: 10px auto;
    }
    .mapa_container {
        display: flex;
        flex-direction: column-reverse;
        overflow: hidden;
    }
    
}

@media (max-width: 767px) {
  body {
    line-height: 1.3;
  }
    
    
    /* misc */
    
    :root {
        --padding: 10px;
        --padding-x2: 20px;
        --padding-x3: 50px;
        
        --font-xxs: 12px;
        --font-xs: 12px;
        --font-s: 14px;
        --font-m: 16px;
        --font-l: 24px;
        --font-xl: 32px;
        
        --margin-m: 50px;
        --gap: 80px;
    }
    .titulo {
        margin-bottom: 20px;
    }
    .eslogan {
        margin-bottom: 20px;
        margin-top: 0px;
        font-size: var(--font-l) !important;
    }
    
    .boton_form {
        padding: 6px 12px;
    }
    
    /*header*/
    .header_kategora {
        flex-direction: column;
        gap: 30px;
        height: fit-content !important;
        padding: 20px !important;
    }
    .header_kategora .logo_kategora {
        max-width: 200px;
    }
    .header_kategora .tlf_kategora {
        font-size: 24px;
    }
    
    
    /* hero */
    .texto-hero {
        padding: 0px !important;
    }
    .title-hero p {
        font-size: 16px !important
    }
    .claim-hero h3 {
        font-size: 24px !important;
      line-height: 1.2;
    }
    .cta-hero * {
        font-size: 16px
    }
  
    /*form*/
  #formulario {
    margin-top: 50px;
  }
    /*banner alto*/
    .banner_container {
        display: flex;
        flex-direction: column-reverse;
    }
   .banner_title {
        margin-bottom: 30px;
    }
    .banner_col_izquierda {
        padding: 40px 20px !important;
    }
    
    
    /* banner simple */
    .texto_banner_simple {
        margin-bottom: 30px;
    }
    
    /* mapa */
    .mapa_texto {
        margin: 0 20px;
        text-align: left;
        font-size: 14px;   
        line-height: 1.4; 
    }
  .mapa_texto * {
    font-size: 16px !important;
}
      .mapa_texto .eslogan {
        font-size: 24px !important;
    }
  .mapa_container {
    height: 760px;
}
    .mapa_image.desktop {
    display: none;
  }
  .mapa_image.mobile {
    display: block;
  }
  
    /*ventajas*/
    .ventajas_container {
        padding: 60px 20px;
        
    }
    .ventaja_item {
        padding: 10px;
    }
    .ventajas_eslogan {
        margin: 0px;
    }
    .grid_ventajas {
        margin-top: 50px;
        gap: 40px;
    }
    .ventaja_icono {
        width: 55px;
        padding: 10px;
        margin-top: -40px;
    }
    .ventaja_titulo {
        font-size: 24px;
    }
    
    /* cifras grid */
    .cifras_cajas_logo_kategora {
        margin: 30px 0;
    }
    .cifras_cajas_imagen_final {
        margin-top: 0;
    }
    
    
    /* dossier */
    .dossier_imagen {
        margin-bottom: -30px;
    }
    .faqs-kora .dos-columnas {
        grid-template-columns: 1fr
    }
    

}

/* ===== NUEVAS VENTAJAS CON IMÁGENES ===== */

.grid_ventajas {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  align-items: start;
}

.ventaja_item {
  height: 720px;
  overflow: hidden;
}

.ventaja_img {
width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
  display: block;
}

/* móvil */
@media (max-width: 980px){

  .grid_ventajas {
    grid-template-columns: 1fr;
  }

  .ventaja_item {
    height: auto;          
    aspect-ratio: 3 / 4;  
    overflow: hidden;
  }

  .ventaja_img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    display: block;
  }
}

/* slide base responsive */

@media (max-width: 767px) {
  .slider_container {
    max-width: 100% !important;
    width: 100% !important;
    height: 380px; 
    overflow: hidden;
  }


 .slider_track {
    height: 100%; 
  }
  
  .slider_slide {
    height: 100%;
  }
  .slider_eslogan {
    font-size: 30px !important; /* ajusta aquí */
    line-height: 1.3;
  }
  
   
  }

  .slider_slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
    .slider_kategora {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

}