/* ============================= */
/* GLOBAL */
/* ============================= */

@media (max-width: 1200px){
  .section{
    padding: 72px 0;
  }

  .site-header{
    top: 20px;
  }

  .site-header::after{
    width: calc(100% - 64px);
  }

  .container{
    padding: 0 32px;
  }

  .main-nav{
    gap: 20px;
  }

  .nav{
    gap: 18px;
  }
}

@media (max-width: 1024px){
  .book-feature{
    grid-template-columns: 1fr;
  }

  .contacto-visual__inner{
    grid-template-columns: 1fr;
    gap: 48px;
  }
}

@media (max-width: 992px){
  .site-header{
    top: 16px;
  }

  .site-header::after{
    width: calc(100% - 48px);
    margin: 14px auto 0;
  }

  .container{
    padding: 0 24px;
  }

  .header-inner{
    min-height: 46px;
    gap: 16px;
  }

  .header-logo{
    max-width: 130px;
    height: auto;
  }

  .main-nav{
    gap: 16px;
  }

  .nav{
    gap: 14px;
  }

  .nav a{
    font-size: 13px;
  }

  .btn-primary{
    min-height: 38px;
    padding: 10px 14px;
    font-size: 13px;
    border-radius: 10px;
  }

  .contacto-form__row{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 860px){
  .contacto-visual--footer-only{
    padding: 80px 0 32px;
  }

  .contacto-visual--footer-only .footer-inner{
    padding-left: 20px;
    padding-right: 20px;
  }

  .site-footer--integrated .footer-top,
  .site-footer--integrated .footer-bottom{
    grid-template-columns: 1fr;
    align-items: start;
    gap: 14px;
  }

  .site-footer--integrated .footer-social,
  .site-footer--integrated .footer-email{
    justify-self: start;
    text-align: left;
  }
}

@media (max-width: 768px){
  .section{
    padding: 56px 0;
  }

  .container{
    padding: 0 20px;
  }

  .site-header{
    top: 14px;
  }

  .site-header::after{
    width: calc(100% - 40px);
    margin: 12px auto 0;
  }

  .header-inner{
    min-height: 44px;
  }

  .header-logo{
    max-width: 118px;
  }

  .main-nav{
    gap: 12px;
  }

  .nav{
    gap: 12px;
  }

  .nav a{
    font-size: 12px;
  }

  .btn-primary{
    min-height: 36px;
    padding: 9px 12px;
    font-size: 12px;
    line-height: 1;
  }

  .site-footer .footer-inner,
  .site-footer--integrated .footer-inner{
    padding-left: 20px;
    padding-right: 20px;
  }

  .contacto-visual__inner{
    padding: 72px 20px 36px;
  }

  .contacto-visual__title{
    font-size: 30px;
  }
}

@media (max-width: 640px){
  .header-inner{
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 14px;
  }

  .brand{
    flex: 0 0 auto;
  }

  .main-nav{
    width: 100%;
    margin-left: 0;
    justify-content: space-between;
  }

  .nav{
    flex-wrap: wrap;
    gap: 10px 14px;
  }
}

@media (max-width: 480px){
  .container{
    padding: 0 16px;
  }

  .site-header{
    top: 12px;
  }

  .site-header::after{
    width: calc(100% - 32px);
  }

  .header-logo{
    max-width: 108px;
  }

  .main-nav{
    align-items: center;
    gap: 10px;
  }

  .nav{
    gap: 8px 10px;
  }

  .nav a{
    font-size: 11px;
  }

  .btn-primary{
    min-height: 34px;
    padding: 8px 10px;
    font-size: 11px;
    border-radius: 9px;
  }

  .site-footer .footer-inner,
  .site-footer--integrated .footer-inner{
    padding-left: 16px;
    padding-right: 16px;
  }

  .contacto-visual--footer-only{
    padding: 64px 0 24px;
  }

  .contacto-visual__inner{
    padding: 64px 16px 28px;
  }

  .contacto-visual__title{
    font-size: 26px;
  }
}

@media (max-width: 390px){
  .scroll-top{
    right: 16px;
    bottom: 16px;
  }
}


/* ============================= */
/* MOBILE */
/* ============================= */

@media (max-width: 768px){

  /* GRID → columna única */
  .sobre-gabriel-hero__grid,
  .sobre-gabriel-bio__grid,
  .sobre-gabriel-profile__grid{
    grid-template-columns: 1fr;
  }

  /* HERO */
  .sobre-gabriel-hero__media{
    min-height: 420px;
  }

  .sobre-gabriel-hero__content{
    padding: 32px 24px;
    min-height: auto;
  }

  /* BIO / PROFILE spacing */
  .sobre-gabriel-bio,
  .sobre-gabriel-profile{
    padding: 80px 0;
  }

  /* FIX imágenes overflow */
  img{
    max-width: 100%;
    height: auto;
  }

}


/* ============================= */
/* HOME */
/* ============================= */

@media (max-width: 1200px){
  .pillars{
    grid-template-columns: repeat(3, 1fr);
  }

  .pillar-card{
    width: 100%;
  }

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

  .clientes-grid{
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 992px){
  .home-hero--dark{
    min-height: auto;
    padding: 160px 0 160px;
  }

  .home-hero__subtitle{
    font-size: 28px;
  }

  .manifiesto-grid{
    grid-template-columns: 1fr;
    gap: 48px;
    align-items: start;
  }

  .manifiesto__sticky{
    position: static;
    min-height: auto;
    height: auto;
  }

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

  .clientes-grid{
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px){
  .home-hero__title-logo,
  .hero-logo-reveal{
    width: 340px;
    margin-bottom: 40px;
  }

  .home-hero__subtitle{
    font-size: 22px;
    max-width: 100%;
  }

  .pillars-section{
    margin-top: -80px;
  }

  .manifiesto{
    padding: 72px 0 32px;
  }

  .manifiesto-grid{
    gap: 28px;
  }

  .manifiesto__title{
    font-size: 34px;
  }

  .servicios{
    padding: 80px 0;
  }

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

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

  .book-feature{
    margin-top: 0;
    padding-top: 0;
  }

  .book-feature__content{
    padding: 32px 24px;
  }

  .book-feature__title{
    font-size: 26px;
  }
}

@media (max-width: 480px){
  .manifiesto{
    padding: 56px 0 20px;
  }

  .manifiesto-grid{
    gap: 20px;
  }

  .manifiesto__sticky{
    min-height: auto;
    margin-bottom: 0;
    padding-bottom: 0;
  }

  .book-feature{
    margin-top: 0;
    padding-top: 0;
  }

  .book-feature__content{
    padding-top: 20px;
  }
}

/* ============================= */
/* MANIFIESTO PAGE */
/* ============================= */

@media (max-width: 1200px){
  .manifiesto-hero__grid{
    min-height: auto;
  }

  .manifiesto-hero__media{
    min-height: 600px;
  }

  .manifiesto-hero__content{
    min-height: 600px;
    padding: 80px 48px 40px 32px;
  }

  .manifiesto-lista__inner{
    padding-left: 48px;
    padding-right: 180px;
  }

  .manifiesto-item{
    grid-template-columns: 70px 1fr;
  }

  .manifiesto-cta__intro{
    font-size: 34px;
  }

  .manifiesto-cta h2{
    font-size: 44px;
  }
}

@media (max-width: 1024px){
  .manifiesto-hero__content{
    padding: 64px 32px 32px 28px;
  }

  .manifiesto-hero__arrow{
    top: 28px;
    right: 24px;
  }

  .manifiesto-hero__arrow img{
    width: 28px;
    opacity: 0.45;
  }

  .manifiesto-hero__copy{
    max-width: 100%;
    gap: 18px;
  }

  .manifiesto-hero__content h1{
    max-width: 100%;
    padding-right: 44px;
  }

  .manifiesto-hero__content p{
    max-width: 100%;
  }
}

@media (max-width: 992px){
  .manifiesto-hero__arrow{
    display: none;
  }

  .manifiesto-lista__inner{
    padding-left: 32px;
    padding-right: 32px;
  }

  .manifiesto-item{
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .manifiesto-item__num{
    font-size: 28px;
  }

  .manifiesto-toggle-wrap{
    display: none;
  }
}

@media (max-width: 900px){
  .manifiesto-hero{
    padding-top: 82px;
  }

  .manifiesto-hero__grid{
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .manifiesto-hero__media{
    min-height: 420px;
  }

  .manifiesto-hero__content{
    min-height: auto;
    padding: 72px 28px 56px;
    border-top: 1px solid #D4D4D8;
  }

  .manifiesto-hero__copy{
    margin-top: 56px;
  }

  .manifiesto-hero__content h1{
    font-size: 34px;
  }

  .manifiesto-hero__content p{
    font-size: 16px;
  }

  .manifiesto-lista{
    padding: 28px 0 80px;
  }

  .manifiesto-item{
    grid-template-columns: 64px 1fr;
    padding: 22px 0;
  }

  .manifiesto-item__num{
    font-size: 34px;
  }

  .manifiesto-item__content h2{
    font-size: 22px;
  }

  .manifiesto-cta{
    padding: 64px 0 36px;
  }

  .manifiesto-cta__intro{
    font-size: 26px;
    max-width: 260px;
  }

  .manifiesto-cta h2{
    font-size: 32px;
  }

  .manifiesto-cta__inner{
    min-height: auto;
    gap: 28px;
  }
}

@media (max-width: 768px){
  .manifiesto-hero{
    padding-top: 0;
  }

  .manifiesto-hero__grid{
    grid-template-columns: 1fr;
    min-height: auto;
    border-bottom: 0;
  }

  .manifiesto-hero__media{
    min-height: auto;
  }

  .manifiesto-hero__media img{
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
  }

  .manifiesto-hero__content{
    min-height: auto;
    padding: 28px 20px 32px;
    border-top: 0;
  }

  .manifiesto-hero__copy{
    margin-top: 0;
    gap: 14px;
  }

  .manifiesto-hero__content h1{
    padding-right: 0;
    font-size: 24px;
  }

  .manifiesto-hero__content p{
    font-size: 15px;
  }
}

  .manifiesto-lista{
    padding: 24px 0 64px;
  }

  .manifiesto-item__content h2{
    font-size: 20px;
  }

  .manifiesto-item__content p{
    font-size: 14px;
  }

  .manifiesto-cta{
    padding: 48px 0 24px;
  }

  .manifiesto-cta__intro{
    font-size: 22px;
  }

  .manifiesto-cta__title{
    font-size: 24px;
  }
}

@media (max-width: 480px){
  .manifiesto-hero__content{
    padding: 40px 16px 32px;
  }

  .manifiesto-hero__content h1{
    font-size: 22px;
  }

  .manifiesto-hero__content p{
    font-size: 14px;
  }

  .manifiesto-item__num{
    font-size: 24px;
  }

  .manifiesto-cta__intro{
    font-size: 20px;
  }

  .manifiesto-cta__title{
    font-size: 22px;
  }
}

@media (max-width: 390px){
  .manifiesto-hero{
    padding-top: 76px;
  }

  .manifiesto-hero__media{
    min-height: 240px;
  }

  .manifiesto-hero__content{
    padding: 24px 16px 28px;
  }

  .manifiesto-hero__copy{
    gap: 12px;
  }
}

@media (max-width: 768px){
  body.page-template-page-manifiesto .site-header,
  body.page-template-page-manifiesto-php .site-header{
    padding-bottom: 12px;
  }

  body.page-template-page-manifiesto .header-inner,
  body.page-template-page-manifiesto-php .header-inner{
    align-items: flex-start;
    gap: 16px;
    min-height: auto;
    padding-bottom: 8px;
  }

  body.page-template-page-manifiesto .main-nav,
  body.page-template-page-manifiesto-php .main-nav{
    gap: 16px;
  }

  body.page-template-page-manifiesto .btn-primary,
  body.page-template-page-manifiesto-php .btn-primary{
    margin-top: 4px;
  }

  .manifiesto-hero{
    padding-top: 0;
  }

  .manifiesto-hero__grid{
    grid-template-columns: 1fr;
    min-height: auto;
    border-bottom: 0;
  }

  .manifiesto-hero__media{
    min-height: auto;
  }

  .manifiesto-hero__media img{
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
  }
}

/* ============================= */
/* SOBRE GABRIEL */
/* ============================= */

@media (max-width: 1024px){

  .sobre-gabriel-bio__grid{
    grid-template-columns: 1fr;
  }

  .sobre-gabriel-bio__media{
    order: 1;
  }

  .sobre-gabriel-bio__text{
    order: 2;
  }

}

@media (max-width: 1024px){

  .sobre-gabriel-hero__grid{
    grid-template-columns: 1fr;
  }

  .sobre-gabriel-hero__media{
    order: 1;
  }

  .sobre-gabriel-hero__content{
    order: 2;
  }

}

@media (max-width: 1024px) {
  .sobre-gabriel-hero__arrow {
    display: none;
  }
}

@media (max-width: 992px){
  .sobre-gabriel-hero__grid,
  .sobre-gabriel-bio__grid,
  .sobre-gabriel-profile__grid{
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .sobre-gabriel-hero__media,
  .sobre-gabriel-hero__content{
    min-height: auto;
  }

  .sobre-gabriel-hero__content{
    padding: 56px 32px;
  }
}

@media (max-width: 768px){
  .sobre-gabriel-hero{
    margin-top: 80px;
  }

  .sobre-gabriel-hero__media{
    min-height: auto;
  }

  .sobre-gabriel-hero__media img{
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
  }

  .sobre-gabriel-hero__content{
    min-height: auto;
    padding: 28px 20px 40px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }

  .sobre-gabriel-hero__arrow{
    position: static;
    margin: 0 0 20px 0;
    align-self: flex-end;
  }

  .sobre-gabriel-hero__arrow img{
    width: 30px;
    opacity: 0.45;
  }

  .sobre-gabriel-hero__copy{
    max-width: 100%;
    gap: 18px;
  }

  .sobre-gabriel-hero__copy h1,
  .sobre-gabriel-hero__copy p{
    max-width: 100%;
  }

  .sobre-gabriel-bio,
  .sobre-gabriel-profile,
  .sobre-gabriel-book{
    padding-bottom: 72px;
  }
}

@media (max-width: 480px){
  .sobre-gabriel-hero__content{
    padding: 24px 16px 32px;
  }

  .sobre-gabriel-hero__arrow{
    display: none;
  }
}

@media (max-width: 768px){
  .sobre-gabriel-bio__grid,
  .sobre-gabriel-profile__grid{
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .sobre-gabriel-bio__media{
    order: 1;
  }

  .sobre-gabriel-bio__text{
    order: 2;
  }

  .sobre-gabriel-profile__media{
    order: 1;
  }

  .sobre-gabriel-profile__text{
    order: 2;
  }

  .sobre-gabriel-bio{
    padding: 56px 0;
  }

  .sobre-gabriel-profile{
    padding: 0 0 72px;
  }

  .sobre-gabriel-bio__text,
  .sobre-gabriel-profile__text{
    max-width: 100%;
    gap: 18px;
  }

  .sobre-gabriel-bio__text p,
  .sobre-gabriel-profile__text p{
    font-size: 15px;
    line-height: 1.55;
  }
}

/* ============================= */
/* SINGLE SERVICIO */
/* ============================= */

@media (max-width: 1200px){
  .servicio-single-body__top{
    grid-template-columns: 1fr;
    gap: 48px;
  }

  .servicio-single-body__col--text,
  .servicio-single-body__col--impact,
  .servicio-single-diferencial__content,
  .servicio-single-diferencial__text{
    width: 100%;
    max-width: 100%;
  }

  .servicio-single-diferencial{
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .servicio-single-diferencial__media{
    width: 100%;
    height: auto;
  }
}

@media (max-width: 992px){
  .servicio-single-hero .container,
  .servicio-single-body .container,
  .servicio-single-faq .container,
  .servicio-single-cta .container{
    padding-left: 32px;
    padding-right: 32px;
  }

  .servicio-single-image-overlap{
    left: 32px;
    right: 32px;
  }

  .servicio-single-incluye__grid,
  .servicio-single-workshops{
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 768px){
  .servicio-single-hero{
    padding-top: 150px;
    padding-bottom: 72px;
  }

  .servicio-single-hero__head{
    margin-bottom: 32px;
  }

  .servicio-single-hero__title{
    margin: 0 0 40px;
    font-size: 30px;
  }

  .servicio-single-hero__bottom{
    min-height: auto;
  }

  .servicio-single-hero__intro{
    max-width: 100%;
    font-size: 20px;
    line-height: 1.35;
    padding-right: 0;
  }

  .servicio-single-hero__arrow{
    display: none;
  }

  .servicio-single-image-overlap{
    position: relative;
    left: auto;
    right: auto;
    bottom: auto;
    margin-top: 32px;
  }

  .servicio-single-image-overlap__media img{
    width: 100%;
    height: 320px;
    object-fit: cover;
  }

  .servicio-single-body{
    padding-top: 56px;
    padding-bottom: 72px;
  }

  .servicio-single-incluye__grid,
  .servicio-single-workshops{
    grid-template-columns: 1fr;
  }

  .servicio-single-metodologia__item{
    gap: 20px;
    padding: 20px 0;
  }

  .servicio-single-faq{
    padding: 80px 0;
  }

  .servicio-single-cta{
    padding-top: 72px;
  }

  .servicio-single-cta__title{
    font-size: 24px;
  }
}

@media (max-width: 480px){
  .servicio-single-hero .container,
  .servicio-single-body .container,
  .servicio-single-faq .container,
  .servicio-single-cta .container{
    padding-left: 16px;
    padding-right: 16px;
  }

  .servicio-single-hero{
    padding-top: 164px;
    padding-bottom: 64px;
  }

  .servicio-single-image-overlap{
    margin-top: 24px;
  }

  .servicio-single-image-overlap__media img{
    height: 220px;
  }

  .servicio-single-hero__title{
    font-size: 26px;
  }

  .servicio-single-hero__intro,
  .servicio-single-body__subtitle{
    font-size: 18px;
  }

  /* HEADER MOBILE — 2 links arriba / 2 abajo */

  .header-inner{
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 16px;
  }

  .brand{
    display: block;
  }

  .main-nav{
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 16px;
    margin-left: 0;
  }

  .nav{
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px 16px;
    align-items: center;
  }

  .nav li{
    width: 100%;
  }

  .nav a{
    display: block;
    width: 100%;
    font-size: 14px;
    line-height: 1.2;
  }

  .btn-primary{
    width: fit-content;
    align-self: flex-start;
  }

  /* CLIENTES — MOBILE GRID */

  .clientes-grid{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    align-items: center;
  }

  .cliente-logo{
    min-height: 110px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .cliente-logo img{
    max-width: 100%;
    max-height: 34px;
    height: auto;
    object-fit: contain;
  }
}

@media (max-width: 390px){
  .servicio-single-hero{
    padding-top: 172px;
  }
}

/* ============================= */
/* HOME — FIX ESPACIO MUERTO MANIFIESTO MOBILE */
/* ============================= */

@media (max-width: 768px){
  .manifiesto-grid__right{
    display: none;
  }

  .manifiesto__sticky{
    min-height: auto;
    height: auto;
  }

  .manifiesto__title-wrap{
    min-height: auto;
  }

  .manifiesto__cta{
    margin-top: 20px;
  }
}

@media (max-width: 480px){
  .manifiesto{
    padding: 56px 0 20px;
  }

  .manifiesto-grid{
    gap: 16px;
  }

  .manifiesto__eyebrow{
    margin-bottom: 28px;
  }

  .manifiesto__cta{
    margin-top: 12px;
    padding-bottom: 14px;
  }
}

/* ============================= */
/* HOME — FIX ALTURA MANIFIESTO MOBILE */
/* ============================= */

@media (max-width: 768px){
  .manifiesto__title-wrap{
    position: relative;
    min-height: 260px;
  }

  .manifiesto__title{
    position: absolute;
    inset: 0;
    max-width: 100%;
  }
}

@media (max-width: 480px){
  .manifiesto__title-wrap{
    min-height: 320px;
  }
}

@media (max-width: 390px){
  .manifiesto__title-wrap{
    min-height: 360px;
  }
}

/* ============================= */
/* HOME — MANIFIESTO FIX ALTURA ESTABLE */
/* evita que el layout salte al cambiar las frases */
/* ============================= */

.manifiesto__title-wrap{
  position: relative;
  min-height: 6.5em;
}

.manifiesto__title{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  max-width: 620px;
}

@media (max-width: 1400px){
  .manifiesto__title-wrap{
    min-height: 7.2em;
  }
}

@media (max-width: 1200px){
  .manifiesto__title-wrap{
    min-height: 8.2em;
  }
}

@media (max-width: 1024px){
  .manifiesto__title-wrap{
    min-height: 9.5em;
  }
}

@media (max-width: 992px){
  .manifiesto__title-wrap{
    min-height: 10.5em;
  }
}

@media (max-width: 768px){
  .manifiesto__title-wrap{
    min-height: 260px;
  }

  .manifiesto__title{
    max-width: 100%;
  }
}

@media (max-width: 480px){
  .manifiesto__title-wrap{
    min-height: 320px;
  }
}

@media (max-width: 390px){
  .manifiesto__title-wrap{
    min-height: 360px;
  }
}

/* ============================= */
/* SERVICIOS — MOBILE GROUPED */
/* ============================= */

@media (max-width: 768px){
  .servicios__tabs{
    display: none;
  }

  .servicios-columns{
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .servicios-column{
    position: relative;
    gap: 20px;
  }

  .servicios-column::before{
    display: block;
    width: 100%;
    min-height: 46px;
    padding: 12px 16px;
    border-radius: 4px;
    font-size: 14px;
    line-height: 1.2;
    text-align: center;
    margin-bottom: 4px;
    box-sizing: border-box;
  }

  .servicios-column--left::before{
    content: "modobeta [LAB]";
    background: #2F54F1;
    color: #FFFFFF;
  }

  .servicios-column--middle::before{
    content: "modobeta [LEARNING]";
    background: #EAE8E5;
    color: #919191;
  }

  .servicios-column--right::before{
    content: "Consultoría & Conferencias";
    background: #D5E0FE;
    color: #2F54F1;
  }

  .servicio-card--tall,
  .servicio-card--short{
    height: auto;
    min-height: 0;
  }
}

@media (max-width: 480px){
  .servicios{
    padding: 80px 0 88px;
  }

  .servicios__eyebrow{
    margin-bottom: 28px;
    font-size: 18px;
  }

  .servicios-columns{
    gap: 32px;
  }

  .servicios-column::before{
    min-height: 42px;
    padding: 11px 14px;
    font-size: 13px;
    margin-bottom: 2px;
  }

  .servicio-card{
    padding: 28px 22px 24px;
  }

  .servicio-card h3{
    font-size: 20px;
    margin-bottom: 12px;
  }

  .servicio-card p{
    max-width: 100%;
    font-size: 15px;
    line-height: 1.5;
  }
}