/* ══════════════════════════════════════
   S3 — HORIZONTAL SCROLL
   Usa variables globales de :root (core.css)
   No las redefine aquí

   NOTA: S3 no es una .lt-section — es un
   <div id="lt-s3"> sin altura fija.
   El pin lo maneja #h-pin-wrapper sticky.
   El ZIP system no toca esta sección.
══════════════════════════════════════ */

/* ── Variables locales de S3 ── */
#lt-s3 {
    --hs-cream: var(--color-cream);
}

/* ── Barra de progreso ── */
#h-progress-bar {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 8px;
    background: rgba(128, 128, 128, .15);
    z-index: 1000;
    pointer-events: none;
    opacity: 0;
    transition: opacity .4s;
}

#h-progress-bar.visible { opacity: 1; }

#h-progress-fill {
    height: 100%;
    width: 0%;
    background: var(--color-green);
    position: relative;
}

#h-progress-fill::after {
    content: '';
    position: absolute;
    right: -1px;
    top: -4px;
    width: 14px;
    height: 16px;
    background: var(--color-green);
    filter: blur(6px);
    border-radius: 50%;
}

/* ── Contador ── */
#h-counter {
    position: fixed;
    top: 1.4rem;
    right: 2.2rem;
    font-family: var(--font-display);
    font-size: 1rem;
    letter-spacing: .22em;
    z-index: 1001;
    opacity: 0;
    transition: opacity .4s, color .35s;
    color: var(--color-white);
}

#h-counter.visible { opacity: 1; }

#h-counter.on-light { color: var(--color-navy); }

#h-counter .cur { color: var(--color-green); }

/* ── Sección horizontal ── */
#h-scroll-section { position: relative; }

#h-pin-wrapper {
    position: sticky;
    top: 0;
    width: 100vw;
    height: 100dvh;
    overflow: hidden;
}

#h-track {
    display: flex;
    height: 100dvh;
    will-change: transform;
}

@media (min-width: 1200px) and (orientation: landscape) and (min-height: 500px) {
    #h-track { width: calc(4 * 100vw); }
}

@media not all and (min-width: 1200px) and (orientation: landscape) and (min-height: 500px) {
    #h-track { width: 100%; }
}

/* ── Slide base ── */
.h-slide {
    position: relative;
    width: 100vw;
    height: 100dvh;
    flex-shrink: 0;
    overflow: hidden;
    display: flex;
    align-items: stretch;
}

.h-slide-inner {
    display: flex;
    width: 100%;
    height: 100%;
    align-items: center;
}

/* ── Tag label ── */
.h-slide-tag {
    position: absolute;
    top: 1.8rem;
    left: 3.5vw;
    font-family: var(--font-body);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: .32em;
    text-transform: uppercase;
    display: flex;
    align-items: center;
    gap: .6rem;
    z-index: 10;
}

.h-slide-tag::before {
    content: '';
    display: inline-block;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--color-green);
}

.h-slide-tag.dark-tag  { color: rgba(11, 26, 46, .6); }
.h-slide-tag.light-tag { color: rgba(255, 255, 255, .9); }

/* ── Imágenes planas ── */
.h-img-flat {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: inherit;
}

/* ── Imágenes cutout ── */
.h-img-cutout {
    width: auto;
    height: 100%;
    max-width: none;
    object-fit: contain;
    object-position: right bottom;
    filter: drop-shadow(-15px 20px 25px rgba(0,0,0,.25)) drop-shadow(0 0 15px rgba(11,26,46,.15));
    pointer-events: none;
}

/* ══════════════════════════════════════
   SLIDE 1 — navy
══════════════════════════════════════ */
#slide-1 { background: var(--color-navy); }


.s1-left {
    flex: 1.1;
    padding: 0 0 0 6vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
    z-index: 10;
}

.s1-left h2 {
    font-family: var(--font-display);
    font-size: clamp(88px, 12vw, 160px);
    line-height: .88;
    letter-spacing: -.02em;
    color: var(--color-white);
}

.s1-left h2 em {
    font-style: normal;
    color: var(--color-green);
}

.s1-left p {
    margin-top: 2.4rem;
    font-size: clamp(17px, 1.4vw, 22px);
    font-weight: 400;
    color: rgba(255,255,255,.78);
    line-height: 1.85;
    max-width: 480px;
}

.s1-right {
    flex: .95;
    position: relative;
    height: 100%;
    width: 52vw;
    max-width: 900px;
    min-width: 500px;
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    overflow: visible;
    pointer-events: none;
    z-index: 5;
}

.s1-img-wrap {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
}

/* picture llena el wrap completo */
#slide-1 .s1-img-wrap picture {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

/* img desktop — portrait transparente, anclada bottom/right, crece hacia arriba */
#slide-1 .s1-img-wrap img {
    position: absolute;
    bottom: 0;
    right: 0;
    height: 100%;
    width: auto;
    max-width: none;
}

.s1-deco {
    position: absolute;
    bottom: -8vh;
    left: 0;
    font-family: var(--font-display);
    font-size: 48vw;
    line-height: 1;
    color: rgba(255,255,255,.045);
    pointer-events: none;
    user-select: none;
    z-index: 0;
    white-space: nowrap;
    letter-spacing: -.02em;
}

/* ══════════════════════════════════════
   SLIDE 2 — cream
══════════════════════════════════════ */
#slide-2 { background: var(--hs-cream); }

#slide-2 .h-slide-inner {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: relative;
}

.s2-center {
    text-align: center;
    position: relative;
    z-index: 3;
    max-width: 680px;
    padding: 0 2vw;
}

.s2-center h2 {
    font-family: var(--font-display);
    font-size: clamp(72px, 10vw, 148px);
    line-height: .9;
    letter-spacing: -.02em;
    color: var(--color-navy);
}

.s2-center h2 em {
    font-style: normal;
    color: var(--color-green);
}

.s2-center p {
    margin-top: 2rem;
    font-size: clamp(17px, 1.4vw, 22px);
    font-weight: 400;
    color: rgba(11,26,46,.78);
    line-height: 1.85;
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
}

.s2-img-a {
    position: absolute;
    top: 30%;
    left: 5vw;
    width: 32vw;
    aspect-ratio: 16 / 9;
    height: auto;
    z-index: 2;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 20px 40px -10px rgba(0,0,0,.3), 0 0 30px rgba(11,26,46,.1);
    border: 1px solid rgba(11,26,46,.05);
}

.s2-img-b {
    position: absolute;
    bottom: 22%;
    right: 5vw;
    width: 24vw;
    aspect-ratio: 4 / 3.2;
    height: auto;
    z-index: 2;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 20px 40px -10px rgba(0,0,0,.3), 0 0 30px rgba(11,26,46,.1);
    border: 1px solid rgba(11,26,46,.05);
}

.s2-img-b img { object-position: center 15%; }

.s2-deco {
    position: absolute;
    bottom: -8vh;
    left: -2vw;
    font-family: var(--font-display);
    font-size: 44vw;
    line-height: 1;
    color: rgba(11,26,46,.05);
    pointer-events: none;
    user-select: none;
    z-index: 0;
    white-space: nowrap;
    letter-spacing: -.02em;
}

/* ══════════════════════════════════════
   SLIDE 3 — navy
══════════════════════════════════════ */
#slide-3 { background: var(--color-navy); }

.s3-right-text {
    flex: 1;
    padding: 5vh 5vw 5vh 2vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-end;
    text-align: right;
    position: relative;
    z-index: 2;
    order: 2;
}

.s3-right-text h2,
.s3-h2-top,
.s3-h2-bottom {
    font-family: var(--font-display);
    font-size: clamp(80px, 11vw, 165px);
    line-height: .88;
    letter-spacing: -.02em;
    color: var(--color-white);
}

/* En desktop el .s3-big-num no se inyecta —
   los dos h2 se ven como uno continuo */
.s3-h2-top { margin-bottom: 0; }
.s3-h2-bottom { margin-top: 0; }

.s3-right-text h2 em,
.s3-h2-top em,
.s3-h2-bottom em {
    font-style: normal;
    color: var(--color-green);
}

.s3-copy-block { margin-top: 1.8rem; }

.s3-copy-block .ch {
    font-family: var(--font-display);
    font-size: clamp(24px, 2.8vw, 42px);
    color: rgba(255,255,255,.85);
    letter-spacing: .04em;
    line-height: 1.1;
    text-transform: uppercase;
}

.s3-copy-block p {
    font-size: clamp(15px, 1.25vw, 20px);
    font-weight: 400;
    color: rgba(255,255,255,.8);
    line-height: 1.85;
    max-width: 420px;
    margin-left: auto;
}

.s3-left-map {
    flex: 1.05;
    position: relative;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding-left: 6vw;
    gap: 1.2vw;
    order: 1;
    perspective: 900px;
}

.s3-map-wrap {
    width: 30vw;
    height: 90vh;
    flex-shrink: 0;
    pointer-events: all;
    position: relative;
    z-index: 10;
}

.peru-map { width: 100%; height: 100%; }

.peru-map path {
    fill: rgba(255,255,255,.07);
    stroke: rgba(255,255,255,.14);
    stroke-width: .8;
    transition: fill .5s ease, stroke .5s ease;
}

.peru-map path.active {
    fill: var(--color-green);
    stroke: rgba(57,181,74,.6);
}

.peru-map #PE-LKT {
    fill: rgba(46,100,180,.12);
    stroke: rgba(46,100,180,.18);
    pointer-events: none;
}

.s3-card {
    width: 18vw;
    min-width: 220px;
    max-width: 320px;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 16px;
    padding: 2.5rem 2rem;
    backdrop-filter: blur(24px);
    flex-shrink: 0;
    align-self: center;
    position: relative;
    z-index: 10;
    transition: border-color .3s, box-shadow .3s;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    transform-style: preserve-3d;
}

.s3-card:hover {
    border-color: rgba(57,181,74,.4);
    box-shadow: 0 0 40px rgba(57,181,74,.1);
}

.card-dept {
    font-family: var(--font-body);
    font-size: clamp(14px, 1.3vw, 18px);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .15em;
    color: rgba(255,255,255,.9);
    margin-bottom: .8rem;
    min-height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.card-val {
    font-family: var(--font-display);
    font-size: clamp(80px, 9vw, 13vw);
    color: var(--color-green);
    line-height: .85;
    margin-bottom: .2rem;
}

.c-lbl {
    font-size: clamp(12px, 1.1vw, 16px);
    font-weight: 600;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: rgba(255,255,255,.75);
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .5em;
}

.cdot {
    display: inline-block;
    width: .55em;
    height: .55em;
    border-radius: 50%;
    background-color: var(--color-green);
    flex-shrink: 0;
}

.s3-deco {
    position: absolute;
    top: 2vh;
    right: 2vw;
    font-family: var(--font-display);
    font-size: 28vw;
    line-height: 1;
    color: rgba(255,255,255,.03);
    pointer-events: none;
    user-select: none;
    z-index: 0;
    white-space: nowrap;
    letter-spacing: -.02em;
}

/* ══════════════════════════════════════
   SLIDE 4 — cream
══════════════════════════════════════ */
#slide-4 { background: var(--hs-cream); }

#slide-4 .h-slide-inner {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    justify-content: flex-start;
    padding: 8vh 4vw 8vh 6vw;
    gap: 4vw;
    position: relative;
}

.s4-left-col {
    flex: 1.2;
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
    z-index: 3;
}

.s4-title-wrap {
    margin-bottom: 2rem;
    position: relative;
    z-index: 3;
}

.s4-title-wrap h2 {
    font-family: var(--font-display);
    font-size: clamp(80px, 12vw, 175px);
    line-height: .82;
    letter-spacing: -.02em;
    color: var(--color-navy);
    margin: 0;
    display: flex;
    flex-direction: column;
}

.s4-title-wrap h2 em {
    font-style: normal;
    color: var(--color-green);
}

.s4-bottom-text {
    max-width: 480px;
    margin-bottom: 3rem;
    position: relative;
    z-index: 3;
}

.s4-bottom-text p {
    font-size: clamp(16px, 1.4vw, 22px);
    font-weight: 500;
    color: rgba(11,26,46,.85);
    line-height: 1.6;
}

.s4-value-bar {
    margin-top: 1.15rem;
    padding-top: .85rem;
    border-top: 1px solid rgba(11,26,46,.16);
    display: flex;
    flex-wrap: wrap;
    gap: .7rem 1rem;
}

.s4-value-bar span {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    font-family: var(--font-body);
    font-size: clamp(11px, .82vw, 13px);
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: rgba(11,26,46,.62);
    line-height: 1.2;
}

.s4-value-bar span::before {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--color-green);
    box-shadow: 0 0 0 2px rgba(57,181,74,.16);
}

.s4-cta-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 1.6rem 3.5rem;
    background: transparent;
    border: 2px solid var(--color-navy);
    border-radius: 999px;
    color: var(--color-navy);
    font-family: var(--font-body);
    font-size: clamp(14px, 1.1vw, 17px);
    font-weight: 600;
    letter-spacing: .2em;
    text-transform: uppercase;
    cursor: pointer;
    position: relative;
    z-index: 10;
    overflow: hidden;
    transition: color .3s ease, border-color .3s ease;
    text-decoration: none;
    margin-top: 2rem;
    align-self: flex-start;
}

.s4-cta-pill::before {
    content: '';
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    height: 100%;
    background: var(--color-navy);
    z-index: -1;
    transition: top .4s cubic-bezier(0.25, 1, 0.5, 1);
}

.s4-cta-pill:hover { color: var(--color-green); border-color: var(--color-navy); }
.s4-cta-pill:hover::before { top: 0; }

.s4-right-col {
    flex: .9;
    position: relative;
    height: 100%;
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    z-index: 2;
}

.s4-img-wrap {
    position: absolute;
    right: -20vw;
    bottom: -15vh;
    width: auto;
    height: 98vh;
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    z-index: 5;
}

.s4-deco {
    position: absolute;
    bottom: -5vh;
    left: 2vw;
    font-family: var(--font-display);
    font-size: 38vw;
    line-height: 1;
    color: rgba(11,26,46,.04);
    pointer-events: none;
    user-select: none;
    z-index: 1;
    white-space: nowrap;
    letter-spacing: -.02em;
}

/* ══════════════════════════════════════
   LAPTOP ESTÁNDAR
   MacBook Air M2, 1600×900, Surface Pro
══════════════════════════════════════ */
@media (max-height: 1080px) and (min-height: 781px) and (min-width: 1100px) {

    .s1-left h2        { font-size: clamp(76px, 11.5vh, 150px); }
    .s1-left p         { font-size: clamp(15px, 1.8vh, 21px); margin-top: 1.6rem; }
    .s1-right          { width: 53vw; max-width: 880px; min-width: 460px; }
    #slide-1 .s1-img-wrap img { height: 100%; object-position: right bottom; }
    .s2-center h2      { font-size: clamp(64px, 10.5vh, 132px); }
    .s2-center p       { font-size: clamp(15px, 1.8vh, 21px); margin-top: 1.4rem; }
    .s2-img-a          { top: 24%; width: 30vw; }
    .s2-img-b          { bottom: 18%; width: 23vw; }
    .s3-map-wrap       { height: 88vh; }
    .s3-right-text h2  { font-size: clamp(72px, 10.5vh, 142px); }
    .s3-copy-block .ch { font-size: clamp(22px, 3vh, 40px); }
    .card-val          { font-size: clamp(76px, 9.5vh, 120px); }
    .s4-title-wrap h2  { font-size: clamp(72px, 11vh, 142px); }
    .s4-bottom-text    { margin-bottom: 2rem; max-width: 420px; }
    .s4-bottom-text p  { font-size: clamp(15px, 1.8vh, 21px); }
    .s4-img-wrap       { right: -16vw; bottom: -8vh; height: 108%; transform: none; }

    #slide-4 .h-slide-inner  { padding: 6vh 4vw 6vh 6vw; }
    #slide-4 .s4-bottom-text p {
        color: var(--color-navy);
        text-shadow: 0 0 12px var(--hs-cream), 0 0 24px var(--hs-cream), 0 0 4px var(--hs-cream);
    }
    #slide-4 .s4-cta-pill {
        color: var(--color-navy);
        border-color: var(--color-navy);
        text-shadow: 0 0 8px var(--hs-cream);
        filter: drop-shadow(0 0 6px var(--hs-cream));
    }
    #slide-4 .s4-cta-pill::before { background: var(--color-navy); }
    #slide-4 .s4-cta-pill:hover   { color: var(--color-green); }
    #slide-4 .s4-cta-pill:hover::before { background: var(--color-navy); }

    /* ── iPad Pro landscape (1366×1024) — S4 imagen como fondo ── */
    @media (max-height: 1024px) and (orientation: landscape) and (max-width: 1366px) {
        #slide-4 .h-slide-inner {
            flex-direction: row !important; /* mantener row — el left-col ocupa su mitad */
            padding: 6vh 4vw 6vh 6vw;
        }
        #slide-4 .s4-right-col {
            position: absolute !important;
            inset: 0;
            width: 100% !important;
            height: 100% !important;
            flex: none !important;
            z-index: 0;
            overflow: hidden;
        }
        #slide-4 .s4-img-wrap {
            position: absolute !important;
            inset: 0 !important;
            width: 100% !important;
            height: 100% !important;
            right: auto !important;
            bottom: auto !important;
            transform: none !important;
        }
        #slide-4 .s4-img-wrap img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            object-position: center top;
        }
        #slide-4 .s4-img-wrap::after {
            content: '';
            position: absolute;
            inset: 0;
            background: rgba(240,235,220,.86);
        }
        #slide-4 .s4-left-col {
            position: relative;
            z-index: 3;
            flex: 1;
            display: flex;
            flex-direction: column;
            justify-content: center;
        }
    }
}

/* ══════════════════════════════════════
   LAPTOP CORTO
   1280×720, 1366×768, 1536×864
══════════════════════════════════════ */
@media (max-height: 780px) and (min-width: 1100px) {

    .s1-left h2        { font-size: clamp(58px, 9.2vh, 104px); }
    .s1-left p         { font-size: clamp(13px, 1.7vh, 18px); margin-top: 1.2rem; line-height: 1.7; }
    .s1-right          { width: 54vw; max-width: 820px; min-width: 420px; }
    #slide-1 .s1-img-wrap img { height: 100%; object-position: right bottom; }
    .s2-center h2      { font-size: clamp(48px, 8.2vh, 96px); }
    .s2-center p       { font-size: clamp(13px, 1.7vh, 18px); margin-top: 1.2rem; }
    .s2-img-a          { top: 20%; width: 28vw; }
    .s2-img-b          { bottom: 15%; width: 22vw; }
    .s3-map-wrap       { height: 86vh; }
    .s3-right-text h2  { font-size: clamp(48px, 8.5vh, 104px); }
    .s3-copy-block     { margin-top: 1rem; }
    .s3-copy-block .ch { font-size: clamp(16px, 2.6vh, 32px); }
    .s3-card           { padding: 1.8rem 1.6rem; }
    .card-val          { font-size: clamp(56px, 7.8vh, 96px); }
    .card-dept         { min-height: 36px; font-size: clamp(12px, 1.5vh, 17px); }
    .s4-title-wrap h2  { font-size: clamp(58px, 9.2vh, 104px); line-height: .82; }
    .s4-title-wrap     { margin-bottom: 1.2rem; }
    .s4-bottom-text    { margin-bottom: 1.5rem; max-width: 400px; }
    .s4-bottom-text p  { font-size: clamp(13px, 1.7vh, 18px); line-height: 1.55; }
    .s4-cta-pill       { padding: 1.2rem 2.8rem; margin-top: 1.2rem; }
    .s4-img-wrap       { right: -18vw; bottom: -8vh; height: 108%; transform: none; }

    #slide-4 .h-slide-inner { padding: 5vh 4vw 5vh 6vw; gap: 3vw; }
    #slide-4 .s4-bottom-text p {
        color: var(--color-navy);
        text-shadow: 0 0 12px var(--hs-cream), 0 0 24px var(--hs-cream), 0 0 4px var(--hs-cream);
    }
    #slide-4 .s4-cta-pill {
        color: var(--color-navy);
        border-color: var(--color-navy);
        text-shadow: 0 0 8px var(--hs-cream);
        filter: drop-shadow(0 0 6px var(--hs-cream));
    }
    #slide-4 .s4-cta-pill::before { background: var(--color-navy); }
    #slide-4 .s4-cta-pill:hover   { color: var(--color-green); }
    #slide-4 .s4-cta-pill:hover::before { background: var(--color-navy); }
}


/* ══════════════════════════════════════
   DESKTOP ESTRECHO — 1024px–1279px
   iPad Mini landscape (1024×768),
   iPad Air landscape (1180×820).
   Con el nuevo sistema de 3 criterios estos
   dispositivos entran en desktop (landscape +
   ≥768px + ≥500px alto) pero tienen ancho
   insuficiente para el layout desktop base.
   Comprimir tipografía y ajustar imagen S4.
══════════════════════════════════════ */
@media (min-width: 1200px) and (orientation: landscape) and (min-height: 500px) and (max-width: 1279px) {

    /* S1 — tipografía comprimida */
    .s1-left h2     { font-size: clamp(52px, 7.5vw, 88px); }
    .s1-left p      { font-size: clamp(13px, 1.3vw, 17px); margin-top: 1.4rem; max-width: 380px; }
    .s1-right       { width: 48vw; min-width: 380px; }

    /* S2 */
    .s2-center h2   { font-size: clamp(48px, 7vw, 88px); }
    .s2-center p    { font-size: clamp(13px, 1.3vw, 17px); }
    .s2-img-a       { top: 20%; width: 26vw; }
    .s2-img-b       { bottom: 14%; width: 20vw; }

    /* S3 */
    .s3-map-wrap    { height: 82vh; }
    .s3-right-text h2 { font-size: clamp(44px, 6.5vw, 80px); }
    .s3-copy-block .ch { font-size: clamp(14px, 1.8vw, 22px); }
    .card-val       { font-size: clamp(48px, 6.5vw, 80px); }

    /* S4 — imagen como fondo con overlay, igual que tablet portrait.
       En 1024px el cutout desborda fuera de vista — convertir a fondo. */
    .s4-title-wrap h2  { font-size: clamp(52px, 7.5vw, 96px); line-height: .84; }
    .s4-bottom-text    { margin-bottom: 1.5rem; max-width: 380px; }
    .s4-bottom-text p  { font-size: clamp(13px, 1.3vw, 17px); }
    .s4-cta-pill       { padding: 1.2rem 2.6rem; font-size: 12px; }

    #slide-4 .h-slide-inner {
        padding: 7vh 4vw 7vh 5vw;
        gap: 3vw;
    }
    #slide-4 .s4-right-col {
        position: absolute !important;
        inset: 0;
        width: 100% !important;
        height: 100% !important;
        flex: none !important;
        z-index: 0;
        overflow: hidden;
    }
    #slide-4 .s4-img-wrap {
        position: absolute !important;
        inset: 0 !important;
        width: 100% !important;
        height: 100% !important;
        right: auto !important;
        bottom: auto !important;
        transform: none !important;
    }
    #slide-4 .s4-img-wrap img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center top;
    }
    #slide-4 .s4-img-wrap::after {
        content: '';
        position: absolute;
        inset: 0;
        background: rgba(240,235,220,.82);
    }
    #slide-4 .s4-left-col {
        position: relative;
        z-index: 3;
        flex: 1;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
    #slide-4 .s4-bottom-text p {
        color: rgba(11,26,46,.85);
        text-shadow: none;
    }
    #slide-4 .s4-cta-pill {
        color: var(--color-navy);
        border-color: var(--color-navy);
        text-shadow: none;
        filter: none;
    }
    #slide-4 .s4-cta-pill:hover { color: var(--color-green); }
}

/* ══════════════════════════════════════
   MOBILE + TABLET — CARD STACK
   Nuevo sistema de 3 criterios (negado):
   Cubre: mobile portrait/landscape,
   tablet portrait (iPad Mini/Air/Pro),
   tablet landscape (iPad Mini/Air/Pro).
   Desktop (≥768px + landscape + ≥500px alto)
   usa scroll horizontal.
══════════════════════════════════════ */
@media not all and (min-width: 1200px) and (orientation: landscape) and (min-height: 500px) {

    /* ── Ocultar UI de desktop ── */
    #h-progress-bar,
    #h-counter { display: none !important; }

    /* Track no se anima en mobile — liberar capa de compositor */
    #h-track { will-change: auto; }

    /* ── Infraestructura del stack ──
       JS setea en runtime:
       - #h-scroll-section: height = N × 100dvh
       - #h-pin-wrapper: sticky, top 0, height 100dvh, overflow hidden
       - #h-track: relative, height 100dvh
       - .h-slide: absolute, top 0, width 100%, height 100dvh
       CSS solo define el interior de cada card. */

    .h-slide {
        border-radius: 24px 24px 0 0;
        overflow: hidden;
        outline: none;
        -webkit-tap-highlight-color: transparent;
        will-change: transform;
    }

    #slide-1 { border-radius: 0; }

    .h-slide-inner {
        display: flex;
        flex-direction: column;
        width: 100%;
        height: 100%;
        padding: 0;
        gap: 0;
        position: relative;
        overflow: hidden;
    }

    .h-slide-tag {
        position: absolute;
        top: 1.4rem;
        left: 1.6rem;
        font-size: 10px;
        letter-spacing: .2em;
        z-index: 20;
    }

    /* ══════════════════════════════════
       SLIDE 1 — navy
       Título top-left. Cutout bottom-right.
       Copy en franja al fondo.
    ══════════════════════════════════ */
    #slide-1 { background: var(--color-navy); }

    #slide-1 .h-slide-inner {
        justify-content: flex-start;
        align-items: flex-start;
        position: relative;
    }

    #slide-1 .s1-left {
        position: absolute;
        top: 0; left: 0; right: 0; bottom: 0;
        padding: 4.5rem 0 0 1.4rem;
        display: flex;
        flex-direction: column;
        justify-content: flex-start;
        z-index: 3;
    }

    #slide-1 .s1-left h2 {
        font-family: var(--font-display);
        font-size: clamp(40px, 10.5vw, 96px);
        line-height: .84;
        color: var(--color-white);
        letter-spacing: -.01em;
        white-space: nowrap;
        overflow: visible;
    }

    #slide-1 .s1-left h2 em {
        font-style: normal;
        color: var(--color-green);
    }

    #slide-1 .s1-left p {
        display: block;
        position: absolute;
        bottom: 0; left: 0; right: 0;
        padding: 1.4rem 1.4rem 2.2rem;
        font-family: var(--font-body);
        font-size: clamp(13px, 2.2vw, 17px);
        color: rgba(255,255,255,.68);
        line-height: 1.65;
        margin: 0;
        border-top: 1px solid rgba(255,255,255,.14);
        z-index: 5;
        background: none;
    }

    #slide-1 .s1-right {
        position: absolute;
        inset: 0;
        width: 100% !important;
        height: 100% !important;
        max-width: none !important;
        min-width: 0 !important;
        z-index: 1;
        overflow: hidden;
        pointer-events: none;
    }

    #slide-1 .s1-img-wrap {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
    }

    #slide-1 .s1-img-wrap picture {
        display: block;
        position: absolute;
        inset: 0;
    }

    #slide-1 .s1-img-wrap img {
        position: absolute !important;
        inset: 0 !important;
        width: 100% !important;
        height: 100% !important;
        max-width: none !important;
        object-fit: cover !important;
        object-position: center 62% !important;
        filter: none !important;
        transform: none !important;
    }

    #slide-1 .s1-img-wrap::after {
        content: '';
        position: absolute;
        inset: 0;
        background: rgba(13,30,56,.76);
    }

    /* Imagen — fondo completo con overlay navy */
    #slide-1 .s1-deco { display: none; }

    /* ══════════════════════════════════
       SLIDE 2 — cream
       Imagen A de fondo con overlay.
       Tipografía + métricas encima.
    ══════════════════════════════════ */
    #slide-2 { background: var(--hs-cream); }

    #slide-2 .h-slide-inner {
        flex-direction: column;
        justify-content: center;
        padding: 5rem 1.4rem 2.4rem;
        align-items: flex-start;
        position: relative;
        gap: 2rem;
    }

    /* Imagen A — fondo completo */
    #slide-2 .s2-img-a {
        display: block !important;
        position: absolute !important;
        inset: 0;
        width: 100% !important;
        height: 100% !important;
        transform: none !important;
        top: 0 !important;
        left: 0 !important;
        border-radius: 0;
        aspect-ratio: unset;
        z-index: 0;
        overflow: hidden;
    }

    #slide-2 .s2-img-a img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center 20%;
    }

    /* Overlay sobre imagen — mantiene texto legible */
    #slide-2 .s2-img-a::after {
        content: '';
        position: absolute;
        inset: 0;
        background: rgba(240,235,220,.9);
    }

    #slide-2 .s2-img-b { display: none !important; }

    #slide-2 .s2-center {
        text-align: left;
        padding: 0;
        max-width: 100%;
        position: relative;
        z-index: 3;
        width: 100%;
    }

    #slide-2 .s2-center h2 {
        font-family: var(--font-display);
        font-size: clamp(36px, 9.5vw, 80px);
        line-height: .85;
        color: var(--color-navy);
        letter-spacing: -.01em;
    }

    #slide-2 .s2-center h2 em {
        font-style: normal;
        color: var(--color-green);
    }

    #slide-2 .s2-center p {
        font-family: var(--font-body);
        font-size: clamp(13px, 2.2vw, 17px);
        color: rgba(11,26,46,.9);
        line-height: 1.65;
        margin-top: 1.2rem;
        max-width: 100%;
        text-align: left;
        margin-left: 0;
        margin-right: 0;
    }

    /* Métricas en fila */
    .s2-metrics {
        display: flex;
        width: 100%;
        gap: 0;
        border-top: 1px solid rgba(11,26,46,.15);
        padding-top: 1.4rem;
        position: relative;
        z-index: 3;
    }

    .s2-metric {
        flex: 1;
        display: flex;
        flex-direction: column;
        gap: .3rem;
    }

    .s2-metric + .s2-metric {
        border-left: 1px solid rgba(11,26,46,.15);
        padding-left: 1.2rem;
    }

    .s2-metric-num {
        font-family: var(--font-display);
        font-size: clamp(44px, 11vw, 88px);
        line-height: .85;
        color: var(--color-navy);
        letter-spacing: -.02em;
    }

    .s2-metric-num span { color: var(--color-green); }

    .s2-metric-label {
        font-family: var(--font-body);
        font-size: clamp(10px, 1.6vw, 13px);
        font-weight: 500;
        color: rgba(11,26,46,.62);
        letter-spacing: .12em;
        text-transform: uppercase;
        line-height: 1.4;
    }

    #slide-2 .s2-deco { display: none; }

    /* ══════════════════════════════════
       SLIDE 3 — navy
       26 integrado en el título como dato
       inline. SVG de fondo decorativo.
    ══════════════════════════════════ */
    #slide-3 { background: var(--color-navy); }

    #slide-3 .s3-left-map,
    #slide-3 .s3-card { display: none !important; }

    #slide-3 .h-slide-inner {
        flex-direction: column;
        justify-content: flex-start;
        padding: 5rem 1.4rem 2.8rem; /* bottom aumentado para el stat */
        position: relative;
        overflow: hidden;
        align-items: flex-start;
        gap: 0;
    }

    /* SVG del mapa como fondo decorativo */
    #slide-3 .s3-map-bg {
        position: absolute;
        right: -12%;
        top: 50%;
        transform: translateY(-50%);
        width: 82%;
        max-width: 700px;
        height: auto;
        opacity: .07;
        pointer-events: none;
        z-index: 0;
    }

    #slide-3 .s3-map-bg path {
        fill: rgba(255,255,255,1);
        stroke: none;
        pointer-events: none !important;
        cursor: default !important;
    }

    /* Número 26 — entre s3-h2-top y s3-h2-bottom,
       con espacio generoso arriba y abajo */
    #slide-3 .s3-big-num {
        font-family: var(--font-display);
        font-size: clamp(72px, 17vw, 160px);
        max-width: 100%;
        line-height: .82;
        color: var(--color-green);
        letter-spacing: -.03em;
        pointer-events: none;
        user-select: none;
        position: relative;
        z-index: 2;
        display: block;
        margin-top: .12em;
        margin-bottom: .06em;
    }

    #slide-3 .s3-right-text {
        width: 100%;
        padding: 0;
        align-items: flex-start;
        text-align: left;
        flex: 0 0 auto;
        z-index: 3;
        position: relative;
        order: unset;
        margin-top: 0;
        display: flex;
        flex-direction: column;
    }

    #slide-3 .s3-right-text h2,
    #slide-3 .s3-h2-top,
    #slide-3 .s3-h2-bottom {
        font-family: var(--font-display);
        font-size: clamp(36px, 9.5vw, 88px);
        line-height: .9;
        color: var(--color-white);
        letter-spacing: .01em;
        text-align: left;
        margin: 0;
    }

    #slide-3 .s3-h2-top { margin-bottom: 0; }
    #slide-3 .s3-h2-bottom { margin-top: 0; }

    #slide-3 .s3-right-text h2 em,
    #slide-3 .s3-h2-top em,
    #slide-3 .s3-h2-bottom em {
        font-style: normal;
        color: var(--color-green);
    }

    #slide-3 .s3-copy-block {
        margin-top: 1rem;
        margin-bottom: 1.6rem;
        order: 3;
        position: relative;
        z-index: 3;
        width: 100%;
    }

    #slide-3 .s3-copy-block .ch {
        font-family: var(--font-body);
        font-size: clamp(13px, 2.4vw, 20px);
        color: rgba(255,255,255,.5);
        letter-spacing: .02em;
        line-height: 1.55;
        text-transform: none;
        font-weight: 400;
    }

    /* Stat única al fondo — dato diferente al título,
       con espacio respirable entre el copy y el borde */
    #slide-3 .s3-bottom-stats {
        display: flex;
        align-items: flex-start;
        gap: 1rem;
        width: 100%;
        position: relative; /* flujo normal en mobile — sin absolute para evitar superposición */
        bottom: auto;
        left: auto;
        right: auto;
        z-index: 3;
        flex-shrink: 0;
        margin-top: auto; /* empuja el stat al fondo del flex column */
        padding-top: 1.4rem;
        border-top: 1px solid rgba(255,255,255,.08);
    }

    #slide-3 .s3-stat-item {
        display: flex;
        align-items: flex-start;
        flex-direction: column;
        gap: .2rem;
    }

    /* Ocultar segundo stat — solo mostramos +200 */
    #slide-3 .s3-stat-item + .s3-stat-item {
        display: none;
    }

    #slide-3 .s3-stat-num {
        font-family: var(--font-display);
        font-size: clamp(36px, 9vw, 72px);
        line-height: .85;
        color: var(--color-green);
        letter-spacing: -.02em;
        flex-shrink: 0;
    }

    #slide-3 .s3-stat-label {
        font-family: var(--font-body);
        font-size: clamp(11px, 3vw, 13px);
        font-weight: 500;
        color: rgba(255,255,255,.4);
        letter-spacing: .1em;
        text-transform: uppercase;
        line-height: 1.4;
        padding-bottom: 0;
    }

    #slide-3 .s3-deco { display: none; }

    /* ══════════════════════════════════
       SLIDE 4 — cream
       Imagen de fondo con overlay cream.
       Texto + CTA encima.
    ══════════════════════════════════ */
    #slide-4 {
        background: var(--hs-cream);
        position: relative; /* necesario para que s4-right-col absolute se ancle aquí */
    }

    #slide-4 .h-slide-inner {
        flex-direction: column !important;
        align-items: flex-start;
        justify-content: space-between;
        padding: 4.5rem 0 2.4rem 1.4rem;
        gap: 0;
        position: relative;
    }

    /* Imagen — fondo completo con overlay */
    #slide-4 .s4-right-col {
        display: block !important;
        position: absolute !important;
        inset: 0;
        width: 100% !important;
        height: 100% !important;
        z-index: 0;
        overflow: hidden;
    }

    #slide-4 .s4-img-wrap {
        position: absolute !important;
        inset: 0;
        width: 100% !important;
        height: 100% !important;
        right: auto !important;
        bottom: auto !important;
        transform: none !important;
    }

    #slide-4 .s4-img-wrap img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center top;
    }

    /* Overlay cream — mantiene legibilidad del texto navy */
    #slide-4 .s4-img-wrap::after {
        content: '';
        position: absolute;
        inset: 0;
        background: rgba(240,235,220,.86);
    }

    #slide-4 .s4-left-col {
        position: relative;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        height: 100%;
        width: 100%;
        z-index: 3;
        padding-right: 1.4rem;
    }

    #slide-4 .s4-title-wrap { margin-bottom: 0; }

    #slide-4 .s4-title-wrap h2 {
        font-family: var(--font-display);
        font-size: clamp(36px, 9.5vw, 80px);
        line-height: .82;
        color: var(--color-navy);
        letter-spacing: -.01em;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
    }

    #slide-4 .s4-title-wrap h2 em {
        font-style: normal;
        color: var(--color-green);
    }

    #slide-4 .s4-bottom-text {
        margin-bottom: 0;
        max-width: 90%;
    }

    #slide-4 .s4-bottom-text p {
        font-family: var(--font-body);
        font-size: clamp(13px, 2.2vw, 17px);
        color: rgba(11,26,46,.82);
        line-height: 1.6;
    }

    #slide-4 .s4-value-bar {
        margin-top: .9rem;
        padding-top: .9rem;
        gap: .7rem .95rem;
    }

    #slide-4 .s4-value-bar span {
        font-size: clamp(11px, 2.95vw, 13px);
        letter-spacing: .08em;
        color: rgba(11,26,46,.74);
    }

    #slide-4 .s4-value-bar span::before {
        width: 8px;
        height: 8px;
        box-shadow: 0 0 0 2px rgba(57,181,74,.2);
    }

    /* CTA — centrado */
    #slide-4 .s4-cta-pill {
        align-self: flex-start;
        margin-top: 1.6rem;
        margin-left: 0;
        margin-right: 0;
        padding: 1rem 2.8rem;
        font-size: 11px;
        letter-spacing: .18em;
        border-color: var(--color-navy);
        color: var(--color-navy);
    }

    #slide-4 .s4-cta-pill::before { background: var(--color-navy); }
    #slide-4 .s4-cta-pill:hover   { color: var(--color-green); }
    #slide-4 .s4-cta-pill:hover::before { background: var(--color-navy); }

    /* Deco "PASO" — marca de agua al fondo */
    #slide-4 .s4-deco {
        display: block;
        position: absolute;
        bottom: -4vh;
        left: -2vw;
        font-family: var(--font-display);
        font-size: 55vw;
        line-height: 1;
        color: rgba(11,26,46,.04);
        pointer-events: none;
        user-select: none;
        z-index: 1;
        white-space: nowrap;
        letter-spacing: -.02em;
    }

    /* ══════════════════════════════════
       PHONE LANDSCAPE — max-height: 499px
    ══════════════════════════════════ */
    @media (max-height: 499px) and (orientation: landscape) {

        .h-slide-tag { top: .7rem; left: 1.2rem; }

        #slide-1 .s1-left       { padding: 2rem 0 0 1.2rem; }
        #slide-1 .s1-left h2    { font-size: clamp(38px, 7vw, 56px); }
        #slide-1 .s1-left p     { font-size: 12px; padding: .9rem 1.2rem 1.4rem; }

        #slide-2 .h-slide-inner { padding: 2rem 1.2rem 1.6rem; }
        #slide-2 .s2-center h2  { font-size: clamp(34px, 6.5vw, 52px); }
        #slide-2 .s2-center p   { font-size: 12px; margin-top: .5rem; }
        .s2-metrics             { padding-top: .7rem; }
        .s2-metric-num          { font-size: clamp(30px, 6vw, 48px); }
        .s2-metric-label        { font-size: 12px; }

        #slide-3 .h-slide-inner     { padding: 2rem 1.2rem 1.2rem; }
        #slide-3 .s3-big-num        { font-size: clamp(80px, 18vw, 120px); }
        #slide-3 .s3-right-text h2  { font-size: clamp(22px, 4.5vw, 36px); }
        #slide-3 .s3-copy-block .ch { font-size: 12px; line-height: 1.45; }
        #slide-3 .s3-map-bg         { width: 62%; max-width: 560px; right: -14%; opacity: .065; }
        #slide-3 .s3-copy-block     { max-width: 58%; margin-top: .6rem; }
        #slide-3 .s3-bottom-stats   {
            position: absolute;
            right: 2.2rem;
            bottom: 1.8rem;
            width: auto;
            border-top: 0;
            border-left: 2px solid rgba(57,181,74,.55);
            background: rgba(8,20,40,.42);
            border-radius: 8px;
            padding: .45rem .75rem .45rem .8rem;
            margin: 0;
        }
        #slide-3 .s3-stat-item      { flex-direction: column; align-items: center; gap: .15rem; }
        #slide-3 .s3-stat-num       { font-size: clamp(38px, 7.4vw, 54px); line-height: .86; }
        #slide-3 .s3-stat-label     { font-size: 12px; line-height: 1.25; padding-bottom: 0; text-align: center; color: rgba(255,255,255,.56); }

        #slide-4 .h-slide-inner    { padding: 2rem 0 1.4rem 1.2rem; }
        #slide-4 .s4-title-wrap h2 { font-size: clamp(40px, 7.6vw, 62px); }
        #slide-4 .s4-bottom-text   { max-width: 76%; }
        #slide-4 .s4-bottom-text p { font-size: 12px; color: rgba(11,26,46,.9); }
        #slide-4 .s4-value-bar     {
            margin-top: .55rem;
            padding-top: .45rem;
            gap: 0;
            flex-wrap: nowrap;
            align-items: center;
        }
        #slide-4 .s4-value-bar span{
            font-size: 12px;
            letter-spacing: .05em;
            color: rgba(11,26,46,.7);
            white-space: nowrap;
        }
        #slide-4 .s4-value-bar span + span {
            margin-left: .5rem;
            padding-left: .5rem;
            border-left: 1px solid rgba(11,26,46,.16);
        }
        #slide-4 .s4-value-bar span::before {
            width: 4px;
            height: 4px;
            box-shadow: none;
        }
        #slide-4 .s4-cta-pill      { padding: .7rem 1.6rem; font-size: 12px; align-self: flex-start; margin-left: 0; margin-right: 0; }
        #slide-2 .s2-img-a::after,
        #slide-4 .s4-img-wrap::after {
            opacity: .82;
        }
    }
}