/* =========================================================
   BLOQUE MOBILE: Ajustes globales
   ========================================================= */
body {
  background: #ffffff;
}

.site-page {
  width: 100%;
  box-shadow: none;
}

/* =========================================================
   BLOQUE MOBILE: Header
   ========================================================= */
.main-header {
  height: auto;
  min-height: 74px;
}

.header-inner {
  padding: 16px 18px;
  grid-template-columns: 1fr;
  gap: 13px;
  text-align: center;
}

.brand-name {
  justify-self: center;
  font-size: 28px;
}

.header-brands {
  justify-self: center;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  font-size: 12px;
}

.header-brands span {
  width: 100%;
}

.header-brands img:first-of-type {
  width: 74px;
}

.header-brands img:last-of-type {
  width: 82px;
}

.header-cta {
  justify-self: center;
  width: min(100%, 310px);
  min-height: 44px;
}

/* =========================================================
   BLOQUE MOBILE: Hero
   ========================================================= */
.hero-section {
  min-height: auto;
  padding: 28px 18px 26px;
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.hero-image-wrap {
  position: relative;
  inset: auto;
  order: 2;
  width: 100%;
  height: 310px;
  border-radius: 18px;
  box-shadow: 0 14px 34px rgba(10, 45, 95, 0.11);
}

.hero-image-wrap::before {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.01) 0%, rgba(255, 255, 255, 0.20) 72%, #ffffff 100%);
}

.hero-content {
  order: 1;
  width: 100%;
}

.eyebrow-badge {
  font-size: 11px;
}

.hero-content h1 {
  margin-top: 20px;
  font-size: 42px;
  line-height: 1.02;
  letter-spacing: -2px;
}

.hero-highlight {
  margin-top: 18px;
  font-size: 15px;
  padding-right: 13px;
}

.hero-content p {
  margin-top: 17px;
  font-size: 15px;
}

.hero-actions {
  margin-top: 22px;
  gap: 12px;
}

.btn {
  width: 100%;
  min-height: 52px;
}

.hero-tags {
  order: 3;
  position: relative;
  left: auto;
  bottom: auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

.hero-tags span {
  min-height: 46px;
  justify-content: center;
  padding: 0 12px;
  font-size: 12px;
}

/* =========================================================
   BLOQUE MOBILE: Panel de marcas
   ========================================================= */
.brand-panel {
  width: calc(100% - 36px);
  margin-bottom: 18px;
  min-height: auto;
  padding: 20px 14px;
}

.brand-logos {
  margin-top: 18px;
  gap: 26px;
}

.brand-logos img:first-child {
  width: 126px;
}

.brand-logos img:last-child {
  width: 105px;
}

.brand-divider {
  height: 47px;
}

/* =========================================================
   BLOQUE MOBILE: Beneficios
   ========================================================= */
.features-section {
  width: calc(100% - 36px);
  grid-template-columns: 1fr;
  gap: 14px;
}

.feature-card {
  min-height: auto;
  padding: 25px 22px 24px;
}

.feature-card img {
  width: 78px;
  height: 78px;
}

.feature-card h3 {
  margin-top: 18px;
  font-size: 19px;
}

.feature-card p {
  max-width: 270px;
}

/* =========================================================
   BLOQUE MOBILE: Pastilla informativa
   ========================================================= */
.info-ribbon {
  width: calc(100% - 36px);
  max-width: none;
  min-height: auto;
  padding: 12px 16px;
  align-items: flex-start;
  font-size: 13px;
}

/* =========================================================
   BLOQUE MOBILE: Proyectos
   ========================================================= */
.projects-section {
  padding: 20px 18px 16px;
}

.section-heading h2 {
  font-size: 29px;
}

.section-heading p {
  font-size: 14px;
}

.project-grid {
  grid-template-columns: 1fr;
  gap: 18px;
}

.project-card {
  min-height: auto;
}

.project-photo {
  height: 190px;
}

.project-icon {
  top: 154px;
  width: 68px;
  height: 68px;
}

.project-content {
  padding: 47px 22px 27px;
}

/* =========================================================
   BLOQUE MOBILE: Proceso de trabajo
   ========================================================= */
.process-section {
  padding: 8px 18px 20px;
}

.process-grid {
  grid-template-columns: 1fr;
  gap: 20px;
}

.process-grid::before {
  display: none;
}

.process-step {
  padding: 18px 16px;
  border: 1px solid #edf2f9;
  border-radius: 18px;
  box-shadow: 0 10px 28px rgba(12, 44, 93, 0.08);
}

.process-step p {
  max-width: 275px;
  font-size: 13px;
}

/* =========================================================
   BLOQUE MOBILE: Llamado a la acción final
   ========================================================= */
.final-cta {
  width: calc(100% - 36px);
  margin-bottom: 18px;
  grid-template-columns: 1fr;
}

.final-cta-content {
  grid-template-columns: 1fr;
  text-align: center;
  justify-items: center;
  gap: 12px;
  padding: 26px 22px 22px;
}

.final-cta h2 {
  font-size: 29px;
}

.final-cta p {
  font-size: 14px;
}

.final-cta .btn {
  width: 100%;
  min-height: 46px;
}

.final-cta-image {
  min-height: 175px;
}

.final-cta-image::before {
  width: 100%;
  height: 30%;
  inset: 0 0 auto 0;
  background: linear-gradient(180deg, #e9f7ff 0%, rgba(233, 247, 255, 0) 100%);
}


/* =========================
   FOOTER CONTACTO - MOBILE
========================= */

@media (max-width: 768px) {

    .footer-contacto-multisplit {
        padding: 0 14px 28px;
    }

    .footer-contacto-card {
        border-radius: 22px;
    }

    .footer-contacto-contenido {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 24px;
        min-height: auto;
        padding: 32px 22px 26px;
    }

    .footer-contacto-item {
        width: 100%;
        gap: 18px;
        align-items: flex-start;
    }

    .footer-contacto-icono {
        width: 64px;
        height: 64px;
        min-width: 64px;
    }

    .footer-contacto-icono img {
        width: 34px;
        height: 34px;
    }

    .footer-contacto-texto p {
        font-size: 17px;
        line-height: 1.25;
        margin-bottom: 6px;
    }

    .footer-contacto-label {
        font-size: 16px !important;
        margin-bottom: 8px !important;
    }

    .footer-contacto-numero {
        font-size: 28px !important;
        line-height: 1.05 !important;
    }

    .footer-contacto-divisor {
        width: 100%;
        height: 1px;
        background: rgba(0, 108, 229, 0.16);
    }

    .footer-contacto-deco {
        min-height: 135px;
        justify-content: center;
        overflow: hidden;
        margin-top: 4px;
    }

    .footer-contacto-deco img {
        width: 190px;
    }

    .footer-contacto-circulo {
        right: 50%;
        transform: translateX(50%);
        bottom: -70px;
        width: 250px;
        height: 250px;
    }

    .footer-contacto-copy {
        padding: 22px 18px 24px;
        font-size: 15px;
        line-height: 1.45;
    }
}

@media (max-width: 420px) {

    .footer-contacto-item {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

    .footer-contacto-texto p {
        font-size: 16px;
    }

    .footer-contacto-numero {
        font-size: 26px !important;
    }
}