/* ============================================================
   IMEI BOMA Connection — Design System
   Dark neon tech. Palette extracted from brand deck.
   ============================================================ */

/* ---------- Fonts ---------- */
@font-face {
    font-family: "Gilroy";
    src: url("../fonts/gilroy/Gilroy-SemiBold.ttf") format("truetype");
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Gilroy";
    src: url("../fonts/gilroy/Gilroy-Bold.ttf") format("truetype");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Gilroy";
    src: url("../fonts/gilroy/Gilroy-ExtraBold.ttf") format("truetype");
    font-weight: 800;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Gilroy";
    src: url("../fonts/gilroy/Gilroy-Heavy.ttf") format("truetype");
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

:root {
    /* Brand palette */
    --navy: #011334;
    --navy-900: #010d26;
    --navy-800: #061b45;
    --ink: #0a1f4d;
    --nav-h: 76px;
    --subnav-h: 60px;
    --mint: #32ffb0;
    --cyan: #40eeff;
    --white: #ffffff;
    --mist: #b9c6e8;
    --mist-dim: #6b7aa3;

    --grad-neon: linear-gradient(120deg, var(--mint) 0%, var(--cyan) 100%);
    --grad-neon-r: linear-gradient(120deg, var(--cyan) 0%, var(--mint) 100%);

    --glow-mint: 0 0 40px rgba(50, 255, 176, 0.35);
    --glow-cyan: 0 0 40px rgba(64, 238, 255, 0.3);

    --font-display: "Gilroy", "Trebuchet MS", sans-serif;
    --font-body: "Poppins", system-ui, sans-serif;

    --maxw: 1240px;
    --radius: 18px;
    --ease: cubic-bezier(0.2, 0.7, 0.2, 1);
}

/* ---------- Reset ---------- */
*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}
html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
}
body {
    font-family: var(--font-body);
    background: var(--navy);
    color: var(--mist);
    line-height: 1.6;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
}
img {
    display: block;
    max-width: 100%;
}
a {
    color: inherit;
    text-decoration: none;
}
button {
    font-family: inherit;
    cursor: pointer;
    border: none;
    background: none;
}
ul {
    list-style: none;
}

/* ---------- Atmospheric background ---------- */
body::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -2;
    background:
        radial-gradient(
            60% 50% at 80% -5%,
            rgba(64, 238, 255, 0.16),
            transparent 60%
        ),
        radial-gradient(
            55% 45% at 5% 10%,
            rgba(50, 255, 176, 0.13),
            transparent 60%
        ),
        radial-gradient(
            70% 60% at 50% 110%,
            rgba(50, 255, 176, 0.1),
            transparent 60%
        ),
        var(--navy);
}
/* ---------- Typography ---------- */
h1,
h2,
h3,
h4 {
    font-family: var(--font-display);
    color: var(--white);
    line-height: 1.04;
    font-weight: 800;
    letter-spacing: -0.02em;
}
.eyebrow {
    font-family: var(--font-body);
    font-weight: 700;
    font-size: 0.8rem;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--mint);
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
}
.eyebrow::before {
    content: "";
    width: 28px;
    height: 2px;
    background: var(--grad-neon);
}
.grad-text {
    background: var(--grad-neon);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* ---------- Layout ---------- */
.wrap {
    width: 100%;
    max-width: var(--maxw);
    margin-inline: auto;
    padding-inline: clamp(1.2rem, 4vw, 2.5rem);
}
section {
    position: relative;
    padding-block: clamp(2.5rem, 4vw, 3.75rem);
}
/* First content section sits tight under the full-bleed banner */
.hero-img + section {
    padding-top: clamp(2rem, 3.5vw, 3rem);
}
.section-head {
    max-width: 760px;
    margin-bottom: clamp(2.2rem, 4vw, 3.5rem);
}
.section-head h2 {
    font-size: clamp(2rem, 5vw, 3.4rem);
    margin-top: 1rem;
}
.section-head p {
    margin-top: 1.1rem;
    font-size: 1.06rem;
    color: var(--mist);
}
.section-head--wide {
    max-width: none;
}
.flow-strip {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    margin-top: 3rem;
}
.flow-word {
    font-family: var(--font-display);
    font-weight: 900;
    font-size: clamp(1.8rem, 4vw, 3rem);
    color: var(--white);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    white-space: nowrap;
}
.flow-line {
    flex: 1;
    height: 2px;
    background: var(--grad-neon);
    border-radius: 2px;
}
@media (max-width: 640px) {
    .flow-strip {
        flex-direction: column;
        gap: 1rem;
    }
    .flow-line {
        width: 40px;
    }
}
.demand-lead {
    margin-top: 1.1rem;
    font-size: 1.06rem;
    color: var(--mist);
    margin-bottom: 0;
}
.demand-cards {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.4rem;
}
.demand-card {
    border-radius: var(--radius);
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: linear-gradient(
        165deg,
        rgba(10, 31, 77, 0.5),
        rgba(1, 13, 38, 0.3)
    );
    padding: 1.8rem;
    transition:
        transform 0.35s var(--ease),
        border-color 0.35s;
}
.demand-card:hover {
    transform: translateY(-6px);
    border-color: rgba(64, 238, 255, 0.35);
}
.demand-card__ico {
    width: 46px;
    height: 46px;
    border-radius: 12px;
    background: rgba(50, 255, 176, 0.1);
    display: grid;
    place-items: center;
    margin-bottom: 1.1rem;
    color: var(--mint);
}
.demand-card__ico svg {
    width: 23px;
    height: 23px;
}
.demand-card p {
    font-size: 1rem;
    font-weight: 600;
    color: var(--white);
    line-height: 1.4;
}
@media (max-width: 760px) {
    .demand-cards {
        grid-template-columns: repeat(2, 1fr);
    }
}
.que-es-cols {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2.5rem;
    margin-top: 2.5rem;
}
.que-es-cols p {
    font-size: 1.06rem;
    color: var(--mist);
    line-height: 1.8;
}
@media (max-width: 760px) {
    .que-es-cols {
        grid-template-columns: 1fr;
    }
}

/* ---------- Navbar ---------- */
.nav {
    position: sticky;
    top: 0;
    z-index: 100;
    backdrop-filter: blur(16px);
    background: rgba(1, 13, 38, 0.55);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.nav__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: var(--nav-h);
}
.brand {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    font-family: var(--font-display);
    font-weight: 800;
    color: var(--white);
    font-size: 1.05rem;
    letter-spacing: -0.01em;
}
.brand__mark {
    width: 34px;
    height: 34px;
    border-radius: 9px;
    background: var(--grad-neon);
    display: grid;
    place-items: center;
    color: var(--navy-900);
    font-weight: 800;
    font-size: 0.9rem;
    box-shadow: var(--glow-mint);
}
.brand small {
    display: block;
    font-family: var(--font-body);
    font-weight: 600;
    font-size: 0.62rem;
    letter-spacing: 0.22em;
    color: var(--mint);
    text-transform: uppercase;
}
.brand__logo {
    height: 56px;
    width: auto;
    max-width: 280px;
    object-fit: contain;
    object-position: left center;
    display: block;
}
.footer .brand__logo {
    height: 52px;
}
@media (max-width: 760px) {
    .brand__logo {
        height: 44px;
    }
}
.nav__links {
    display: flex;
    align-items: center;
    gap: 2rem;
}
.nav__links a {
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--mist);
    position: relative;
    transition: color 0.25s;
}
.nav__links a:hover,
.nav__links a.is-active {
    color: var(--white);
}
.nav__links a.is-active::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -6px;
    height: 2px;
    background: var(--grad-neon);
}
.nav__toggle {
    display: none;
    width: 44px;
    height: 44px;
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    flex-direction: column;
    gap: 5px;
    align-items: center;
    justify-content: center;
}
.nav__toggle span {
    width: 20px;
    height: 2px;
    background: var(--white);
    transition: 0.3s;
}
.nav.open .nav__toggle span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
}
.nav.open .nav__toggle span:nth-child(2) {
    opacity: 0;
}
.nav.open .nav__toggle span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
}

/* ---------- Secondary nav (in-page pills) ---------- */
.subnav {
    position: sticky;
    top: var(--nav-h);
    z-index: 99;
    background: rgba(1, 13, 38, 0.55);
    backdrop-filter: blur(16px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.subnav__inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: clamp(0.6rem, 1.8vw, 1.6rem);
    min-height: var(--subnav-h);
    padding-block: 0.7rem;
}
.subnav__pill {
    font-weight: 600;
    font-size: 0.9rem;
    white-space: nowrap;
    color: var(--mist);
    border: 1px solid rgba(50, 255, 176, 0.45);
    border-radius: 999px;
    padding: 0.55rem 1.35rem;
    transition:
        color 0.25s,
        background 0.25s,
        border-color 0.25s,
        box-shadow 0.25s;
}
.subnav__pill:hover,
.subnav__pill:focus-visible {
    color: var(--navy-900);
    background: var(--grad-neon);
    border-color: transparent;
    box-shadow: var(--glow-mint);
}
/* Mobile sub-items are cloned into the drawer; hidden on desktop */
.nav__sub {
    display: none;
}
/* Offset anchor targets so the sticky header + subnav don't cover them */
section[id] {
    scroll-margin-top: calc(var(--nav-h) + var(--subnav-h) + 8px);
}

/* ---------- Buttons ---------- */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.9rem 1.5rem;
    border-radius: 999px;
    font-weight: 700;
    font-size: 0.96rem;
    letter-spacing: -0.01em;
    transition:
        transform 0.25s var(--ease),
        box-shadow 0.3s,
        background 0.3s,
        color 0.3s;
    white-space: nowrap;
}
.btn:hover {
    cursor: pointer;
}
.btn--primary {
    background: var(--grad-neon);
    color: var(--navy-900);
}
.btn--primary:hover {
    transform: translateY(-3px);
}
.btn--light {
    background: var(--white);
    color: var(--navy-900);
}
.btn--light:hover {
    transform: translateY(-3px);
    box-shadow: 0 16px 34px rgba(1, 13, 38, 0.32);
}
.btn--ghost {
    color: var(--white);
    border: 1px solid rgba(255, 255, 255, 0.18);
}
.btn--ghost:hover {
    border-color: var(--mint);
    color: var(--mint);
    transform: translateY(-3px);
}
.btn--lg {
    padding: 1.1rem 2rem;
    font-size: 1.05rem;
}
.btn .arr {
    transition: transform 0.25s var(--ease);
}
.btn:hover .arr {
    transform: translateX(4px);
}

/* ---------- Intro text (two-column opener) ---------- */
.intro-text {
    position: relative;
}
.intro-text .wrap {
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    gap: clamp(2rem, 4vw, 3.5rem);
    align-items: center;
}
.intro-text__copy::before {
    content: "";
    display: block;
    width: 56px;
    height: 3px;
    background: var(--grad-neon);
    border-radius: 2px;
    margin: 0 0 2rem;
}
.intro-text__title {
    font-size: clamp(1.6rem, 3.5vw, 2.6rem);
    font-weight: 900;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--white);
    line-height: 1.25;
    margin-bottom: 1.8rem;
}
.intro-text__body {
    font-size: clamp(1.15rem, 2vw, 1.4rem);
    color: var(--mist);
    max-width: 52ch;
    line-height: 1.85;
}
.intro-text__media {
    margin: 0;
    border-radius: var(--radius);
    overflow: hidden;
    aspect-ratio: 4 / 3;
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 30px 70px rgba(0, 0, 0, 0.45);
}
.intro-text__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    filter: saturate(0.9);
    transition:
        transform 0.6s var(--ease),
        filter 0.4s;
}
.intro-text__media:hover img {
    transform: scale(1.04);
    filter: saturate(1.05);
}
@media (max-width: 768px) {
    .intro-text .wrap {
        grid-template-columns: 1fr;
    }
    .intro-text__media {
        aspect-ratio: 16 / 9;
    }
}

/* ---------- Hero ---------- */
.hero-img {
    display: block;
    width: 100%;
    line-height: 0;
    padding: 0;
}
.hero-img img {
    display: block;
    width: 100%;
    height: auto;
}
.hero {
    padding-block: clamp(4rem, 10vw, 8rem) clamp(4rem, 8vw, 6.5rem);
}
.hero__grid {
    display: grid;
    gap: 3rem;
    align-items: center;
}
.hero h1 {
    font-size: clamp(2.8rem, 8vw, 6rem);
}
.hero__lede {
    margin-top: 1.6rem;
    font-size: clamp(1.05rem, 2vw, 1.3rem);
    max-width: 56ch;
    color: var(--mist);
}
.hero__cta {
    margin-top: 2.5rem;
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}
.hero__meta {
    margin-top: 3rem;
    display: flex;
    flex-wrap: wrap;
    gap: 2.4rem;
}
.hero__meta div span {
    display: block;
}
.hero__meta .k {
    font-family: var(--font-display);
    font-size: 1.9rem;
    color: var(--white);
    font-weight: 800;
}
.hero__meta .l {
    font-size: 0.82rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--mist-dim);
    margin-top: 0.2rem;
}

/* floating badge cluster (home hero visual) */
.hero__art {
    position: relative;
    min-height: 320px;
}
.orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(2px);
    animation: float 7s var(--ease) infinite;
}
.orb--1 {
    width: 240px;
    height: 240px;
    background: radial-gradient(
        circle at 30% 30%,
        rgba(50, 255, 176, 0.5),
        transparent 70%
    );
    top: 0;
    right: 6%;
}
.orb--2 {
    width: 200px;
    height: 200px;
    background: radial-gradient(
        circle at 30% 30%,
        rgba(64, 238, 255, 0.45),
        transparent 70%
    );
    bottom: 4%;
    left: 8%;
    animation-delay: -2.5s;
}
.glass-card {
    position: relative;
    z-index: 2;
    background: linear-gradient(
        160deg,
        rgba(10, 31, 77, 0.85),
        rgba(1, 13, 38, 0.7)
    );
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--radius);
    padding: 1.8rem;
    backdrop-filter: blur(10px);
    box-shadow: 0 30px 80px rgba(0, 0, 0, 0.5);
    max-width: 380px;
    margin-left: auto;
}
.glass-card h4 {
    font-size: 1.1rem;
    margin-bottom: 0.5rem;
}
.glass-card .pill {
    display: inline-block;
    padding: 0.3rem 0.8rem;
    border-radius: 999px;
    background: rgba(50, 255, 176, 0.12);
    color: var(--mint);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}
.glass-card ul {
    margin-top: 1.2rem;
    display: grid;
    gap: 0.7rem;
}
.glass-card li {
    display: flex;
    gap: 0.6rem;
    align-items: flex-start;
    font-size: 0.92rem;
    color: var(--mist);
}
.glass-card li::before {
    content: "▸";
    color: var(--cyan);
}

@keyframes float {
    0%,
    100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-22px);
    }
}

/* ---------- Pillars (home) ---------- */
.pillars {
    display: grid;
    gap: 1.5rem;
    grid-template-columns: 1fr 1fr;
}
.pillar {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius);
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: linear-gradient(
        165deg,
        rgba(10, 31, 77, 0.6),
        rgba(1, 13, 38, 0.4)
    );
    padding: clamp(1.8rem, 3vw, 2.8rem);
    transition:
        transform 0.4s var(--ease),
        border-color 0.4s;
}
.pillar:hover {
    transform: translateY(-8px);
    border-color: rgba(50, 255, 176, 0.4);
}
.pillar::after {
    content: "";
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 0.4s;
    z-index: 1;
    background: radial-gradient(
        80% 60% at 100% 0%,
        rgba(64, 238, 255, 0.14),
        transparent 60%
    );
}
.pillar:hover::after {
    opacity: 1;
}
.pillar__tag {
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--cyan);
}
.pillar h3 {
    font-size: clamp(1.7rem, 3.4vw, 2.5rem);
    margin: 0.8rem 0 1rem;
}
.pillar p {
    margin-bottom: 1.8rem;
}
.pillar__link {
    color: var(--white);
    font-weight: 700;
    display: inline-flex;
    gap: 0.5rem;
    align-items: center;
}
.pillar__link::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 2;
}
.pillar__link .arr {
    transition: transform 0.25s var(--ease);
}
.pillar:hover .pillar__link .arr {
    transform: translateX(5px);
}
.pillar__num {
    position: absolute;
    top: 1.4rem;
    right: 1.6rem;
    font-family: var(--font-display);
    font-weight: 800;
    font-size: 3.4rem;
    color: rgba(255, 255, 255, 0.05);
}

/* ---------- Pillar variants ---------- */
.pillar--cumbre {
    background:
        radial-gradient(
            ellipse 85% 70% at 0% 0%,
            rgba(50, 255, 176, 0.42) 0%,
            transparent 62%
        ),
        linear-gradient(150deg, #0f3d28 0%, #081e1a 55%, #021510 100%);
    border-color: rgba(50, 255, 176, 0.5);
}
.pillar--cumbre:hover {
    border-color: rgba(50, 255, 176, 0.8);
}
.pillar--cumbre::after {
    background: radial-gradient(
        85% 70% at 0% 0%,
        rgba(50, 255, 176, 0.28),
        transparent 62%
    );
}
.pillar--cumbre .pillar__tag {
    color: var(--mint);
}

.pillar--premio {
    background:
        radial-gradient(
            ellipse 85% 70% at 100% 0%,
            rgba(64, 238, 255, 0.38) 0%,
            transparent 62%
        ),
        linear-gradient(150deg, #093448 0%, #062030 55%, #010d26 100%);
    border-color: rgba(64, 238, 255, 0.5);
}
.pillar--premio:hover {
    border-color: rgba(64, 238, 255, 0.8);
}
.pillar--premio::after {
    background: radial-gradient(
        85% 70% at 100% 0%,
        rgba(64, 238, 255, 0.28),
        transparent 62%
    );
}

/* ---------- Stats strip ---------- */
.stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    text-align: center;
    border-block: 1px solid rgba(255, 255, 255, 0.08);
    padding-block: 2.6rem;
}
.stats .k {
    font-family: var(--font-display);
    font-size: clamp(2.2rem, 5vw, 3.2rem);
    font-weight: 800;
}
.stats .l {
    font-size: 0.85rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--mist-dim);
    margin-top: 0.3rem;
}

/* ---------- Feature / objective cards ---------- */
.cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.4rem;
}
.card {
    border-radius: var(--radius);
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: linear-gradient(
        165deg,
        rgba(10, 31, 77, 0.5),
        rgba(1, 13, 38, 0.3)
    );
    padding: 1.8rem;
    transition:
        transform 0.35s var(--ease),
        border-color 0.35s;
}
.card:hover {
    transform: translateY(-6px);
    border-color: rgba(64, 238, 255, 0.35);
}
.card__ico {
    width: 46px;
    height: 46px;
    border-radius: 12px;
    background: rgba(50, 255, 176, 0.1);
    display: grid;
    place-items: center;
    margin-bottom: 1.1rem;
    color: var(--mint);
}
.card__ico svg {
    width: 23px;
    height: 23px;
}
.fact svg {
    width: 17px;
    height: 17px;
    stroke: var(--mint);
    flex-shrink: 0;
}
.contact-line span svg {
    width: 18px;
    height: 18px;
    stroke: var(--cyan);
}
.card h4 {
    font-size: 1.2rem;
    margin-bottom: 0.5rem;
}
.card p {
    font-size: 0.95rem;
}

/* ---------- Timeline / agenda ---------- */
.timeline {
    display: grid;
    gap: 0;
    max-width: 880px;
}
.tl-item {
    display: grid;
    grid-template-columns: 130px 1fr;
    gap: 1.8rem;
    padding: 1.6rem 0;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    position: relative;
}
.tl-item:last-child {
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.tl-time {
    font-family: var(--font-display);
    font-weight: 800;
    color: var(--mint);
    font-size: 1.05rem;
    padding-top: 0.1rem;
}
.tl-body h4 {
    font-size: 1.2rem;
    margin-bottom: 0.35rem;
}
.tl-body .who {
    font-size: 0.85rem;
    color: var(--mist-dim);
    margin-top: 0.5rem;
    letter-spacing: 0.04em;
}
.tl-tag {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    padding: 0.25rem 0.7rem;
    border-radius: 999px;
    border: 1px solid rgba(64, 238, 255, 0.3);
    color: var(--cyan);
    margin-bottom: 0.6rem;
}

/* ---------- Gallery ---------- */
.gallery {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.9rem;
}
.gallery--winners {
    grid-template-columns: repeat(5, 1fr);
}
.shot {
    position: relative;
    overflow: hidden;
    border-radius: 14px;
    aspect-ratio: 4/3;
    cursor: pointer;
    background: var(--navy-800);
    border: 1px solid rgba(255, 255, 255, 0.06);
}
.gallery--winners .shot {
    aspect-ratio: 3/4;
}
.shot img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition:
        transform 0.6s var(--ease),
        filter 0.4s;
    filter: saturate(0.9);
}
.shot:hover img {
    transform: scale(1.08);
    filter: saturate(1.1);
}
.shot__cap {
    position: absolute;
    inset: auto 0 0 0;
    padding: 1.4rem 0.9rem 0.8rem;
    background: linear-gradient(transparent, rgba(1, 13, 38, 0.92));
    font-size: 0.8rem;
    color: var(--white);
    opacity: 0;
    transform: translateY(8px);
    transition: 0.35s;
}
.shot:hover .shot__cap {
    opacity: 1;
    transform: translateY(0);
}
.shot__cap b {
    color: var(--mint);
    display: block;
    font-family: var(--font-display);
}
.shot__yr {
    position: absolute;
    top: 0.7rem;
    left: 0.7rem;
    background: rgba(1, 13, 38, 0.7);
    backdrop-filter: blur(6px);
    color: var(--mint);
    font-weight: 800;
    font-family: var(--font-display);
    font-size: 0.78rem;
    padding: 0.2rem 0.6rem;
    border-radius: 7px;
}

/* ---------- Carousel (coverflow) ---------- */
.carousel {
    position: relative;
    margin-top: 1.6rem;
}
.carousel__viewport {
    position: relative;
    overflow: hidden;
    -webkit-mask-image: linear-gradient(
        90deg,
        transparent 0,
        #000 7%,
        #000 93%,
        transparent 100%
    );
    mask-image: linear-gradient(
        90deg,
        transparent 0,
        #000 7%,
        #000 93%,
        transparent 100%
    );
}
.carousel__track {
    display: flex;
    align-items: center;
    gap: 1.2rem;
    will-change: transform;
    transition: transform 0.6s var(--ease);
}
.carousel__slide {
    position: relative;
    flex: 0 0 auto;
    width: clamp(280px, 60vw, 640px);
    aspect-ratio: 16 / 10;
    border-radius: 14px;
    overflow: hidden;
    background: var(--navy-800);
    border: 1px solid rgba(255, 255, 255, 0.06);
    cursor: pointer;
    opacity: 0.4;
    filter: brightness(0.4) saturate(0.85);
    transform: scale(0.82);
    transition:
        transform 0.6s var(--ease),
        filter 0.6s var(--ease),
        opacity 0.6s var(--ease);
}
.carousel__slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.carousel__slide.is-active {
    opacity: 1;
    filter: none;
    transform: scale(1);
    border-color: rgba(50, 255, 176, 0.4);
    box-shadow:
        var(--glow-cyan),
        0 30px 70px rgba(0, 0, 0, 0.5);
}
.carousel__slide:focus-visible {
    outline: 2px solid var(--mint);
    outline-offset: 4px;
}
.carousel__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 5;
    width: 54px;
    height: 54px;
    border-radius: 50%;
    background: rgba(1, 13, 38, 0.55);
    backdrop-filter: blur(6px);
    border: 1px solid rgba(255, 255, 255, 0.18);
    color: var(--white);
    font-size: 1.6rem;
    line-height: 1;
    display: grid;
    place-items: center;
    cursor: pointer;
    transition:
        background 0.25s var(--ease),
        color 0.25s var(--ease),
        transform 0.25s var(--ease);
}
.carousel__nav:hover {
    background: var(--grad-neon);
    color: var(--navy-900);
    border-color: transparent;
}
.carousel__nav:focus-visible {
    outline: 2px solid var(--mint);
    outline-offset: 3px;
}
.carousel__nav--prev {
    left: clamp(0.5rem, 5vw, 3.5rem);
}
.carousel__nav--next {
    right: clamp(0.5rem, 5vw, 3.5rem);
}
.carousel__counter {
    text-align: center;
    margin-top: 1.4rem;
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 1rem;
    letter-spacing: 0.1em;
    color: var(--mist-dim);
}
.carousel__cur {
    color: var(--mint);
}
@media (prefers-reduced-motion: reduce) {
    .carousel__track,
    .carousel__slide {
        transition: none;
    }
}

/* ---------- Salón de la fama (Splide marquee) ---------- */
.salon {
    position: relative;
    margin-top: 1.6rem;
}
/* Edge fades over the track edges; on the static root so they never flicker. */
.salon::before,
.salon::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 40px;
    z-index: 2;
    pointer-events: none;
}
.salon::before {
    left: 0;
    background: linear-gradient(90deg, var(--navy), transparent);
}
.salon::after {
    right: 0;
    background: linear-gradient(270deg, var(--navy), transparent);
}
.salon__card {
    position: relative;
    width: 100%;
    aspect-ratio: 3/4;
    border-radius: 14px;
    overflow: hidden;
    cursor: pointer;
    background: var(--navy-800);
    border: 1px solid rgba(255, 255, 255, 0.06);
}
.salon__card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition:
        transform 0.6s var(--ease),
        filter 0.4s;
    filter: saturate(0.9);
}
.salon__card:hover img {
    transform: scale(1.06);
    filter: saturate(1.1);
}
.salon__card:hover .shot__cap {
    opacity: 1;
    transform: translateY(0);
}
.salon .splide__slide:focus-visible {
    outline: 2px solid var(--mint);
    outline-offset: 4px;
}

/* ---------- Sponsor strip ---------- */
.sponsors {
    display: flex;
    flex-wrap: wrap;
    gap: 2.4rem 3rem;
    align-items: center;
    justify-content: center;
}
.sponsors img {
    height: 64px;
    width: auto;
    opacity: 0.55;
    filter: brightness(0) invert(1);
    transition: opacity 0.3s;
}
.sponsors img:hover {
    opacity: 1;
}
.sponsor-ph {
    width: 120px;
    height: 120px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 8px;
}

/* ---------- Form ---------- */
.form-wrap {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 2.5rem;
    border-radius: var(--radius);
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: linear-gradient(
        165deg,
        rgba(10, 31, 77, 0.6),
        rgba(1, 13, 38, 0.45)
    );
    padding: clamp(1.8rem, 3vw, 2.8rem);
    overflow: hidden;
}
form.reg {
    display: grid;
    gap: 1.1rem;
}
.field {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}
.field--row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.1rem;
}
.field label {
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    color: var(--mist);
}
.field input,
.field textarea {
    background: rgba(1, 13, 38, 0.6);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 11px;
    padding: 0.85rem 1rem;
    color: var(--white);
    font-family: var(--font-body);
    font-size: 0.95rem;
    transition:
        border-color 0.25s,
        box-shadow 0.25s;
}
.field input:focus,
.field textarea:focus {
    outline: none;
    border-color: var(--mint);
    box-shadow: 0 0 0 3px rgba(50, 255, 176, 0.12);
}
.field textarea {
    resize: vertical;
    min-height: 96px;
}
.field.invalid input,
.field.invalid textarea {
    border-color: #ff6b8a;
    box-shadow: 0 0 0 3px rgba(255, 107, 138, 0.12);
}
.field .err {
    font-size: 0.78rem;
    color: #ff8da0;
    display: none;
}
.field.invalid .err {
    display: block;
}
.form-aside h4 {
    font-size: 1.3rem;
    margin-bottom: 0.8rem;
}
.form-aside .contact-line {
    display: flex;
    gap: 0.7rem;
    align-items: center;
    margin-top: 1rem;
    font-size: 0.95rem;
}
.form-aside .contact-line span {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    background: rgba(64, 238, 255, 0.1);
    display: grid;
    place-items: center;
    flex-shrink: 0;
}
.toast {
    margin-top: 0.4rem;
    padding: 0.95rem 1.1rem;
    border-radius: 11px;
    background: rgba(50, 255, 176, 0.12);
    border: 1px solid rgba(50, 255, 176, 0.4);
    color: var(--mint);
    font-weight: 600;
    font-size: 0.92rem;
    display: none;
}
.toast.show {
    display: block;
    animation: pop 0.4s var(--ease);
}
@keyframes pop {
    from {
        transform: scale(0.96);
        opacity: 0;
    }
    to {
        transform: scale(1);
        opacity: 1;
    }
}

/* ---------- Registro CTA ---------- */
.reg-cta {
    display: grid;
    grid-template-columns: 1.15fr 0.85fr;
    gap: clamp(2rem, 5vw, 4rem);
    align-items: start;
}
.reg-cta__pill {
    display: inline-block;
    padding: 0.35rem 0.9rem;
    border-radius: 999px;
    background: rgba(50, 255, 176, 0.12);
    color: var(--mint);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}
.reg-cta h3 {
    font-size: clamp(1.8rem, 3.5vw, 2.7rem);
    line-height: 1.08;
    color: var(--white);
    margin: 1.1rem 0 0.9rem;
}
.reg-cta__lead {
    color: var(--mist);
    font-size: 1.05rem;
    max-width: 46ch;
    margin-bottom: 1.8rem;
}
.reg-steps {
    margin: 0 0 1.8rem;
    padding-top: 1.4rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}
.reg-steps__title {
    display: block;
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--mint);
    margin-bottom: 1.1rem;
}
.reg-steps__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 1rem;
}
.reg-steps__list li {
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
}
.reg-steps__num {
    flex-shrink: 0;
    width: 1.9rem;
    height: 1.9rem;
    display: grid;
    place-items: center;
    border-radius: 999px;
    border: 1px solid rgba(50, 255, 176, 0.35);
    background: rgba(50, 255, 176, 0.1);
    color: var(--mint);
    font-family: var(--font-display);
    font-size: 0.95rem;
    font-weight: 700;
    line-height: 1;
}
.reg-steps__list p {
    margin: 0;
    padding-top: 0.18rem;
    color: var(--mist);
    font-size: 0.95rem;
    line-height: 1.5;
}
.reg-steps__list strong {
    color: var(--white);
    font-weight: 600;
}
.reg-steps__note {
    color: var(--mist-dim);
}
.reg-cta__contact {
    margin-top: 1.6rem;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.5rem 0.6rem;
    font-size: 0.92rem;
    color: var(--mist);
}
.reg-cta__contact a {
    color: var(--mist);
}
.reg-cta__contact a:hover {
    color: var(--mint);
}
.reg-cta__contact svg {
    width: 18px;
    height: 18px;
    stroke: var(--cyan);
}
.reg-offer {
    border-radius: 16px;
    border: 1px solid rgba(64, 238, 255, 0.22);
    background: radial-gradient(
        120% 120% at 100% 0%,
        rgba(64, 238, 255, 0.1),
        rgba(1, 13, 38, 0.4)
    );
    padding: clamp(1.6rem, 3vw, 2.2rem);
}
.reg-offer__price {
    display: flex;
    align-items: baseline;
    gap: 0.4rem;
}
.reg-offer__price b {
    font-size: clamp(2.6rem, 6vw, 3.6rem);
    font-weight: 700;
    line-height: 1;
    background: var(--grad-neon);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.reg-offer__price span {
    font-size: 1rem;
    font-weight: 700;
    color: var(--mist);
}
.reg-offer__label {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--mist-dim);
    margin-top: 0.4rem;
}
.reg-offer__meta {
    margin-top: 1.4rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    padding-top: 1.2rem;
    display: grid;
    gap: 0.9rem;
}
.reg-offer__meta div {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    color: var(--white);
    font-weight: 600;
    font-size: 0.95rem;
}
.reg-offer__meta svg {
    width: 20px;
    height: 20px;
    stroke: var(--mint);
    flex-shrink: 0;
}
.reg-offer__cta {
    width: 100%;
    justify-content: center;
    margin-top: 1.6rem;
    padding: 1.15rem 1.6rem;
    font-size: 1.08rem;
    box-shadow: var(--glow-mint);
}
/* Mint-gradient variant (registro panel only; hero .reg-offer stays dark) */
.reg-offer--mint {
    border: none;
    border-radius: var(--radius);
    background: var(--grad-neon);
    color: var(--navy-900);
    box-shadow: 0 26px 60px rgba(1, 13, 38, 0.45);
}

@media (min-width: 821px) {
    .reg-offer--mint {
        margin-top: 60px;
    }
}

.reg-offer--mint .reg-offer__price b {
    background: none;
    -webkit-text-fill-color: var(--navy-900);
    color: var(--navy-900);
}
.reg-offer--mint .reg-offer__price span {
    color: rgba(1, 13, 38, 0.72);
}
.reg-offer--mint .reg-offer__label {
    color: rgba(1, 13, 38, 0.68);
}
.reg-offer--mint .reg-offer__meta {
    border-top-color: rgba(1, 13, 38, 0.18);
}
.reg-offer--mint .reg-offer__meta div {
    color: var(--navy-900);
}
.reg-offer--mint .reg-offer__meta svg {
    stroke: var(--navy-900);
}
.reg-offer--mint .reg-offer__meta .reg-offer__meta-strong {
    color: var(--navy-900);
}
.reg-offer--mint .reg-offer__cta {
    box-shadow: 0 12px 26px rgba(1, 13, 38, 0.28);
}
/* ---------- Qué es intro split ---------- */
.intro-split {
    display: grid;
    grid-template-columns: 1.15fr 0.85fr;
    gap: clamp(2rem, 5vw, 4rem);
    align-items: center;
}
.intro-offer__cta {
    width: 100%;
    justify-content: center;
    margin-top: 1.6rem;
}
/* "a little more weight" on Cupo limitado — beats `.reg-offer__meta div` (0,1,1) */
.reg-offer__meta .reg-offer__meta-strong {
    font-weight: 700;
    color: var(--mint);
}
@media (max-width: 820px) {
    .intro-split {
        grid-template-columns: 1fr;
    }
    .reg-cta {
        grid-template-columns: 1fr;
    }
}
/* ---------- CTA band ---------- */
.cta-band {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius);
    background: var(--grad-neon);
    color: var(--navy-900);
    padding: clamp(2.5rem, 5vw, 4.5rem);
    text-align: center;
}
.cta-band h2 {
    color: var(--navy-900);
    font-size: clamp(2rem, 5vw, 3.4rem);
}
.cta-band p {
    color: rgba(1, 13, 38, 0.8);
    max-width: 60ch;
    margin: 1.1rem auto 2rem;
    font-weight: 600;
    font-size: 1.05rem;
}
.cta-band .btn--dark {
    background: var(--navy-900);
    color: var(--white);
}
.cta-band .btn--dark:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 50px rgba(1, 13, 38, 0.45);
}
.cta-band .btn--outline-dark {
    border: 1px solid rgba(1, 13, 38, 0.4);
    color: var(--navy-900);
}
.cta-band .cta-actions {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    justify-content: center;
}
/*.cta-band::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(
        60% 100% at 100% 0%,
        rgba(255, 255, 255, 0.35),
        transparent 60%
    );
}*/

/* ---------- Split CTA (home) ---------- */
.split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
}
.split__card {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius);
    padding: clamp(2rem, 4vw, 3.2rem);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    transition: transform 0.4s var(--ease);
}
.split__card:hover {
    transform: translateY(-6px);
}
.split__card > * {
    position: relative;
    z-index: 1;
}
.split__card h3 {
    font-size: clamp(1.7rem, 3.4vw, 2.5rem);
    margin: 0.7rem 0 1rem;
}
.split__card p {
    margin-bottom: 1.8rem;
    flex: 1;
}
.split__card .btn {
    margin-top: auto;
}
.split__card--cumbre {
    background: var(--grad-neon);
    color: var(--navy-900);
}
.split__card--cumbre h3 {
    color: var(--navy-900);
}
.split__card--cumbre p {
    color: rgba(1, 13, 38, 0.78);
    font-weight: 600;
}
.split__card--cumbre::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(
        70% 100% at 100% 0%,
        rgba(255, 255, 255, 0.3),
        transparent 60%
    );
    pointer-events: none;
}
.split__card--premio {
    background: linear-gradient(
        165deg,
        rgba(10, 31, 77, 0.8),
        rgba(1, 13, 38, 0.7)
    );
    border: 1px solid rgba(64, 238, 255, 0.3);
}
@media (max-width: 760px) {
    .split {
        grid-template-columns: 1fr;
    }
}

/* ---------- Page hero (subpages) ---------- */
.phero {
    padding-block: clamp(3.5rem, 7vw, 6rem) clamp(2.5rem, 5vw, 4rem);
}
.phero h1 {
    font-size: clamp(2.6rem, 7vw, 5rem);
    margin-top: 1rem;
}
.phero__lede {
    margin-top: 1.4rem;
    font-size: clamp(1.05rem, 2vw, 1.25rem);
    max-width: 62ch;
}
.phero__facts {
    margin-top: 2.4rem;
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}
.fact {
    display: flex;
    gap: 0.7rem;
    align-items: center;
    padding: 0.7rem 1.1rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(10, 31, 77, 0.4);
    font-size: 0.9rem;
    font-weight: 600;
}
.fact b {
    color: var(--mint);
}

/* ---------- Footer ---------- */
.footer {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding-block: 3.5rem 2.5rem;
    margin-top: 2rem;
}
.footer__grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr;
    gap: 2.5rem;
}
.footer p {
    font-size: 0.92rem;
    max-width: 40ch;
    margin-top: 1rem;
}
.footer h5 {
    font-family: var(--font-display);
    color: var(--white);
    font-size: 0.85rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    margin-bottom: 1.1rem;
}
.footer a {
    display: block;
    font-size: 0.94rem;
    margin-bottom: 0.6rem;
    color: var(--mist);
    transition: color 0.25s;
}
.footer a:hover {
    color: var(--mint);
}
.footer__bottom {
    margin-top: 3rem;
    padding-top: 1.6rem;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem;
    font-size: 0.82rem;
    color: var(--mist-dim);
}

/* ---------- Lightbox ---------- */
.lightbox {
    position: fixed;
    inset: 0;
    z-index: 200;
    background: rgba(1, 9, 28, 0.92);
    backdrop-filter: blur(10px);
    display: none;
    align-items: center;
    justify-content: center;
    padding: 3vw;
}
.lightbox.open {
    display: flex;
    animation: pop 0.3s var(--ease);
}
.lightbox img {
    max-width: 90vw;
    max-height: 84vh;
    border-radius: 14px;
    box-shadow: 0 30px 90px rgba(0, 0, 0, 0.6);
}
.lightbox__cap {
    position: absolute;
    bottom: 4vh;
    left: 50%;
    transform: translateX(-50%);
    color: var(--white);
    font-weight: 600;
    font-size: 0.95rem;
    text-align: center;
}
.lb-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 54px;
    height: 54px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.18);
    color: var(--white);
    font-size: 1.4rem;
    display: grid;
    place-items: center;
    transition: 0.25s;
}
.lb-btn:hover {
    background: var(--grad-neon);
    color: var(--navy-900);
}
.lb-prev {
    left: 3vw;
}
.lb-next {
    right: 3vw;
}
.lb-close {
    top: 3vh;
    right: 3vw;
    transform: none;
}

/* ---------- Reveal animation ---------- */
.reveal {
    opacity: 0;
    transform: translateY(26px);
    transition:
        opacity 0.7s var(--ease),
        transform 0.7s var(--ease);
}
.reveal.in {
    opacity: 1;
    transform: none;
}
.reveal[data-d="1"] {
    transition-delay: 0.08s;
}
.reveal[data-d="2"] {
    transition-delay: 0.16s;
}
.reveal[data-d="3"] {
    transition-delay: 0.24s;
}
.reveal[data-d="4"] {
    transition-delay: 0.32s;
}

/* ---------- Responsive ---------- */
@media (max-width: 980px) {
    .hero__grid {
        grid-template-columns: 1fr;
    }
    .hero__art {
        min-height: 260px;
    }
    .glass-card {
        margin: 0 auto;
    }
    .form-wrap {
        grid-template-columns: 1fr;
    }
    .footer__grid {
        grid-template-columns: 1fr 1fr;
    }
    .gallery--winners {
        grid-template-columns: repeat(4, 1fr);
    }
}
@media (max-width: 760px) {
    .nav__links {
        position: fixed;
        top: var(--nav-h);
        right: 0;
        left: auto;
        bottom: auto;
        height: calc(100dvh - var(--nav-h));
        width: min(80vw, 320px);
        flex-direction: column;
        gap: 0;
        align-items: stretch;
        background: rgba(1, 13, 38, 0.98);
        backdrop-filter: blur(20px);
        padding: 1.2rem 1.4rem 2rem;
        border-left: 1px solid rgba(255, 255, 255, 0.08);
        overflow-y: auto;
        transform: translateX(100%);
        transition: transform 0.35s var(--ease);
    }
    .nav.open .nav__links {
        transform: translateX(0);
    }
    /* Blurred scrim over the visible page while the drawer is open */
    body::before {
        content: "";
        position: fixed;
        inset: 0;
        z-index: 90;
        background: rgba(1, 13, 38, 0.4);
        backdrop-filter: blur(6px);
        -webkit-backdrop-filter: blur(6px);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transition:
            opacity 0.35s var(--ease),
            visibility 0.35s;
    }
    body.menu-open::before {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }
    .nav__links a {
        padding: 0.9rem 0;
        border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    }
    .nav__links a.is-active::after {
        display: none;
    }
    .nav__links .btn {
        margin-top: 1rem;
        justify-content: center;
    }
    .nav__toggle {
        display: flex;
    }
    /* Desktop pill bar hidden; links become nested drawer sub-items */
    .subnav {
        display: none;
    }
    .nav__sub {
        display: flex;
        flex-direction: column;
    }
    .nav__sub a {
        padding: 0.7rem 0 0.7rem 1rem;
        font-size: 0.9rem;
        color: var(--mist);
        border-bottom: 1px solid rgba(255, 255, 255, 0.06);
        border-left: 2px solid rgba(50, 255, 176, 0.4);
    }
    section[id] {
        scroll-margin-top: calc(var(--nav-h) + 8px);
    }
    .pillars {
        grid-template-columns: 1fr;
    }
    .stats {
        grid-template-columns: 1fr 1fr;
        gap: 1.6rem 1rem;
    }
    .cards {
        grid-template-columns: 1fr;
    }
    .gallery,
    .gallery--winners {
        grid-template-columns: 1fr 1fr;
    }
    .carousel__viewport {
        -webkit-mask-image: none;
        mask-image: none;
    }
    .carousel__slide {
        width: 84vw;
    }
    .carousel__nav {
        width: 44px;
        height: 44px;
        font-size: 1.3rem;
    }
    .carousel__nav--prev {
        left: 0.25rem;
    }
    .carousel__nav--next {
        right: 0.25rem;
    }
    .tl-item {
        grid-template-columns: 1fr;
        gap: 0.6rem;
    }
    .footer__grid {
        grid-template-columns: 1fr;
    }
    .field--row {
        grid-template-columns: 1fr;
    }
}
@media (prefers-reduced-motion: reduce) {
    * {
        animation: none !important;
        transition: none !important;
        scroll-behavior: auto;
    }
    .reveal {
        opacity: 1;
        transform: none;
    }
}

/* === Lo que te llevas === */
.value-split {
    display: grid;
    grid-template-columns: 55fr 45fr;
    gap: clamp(2.5rem, 6vw, 5rem);
    align-items: start;
}
.value-split__img-wrap {
    position: sticky;
    top: 5rem;
}
.value-split__img {
    border-radius: var(--radius);
    overflow: hidden;
    aspect-ratio: 3 / 4;
}
.value-split__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.value-lead {
    margin-top: 1.2rem;
    font-size: clamp(0.95rem, 1.5vw, 1.05rem);
    line-height: 1.65;
    max-width: 58ch;
}
.value-list {
    list-style: none;
    padding: 0;
    margin: 1.8rem 0 0;
}
.value-list li {
    padding: 1.1rem 0;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}
.value-list li:last-child {
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.value-list li strong {
    display: block;
    color: var(--white);
    font-size: 0.95rem;
    font-weight: 600;
    margin-bottom: 0.3rem;
}
.value-list li span {
    color: var(--mist);
    font-size: 0.875rem;
    line-height: 1.6;
}
#takeaways .value-split__content h2 {
    font-size: clamp(2rem, 5vw, 3.6rem);
    margin-top: 1rem;
}
@media (max-width: 768px) {
    .value-split {
        grid-template-columns: 1fr;
    }
    .value-split__img-wrap {
        position: static;
        order: -1;
    }
    .value-split__img {
        aspect-ratio: 16 / 9;
    }
}

/* === Section media band (editorial photos in text sections) === */
.media-band {
    position: relative;
    margin-top: clamp(2rem, 4vw, 3rem);
    border-radius: var(--radius);
    overflow: hidden;
    aspect-ratio: 21 / 9;
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 30px 70px rgba(0, 0, 0, 0.45);
}
.media-band img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    filter: saturate(0.9);
    transition:
        transform 0.6s var(--ease),
        filter 0.4s;
}
.media-band:hover img {
    transform: scale(1.04);
    filter: saturate(1.05);
}
.media-band::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(
        180deg,
        rgba(1, 13, 38, 0) 55%,
        rgba(1, 13, 38, 0.55)
    );
}
@media (max-width: 768px) {
    .media-band {
        aspect-ratio: 16 / 9;
    }
}

/* === Recap video (Galería) === */
.recap {
    margin: 1.4rem 0 3.5rem;
}
.recap__title {
    font-size: clamp(1.7rem, 4vw, 2.8rem);
    margin-bottom: 3rem;
}
.recap__frame {
    position: relative;
    aspect-ratio: 16 / 9;
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--navy-900); /* dark pillarbox bleed */
    border: 1px solid rgba(64, 238, 255, 0.25);
    border-radius: var(--radius);
    /*box-shadow: var(--glow-cyan);*/
}
.recap__frame iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
}
