:root {
    --primario: #ea580c;
    --secundario: #38bdf8;
    --gris: #475569;
    --blanco: #f8fafc;
    --negro: #0f172a;
    --grisClaro: #e2e8f0;
    --superficie: #1e293b;

    --separacion: 5rem;
    /* Móvil: mismo criterio horizontal en todo el sitio (90% del .contenedor + este inset interno donde aplica) */
    --margen-inline-site: clamp(1.6rem, 5vw, 2.4rem);
    /* Separación vertical entre bloques en viewport estrecho */
    --seccion-padding-y-mobile: clamp(3.5rem, 11vw, 5rem);

    --fuentePrincipal: 'DM Sans', system-ui, sans-serif;
    --fuenteSecundaria: 'Outfit', system-ui, sans-serif;
}

html {
    box-sizing: border-box;
    font-size: 62.5%;
    scroll-behavior: smooth;
}

*, *:before, *:after {
    box-sizing: inherit;
}

@media (prefers-reduced-motion: reduce) {
    html {
        scroll-behavior: auto;
    }
}

body {
    font-family: var(--fuentePrincipal);
    font-size: 1.6rem;
    line-height: 1.6;
    color: var(--negro);
    background-color: var(--blanco);
    margin: 0;
}

/** Globales **/
.contenedor {
    max-width: 120rem;
    width: 90%;
    margin: 0 auto;
    box-sizing: border-box;
}

@media (max-width: 767px) {
    .contenedor,
    .nav-principal .nav-bar-inner {
        padding-inline: max(0px, env(safe-area-inset-left, 0px)) max(0px, env(safe-area-inset-right, 0px));
    }

    .header {
        padding: var(--seccion-padding-y-mobile) 0 calc(var(--seccion-padding-y-mobile) * 1.25);
    }

    .texto-header {
        padding-top: calc(var(--seccion-padding-y-mobile) * 0.65);
    }

    h2,
    h3 {
        margin-block: clamp(1.4rem, 3.5vw, 2.2rem);
    }

    .iconos {
        padding: var(--seccion-padding-y-mobile) 0;
    }

    .especificaciones,
    .faq {
        padding: var(--seccion-padding-y-mobile) 0;
    }

    .especificaciones .lead {
        margin-bottom: 2rem;
    }

    .especificaciones h2 {
        margin-bottom: 0.8rem;
    }

    .modelos {
        padding: var(--seccion-padding-y-mobile) 0;
    }

    .header-modelos {
        margin-bottom: calc(var(--seccion-padding-y-mobile) * 0.8);
    }

    .tabla-specs th,
    .tabla-specs td {
        padding: 1rem 1.2rem;
        font-size: 1.4rem;
    }

    .faq h2 {
        margin-bottom: 2.4rem;
    }

    .footer {
        padding-block: calc(var(--seccion-padding-y-mobile) * 0.9);
    }
}

h1, h2, h3 {
    font-family: var(--fuenteSecundaria);
    font-weight: 800;
    margin: calc(var(--separacion) / 2) 0;
}

h1 {
    font-size: clamp(3.6rem, 8vw, 4.4rem);
}

h2 {
    font-size: clamp(2.8rem, 5vw, 3.6rem);
}

h3 {
    font-size: clamp(2.2rem, 3vw, 2.8rem);
}

img {
    max-width: 100%;
    display: block;
    height: auto;
}

a:focus-visible,
button:focus-visible,
input:focus-visible {
    outline: 2px solid var(--secundario);
    outline-offset: 3px;
}

/** Utilidades **/
.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.text-center {
    text-align: center;
}

.text-gradient-brand {
    color: transparent;
    background: linear-gradient(105deg, var(--primario) 0%, var(--secundario) 50%, var(--primario) 100%);
    background-size: 200% auto;
    -webkit-background-clip: text;
    background-clip: text;
}

@media (prefers-reduced-motion: no-preference) {
    .text-gradient-brand {
        animation: gradient-flow 10s ease-in-out infinite;
    }
}

@keyframes gradient-flow {
    0%, 100% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
}

/** Navegación **/
.nav-principal {
    position: sticky;
    top: 0;
    z-index: 100;
    background: color-mix(in srgb, var(--negro) 92%, transparent);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-bottom: 1px solid color-mix(in srgb, var(--blanco) 12%, transparent);
    transition: box-shadow 0.35s ease, border-color 0.35s ease;
}

.nav-principal.nav-scrolled {
    box-shadow: 0 0.8rem 2.4rem rgba(0, 0, 0, 0.25);
    border-bottom-color: color-mix(in srgb, var(--primario) 25%, transparent);
}

.nav-principal .nav-bar-inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1.2rem;
    padding: 1.2rem 0;
    max-width: 120rem;
    width: 90%;
    margin: 0 auto;
    position: relative;
}

.logo-marca {
    font-family: var(--fuenteSecundaria);
    font-weight: 800;
    font-size: 2rem;
    color: var(--blanco);
    text-decoration: none;
    letter-spacing: -0.02em;
    position: relative;
    z-index: 103;
}

.logo-marca span {
    color: var(--primario);
}

.nav-panel {
    display: contents;
}

.nav-toggle,
.nav-backdrop {
    display: none;
}

.nav-toggle {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 4.4rem;
    height: 4.4rem;
    padding: 0;
    border: none;
    border-radius: 0.6rem;
    background: color-mix(in srgb, var(--blanco) 10%, transparent);
    cursor: pointer;
    position: relative;
    z-index: 103;
    flex-shrink: 0;
}

.nav-toggle:hover {
    background: color-mix(in srgb, var(--blanco) 16%, transparent);
}

.nav-toggle-caja {
    display: grid;
    grid-template-rows: repeat(3, 2px);
    gap: 5px;
    width: 2.2rem;
    align-content: center;
}

.nav-toggle-linea {
    display: block;
    background: var(--blanco);
    border-radius: 2px;
    transition: transform 0.3s ease, opacity 0.3s ease;
}

.nav-principal.is-open .nav-toggle-linea:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
}

.nav-principal.is-open .nav-toggle-linea:nth-child(2) {
    opacity: 0;
}

.nav-principal.is-open .nav-toggle-linea:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
}

.nav-enlaces {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.8rem 1.6rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.nav-enlaces a {
    color: color-mix(in srgb, var(--blanco) 88%, transparent);
    text-decoration: none;
    font-weight: 500;
    font-size: 1.5rem;
    padding: 0.4rem 0;
    border-bottom: 2px solid transparent;
    transition: color 0.2s ease, border-color 0.2s ease;
}

.nav-enlaces a:hover {
    color: var(--blanco);
}

.nav-enlaces a.nav-cta {
    background: var(--primario);
    color: var(--blanco);
    padding: 0.8rem 1.4rem;
    border-radius: 0.6rem;
    border-bottom: none;
    font-weight: 700;
}

.nav-enlaces a.nav-cta:hover {
    background: color-mix(in srgb, var(--primario) 88%, var(--negro));
    color: var(--blanco);
}

body.nav-menu-abierto {
    overflow: hidden;
}

@media (max-width: 900px) {
    .nav-principal .nav-bar-inner {
        flex-wrap: nowrap;
    }

    .nav-toggle {
        display: inline-flex;
    }

    .nav-backdrop {
        display: block;
        position: fixed;
        inset: 0;
        z-index: 101;
        background: rgba(15, 23, 42, 0.72);
        backdrop-filter: blur(4px);
        -webkit-backdrop-filter: blur(4px);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transition: opacity 0.35s ease, visibility 0.35s ease;
    }

    .nav-principal.is-open .nav-backdrop {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }

    .nav-panel {
        display: flex;
        flex-direction: column;
        position: fixed;
        top: 0;
        right: 0;
        width: min(100%, 36rem);
        height: 100vh;
        height: 100dvh;
        max-height: 100dvh;
        margin: 0;
        padding: 7.2rem var(--margen-inline-site) 2.4rem;
        background: linear-gradient(165deg, var(--negro) 0%, #1a2332 100%);
        border-left: 1px solid color-mix(in srgb, var(--blanco) 12%, transparent);
        box-shadow: -1.2rem 0 4rem rgba(0, 0, 0, 0.45);
        z-index: 102;
        overflow-y: auto;
        overscroll-behavior: contain;
        transform: translateX(100%);
        visibility: hidden;
        transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1), visibility 0.35s ease;
    }

    .nav-principal.is-open .nav-panel {
        transform: translateX(0);
        visibility: visible;
    }

    .nav-enlaces {
        flex-direction: column;
        align-items: stretch;
        flex-wrap: nowrap;
        gap: 0;
        width: 100%;
    }

    .nav-enlaces li {
        border-bottom: 1px solid color-mix(in srgb, var(--blanco) 10%, transparent);
    }

    .nav-enlaces li:last-child {
        border-bottom: none;
    }

    .nav-enlaces a {
        display: block;
        padding: 1.5rem 0;
        font-size: 1.8rem;
        border-bottom: none;
    }

    .nav-enlaces a.nav-cta {
        margin-top: 1.2rem;
        padding: 1.4rem 1.6rem;
        text-align: center;
        border-radius: 0.8rem;
    }

    @media (prefers-reduced-motion: reduce) {
        .nav-panel,
        .nav-backdrop,
        .nav-toggle-linea {
            transition: none;
        }
    }
}

@media (min-width: 901px) {
    body.nav-menu-abierto {
        overflow: visible;
    }
}

/** Header **/
.header {
    position: relative;
    overflow: hidden;
    background-color: var(--negro);
    padding: calc(var(--separacion) * 2) 0 calc(var(--separacion) * 3);
    color: var(--blanco);
}

@media (prefers-reduced-motion: no-preference) {
    .header::before {
        content: "";
        position: absolute;
        inset: -40% -20%;
        background:
            radial-gradient(ellipse 50% 45% at 25% 35%, color-mix(in srgb, var(--primario) 22%, transparent) 0%, transparent 55%),
            radial-gradient(ellipse 45% 40% at 78% 65%, color-mix(in srgb, var(--secundario) 14%, transparent) 0%, transparent 50%);
        animation: ambient-drift 22s ease-in-out infinite;
        pointer-events: none;
    }
}

@keyframes ambient-drift {
    0%, 100% {
        transform: translate(0, 0) rotate(0deg);
        opacity: 1;
    }
    33% {
        transform: translate(2%, 1%) rotate(1deg);
        opacity: 0.95;
    }
    66% {
        transform: translate(-1.5%, 2%) rotate(-0.5deg);
        opacity: 1;
    }
}

.header .contenedor {
    position: relative;
    z-index: 1;
}

@media (min-width: 768px) {
    .contenido-header {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 3rem;
        align-items: center;
    }
}

.imagen-header picture {
    border-radius: 1.2rem;
    overflow: hidden;
    box-shadow: 0 2.5rem 5rem rgba(0, 0, 0, 0.35);
    transition: box-shadow 0.45s ease, transform 0.45s ease;
}

.imagen-header:hover picture {
    box-shadow:
        0 2.8rem 5.5rem rgba(0, 0, 0, 0.4),
        0 0 0 1px color-mix(in srgb, var(--primario) 35%, transparent);
}

@media (prefers-reduced-motion: no-preference) {
    .imagen-header img {
        animation: hero-float 8s ease-in-out infinite;
    }
}

@keyframes hero-float {
    0%, 100% {
        transform: translateY(0) scale(1);
    }
    50% {
        transform: translateY(-10px) scale(1.02);
    }
}

.texto-header {
    text-align: center;
    padding-top: var(--separacion);
}

@media (min-width: 768px) {
    .texto-header {
        text-align: left;
        display: flex;
        flex-direction: column;
        justify-content: center;
        gap: 1.6rem;
        padding: 0;
    }
}

.texto-header p {
    margin: 0;
}

.tagline-producto {
    font-size: 1.4rem;
    font-weight: 700;
    color: color-mix(in srgb, var(--blanco) 85%, transparent);
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.nombre-producto {
    font-size: clamp(5rem, 12vw, 10rem);
    margin: 0;
    line-height: 1.05;
    letter-spacing: -0.03em;
}

.descripcion-producto {
    color: color-mix(in srgb, var(--blanco) 82%, transparent);
    max-width: 52ch;
    margin-inline: auto;
    font-size: 1.7rem;
}

@media (min-width: 768px) {
    .descripcion-producto {
        margin-inline: 0;
    }
}

.precio-producto {
    font-size: 2rem;
    font-weight: 700;
    margin-top: 0.8rem;
}

.precio-producto span {
    font-size: clamp(4rem, 8vw, 6rem);
    font-weight: 800;
    color: var(--primario);
}

.hero-cta {
    display: inline-block;
    margin-top: 1.2rem;
    padding: 1.2rem 2.4rem;
    background: linear-gradient(105deg, var(--primario), color-mix(in srgb, var(--primario) 75%, #000));
    color: var(--blanco);
    text-decoration: none;
    font-family: var(--fuenteSecundaria);
    font-weight: 700;
    font-size: 1.5rem;
    border-radius: 0.8rem;
    border: none;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    box-shadow: 0 1rem 2.5rem color-mix(in srgb, var(--primario) 35%, transparent);
}

.hero-cta:hover {
    transform: translateY(-2px);
    box-shadow: 0 1.2rem 3rem color-mix(in srgb, var(--primario) 45%, transparent);
}

@media (prefers-reduced-motion: reduce) {
    .hero-cta {
        transition: none;
    }
    .hero-cta:hover {
        transform: none;
    }
}

/** Iconos **/
.iconos {
    padding: var(--separacion) 0;
}

@media (min-width: 768px) {
    .iconos {
        display: flex;
        gap: 3rem;
    }
}

.icono {
    text-align: center;
    margin-bottom: calc(var(--separacion) / 2);
    transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
    border-radius: 1.2rem;
    padding: 1.6rem 1rem;
}

@media (prefers-reduced-motion: no-preference) {
    .icono:hover {
        transform: translateY(-8px);
    }
}

.icono:last-of-type {
    margin-bottom: 0;
}

@media (min-width: 768px) {
    .icono {
        margin: 0;
        flex: 1;
    }
}

.icono img {
    width: 5rem;
    margin: 0 auto;
    transition: transform 0.45s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@media (prefers-reduced-motion: no-preference) {
    .icono:hover img {
        transform: scale(1.1) rotate(-4deg);
    }
}

.icono h3 {
    color: var(--primario);
    text-transform: uppercase;
    margin-top: calc(var(--separacion) / 2);
    font-size: 1.8rem;
    letter-spacing: 0.06em;
}

.icono p {
    color: var(--gris);
    max-width: 36ch;
    margin-inline: auto;
}

/** Sobre marca **/
@media (min-width: 768px) {
    .sobre-marca {
        background-position: right;
        background-repeat: repeat, no-repeat;
        background-size: 100%, 110rem;
    }

    .notavif.notwebp .sobre-marca {
        background-image: linear-gradient(to left, transparent 50%, var(--primario) 0%), url('../img/imagen-mujer.jpg');
    }

    .webp .sobre-marca {
        background-image: linear-gradient(to left, transparent 50%, var(--primario) 0%), url('../img/imagen-mujer.webp');
    }

    .avif .sobre-marca {
        background-image: linear-gradient(to left, transparent 50%, var(--primario) 0%), url('../img/imagen-mujer.avif');
    }
}

@media (min-width: 1600px) {
    .sobre-marca {
        background-size: 100%, 210rem;
    }
}

.sobre-marca-grid {
    display: grid;
}

@media (max-width: 767px) {
    .sobre-marca-grid {
        grid-template-rows: minmax(14rem, 38vw) auto;
        row-gap: 0;
    }
}

@media (min-width: 768px) {
    .sobre-marca-grid {
        grid-template-columns: repeat(2, 1fr);
        column-gap: 4rem;
        padding: calc(var(--separacion) * 2) 0;
    }
}

.texto-sobre-marca {
    grid-row: 2/3;
    color: var(--blanco);
    display: flex;
    flex-direction: column;
    justify-content: space-around;
}

@media (max-width: 767px) {
    /* Debe ir después de las reglas base: antes el grid fijo 40rem + el gradiente 50% (más abajo en la hoja)
       pisaban estos arreglos → la fila del texto medía 40rem y el copy desbordaba el fondo naranja. */
    .notavif.notwebp .sobre-marca {
        background-image: url('../img/imagen-mujer.jpg');
        background-size: cover;
        background-position: center top;
        background-repeat: no-repeat;
        background-color: var(--negro);
    }

    .webp .sobre-marca {
        background-image: url('../img/imagen-mujer.webp');
        background-size: cover;
        background-position: center top;
        background-repeat: no-repeat;
        background-color: var(--negro);
    }

    .avif .sobre-marca {
        background-image: url('../img/imagen-mujer.avif');
        background-size: cover;
        background-position: center top;
        background-repeat: no-repeat;
        background-color: var(--negro);
    }

    .texto-sobre-marca {
        background-color: var(--primario);
        padding: 2.4rem var(--margen-inline-site) calc(var(--seccion-padding-y-mobile) * 0.95);
        justify-content: flex-start;
        gap: 1.6rem;
        border-radius: 1.2rem 1.2rem 0 0;
        box-sizing: border-box;
        min-height: 0;
        align-self: stretch;
    }
}

@media (min-width: 768px) {
    .texto-sobre-marca {
        padding-bottom: 0;
        justify-content: space-around;
    }
}

.texto-sobre-marca h2 {
    font-size: clamp(3rem, 4vw, 4rem);
}

.texto-sobre-marca p {
    font-size: 1.8rem;
    line-height: 1.85;
}

.texto-sobre-marca .marca-alt {
    color: color-mix(in srgb, var(--blanco) 92%, var(--secundario));
}

/** Especificaciones **/
.especificaciones {
    padding: calc(var(--separacion) * 1.25) 0;
    background: linear-gradient(180deg, var(--grisClaro) 0%, var(--blanco) 100%);
}

.especificaciones h2 {
    text-align: center;
    margin-bottom: 1rem;
}

.especificaciones .lead {
    text-align: center;
    color: var(--gris);
    max-width: 60ch;
    margin: 0 auto 3rem;
    font-size: 1.7rem;
}

.tabla-wrap {
    overflow-x: auto;
    border-radius: 1.2rem;
    box-shadow: 0 1rem 3rem rgba(15, 23, 42, 0.08);
    transition: box-shadow 0.4s ease, transform 0.4s ease;
}

@media (prefers-reduced-motion: no-preference) {
    .tabla-wrap:hover {
        box-shadow:
            0 1.4rem 4rem rgba(15, 23, 42, 0.12),
            0 0 0 1px color-mix(in srgb, var(--primario) 18%, transparent);
        transform: translateY(-4px);
    }
}

.tabla-specs {
    width: 100%;
    border-collapse: collapse;
    background: var(--blanco);
    font-size: 1.5rem;
    min-width: 56rem;
}

.tabla-specs th,
.tabla-specs td {
    padding: 1.4rem 1.6rem;
    text-align: left;
    border-bottom: 1px solid var(--grisClaro);
}

.tabla-specs thead th {
    background: var(--negro);
    color: var(--blanco);
    font-family: var(--fuenteSecundaria);
    font-weight: 700;
}

.tabla-specs tbody th {
    font-weight: 600;
    background: color-mix(in srgb, var(--grisClaro) 55%, var(--blanco));
    width: 22%;
}

.tabla-specs tbody tr:last-child td,
.tabla-specs tbody tr:last-child th {
    border-bottom: none;
}

/** FAQ **/
.faq {
    padding: calc(var(--separacion) * 1.25) 0;
}

.faq h2 {
    text-align: center;
    margin-bottom: 3rem;
}

.faq-lista {
    max-width: 72rem;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

.faq-lista details {
    background: var(--blanco);
    border: 1px solid var(--grisClaro);
    border-radius: 0.8rem;
    padding: 0 1.6rem;
    box-shadow: 0 0.4rem 1.2rem rgba(15, 23, 42, 0.04);
}

.faq-lista summary {
    font-family: var(--fuenteSecundaria);
    font-weight: 700;
    font-size: 1.7rem;
    padding: 1.4rem 0;
    padding-right: 2.4rem;
    cursor: pointer;
    list-style: none;
    position: relative;
    transition: color 0.25s ease;
}

.faq-lista summary::after {
    content: "";
    position: absolute;
    right: 0;
    top: 50%;
    width: 0.9rem;
    height: 0.9rem;
    border-right: 2px solid var(--primario);
    border-bottom: 2px solid var(--primario);
    transform: translateY(-70%) rotate(45deg);
    transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
    opacity: 0.85;
}

.faq-lista details[open] summary::after {
    transform: translateY(-20%) rotate(225deg);
}

.faq-lista summary::-webkit-details-marker {
    display: none;
}

.faq-lista details[open] summary {
    padding-bottom: 0.8rem;
    color: var(--primario);
}

.faq-lista details p {
    margin: 0 0 1.4rem;
    color: var(--gris);
    font-size: 1.55rem;
    line-height: 1.65;
}

/** Modelos **/
.modelos {
    padding: var(--separacion) 0;
}

.header-modelos {
    font-size: clamp(3.6rem, 7vw, 6rem);
    margin-bottom: var(--separacion);
}

.listado-modelos {
    display: flex;
    flex-direction: column-reverse;
    gap: 2rem;
}

@media (min-width: 992px) {
    .listado-modelos {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: repeat(2, 20rem);
        gap: 4rem;
    }
}

.modelo {
    background-color: var(--grisClaro);
    padding-left: clamp(2.4rem, 6vw, 4rem);
    padding-right: clamp(11rem, 42vw, 15rem);
    color: var(--primario);
    border-radius: 2rem;
    min-height: 20rem;
    background-repeat: no-repeat;
    background-position: right clamp(1rem, 3vw, 2rem) center;
    background-size: clamp(11rem, 38vw, 15rem);
    display: flex;
    flex-direction: column;
    justify-content: center;
    transition-property: transform, background-size;
    transition-duration: 0.3s;
    transition-timing-function: ease;
    box-shadow: 0 0.8rem 2rem rgba(15, 23, 42, 0.06);
}

.modelo:hover {
    transform: scale(1.04);
    background-size: clamp(13rem, 44vw, 30rem);
}

.modelo.reveal.is-visible {
    transition:
        opacity 0.85s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.35s ease,
        background-size 0.35s ease;
}

@media (prefers-reduced-motion: reduce) {
    .modelo {
        transition: none;
    }

    .modelo:hover {
        transform: none;
        background-size: 15rem;
    }

    .modelo.reveal.is-visible {
        transition: none;
    }
}

@media (min-width: 992px) {
    .modelo {
        margin-bottom: 0;
    }
}

.modelo h3 {
    font-size: 2.4rem;
}

.modelo .precio {
    font-size: 4rem;
    font-weight: 900;
    line-height: 1.1;
    margin: 0;
}

.modelo-stratus {
    background-image: url(../img/modelo-x.svg);
}

.modelo-cirrus {
    background-image: url(../img/modelo-y.svg);
}

.modelo-apex {
    background-image: url(../img/modelo-z.svg);
    background-color: var(--primario);
    color: var(--blanco);
    padding-right: clamp(13rem, 48vw, 18rem);
    background-size: clamp(11rem, 36vw, 15rem);
    background-position: right clamp(0.8rem, 2.5vw, 1.6rem) center;
}

.modelo-apex .precio {
    font-size: clamp(3.6rem, 12vw, 6rem);
    max-width: min(100%, 16ch);
}

@media (min-width: 992px) {
    .modelo-apex {
        grid-column: 2 / 3;
        grid-row: 1 / 3;
        background-size: clamp(18rem, 22vw, 25rem);
        padding-right: clamp(16rem, 20vw, 22rem);
        background-position: right 1.6rem center;
    }

    .modelo-apex h3 {
        font-size: 4rem;
    }

    .modelo-apex .precio {
        font-size: 6rem;
        max-width: none;
    }
}

/** Newsletter **/
.newsletter {
    background-position: top center;
    background-repeat: no-repeat;
    background-size: 100%, 70rem;
}

.notavif.notwebp .newsletter {
    background-image: linear-gradient(to bottom, transparent 50%, var(--blanco) 0%), url(../img/newsletter.jpg);
}

.webp .newsletter {
    background-image: linear-gradient(to bottom, transparent 50%, var(--blanco) 0%), url(../img/newsletter.webp);
}

.avif .newsletter {
    background-image: linear-gradient(to bottom, transparent 50%, var(--blanco) 0%), url(../img/newsletter.avif);
}

@media (min-width: 768px) {
    .newsletter {
        background-position: center, -21rem 0;
        background-size: 100%, 100rem;
        padding: 10rem 0;
    }

    .notavif.notwebp .newsletter {
        background-image: linear-gradient(to right, transparent 50%, var(--blanco) 0%), url(../img/newsletter.jpg);
    }

    .webp .newsletter {
        background-image: linear-gradient(to right, transparent 50%, var(--blanco) 0%), url(../img/newsletter.webp);
    }

    .avif .newsletter {
        background-image: linear-gradient(to right, transparent 50%, var(--blanco) 0%), url(../img/newsletter.avif);
    }
}

@media (min-width: 2200px) {
    .newsletter {
        background-size: 100%, 200rem;
        background-position: center, 0% -30rem;
    }
}

.contenido-newsletter {
    display: grid;
    grid-template-rows: repeat(2, 30rem);
    gap: var(--separacion);
}

@media (max-width: 767px) {
    .newsletter {
        padding: 0 0 calc(var(--separacion) * 1.5);
        background-image: none;
        background-color: var(--blanco);
    }

    .notavif.notwebp .newsletter {
        background-image: none;
    }

    .webp .newsletter {
        background-image: none;
    }

    .avif .newsletter {
        background-image: none;
    }

    .contenido-newsletter {
        grid-template-rows: auto;
        gap: 0;
        min-height: 0;
    }

    .texto-newsletter {
        grid-row: 1;
        min-height: 0;
        display: flex;
        flex-direction: column;
        gap: 0;
    }

    .newsletter-intro {
        padding: 4.5rem var(--margen-inline-site) 3.2rem;
        min-height: 28rem;
        color: var(--blanco);
        background-repeat: no-repeat;
        background-position: center top;
        background-size: cover;
        border-radius: 0 0 1.2rem 1.2rem;
        box-shadow: 0 0.8rem 2.4rem rgba(15, 23, 42, 0.2);
    }

    .newsletter-intro h2 {
        color: var(--blanco);
        margin-top: 0;
        text-shadow: 0 2px 24px rgba(0, 0, 0, 0.45);
    }

    .newsletter-intro p {
        color: color-mix(in srgb, var(--blanco) 94%, transparent);
        margin-bottom: 0;
        max-width: 42ch;
        line-height: 1.65;
        text-shadow: 0 1px 12px rgba(0, 0, 0, 0.5);
    }

    .notavif.notwebp .newsletter-intro {
        background-image: linear-gradient(
            to top,
            rgba(15, 23, 42, 0.88) 0%,
            rgba(15, 23, 42, 0.5) 45%,
            rgba(15, 23, 42, 0.35) 100%
        ), url(../img/newsletter.jpg);
    }

    .webp .newsletter-intro {
        background-image: linear-gradient(
            to top,
            rgba(15, 23, 42, 0.88) 0%,
            rgba(15, 23, 42, 0.5) 45%,
            rgba(15, 23, 42, 0.35) 100%
        ), url(../img/newsletter.webp);
    }

    .avif .newsletter-intro {
        background-image: linear-gradient(
            to top,
            rgba(15, 23, 42, 0.88) 0%,
            rgba(15, 23, 42, 0.5) 45%,
            rgba(15, 23, 42, 0.35) 100%
        ), url(../img/newsletter.avif);
    }

    .newsletter-form-wrap {
        flex: 0 0 auto;
        margin-top: 2.4rem;
        padding: 0 var(--margen-inline-site) 0.4rem;
        background: var(--blanco);
    }
}

@media (min-width: 768px) {
    .newsletter-intro {
        background: none;
        padding: 0;
        min-height: 0;
        color: inherit;
        border-radius: 0;
        box-shadow: none;
    }

    .newsletter-intro h2,
    .newsletter-intro p {
        color: inherit;
        text-shadow: none;
    }

    .newsletter-intro h2 {
        margin-top: unset;
    }

    .newsletter-intro p {
        max-width: none;
    }

    .newsletter-form-wrap {
        margin-top: 0;
        padding: 0;
        background: transparent;
    }

    .contenido-newsletter {
        grid-template-rows: unset;
        grid-template-columns: repeat(2, 1fr);
    }

    .texto-newsletter {
        display: block;
        grid-column: 2 / 3;
    }
}

.formulario {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

.formulario .input {
    margin: 0;
}

.formulario label {
    display: block;
    font-weight: 600;
    margin-bottom: 0.6rem;
    font-size: 1.5rem;
}

.formulario input[type="email"] {
    width: 100%;
    padding: 1.2rem 1.4rem;
    border: 2px solid var(--grisClaro);
    border-radius: 0.6rem;
    font-family: inherit;
    font-size: 1.6rem;
    background: var(--blanco);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.formulario input[type="email"]:hover {
    border-color: color-mix(in srgb, var(--primario) 40%, var(--grisClaro));
}

.formulario input[type="email"]:focus-visible {
    outline: none;
    border-color: var(--primario);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--primario) 25%, transparent);
}

.formulario .hint-privacidad {
    font-size: 1.3rem;
    color: var(--gris);
    margin: 0;
    line-height: 1.5;
}

.formulario input[type="submit"] {
    width: 100%;
    padding: 1.8rem 2rem;
    background-color: var(--primario);
    color: var(--blanco);
    text-transform: uppercase;
    font-family: var(--fuenteSecundaria);
    font-size: 1.6rem;
    font-weight: 800;
    border: none;
    border-radius: 0.6rem;
    cursor: pointer;
    letter-spacing: 0.04em;
    transition: background 0.2s ease, transform 0.2s ease;
}

.formulario input[type="submit"]:hover {
    background: color-mix(in srgb, var(--primario) 88%, var(--negro));
}

@media (prefers-reduced-motion: reduce) {
    .formulario input[type="submit"] {
        transition: none;
    }
}

/** Footer **/
.footer {
    background: var(--negro);
    color: color-mix(in srgb, var(--blanco) 75%, transparent);
    padding: 3rem 0;
}

.footer-inner {
    text-align: center;
}

.footer-marca {
    font-family: var(--fuenteSecundaria);
    font-weight: 800;
    font-size: 1.8rem;
    color: var(--blanco);
    margin: 0 0 1rem;
    letter-spacing: -0.02em;
}

.footer-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1.2rem 2rem;
    margin-bottom: 1.6rem;
}

.footer-links a {
    position: relative;
    color: var(--secundario);
    text-decoration: none;
    font-size: 1.5rem;
    font-weight: 500;
}

.footer-links a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -2px;
    width: 0;
    height: 1px;
    background: var(--secundario);
    transition: width 0.35s ease;
}

.footer-links a:hover {
    text-decoration: none;
}

@media (prefers-reduced-motion: no-preference) {
    .footer-links a:hover::after {
        width: 100%;
    }
}

.footer-copy {
    font-size: 1.4rem;
    margin: 0;
    opacity: 0.85;
}

/** Revelado al entrar en vista **/
.reveal {
    opacity: 0;
    transform: translate3d(0, 2.8rem, 0);
    transition:
        opacity 0.85s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.85s cubic-bezier(0.22, 1, 0.36, 1);
}

.reveal.is-visible {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}

.reveal-delay-sm {
    transition-delay: 0.12s;
}

.reveal-delay-1 {
    transition-delay: 0.06s;
}

.reveal-delay-2 {
    transition-delay: 0.12s;
}

.reveal-delay-3 {
    transition-delay: 0.18s;
}

.reveal-delay-4 {
    transition-delay: 0.24s;
}

.reveal-delay-md {
    transition-delay: 0.2s;
}

@media (prefers-reduced-motion: reduce) {
    .text-gradient-brand {
        animation: none;
        background: linear-gradient(105deg, var(--primario) 0%, var(--secundario) 100%);
        background-size: auto;
    }

    .reveal {
        opacity: 1;
        transform: none;
        transition: none;
    }

    .reveal-delay-sm,
    .reveal-delay-1,
    .reveal-delay-2,
    .reveal-delay-3,
    .reveal-delay-4,
    .reveal-delay-md {
        transition-delay: 0s;
    }

    .imagen-header:hover picture {
        box-shadow: 0 2.5rem 5rem rgba(0, 0, 0, 0.35);
    }

    .faq-lista summary::after {
        transition: none;
    }

    .footer-links a::after {
        transition: none;
    }

    .footer-links a:hover {
        text-decoration: underline;
    }
}

@media (prefers-reduced-motion: no-preference) {
    .nav-enlaces a:not(.nav-cta) {
        transition:
            color 0.2s ease,
            border-color 0.2s ease,
            transform 0.25s ease;
    }

    .nav-enlaces a:not(.nav-cta):hover {
        transform: translateY(-2px);
    }

    .nav-enlaces a.nav-cta {
        transition:
            background 0.2s ease,
            transform 0.25s ease,
            box-shadow 0.25s ease;
    }

    .nav-enlaces a.nav-cta:hover {
        transform: translateY(-2px);
        box-shadow: 0 0.6rem 1.6rem color-mix(in srgb, var(--primario) 45%, transparent);
    }
}
