/* =============================================================================
   Leon Livings — sistema de diseño (tokens + componentes)
   Derivado del HTML/Figma: tipografía Inter, fondos blanco/#fafafa, acento negro.
   ============================================================================= */

:root {
    /* --- Color primitives --- */
    --color-white: #ffffff;
    --color-black: #000000;
    --color-neutral-950: #0a0a0a;
    --color-neutral-900: #282828;
    --color-neutral-700: #525252;
    --color-neutral-500: #737373;
    --color-neutral-200: #e5e5e5;

    /* --- Semantic: texto --- */
    --color-text: var(--color-neutral-950);
    --color-text-muted: var(--color-neutral-500);
    --color-text-body: var(--color-neutral-900);
    --color-text-soft: var(--color-neutral-700);
    --color-text-on-dark: var(--color-white);

    /* --- Semantic: superficies --- */
    --color-surface: var(--color-white);
    --color-surface-muted: #fafafa;
    --color-surface-inverse: var(--color-black);

    /* --- Semantic: bordes y divisores --- */
    --color-border: var(--color-neutral-200);
    --color-border-subtle: rgba(229, 229, 229, 0.5);

    /* --- Semantic: interacción --- */
    --color-interactive: var(--color-black);
    --color-interactive-hover: #262626;

    /* --- Superposiciones (fotos / hero / cards) --- */
    /* Escritorio: barra translúcida; en móvil se sobrescribe más abajo */
    --overlay-header-bg: rgba(255, 255, 255, 0.34);
    --overlay-collection: rgba(53, 52, 52, 0.3);
    --overlay-category: rgba(0, 0, 0, 0.2);
    --overlay-hero: linear-gradient(
        to right,
        rgba(0, 0, 0, 0.4) 19.712%,
        rgba(0, 0, 0, 0.21) 50.962%,
        rgba(255, 255, 255, 0.1) 97.115%
    );
    --overlay-cta: linear-gradient(
        to top,
        rgba(0, 0, 0, 0.6),
        rgba(0, 0, 0, 0.3) 50%,
        rgba(0, 0, 0, 0.4)
    );
    --overlay-category-bottom: linear-gradient(
        to top,
        rgba(0, 0, 0, 0.5) 37.019%,
        transparent
    );

    /* --- Tipografía --- */
    --font-family-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --font-weight-light: 300;
    --font-weight-regular: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;

    --text-overline-13: 0.8125rem;
    --text-overline-14: 0.875rem;
    --text-body-14: 0.875rem;
    --text-body-16: 1rem;
    --text-body-18: 1.125rem;
    --text-lead-21: 1.328125rem;
    --text-hero-display: 6.9791875rem;
    --text-hero-display-lh: 6.28125rem;
    --text-section-48: 3rem;
    --text-section-48-lh: 3.75rem;
    --text-display-64: 4rem;
    --text-display-64-lh: 4.4rem;
    --text-cta-96: 6rem;
    --text-cta-96-lh: 5.7rem;
    --text-collection-36: 2.25rem;
    --text-btn-primary: 1;
    --text-btn-secondary: 0.9130625rem;
    --text-btn-dark: 1rem;

    --tracking-nav: 0.03585rem;
    --tracking-tight-hero: -0.13958125rem;
    --tracking-tight: -0.053025rem;
    --tracking-subtitle: 0.03435rem;
    --tracking-product: -0.05914375rem;
    --tracking-btn-primary: 0.07006875rem;
    --tracking-btn-secondary: 0.07839375rem;
    --tracking-link-16: 0.0602375rem;
    --tracking-hero-sub: 0.136225rem;
    --tracking-label-wide: 0.1171125rem;
    --tracking-feature-title: 0.0606rem;
    --tracking-cta-title: -0.12rem;

    /* --- Espaciado --- */
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-7: 1.75rem;
    --space-8: 2rem;
    --space-9: 2.25rem;
    --space-10: 2.5rem;
    --space-11: 2.75rem;
    --space-12: 3rem;
    --space-14: 3.5rem;
    --space-16: 4rem;
    --space-20: 5rem;
    --space-24: 6rem;
    --space-32: 8rem;

    --radius-sm: 4px;
    --radius-md: 8px;

    --shadow-floating-image: -8px 11px 14px 2px rgba(0, 0, 0, 0.12);

    --blur-header: 18px;
    --border-feature-accent: 2px solid var(--color-border);

    --container-max: 1600px;
    --content-wide: 1423px;
    --hero-text-max: 800px;
    --customization-text-max: 648px;
    --cta-text-max: 768px;
    --cta-desc-max: 576px;

    --padding-x: 80px;
    --header-padding-y: 18px;
    /* Navbar escritorio: alineado a secciones — 80px laterales y ancho máx. 1600px (no sigue el 40px de tablet) */
    --header-padding-x: 80px;

    --header-offset: 0px;
    --header-bar-height: calc(var(--header-padding-y) * 2 + var(--logo-height));
    --categories-grid-height: 1195px;
    --category-tall-height: 689px;
    --category-full-height: 403px;
    --customization-height: 684px;
    --cta-height: 873px;
    --footer-image-height: 267px;
    --footer-logo-block-height: 165px;
    --logo-height: 50px;

    --categories-left-width: 458px;
    --about-image-width: 680px;
    --about-image-height: 510px;
    --float-image-w: 356px;
    --float-image-h: 475px;
    --float-2-right: 382px;
    --float-2-top: 172px;
    --float-1-top: 30px;

    --ease-out-soft: cubic-bezier(0.16, 1, 0.3, 1);
    --duration-fast: 0.3s;
    --duration-image: 0.6s;
    --duration-collection: 0.7s;

    --z-header: 110;
    --z-nav-overlay: 100;
    --z-nav-drawer: 105;
}

/* Tablet: una columna — texto e imágenes sin superponer */
@media (max-width: 1024px) {
    .customization-wrapper {
        grid-template-columns: 1fr;
        min-height: 0;
        gap: var(--space-10);
    }

    .customization-content {
        max-width: 100%;
    }

    .customization-images {
        justify-self: center;
        margin-left: 0;
        min-height: 0;
        max-width: min(100%, 520px);
        aspect-ratio: auto;
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: flex-start;
        gap: var(--space-6);
        padding-top: var(--space-4);
    }

    .floating-image-1,
    .floating-image-2 {
        position: static;
        width: min(100%, var(--float-image-w));
        max-width: 100%;
        height: auto;
        aspect-ratio: 356 / 475;
    }
}

@media (max-width: 1200px) {
    :root {
        --padding-x: 40px;
    }
}

@media (max-width: 768px) {
    :root {
        --padding-x: 24px;
        --header-padding-x: 24px;
        --logo-height: 40px;
        --header-bar-height: calc(var(--header-padding-y) * 2 + max(var(--logo-height), 44px));
        --overlay-header-bg: rgba(255, 255, 255, 0.93);
        --blur-header: 14px;
        --category-tall-height: 400px;
    }
}

*,
*::before,
*::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    overflow-x: hidden;
}

body {
    font-family: var(--font-family-sans);
    background: var(--color-surface);
    color: var(--color-text);
    overflow-x: hidden;
    max-width: 100%;
}

body.nav-open {
    overflow: hidden;
}



/* Contenido debajo del header fijo (todas las páginas con <main>) */
body > main {
    padding-top: var(--header-bar-height);
}

body.collection-page .collection-page-root:has(> .collection-hero-banner:first-child),
.collection-page-root:has(> .collection-hero-banner:first-child),
.product-detail-root {
    padding-top: 0;
}

@media (prefers-reduced-motion: reduce) {
    .nav-drawer,
    .nav-overlay,
    .nav-toggle-bar {
        transition-duration: 0.01ms !important;
    }

    .hero-text,
    .hero-text .hero-subtitle,
    .hero-text .hero-description,
    .hero-text .btn-primary,
    .hero-title-line-inner {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }

    .collection-card--enter-left,
    .collection-card--enter-right,
    .collection-card.is-visible {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }

    /* Texto reveal: sin translateX (evita texto cortado en personalizable/profesionales) */
    .profesionales-reveal,
    .profesionales-reveal-group.is-visible .profesionales-reveal {
        opacity: 1 !important;
        transform: none !important;
        visibility: visible !important;
        transition: none !important;
    }

    .profesionales-line-expand.is-visible::after {
        transform: scaleX(1) !important;
        transition: none !important;
    }

    .profesionales-line-heading.is-visible::after,
    .profesionales-reveal-group.is-visible .profesionales-line-heading::after,
    .is-visible .profesionales-line-heading::after,
    .profesionales-zigzag-item.is-visible .profesionales-line-heading::after {
        transform: scaleX(1) !important;
        transition: none !important;
    }

    /* Línea decorativa centrada del hero personalizable */
    .personalizable-hero .personalizable-hero__subtitle.profesionales-line-heading::after,
    .personalizable-hero .personalizable-hero__subtitle.profesionales-line-heading.is-visible::after,
    .personalizable-hero .profesionales-reveal-group.is-visible .personalizable-hero__subtitle.profesionales-line-heading::after,
    .personalizable-hero .personalizable-hero__text.is-visible .personalizable-hero__subtitle.profesionales-line-heading::after {
        transform: translateX(-50%) scaleX(1) !important;
        transition: none !important;
    }

    .personalizable-page .section-cta.personalizable-final-cta .personalizable-hero__subtitle.profesionales-line-heading::after,
    .personalizable-page .section-cta.personalizable-final-cta .personalizable-hero__subtitle.profesionales-line-heading.is-visible::after,
    .personalizable-page .section-cta.personalizable-final-cta .profesionales-reveal-group.is-visible .personalizable-hero__subtitle.profesionales-line-heading::after,
    .profesionales-page .section-cta.profesionales-final-cta .personalizable-hero__subtitle.profesionales-line-heading::after,
    .profesionales-page .section-cta.profesionales-final-cta .personalizable-hero__subtitle.profesionales-line-heading.is-visible::after {
        transform: scaleX(1) !important;
        transition: none !important;
    }

    .home-catalog-fab-wrap,
    .home-catalog-fab-wrap.is-visible {
        opacity: 1 !important;
        transform: translateX(-50%) translateY(0) !important;
        visibility: visible !important;
        transition: none !important;
    }
}

.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;
}

/* Salto de línea solo en viewport ≥901px (mismo corte que zigzag mobile) */
@media (max-width: 900px) {
    .br-desktop,
    .hide-mobile {
        display: none;
    }

    .nosotros-materials .materiales-zigzag--intro {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .nosotros-materials .materiales-eyebrow,
    .nosotros-materials .materiales-heading {
        width: 100%;
        text-align: left;
    }
}

.container {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--padding-x);
}

.header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: var(--z-header);
    background: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border-bottom: 1px solid transparent;
    transition: background 0.35s ease, backdrop-filter 0.35s ease,
        -webkit-backdrop-filter 0.35s ease, border-color 0.35s ease;
}

.header.header--scrolled {
    background: rgba(255, 255, 255, 0.97);
    backdrop-filter: blur(var(--blur-header));
    -webkit-backdrop-filter: blur(var(--blur-header));
    border-bottom-color: var(--color-border-subtle);
}

@media (max-width: 768px) {
    .header.header--scrolled {
        background: rgba(255, 255, 255, 0.96);
        backdrop-filter: blur(14px);
        -webkit-backdrop-filter: blur(14px);
    }
}

/* Barra superior: texto blanco sobre el hero; al scroll, negro sobre fondo blanco */
.header .nav-link,
.header .nav-logo-link,
.header .nav-mobile-logo,
.header .logo-text,
.header .nav-toggle {
    color: var(--color-text-on-dark);
    transition: color 0.35s ease, opacity var(--duration-fast);
}

.header.header--scrolled .nav-link,
.header.header--scrolled .nav-logo-link,
.header.header--scrolled .nav-mobile-logo,
.header.header--scrolled .logo-text,
.header.header--scrolled .nav-toggle {
    color: var(--color-text);
}

.header .nav-toggle:focus:not(:focus-visible) {
    outline: none;
}

.header .nav-toggle:focus-visible {
    outline: 2px solid var(--color-text-on-dark);
    outline-offset: 2px;
}

.header.header--scrolled .nav-toggle:focus-visible {
    outline-color: var(--color-interactive);
}

/* Forzar texto oscuro en headers de páginas internas puntuales */
body.header-dark-text .header .nav-link,
body.header-dark-text .header .nav-logo-link,
body.header-dark-text .header .nav-mobile-logo,
body.header-dark-text .header .logo-text,
body.header-dark-text .header .nav-toggle {
    color: var(--color-text);
}

body.header-dark-text .header .nav-toggle:focus:not(:focus-visible) {
    outline: none;
}

body.header-dark-text .header .nav-toggle:focus-visible {
    outline: 2px solid var(--color-interactive);
    outline-offset: 2px;
}

.header-container {
    box-sizing: border-box;
    width: 100%;
    max-width: var(--container-max);
    margin-left: auto;
    margin-right: auto;
    padding: 4px 80px;
    border-bottom: 0.5px solid var(--color-border-subtle);
   
}

.breadcrumb-nav {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
    margin-bottom: 24px;
    font-size: var(--text-body-14);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--color-text-soft);
}

.breadcrumb-link {
    color: inherit;
    text-decoration: none;
}

.breadcrumb-link:hover {
    text-decoration: underline;
}

.breadcrumb-separator {
    opacity: 0.6;
}

.breadcrumb-current {
    color: var(--color-text);
}

/* Category page: breadcrumb arriba del contenido */
.category-page-body .collection-page-top {
    padding-bottom: 0;
    background: var(--color-white);
}

.category-page-body .collection-page-top .breadcrumb-nav,
.category-page-body .collection-page-products > .container > .breadcrumb-nav {
    margin-top: 0;
    margin-bottom: var(--space-8);
}

.category-page-body .collection-page-intro.section-products {
    padding-top: var(--space-10);
    padding-bottom: 0;
}

/* Ajuste exclusivo del bloque de productos en category-page */
.category-page-body .category-products-section {
    padding-top: var(--space-10);
}

/* Categoría y colección: grilla estática (no carrusel horizontal del .products-grid global) */
.category-page-body [data-category-products].products-grid,
.collection-page [data-collection-products].products-grid {
    grid-template-columns: 1fr;
    grid-auto-flow: row;
    grid-auto-columns: unset;
    overflow-x: visible;
    scroll-snap-type: none;
    row-gap: var(--space-12);
    column-gap: 0;
}

.category-page-body [data-category-products] .product-card,
.collection-page [data-collection-products] .product-card {
    scroll-snap-align: unset;
}

@media (min-width: 769px) {
    .category-page-body [data-category-products].products-grid,
    .collection-page [data-collection-products].products-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        row-gap: var(--space-20);
        column-gap: var(--space-8);
    }
}

/* ——— Escritorio: logo centrado, enlaces a ambos lados ——— */
.nav--desktop {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-8);
}

.nav-cluster {
    display: flex;
    align-items: center;
}

.nav-cluster--left,
.nav-cluster--right {
    flex: 1;
    gap: var(--space-12);
}

.nav-cluster--left {
    justify-content: flex-start;
}

.nav-cluster--right {
    justify-content: flex-end;
}

.nav-logo-link {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-shrink: 0;
    margin: 0 var(--space-8);
    line-height: 0;
    text-decoration: none;
}

.logo-text {
    font-size: var(--text-lead-21);
    letter-spacing: 0.5738px;
    font-weight: var(--font-weight-regular);
    text-transform: uppercase;
}

.nav-link {
    font-size: var(--text-body-16);
    font-weight: var(--font-weight-light);
    text-transform: uppercase;
    text-decoration: none;
    transition: opacity var(--duration-fast);
    white-space: nowrap;
    width: auto;
}

.nav-link:hover {
    opacity: 0.5;
}

.nav-link--disabled {
    opacity: 0.55;
    cursor: default;
    pointer-events: none;
}

.nav-item {
    position: relative;
    display: flex;
    align-items: center;
}

.nav-item--has-dropdown .nav-link {
    display: inline-flex;
    align-items: center;
    height: 100%;
}

.nav-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 220px;
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 12px;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border-subtle);
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.1);
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
    pointer-events: none;
    transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
}

.nav-dropdown::before {
    content: "";
    position: absolute;
    top: -12px;
    left: 0;
    right: 0;
    height: 12px;
}

.nav-item--has-dropdown:hover .nav-dropdown,
.nav-item--has-dropdown:focus-within .nav-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
}

.nav-dropdown-link {
    font-size: var(--text-body-14);
    font-weight: var(--font-weight-regular);
    letter-spacing: var(--tracking-nav);
    text-transform: uppercase;
    text-decoration: none;
    color: var(--color-text);
    padding: 8px 10px;
    border-radius: var(--radius-sm);
    transition: background var(--duration-fast), opacity var(--duration-fast);
}

.nav-dropdown-link:hover {
    background: var(--color-surface-muted);
    opacity: 1;
}

.nav-dropdown-link:focus-visible {
    outline: 2px solid var(--color-interactive);
    outline-offset: 2px;
}

.header .nav-link:focus-visible {
    outline: 2px solid currentColor;
    outline-offset: 4px;
    border-radius: 2px;
}

.logo {
    height: var(--logo-height);
    width: auto;
    display: block;
    filter: none;
    transition: filter 0.35s ease;
}

.header.header--scrolled .logo {
    filter: brightness(0);
}

body.header-dark-text .header .logo,
.product-page .header .logo,
.collection-page .header .logo {
    filter: brightness(0);
}

body.nav-open .header .nav-link,
body.nav-open .header .nav-logo-link,
body.nav-open .header .nav-mobile-logo,
body.nav-open .header .logo-text,
body.nav-open .header .nav-toggle {
    color: var(--color-text);
}

body.nav-open .header .logo {
    filter: brightness(0);
}

.nav-mobile-bar {
    display: none;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
}

.nav-mobile-logo {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    line-height: 1;
    text-decoration: none;
}

.nav-mobile-logo-text {
    font-size: 0.95rem;
    line-height: 1;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: currentColor;
    white-space: nowrap;
}

.nav-mobile-spacer {
    width: 44px;
    flex-shrink: 0;
}

.nav-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    padding: 0;
    border: none;
    background: transparent;
    cursor: pointer;
    flex-shrink: 0;
    -webkit-tap-highlight-color: transparent;
}

.nav-toggle:focus:not(:focus-visible) {
    outline: none;
}

.nav-toggle:focus-visible {
    outline: 2px solid var(--color-text);
    outline-offset: 2px;
}

.nav-toggle-box {
    position: relative;
    width: 22px;
    height: 14px;
    display: block;
}

.nav-toggle-bar {
    position: absolute;
    left: 0;
    right: 0;
    height: 2px;
    background: currentColor;
    border-radius: 1px;
    transition: transform var(--duration-fast) ease, opacity var(--duration-fast) ease,
        top var(--duration-fast) ease;
}

.nav-toggle-bar:nth-child(1) {
    top: 0;
}

.nav-toggle-bar:nth-child(2) {
    top: 6px;
}

.nav-toggle-bar:nth-child(3) {
    top: 12px;
}

.nav-toggle.is-open .nav-toggle-bar:nth-child(1) {
    top: 6px;
    transform: rotate(45deg);
}

.nav-toggle.is-open .nav-toggle-bar:nth-child(2) {
    opacity: 0;
}

.nav-toggle.is-open .nav-toggle-bar:nth-child(3) {
    top: 6px;
    transform: rotate(-45deg);
}

.nav-overlay {
    position: fixed;
    inset: 0;
    z-index: var(--z-nav-overlay);
    background: rgba(0, 0, 0, 0.45);
    opacity: 0;
    transition: opacity var(--duration-fast) ease;
    pointer-events: none;
}

.nav-overlay:not([hidden]) {
    opacity: 1;
    pointer-events: auto;
}

.nav-drawer {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    z-index: var(--z-nav-drawer);
    width: min(100%, 20rem);
    background: var(--color-surface);
    box-shadow: 4px 0 24px rgba(0, 0, 0, 0.12);
    transform: translateX(-100%);
    transition: transform var(--duration-fast) var(--ease-out-soft);
    overflow-y: auto;
    padding: max(var(--header-bar-height), env(safe-area-inset-top)) var(--padding-x)
        max(var(--space-8), env(safe-area-inset-bottom));
}

.nav-drawer:not([hidden]) {
    transform: translateX(0);
}

.nav-drawer-inner {
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
}

.nav-drawer-nav {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.nav-drawer-link {
    font-size: var(--text-body-16);
    font-weight: var(--font-weight-medium);
    letter-spacing: var(--tracking-nav);
    text-transform: uppercase;
    text-decoration: none;
    color: var(--color-text);
    padding: var(--space-4) 0;
    border-bottom: 1px solid var(--color-border-subtle);
    transition: opacity var(--duration-fast);
}

.nav-drawer-nav > .nav-drawer-link,
.nav-drawer-nav > .nav-drawer-link--disabled {
    display: block;
    opacity: 1;
    color: var(--color-text);
}

.nav-drawer-link:hover {
    opacity: 0.55;
}

.nav-drawer-link:focus:not(:focus-visible) {
    outline: none;
}

.nav-drawer-link:focus-visible {
    outline: 2px solid var(--color-interactive);
    outline-offset: 4px;
}

.nav-drawer-link--disabled {
    opacity: 0.55;
    cursor: default;
    pointer-events: none;
}

.nav-drawer-group {
    border-bottom: 1px solid var(--color-border-subtle);
}

.nav-drawer-parent-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-2);
}

.nav-drawer-link--parent {
    flex: 1;
    border-bottom: 0;
}

.nav-drawer-toggle {
    width: 40px;
    height: 40px;
    border: none;
    background: transparent;
    color: var(--color-text);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    border-radius: var(--radius-sm);
    transition: background var(--duration-fast), transform var(--duration-fast);
}

.nav-drawer-toggle-icon {
    font-size: 18px;
    line-height: 1;
    display: inline-block;
    transition: transform var(--duration-fast);
}

.nav-drawer-toggle[aria-expanded="true"] .nav-drawer-toggle-icon {
    transform: rotate(180deg);
}

.nav-drawer-toggle:focus-visible {
    outline: 2px solid var(--color-interactive);
    outline-offset: 2px;
}

.nav-drawer-submenu {
    padding: 0 0 var(--space-3) var(--space-4);
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.nav-drawer-submenu[hidden] {
    display: none;
}

.nav-drawer-sublink {
    display: block;
    color: var(--color-text-soft);
    text-decoration: none;
    font-size: var(--text-body-14);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 10px 0;
}

.nav-drawer-sublink:focus-visible {
    outline: 2px solid var(--color-interactive);
    outline-offset: 2px;
    border-radius: 2px;
}

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

    .nav-mobile-bar {
        display: flex;
    }

    .nav-drawer-link:focus,
    .nav-drawer-link:focus-visible,
    .nav-drawer-toggle:focus,
    .nav-drawer-toggle:focus-visible {
        outline: none;
    }

    .header-container {
        padding-top: var(--header-padding-y);
        padding-bottom: var(--header-padding-y);
    }

    .nav-dropdown {
        display: none;
    }
}

@media (min-width: 769px) {
    .nav-overlay,
    .nav-drawer {
        display: none !important;
    }
}

/* Home — catálogo flotante alineado al contenedor (solo desktop) */
.home-catalog-fab-wrap {
    display: none;
}

@media (min-width: 769px) {
    body.home-page .home-catalog-fab-wrap {
        display: flex;
        justify-content: flex-end;
        position: fixed;
        left: 50%;
        bottom: var(--space-10);
        transform: translateX(-50%) translateY(12px);
        z-index: 90;
        width: min(100%, var(--container-max));
        max-width: var(--container-max);
        padding: 0 var(--padding-x);
        box-sizing: border-box;
        pointer-events: none;
        opacity: 0;
        visibility: hidden;
        transition: opacity 0.4s ease, visibility 0.4s ease, transform 0.4s var(--ease-out-soft);
    }

    body.home-page .home-catalog-fab-wrap.is-visible {
        opacity: 1;
        visibility: visible;
        transform: translateX(-50%) translateY(0);
    }

    body.home-page .home-catalog-fab {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: var(--space-3) var(--space-6);
        background: var(--color-text);
        color:  var(--color-white);
        border: 1px solid var(--color-border);
        font-size: var(--text-body-14);
        font-weight: var(--font-weight-medium);
        letter-spacing: var(--tracking-link-16);
        text-transform: uppercase;
        text-decoration: none;
        border-radius: var(--radius-sm);
        box-shadow: 0 8px 22px rgba(0, 0, 0, 0.1);
        pointer-events: auto;
        transition: background var(--duration-fast), border-color var(--duration-fast),
            transform var(--duration-fast), box-shadow var(--duration-fast);
    }

    body.home-page .home-catalog-fab:hover {
        background: var(--color-surface-muted);
        border-color: var(--color-neutral-500);
        transform: translateY(-2px);
        box-shadow: 0 12px 28px rgba(0, 0, 0, 0.14);
    }

    body.home-page .home-catalog-fab:focus-visible {
        outline: 2px solid var(--color-interactive);
        outline-offset: 3px;
    }
}

.hero {
    position: relative;
    min-height: 100vh;
    min-height: 100dvh;
    height: auto;
    overflow: hidden;
    margin-top: var(--header-offset);
}

.hero-image {
    position: absolute;
    inset: 0;
}

.hero-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hero-overlay {
    position: absolute;
    inset: 0;
    background: var(--overlay-hero);
}

.hero-content {
    position: relative;
    z-index: 1;
    min-height: 100vh;
    min-height: 100dvh;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--padding-x);
    display: flex;
    align-items: center;
}

.hero-text {
    max-width: var(--hero-text-max);
    color: var(--color-text-on-dark);
    opacity: 0;
    transform: translateY(12px);
    transition: opacity 0.55s ease, transform 0.55s var(--ease-out-soft);
}

.hero-text.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.hero-text .hero-subtitle,
.hero-text .hero-description,
.hero-text .btn-primary {
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 0.45s ease, transform 0.45s var(--ease-out-soft);
}

.hero-text.is-visible .hero-subtitle {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 0.08s;
}

.hero-text.is-visible .hero-description {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 0.4s;
}

.hero-text.is-visible .btn-primary {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 0.52s;
}

.hero-title-line {
    display: block;
    overflow: hidden;
}

.hero-title-line-inner {
    display: block;
    transform: translateY(115%);
    opacity: 0.96;
    transition: transform 0.55s var(--ease-out-soft), opacity 0.55s ease;
}

.hero-text.is-visible .hero-title-line-inner {
    transform: translateY(0);
    opacity: 1;
    transition-delay: calc(0.16s + (var(--hero-line-index, 0) * 0.1s));
}

.hero-subtitle {
    font-size: 15.122px;
    letter-spacing: var(--tracking-hero-sub);
    text-transform: uppercase;
    margin-bottom: var(--space-12);
    opacity: 0.9;
}

.hero-title {
    font-size: var(--text-hero-display);
    line-height: var(--text-hero-display-lh);
    letter-spacing: var(--tracking-tight-hero);
    font-weight: var(--font-weight-light);
    margin-bottom: var(--space-10);
}

.hero-description {
    font-size: 20.938px;
    line-height: 34.023px;
    letter-spacing: -0.5112px;
    font-weight: var(--font-weight-regular);
    margin-bottom: var(--space-16);
    opacity: 0.9;
}

.btn-primary {
    background: var(--color-interactive);
    color: var(--color-text-on-dark);
    padding: var(--space-4) var(--space-7);
    font-size: var(--text-btn-primary);
    letter-spacing: var(--tracking-btn-primary);
    text-transform: uppercase;
    font-weight: var(--font-weight-medium);
    border: none;
    border-radius: var(--radius-sm);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: var(--space-3);
    transition: background var(--duration-fast);
    display: inline-flex;
    align-items: center;      
    justify-content: center;   
}

.btn-primary:hover {
    background: var(--color-interactive-hover);
    transform: translateY(-1px);
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.22);
}

.btn-icon {
    width: 20px;
    height: 20px;
}

.btn-icon-small {
    width: 16px;
    height: 16px;
}

.section-products {
    padding: var(--space-32) 0;
}
.section-products1 {
    padding: var(--space-32) 0;
    background: var(--color-white);
}

.section-collections {
    padding: var(--space-32) 0 var(--space-16);
    background: white;
}

.section-categories {
    padding: var(--space-32) 0;
    background: var(--color-surface);
}

.section-about {
    padding: var(--space-32) 0;
    background: var(--color-surface-muted);
}

.section-customization {
    padding: var(--space-32) 0;
    background: var(--color-surface);
}

.section-header {
    margin-bottom: var(--space-16);
}

.section-title {
    font-size: var(--text-section-48);
    font-weight: var(--font-weight-light);
    line-height: var(--text-section-48-lh);
    letter-spacing: var(--tracking-tight);
    margin-bottom: var(--space-3);
}

.section-subtitle {
    font-size: var(--text-body-14);
    font-weight: var(--font-weight-light);
    line-height: var(--space-5);
    letter-spacing: var(--tracking-subtitle);
    text-transform: uppercase;
    color: var(--color-text-muted);
}

.products-grid {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: calc((100% - (var(--space-8) * 2)) / 3);
    gap: var(--space-8);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.products-grid::-webkit-scrollbar {
    display: none;
}

.products-carousel {
    position: relative;
}

.products-carousel-nav {
    position: absolute;
    top: 42%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    border: none;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.75);
    color: var(--color-text-on-dark);
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
    z-index: 2;
}

.products-carousel-nav--prev {
    left: 12px;
}

.products-carousel-nav--next {
    right: 12px;
}

.products-carousel-nav:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.product-card {
    cursor: pointer;
    scroll-snap-align: start;
}

.product-image {
    width: 100%;
    height: clamp(260px, 40vw, 500px);
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-surface-muted);
    margin-bottom: var(--space-6);
    overflow: hidden;
    border-radius: var(--radius-sm);
}

.product-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--duration-image) var(--ease-out-soft);
}

.product-image--contain img {
    object-fit: contain;
}

.product-card:hover .product-image img {
    transform: scale(1.05);
}

.product-name {
    font-size: var(--text-lead-21);
    font-weight: var(--font-weight-light);
    line-height: 31.874px;
    letter-spacing: var(--tracking-product);
    margin-bottom: var(--space-4);
}

.btn-secondary {
    border: 1px solid var(--color-interactive);
    background: transparent;
    color: var(--color-interactive);
    font-family: inherit;
    padding: var(--space-3) var(--space-9);
    font-size: var(--text-btn-secondary);
    font-weight: var(--font-weight-medium);
    letter-spacing: var(--tracking-btn-secondary);
    text-transform: uppercase;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all var(--duration-fast);
    -webkit-tap-highlight-color: transparent;
}

.btn-secondary:hover {
    background: var(--color-interactive);
    color: var(--color-text-on-dark);
}

.collections-container {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
    max-width: var(--content-wide);
}

.collection-card {
    position: relative;
    aspect-ratio: 1423 / 380;
    overflow: hidden;
    border-radius: var(--radius-md);
    cursor: pointer;
}

.collection-card--enter-left,
.collection-card--enter-right {
    opacity: 0;
    will-change: transform, opacity;
    transition: transform 0.75s var(--ease-out-soft), opacity 0.75s ease;
}

.collection-card--enter-left {
    transform: translateX(-28px);
}

.collection-card--enter-right {
    transform: translateX(28px);
}

.collection-card.is-visible {
    opacity: 1;
    transform: translateX(0);
}

.collection-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--duration-collection) var(--ease-out-soft);
}

.collection-card:hover img {
    transform: scale(1.03);
}

.collection-overlay {
    position: absolute;
    inset: 0;
    background: var(--overlay-collection);
}

.collection-content {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--space-12);
    color: var(--color-text-on-dark);
}

.collection-name {
    font-size: var(--text-collection-36);
    font-weight: var(--font-weight-medium);
    line-height: var(--space-10);
    letter-spacing: 5.7691px;
    margin-bottom: var(--space-2);
}

.collection-link {
    font-size: var(--text-body-16);
    font-weight: var(--font-weight-medium);
    line-height: 19.5px;
    letter-spacing: var(--tracking-link-16);
    text-transform: uppercase;
    opacity: 0.8;
    transition: opacity var(--duration-fast);
}

.collection-card:hover .collection-link {
    opacity: 1;
}

.collections-cta {
    display: flex;
    justify-content: center;
    margin-top: var(--space-16);
}

.btn-primary-dark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--color-interactive);
    color: var(--color-text-on-dark);
    padding: var(--space-4) 18px;
    font-size: var(--text-btn-dark);
    font-weight: var(--font-weight-medium);
    line-height: 19.5px;
    letter-spacing: var(--tracking-link-16);
    text-transform: uppercase;
    border: none;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: background var(--duration-fast);
    -webkit-tap-highlight-color: transparent;
}

.btn-primary-dark:hover {
    background: var(--color-interactive-hover);
}

.categories-grid {
    display: flex;
    gap: var(--space-6);
    height: var(--categories-grid-height);
    margin-bottom: var(--space-8);
}

.categories-left {
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
    width: var(--categories-left-width);
    flex-shrink: 0;
}

.category-tall {
    height: var(--category-tall-height);
}

.category-medium {
    flex: 1;
}

.categories-right {
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
    flex: 1;
}

.categories-bottom {
    display: flex;
    gap: var(--space-8);
    flex: 1;
}

.category-small {
    flex: 1;
}

.category-card {
    display: block;
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-sm);
    cursor: pointer;
}

.category-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.category-overlay {
    position: absolute;
    inset: 0;
    background: var(--overlay-category);
}

.category-content {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--space-6);
    background: var(--overlay-category-bottom);
}

.category-name {
    font-size: var(--text-collection-36);
    font-weight: var(--font-weight-medium);
    line-height: var(--space-10);
    letter-spacing: 5.7691px;
    color: var(--color-text-on-dark);
    margin-bottom: var(--space-2);
}

.category-link {
    font-size: var(--text-body-16);
    font-weight: var(--font-weight-medium);
    line-height: 19.5px;
    letter-spacing: var(--tracking-link-16);
    text-transform: uppercase;
    color: var(--color-text-on-dark);
    opacity: 0.8;
}

.category-full {
    height: var(--category-full-height);
    max-width: var(--content-wide);
}

.categories-featured {
    display: flex;
    gap: var(--space-6);
}

.categories-featured .category-card {
    flex: 1;
    min-height: 478px;
}

.about-content {
    display: flex;
    align-items: center;
    gap: var(--space-24);
}

.about-image {
    width: var(--about-image-width);
    flex-shrink: 0;
}

.about-image img {
    width: 100%;
    height: var(--about-image-height);
    object-fit: cover;
    border-radius: var(--radius-md);
}

.about-text {
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
}

.about-title {
    font-size: var(--text-display-64);
    font-weight: var(--font-weight-light);
    line-height: var(--text-display-64-lh);
    letter-spacing: -0.6289px;
}

.about-description {
    font-size: var(--text-body-16);
    font-weight: var(--font-weight-light);
    line-height: 26px;
    letter-spacing: -0.3125px;
    color: var(--color-text-body);
}

.btn-secondary-large,
a.btn-secondary-large {
    border: 1px solid var(--color-interactive);
    background: transparent;
    color: var(--color-text);
    -webkit-text-fill-color: var(--color-text);
    font-family: inherit;
    padding: var(--space-4) var(--space-6);
    font-size: var(--text-btn-primary);
    font-weight: var(--font-weight-medium);
    letter-spacing: var(--tracking-nav);
    text-transform: uppercase;
    border-radius: var(--radius-sm);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    width: fit-content;
    transition: background var(--duration-fast), color var(--duration-fast), border-color var(--duration-fast);
    -webkit-tap-highlight-color: transparent;
    appearance: none;
    -webkit-appearance: none;
    box-sizing: border-box;
}

a.btn-secondary-large {
    text-decoration: none;
}

a.btn-secondary-large:link,
a.btn-secondary-large:visited,
a.btn-secondary-large:active {
    color: var(--color-text);
    -webkit-text-fill-color: var(--color-text);
}

button.btn-secondary-large {
    color: var(--color-text);
    -webkit-text-fill-color: var(--color-text);
}

.btn-secondary-large:focus:not(:focus-visible),
a.btn-secondary-large:focus:not(:focus-visible) {
    outline: none;
}

.btn-secondary-large:hover,
a.btn-secondary-large:hover {
    background: var(--color-interactive);
    color: var(--color-text-on-dark);
    -webkit-text-fill-color: var(--color-text-on-dark);
}

.customization-wrapper {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: clamp(var(--space-8), 4vw, var(--space-16));
    align-items: start;
    height: auto;
    min-height: var(--customization-height);
}

.customization-content {
    max-width: var(--customization-text-max);
    min-width: 0;
}

.customization-label {
    font-size: var(--text-overline-13);
    font-weight: var(--font-weight-regular);
    line-height: 19.5px;
    letter-spacing: var(--tracking-label-wide);
    text-transform: uppercase;
    opacity: 0.6;
    margin-bottom: var(--space-11);
}

.customization-title {
    font-size: var(--text-display-64);
    font-weight: var(--font-weight-light);
    line-height: var(--text-display-64-lh);
    letter-spacing: -1.0612px;
    margin-bottom: var(--space-9);
}

.customization-description {
    font-size: var(--text-body-18);
    font-weight: var(--font-weight-light);
    line-height: 29.25px;
    letter-spacing: -0.4395px;
    color: var(--color-text-soft);
    margin-bottom: var(--space-14);
}

.customization-features {
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
    margin-bottom: var(--space-14);
}

.feature-item {
    border-left: var(--border-feature-accent);
    padding-left: var(--space-9);
}

.feature-title {
    font-size: var(--text-body-14);
    font-weight: var(--font-weight-regular);
    line-height: var(--space-5);
    letter-spacing: var(--tracking-feature-title);
    text-transform: uppercase;
    margin-bottom: var(--space-2);
}

.feature-description {
    font-size: var(--text-body-16);
    font-weight: var(--font-weight-light);
    line-height: var(--space-6);
    letter-spacing: -0.3125px;
    color: var(--color-text-soft);
}

.customization-buttons {
    display: flex;
    gap: var(--space-4);
    flex-wrap: wrap;
}

/* Caja de imágenes: proporciones del diseño (356×475, offset ~382px) en % para no invadir el texto */
.customization-images {
    position: relative;
    width: 100%;
    min-width: 0;
    max-width: 738px;
    aspect-ratio: 738 / 505;
    min-height: 360px;
    justify-self: end;
    margin-left: auto;
}

.floating-image-1 {
    position: absolute;
    right: 0;
    top: 5.9%;
    width: 48.24%;
    max-width: var(--float-image-w);
    height: auto;
    aspect-ratio: 356 / 475;
    object-fit: cover;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-floating-image);
}

.floating-image-2 {
    position: absolute;
    right: 51.76%;
    top: 34%;
    width: 48.24%;
    max-width: var(--float-image-w);
    height: auto;
    aspect-ratio: 356 / 475;
    object-fit: cover;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-floating-image);
}

.section-cta {
    position: relative;
    height: var(--cta-height);
    overflow: hidden;
}

.cta-image {
    position: absolute;
    inset: 0;
}

.cta-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.cta-overlay {
    position: absolute;
    inset: 0;
    background: var(--overlay-cta);
}

.cta-content {
    position: relative;
    height: 100%;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--padding-x);
    display: flex;
    align-items: center;
}

.cta-text {
    max-width: var(--cta-text-max);
    color: var(--color-text-on-dark);
}

.cta-label {
    font-size: var(--text-overline-13);
    font-weight: var(--font-weight-regular);
    line-height: 19.5px;
    letter-spacing: var(--tracking-label-wide);
    text-transform: uppercase;
    opacity: 0.9;
    margin-bottom: var(--space-12);
}

.cta-title {
    font-size: var(--text-cta-96);
    font-weight: var(--font-weight-light);
    line-height: var(--text-cta-96-lh);
    letter-spacing: var(--tracking-cta-title);
    margin-bottom: var(--space-10);
}

.cta-description {
    font-size: var(--text-body-18);
    font-weight: var(--font-weight-light);
    line-height: 29.25px;
    letter-spacing: -0.4395px;
    opacity: 0.9;
    margin-bottom: var(--space-16);
    max-width: var(--cta-desc-max);
}

.site-footer {
    background: var(--color-surface-inverse);
    color: var(--color-text-on-dark);
}

.site-footer__inner {
    display: grid;
    grid-template-columns: 1.5fr 0.85fr 0.85fr 1fr;
    gap: var(--space-12);
    padding-top: var(--space-20);
    padding-bottom: var(--space-16);
}

.site-footer__brand {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    min-width: 0;
}

.site-footer__logo-link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    text-decoration: none;
    color: inherit;
    margin-bottom: var(--space-5);
}

.site-footer__logo {
    height: var(--logo-height);
    width: auto;
    display: block;
}

.site-footer__logo-text {
    font-size: var(--text-lead-21);
    letter-spacing: 0.5738px;
    font-weight: var(--font-weight-regular);
    text-transform: uppercase;
}

.site-footer__description {
    max-width: 34ch;
    margin: 0 0 var(--space-5);
    color: #b5b5b5;
    font-size: var(--text-body-14);
    line-height: 1.65;
    font-weight: var(--font-weight-light);
}

.site-footer__icons-row {
    display: inline-flex;
    align-items: center;
    gap: var(--space-5);
    margin-bottom: var(--space-2);
}

.site-footer__icon-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #d4d4d4;
    text-decoration: none;
    transition: color var(--duration-fast), transform var(--duration-fast);
}

.site-footer__icon-link:hover {
    color: var(--color-text-on-dark);
    transform: translateY(-1px);
}

.site-footer__icon-link i {
    font-size: 1.9rem;
    line-height: 1;
}

.site-footer__trust-card {
    display: flex;
    align-items: center;
    gap: 8px 10px;
    width: 100%;
    max-width: min(100%, 22rem);
    margin-top: 0;
    padding: 8px 10px;
    border-radius: 12px;
    border: 1px solid rgba(199, 163, 89, 0.42);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
    box-sizing: border-box;
}

.site-footer__trust-copy {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.site-footer__trust-title {
    margin: 0;
    color: #f5f5f5;
    font-size: 0.875rem;
    line-height: 1.2;
    letter-spacing: 0.01em;
    font-weight: var(--font-weight-medium);
}

.site-footer__trust-text {
    margin: 0;
    color: #bdbdbd;
    font-size: 0.6875rem;
    line-height: 1.3;
    font-weight: var(--font-weight-regular);
}

.site-footer__trust-logo {
    flex-shrink: 0;
    object-fit: contain;
    display: block;
}

.site-footer__trust-logo--medal {
    width: 36px;
    height: 36px;
}

.site-footer__trust-logo--ml {
    width: 44px;
    height: 44px;
}

.site-footer__column {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.site-footer__title {
    font-size: var(--text-overline-13);
    letter-spacing: var(--tracking-nav);
    text-transform: uppercase;
    margin-bottom: var(--space-2);
    color: #f1f1f1;
}

.site-footer__link {
    color: #d4d4d4;
    text-decoration: none;
    font-size: var(--text-body-14);
    font-weight: var(--font-weight-light);
    letter-spacing: 0.03em;
    transition: color var(--duration-fast), opacity var(--duration-fast);
}

.site-footer__link:hover {
    color: var(--color-text-on-dark);
}

.site-footer__meta {
    color: #9c9c9c;
    font-size: var(--text-body-14);
    font-weight: var(--font-weight-light);
    margin-top: var(--space-2);
}

.site-footer__bottom {
    border-top: 1px solid rgba(255, 255, 255, 0.14);
}

.site-footer__bottom-inner {
    display: flex;
    justify-content: space-between;
    gap: var(--space-6);
    padding-top: var(--space-6);
    padding-bottom: var(--space-6);
}

.site-footer__copyright,
.site-footer__made {
    color: #8d8d8d;
    font-size: var(--text-overline-13);
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.site-footer__made-link {
    text-decoration: none;
    transition: color var(--duration-fast), opacity var(--duration-fast);
}

.site-footer__made-link:hover {
    color: #bcbcbc;
}

@media (max-width: 768px) {
    .hero-title {
        font-size: 56px;
        line-height: 54px;
    }

    .hero-description {
        font-size: var(--text-body-16);
        line-height: var(--space-6);
    }

    .products-grid {
        grid-auto-columns: 82%;
        gap: var(--space-4);
    }

    .products-carousel-nav {
        display: none;
    }

    .section-title {
        font-size: 36px;
        line-height: 44px;
    }

    .categories-grid {
        flex-direction: column;
        height: auto;
    }

    .categories-left,
    .categories-right {
        width: 100%;
    }

    .categories-featured {
        flex-direction: column;
    }

    .categories-featured .category-card {
        min-height: 280px;
    }

    .about-content {
        flex-direction: column;
        gap: var(--space-10);
    }

    .about-image {
        width: 100%;
    }

    .about-title {
        font-size: 40px;
        line-height: 48px;
    }

    .customization-wrapper {
        display: flex;
        flex-direction: column;
        gap: var(--space-8);
        min-height: 0;
        height: auto;
    }

    .customization-content {
        display: contents;
    }

    .customization-label {
        order: 1;
        margin-bottom: var(--space-6);
    }

    .customization-title {
        order: 2;
        font-size: 40px;
        line-height: 48px;
        margin-bottom: var(--space-6);
    }

    .customization-description {
        order: 3;
        margin-bottom: 0;
    }

    .customization-images {
        order: 4;
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: var(--space-4);
        width: 100%;
        max-width: 100%;
        min-height: 0;
        aspect-ratio: unset;
        margin: 0;
        padding: 0;
    }

    .floating-image-1,
    .floating-image-2 {
        position: static;
        width: 100%;
        max-width: none;
        aspect-ratio: 3 / 4;
        object-fit: cover;
    }

    .customization-features {
        order: 5;
        margin-bottom: var(--space-10);
    }

    .customization-buttons {
        order: 6;
        flex-direction: column;
        width: 100%;
        gap: var(--space-3);
    }

    .customization-buttons .btn-primary,
    .customization-buttons .btn-secondary-large {
        width: 100%;
        justify-content: center;
    }

    .cta-title {
        font-size: 56px;
        line-height: 60px;
    }

    .site-footer__inner {
        grid-template-columns: 1fr;
        gap: var(--space-8);
        padding-top: var(--space-14);
        padding-bottom: var(--space-12);
    }

    .site-footer__description {
        max-width: 100%;
    }

    .site-footer__trust-card {
        max-width: 100%;
        padding: 10px 12px;
        gap: 8px;
    }

    .site-footer__trust-title {
        font-size: 0.875rem;
    }

    .site-footer__trust-text {
        font-size: 0.7rem;
    }

    .site-footer__trust-logo {
        max-width: 34px;
        max-height: 34px;
    }

    .site-footer__trust-logo--ml {
        max-width: 40px;
        max-height: 40px;
    }

    .site-footer__bottom-inner {
        flex-direction: column;
    }
}



 /* Estilos adicionales específicos para la página de producto */
 .product-page {
    min-height: 100vh;
    background: white;
}

/* Sin hero oscuro: el header legible desde el inicio */
.product-page .header {
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom-color: var(--color-border-subtle);
}

.product-page .header .nav-link,
.product-page .header .nav-logo-link,
.product-page .header .nav-mobile-logo,
.product-page .header .logo-text,
.product-page .header .nav-toggle {
    color: var(--color-text);
}

.product-page .header .nav-toggle:focus:not(:focus-visible) {
    outline: none;
}

.product-page .header .nav-toggle:focus-visible {
    outline: 2px solid var(--color-interactive);
    outline-offset: 2px;
}

/* Página de colección (misma base que producto) */
.collection-page {
    min-height: 100vh;
    background: white;
}

.collection-page .header {
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom-color: var(--color-border-subtle);
}

.collection-page .header .nav-link,
.collection-page .header .nav-logo-link,
.collection-page .header .nav-mobile-logo,
.collection-page .header .logo-text,
.collection-page .header .nav-toggle {
    color: var(--color-text);
}

.collection-page .header .nav-toggle:focus:not(:focus-visible) {
    outline: none;
}

.collection-page .header .nav-toggle:focus-visible {
    outline: 2px solid var(--color-interactive);
    outline-offset: 2px;
}

.collections-cta .btn-primary-dark {
    text-decoration: none;
}

.collection-page-root {
    min-height: 40vh;
}

.collection-page-top {
    padding-bottom: 0;
    background: var(--color-white);
}

/* Colección detalle: hero arriba; breadcrumb debajo con el mismo ritmo que categoría */
.collection-hero-banner + .collection-page-top.section-products {
    padding-top: var(--space-8);
    padding-bottom: 0;
}

.collection-page-top .breadcrumb-nav,
.contact-page .contact-hero > .container > .breadcrumb-nav,
.collection-page-products > .container > .breadcrumb-nav,
.collection-page-intro > .container > .breadcrumb-nav {
    margin-top: 0;
    margin-bottom: var(--space-8);
}

/* Desktop: menos aire entre navbar y breadcrumb (~64px en lugar de 128px) */
@media (min-width: 769px) {
    body.contact-page > main .contact-hero.section-products,
    body.nosotros-page > main .nosotros-hero.section-products,
    body.profesionales-page:not(.personalizable-page) > main .profesionales-content.section-products,
    body.collection-page .collection-page-root > .collection-page-top.section-products,
    body.collection-page .collection-page-root > .collection-page-products.section-collections,
    body.collection-page .collection-page-root > .collection-page-intro.section-products:first-child,
    body.collection-page .collection-page-root > .collection-hero-banner:first-child + .collection-page-top.section-products,
    body.category-page-body > main > .collection-page-top.section-products,
    body.category-page-body > main > .collection-page-products.section-collections {
        padding-top: var(--space-16);
    }

    body.contact-page .contact-hero .breadcrumb-nav,
    body.nosotros-page .nosotros-hero .breadcrumb-nav,
    body.profesionales-page:not(.personalizable-page) .profesionales-content > .container > .breadcrumb-nav {
        margin-top: 0;
    }
}

body.collection-page .collection-page-root:has(> .collection-page-top:first-child),
body.collection-page .collection-page-root:has(> .collection-page-intro.section-products:first-child) {
    padding-top: var(--header-bar-height);
}

.collection-hero-banner {
    position: relative;
    margin-top: 0;
    padding-top: 0;
}

.collection-hero-banner__media {
    position: relative;
    aspect-ratio: 1423 / 380;
    width: 100%;
    max-height: 420px;
    overflow: hidden;
    border-radius: 0 0 var(--radius-md) var(--radius-md);
}

.collection-hero-banner__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.collection-hero-banner__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to top,
        rgba(0, 0, 0, 0.55) 0%,
        rgba(0, 0, 0, 0.15) 45%,
        transparent 100%
    );
}

.collection-hero-banner__content {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: var(--space-12) var(--space-10);
    max-width: var(--content-wide);
    margin: 0 auto;
}

.collection-hero-banner__title {
    font-size: var(--text-collection-36);
    font-weight: var(--font-weight-medium);
    letter-spacing: 5.7691px;
    color: var(--color-text-on-dark);
    margin: 0;
}

.collection-page-intro .back-button {
    margin-bottom: var(--space-8);
}

/* Showcase de colección: misma grilla y tipografía que .product-grid + .product-info en ficha de producto */
.collection-showcase-root {
    align-items: start;
    margin-top: var(--space-4);
}

.collection-showcase-root--text-only {
    grid-template-columns: 1fr;
    max-width: 100%;
}

.product-gallery .collection-showcase__visual {
    position: relative;
    border-radius: 4px;
    overflow: hidden;
    background: var(--color-surface-muted);
    width: 100%;
    max-width: 800px;
    aspect-ratio: 4 / 3;
    max-height: min(750px, 70vh);
}

.collection-showcase__visual img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

@media (max-width: 900px) {
    .collection-showcase-root.product-grid {
        grid-template-columns: 1fr;
    }

    .product-gallery .collection-showcase__visual {
        max-height: none;
        aspect-ratio: 16 / 10;
    }
}

.collection-page-style {
    font-size: var(--text-body-14);
    text-transform: uppercase;
    letter-spacing: var(--tracking-subtitle);
    color: var(--color-text-muted);
    margin: 0 0 var(--space-4);
}

.collection-page-description {
    font-size: var(--text-body-16);
    line-height: 1.55;
    color: var(--color-text);
    max-width: 52rem;
    margin: 0 0 var(--space-6);
}

.collection-page-features {
    margin: 0;
    padding-left: 1.25rem;
    max-width: 52rem;
    font-size: var(--text-body-16);
    line-height: 1.55;
    color: var(--color-text-muted);
}

.collection-page-features li {
    margin-bottom: var(--space-3);
}

.collection-page-empty {
    grid-column: 1 / -1;
    font-size: var(--text-body-16);
    color: var(--color-text-muted);
    margin: 0;
}

.collection-page-products .section-header {
    margin-bottom: var(--space-8);
}

.product-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 50;
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid rgba(229, 229, 229, 0.5);
}

.product-header-container {
    max-width: 1800px;
    margin: 0 auto;
    padding: 28px 80px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.product-logo {
    font-size: 20px;
    letter-spacing: 0.4em;
    font-weight: 300;
}

.product-nav {
    display: flex;
    gap: 56px;
}

.product-nav a {
    font-size: 13px;
    letter-spacing: 0.5738px;
    text-transform: uppercase;
    text-decoration: none;
    color: #0a0a0a;
    transition: opacity 0.3s;
}

.product-nav a:hover {
    opacity: 0.5;
}

.back-button {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    letter-spacing: 0.5738px;
    text-transform: uppercase;
    color: #737373;
    background: none;
    border: none;
    cursor: pointer;
    transition: color 0.3s;
    margin-bottom: 48px;
}

.back-button:hover {
    color: black;
}

.back-icon {
    width: 16px;
    height: 16px;
    transition: transform 0.3s;
}

.back-button:hover .back-icon {
    transform: translateX(-4px);
}

.product-hero {
    padding-top: calc(var(--header-bar-height) + var(--space-6));
    padding-bottom: 192px;
}

.product-container {
    max-width: 1600px;
    margin: 0 auto;
    padding: 0 80px;
}

.product-grid {
    display: grid;
    grid-template-columns: 6fr 5fr;
    gap: 60px;
}

.product-gallery {
    display: flex;
    flex-direction: column;
}

.main-image {
    position: relative;
    overflow: hidden;
    border-radius: 4px;
    margin-bottom: 24px;
    width: 100%;
    max-width: 800px;
    max-height: 750px;
    aspect-ratio: 4 / 5;
}

.main-image:focus {
    outline: 2px solid var(--color-interactive, #0a0a0a);
    outline-offset: 2px;
}

.main-image:focus:not(:focus-visible) {
    outline: none;
}

/* Una sola imagen (sin carrusel) */
.main-image > img {
    border-radius: 4px;
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center center;
    display: block;
}


.gallery-slide-viewport {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
    border-radius: 4px;
}

.gallery-slide-track {
    display: flex;
    width: 200%;
    height: 100%;
    will-change: transform;
    transition: transform 0.48s cubic-bezier(0.25, 0.1, 0.25, 1);
}

.gallery-slide {
    flex: 0 0 50%;
    width: 50%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.gallery-slide img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center center;
    display: block;
    border-radius: 4px;
}

.gallery-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
    width: 44px;
    height: 44px;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: var(--color-text-body);
    color: white;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.12);
    transition: background 0.2s ease, opacity 0.2s ease;
}

.gallery-nav:hover {
    background: var(--color-interactive-hover);
}

.gallery-nav:focus-visible {
    outline: 2px solid #0a0a0a;
    outline-offset: 2px;
}

.product-gallery--busy .gallery-nav,
.product-gallery--busy .gallery-bullet {
    pointer-events: none;
}

.gallery-nav--prev {
    left: 12px;
}

.gallery-nav--next {
    right: 12px;
}

.gallery-bullets {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 10px;
    margin-top: 4px;
    margin-bottom: 8px;
}

.gallery-bullet {
    width: 8px;
    height: 8px;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: #d4d4d4;
    cursor: pointer;
    transition: background 0.2s ease, transform 0.2s ease;
}

.gallery-bullet:hover {
    background: #737373;
}

.gallery-bullet.is-active {
    background: #0a0a0a;
    transform: scale(1.15);
}

.gallery-bullet:focus-visible {
    outline: 2px solid #0a0a0a;
    outline-offset: 2px;
}

.thumbnails {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
}

.thumbnail {
    flex: 0 0 auto;
    width: 82px;   /* o el tamaño que quieras */
    aspect-ratio: 1 / 1;
    border-radius: 4px;
    overflow: hidden;
    cursor: pointer;
    transition: all 0.3s;
    border: 2px solid transparent;
    padding: 0;
    margin: 0;
    font: inherit;
    color: inherit;
    appearance: none;
    /* el resto de estilos que ya tengas */
}

.thumbnail:hover {
    opacity: 0.7;
}

.thumbnail.active {
    border-color: black;
    opacity: 1;
}

.thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.product-info {
    display: flex;
    flex-direction: column;
    justify-content:space-between;
    gap: 64px;
    max-height: none;
}

.product-category {
    font-size: 13px;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    margin-bottom: 24px;
}

.product-lead--mobile {
    display: none;
}

.product-category--mobile {
    display: none;
}

.product-title {
    font-size: 68px;
    line-height: 1;
    letter-spacing: -0.02em;
    font-weight: 300;
    margin-bottom: 40px;
}

.product-description {
    font-size: 18px;
    color: var(--color-text-body);
    font-weight: 300;
    line-height: 1.3;
}

.product-details {
    display: flex;
    flex-direction: column;
    gap: 32px;
    padding-top: 32px;
}

.detail-item {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.detail-label {
    font-size: 14px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 300;
    
    color: var(--color-text-muted);
}

.detail-value {
    color: var(--color-text-body);
    font-weight: 300;
    line-height: 1.3;

}

.detail-value--muted {
    margin-top: 12px;
    color: var(--color-text-soft);
    font-size: 15px;
}

.detail-value--group-title {
    margin-top: 14px;
    margin-bottom: 8px;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-muted);
}

.color-swatch-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.color-swatch {
    width: 48px;
    height: 48px;
    border: 1px solid var(--color-border);
    border-radius: 6px;
    padding: 0;
    overflow: hidden;
    background: var(--color-surface);
    cursor: pointer;
}

.color-swatch img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.color-swatch:hover {
    border-color: var(--color-interactive);
}

.color-swatch:focus-visible {
    outline: 2px solid var(--color-interactive);
    outline-offset: 2px;
}

.color-modal {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    z-index: 130;
}

.color-modal[hidden] {
    display: none;
}

.color-modal__dialog {
    position: relative;
    background: var(--color-white);
    border-radius: var(--radius-md);
    padding: 16px;
    max-width: min(80vw, 520px);
    width: 100%;
}

.color-modal__dialog img {
    width: 100%;
    max-height: 65vh;
    object-fit: contain;
    border-radius: var(--radius-sm);
    display: block;
}

.color-modal__label {
    margin-top: 10px;
    font-size: var(--text-body-16);
    color: var(--color-text);
}

.color-modal__close {
    position: absolute;
    top: 6px;
    right: 10px;
    width: 34px;
    height: 34px;
    border: 1px solid var(--color-border);
    border-radius: 999px;
    background: var(--color-white);
    font-size: 28px;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: var(--color-text);
}

.product-cta {
    display: flex;
    flex-direction: column;
    gap: 20px;

}

.product-cta .btn-primary {
    width: 100%;
    justify-content: center;
}

.cta-note {
    font-size: 14px;
    color: #a3a3a3;
    text-align: center;
    font-weight: 300;
}

.quality-section {
    padding: 128px 0;
    background: #fafafa;
}

.quality-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 80px;
}

.quality-item h3 {
    font-size: 48px;
    letter-spacing: -0.02em;
    font-weight: 300;
    margin-bottom: 32px;
    line-height: 1.1;
}

.quality-item p {
    font-size: 18px;
    color: #525252;
    font-weight: 300;
    line-height: 1.6;
}

.product-footer {
    background: black;
    color: white;
    padding: 80px 0;
}

.footer-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 64px;
    margin-bottom: 64px;
}

.footer-brand {
    font-size: 20px;
    letter-spacing: 0.4em;
    margin-bottom: 32px;
    font-weight: 300;
}

.footer-description {
    color: #a3a3a3;
    font-size: 14px;
    font-weight: 300;
    line-height: 1.6;
}

.footer-title {
    font-size: 13px;
    letter-spacing: 0.08em;
    margin-bottom: 24px;
    text-transform: uppercase;
    font-weight: 300;
}

.footer-links {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.footer-links a {
    color: #d4d4d4;
    font-size: 14px;
    text-decoration: none;
    font-weight: 300;
    transition: color 0.3s;
}

.footer-links a:hover {
    color: white;
}

.footer-bottom {
    border-top: 1px solid #262626;
    padding-top: 40px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 13px;
    color: #737373;
    font-weight: 300;
}

.footer-social {
    display: flex;
    gap: 32px;
}

.contact-main {
    background: var(--color-white);
}

.nosotros-main {
    background: var(--color-surface);
}

.nosotros-page .section-products,
.nosotros-page .section-collections {
    background: var(--color-surface);
}

.nosotros-hero {
    padding-bottom: var(--space-20);
}

.nosotros-frame {
    border: 1px solid var(--color-black);
    padding: 2px;
    border-radius: var(--radius-md);
    background: var(--color-black);
}

.nosotros-frame-inner {
    background: var(--color-white);
    border-radius: var(--radius-sm);
    padding: var(--space-10);
}

.nosotros-grid {
    display: grid;
    grid-template-columns: 1.15fr 1fr;
    gap: var(--space-10);
    align-items:center;
}

.nosotros-title {
    font-size: var(--text-display-64);
    font-weight: var(--font-weight-light);
    line-height: var(--text-display-64-lh);
    letter-spacing: -0.8px;
    margin-bottom: var(--space-6);
}

.nosotros-subtitle {
    font-size: var(--text-body-18);
    line-height: 1.5;
    color: var(--color-text-body);
    margin-bottom: var(--space-6);
}

.nosotros-description {
    font-size: var(--text-body-16);
    line-height: 1.7;
    color: var(--color-text-soft);
    margin-bottom: var(--space-5);
}

.nosotros-video-wrap {
    border-radius: var(--radius-md);
    overflow: hidden;
    background: var(--color-surface-muted);
}

.nosotros-video-wrap img,
.nosotros-media-img {
    display: block;
    width: 100%;
    max-width: 600px;
    height: auto;
    margin-inline: auto; /* centra si el contenedor es más ancho */
    object-fit: contain; /* o quitá object-fit */
}

.nosotros-video {
    width: 100%;
    height: 100%;
    min-height: 360px;
    max-height: 555px;
    object-fit: cover;
    display: block;
}

.nosotros-materials {
    padding-top: 0;
    background: var(--color-white);
}

.materiales-zigzag {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-20);
    align-items: center;
    padding-block: 0;
}

.materiales-zigzag--intro {
    padding-top: 0;
}

.materiales-zigzag--reverse .materiales-zigzag__media {
    order: 1;
}

.materiales-zigzag--reverse .materiales-zigzag__content {
    order: 2;
}

.materiales-zigzag__media {
    border-radius: var(--radius-md);
    overflow: hidden;
    background: var(--color-surface-muted);
}

.materiales-zigzag__media img,
.materiales-zigzag__media video {
    display: block;
    width: 100%;
    height: 704px;
    min-height: 704px;
    max-height: 704px;
    object-fit: cover;
}

.materiales-eyebrow {
    margin: 0 0 var(--space-4);
    font-size: var(--text-body-14);
    font-weight: var(--font-weight-light);
    line-height: 1.4;
    letter-spacing: var(--tracking-subtitle);
    text-transform: uppercase;
    color: var(--color-text-muted);
}

.materiales-heading {
    margin: 0 0 var(--space-5);
    font-size: var(--text-display-64);
    font-weight: var(--font-weight-light);
    line-height: var(--text-display-64-lh);
    letter-spacing: var(--tracking-tight);
    color: var(--color-text);
}

.materiales-heading--md {
    font-size: var(--text-section-48);
    line-height: var(--text-section-48-lh);
}

.materiales-lead {
    margin: 0 0 var(--space-5);
    font-size: var(--text-body-18);
    line-height: 1.65;
    color: var(--color-text-soft);
    padding-top: 10px;
}

.materiales-text {
    margin: 0;
    font-weight: var(--font-weight-light);
    font-size: var(--text-body-18);
    line-height: 1.3;
    color: var(--color-text-body);
}

.materiales-text + .materiales-text {
    margin-top: var(--space-4);
}

.materiales-text:last-of-type {
    margin-bottom: 0;
}

.materiales-swatches-group {
    padding-top: 20px;
}

.materiales-swatches-label {
    margin: 0 0 var(--space-4);
    font-size: var(--text-body-14);
    font-weight: var(--font-weight-medium);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--color-text);
}

.materiales-swatches {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-5) var(--space-6);
    list-style: none;
    margin: 0;
    padding: 0;
}

.materiales-swatch {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-2);
    min-width: 4.5rem;
}

.materiales-swatch__chip {
    display: block;
    overflow: hidden;
    border: 1px solid var(--color-border);
    background: var(--color-surface);
}

.materiales-swatches--round .materiales-swatch__chip,
.materiales-swatches--fabric .materiales-swatch__chip {
    width: 56px;
    height: 56px;
    border-radius: var(--radius-sm);
}

.materiales-swatch__chip img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.materiales-swatch__label {
    font-size: var(--text-body-14);
    line-height: 1.3;
    text-align: center;
    color: var(--color-text-soft);
}

.materiales-features {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    margin-top: 0;
    padding: 48px 0 var(--space-12);
    background: var(--color-white);
    color: var(--color-text);
}

.materiales-feature {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--space-5);
    padding: var(--space-6) var(--space-8);
}

.materiales-feature + .materiales-feature {
    border-left: 1px solid var(--color-border);
}

.materiales-feature__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text);
}

.materiales-feature__icon svg {
    width: 48px;
    height: 48px;
    stroke: currentColor;
}

.materiales-feature__title {
    margin: 0;
    font-size: var(--text-lead-21);
    font-weight: var(--font-weight-medium);
    line-height: 1.3;
    color: var(--color-text);
}

.materiales-feature__text {
    margin: 0;
    max-width: 18rem;
    font-size: var(--text-body-16);
    line-height: 1.6;
    color: var(--color-text-soft);
}

.contact-page .section-products,
.contact-page .section-collections {
    background: var(--color-white);
}

.contact-page {
    overflow-x: hidden;
}

.contact-hero {
    padding-bottom: var(--space-20);
}

.contact-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8);
    align-items: start;
}

.contact-image-card {
    border-radius: var(--radius-md);
    overflow: hidden;
    min-height: 560px;
    margin-left: 0;
    width: 100%;
}

.contact-image-card img {
    width: 100%;
    height: 100%;
    min-height: 560px;
    object-fit: cover;
    display: block;
}

.contact-card {
    background: var(--color-surface);
    border: none;
    border-radius: var(--radius-md);
    padding-left: var(--space-8);
    padding-right: var(--space-8);
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.contact-card__title {
    font-size: var(--text-lead-21);
    font-weight: var(--font-weight-medium);
    margin-bottom: var(--space-3);
}

.contact-card__text {
    color: var(--color-text-soft);
    margin-bottom: var(--space-6);
}

.contact-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.contact-list li {
    font-size: var(--text-body-16);
    color: var(--color-text-body);
}

.contact-list a {
    color: var(--color-text);
}

.contact-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
}

.contact-form__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
}

.contact-field {
    display: flex;
    flex-direction: column;
    gap: 8px;
    font-size: var(--text-body-14);
    text-transform: uppercase;
    letter-spacing: var(--tracking-nav);
    color: var(--color-text-muted);
}

.contact-field input,
.contact-field textarea {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font: inherit;
    font-size: var(--text-body-16);
    text-transform: none;
    letter-spacing: normal;
    color: var(--color-text);
    background: var(--color-surface);
    resize: none;
}


.contact-field input:focus,
.contact-field textarea:focus {
    outline: 1px solid var(--color-interactive);

}
.contact-field textarea {
    height: 180px; /* Altura específica para el área de mensaje */
}

.contact-field--full {
    grid-column: 1 / -1;
}

.contact-map-section {
    padding-top: var(--space-10);
}

.contact-info-section {
    padding-top: 0;
    padding-bottom: var(--space-10);
}

.contact-quick-info {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
}

.contact-quick-item {
    display: flex;
    align-items: flex-start;
    gap: var(--space-4);
    background: var(--color-surface);
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-md);
    padding: var(--space-6);
}

.contact-quick-icon {
    width: 42px;
    height: 42px;
    border-radius: 999px;
    background: var(--color-surface-muted);
    border: 1px solid var(--color-border);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--color-text);
}

.contact-quick-label {
    margin: 0 0 6px;
    font-size: var(--text-body-14);
    text-transform: uppercase;
    letter-spacing: var(--tracking-nav);
    color: var(--color-text);
   
}
.contact-quick-subtitle {
    margin: 0 0 6px;
    font-size: var(--text-body-14);
    letter-spacing: var(--tracking-nav);
    color: var(--color-text-muted);
   
}

.contact-quick-value {
    margin: 0;
    font-size: var(--text-body-14);
    color: var(--color-text);
    text-decoration: none;
    line-height: 1.4;
}

.contact-quick-value[href]:hover {
    text-decoration: underline;
}

.contact-map-wrapper {
    border-radius: var(--radius-md);
    overflow: hidden;
    border: 1px solid var(--color-border-subtle);
    background: var(--color-surface);
}

.contact-map-wrapper iframe {
    display: block;
    width: 100%;
    min-height: 460px;
}

.profesionales-main {
    background: var(--color-white);
}

.profesionales-page .section-products,
.profesionales-page .section-collections {
    background: var(--color-white);
}

.profesionales-hero {
    padding-bottom: var(--space-16);
}

.profesionales-hero-card {
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: var(--space-8);
    align-items: center;
    padding-top: 30px;
}

.profesionales-hero-media {
    border-radius: var(--radius-md);
    overflow: hidden;
}

.profesionales-hero-media img {
    width: 100%;
    object-fit: cover;
    display: block;
}

.profesionales-hero-content {
    padding: var(--space-10);
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: var(--space-6);
}

.profesionales-hero-content .section-title {
    margin-bottom: 0;
}

.profesionales-hero-subtitle {
    font-size: var(--text-body-18);
    line-height: 1.55;
    color: var(--color-text-soft);
    margin: 0;
}

.profesionales-content {
    padding-top: 0;
}
body.personalizable-page .profesionales-content.section-products {
    padding-bottom: 0;
}

.personalizable-page .profesionales-content > .container > .breadcrumb-nav {
    margin-top: var(--space-6);
    margin-bottom: var(--space-10);
    color: var(--color-text);
}

.personalizable-page .profesionales-content .breadcrumb-link {
    color: var(--color-text-soft);
}

.personalizable-page .profesionales-content .breadcrumb-link:hover {
    color: var(--color-text);
}

.personalizable-page .profesionales-content .breadcrumb-current {
    color: var(--color-text);
}

.profesionales-block {
    max-width: 980px;
    width: 100%;
    min-width: 0;
}

.profesionales-zigzag-item {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8);
    align-items: center;
    padding-block: 0;
}

.profesionales-zigzag-item--reverse .profesionales-zigzag-media {
    order: 2;
}

.profesionales-zigzag-item--reverse .profesionales-block {
    order: 1;
}

.profesionales-zigzag-media {
    border-radius: var(--radius-md);
    overflow: hidden;
    background: var(--color-surface-muted);
}

.profesionales-zigzag-media img {
    width: 100%;
    object-fit: cover;
    display: block;
}

/* Solo personalizable + profesionales: evita overflow por imgs con width HTML grande */
.profesionales-main .profesionales-zigzag-item > * {
    min-width: 0;
}

.profesionales-main .profesionales-zigzag-media {
    width: 100%;
    max-width: 100%;
}

.profesionales-zigzag-item .profesionales-cta {
    max-width: 100%;
}

.profesionales-block-title {
    font-size: var(--text-section-48);
    font-weight: var(--font-weight-light);
    line-height: var(--text-section-48-lh);
    letter-spacing: var(--tracking-tight);
    margin-bottom: var(--space-5);
}

.profesionales-block-text {
    font-size: var(--text-body-18);
    line-height: 1.65;
    color: var(--color-text-soft);
}

.profesionales-divider {
    height: 1px;
    background: transparent;
    margin: calc(var(--space-10) + 20px) 0;
    overflow: hidden;
}

.profesionales-line-expand::after {
    content: "";
    display: block;
    height: 1px;
    width: 100%;
    background: var(--color-border);
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 0.65s var(--ease-out-soft);
}

.profesionales-line-expand.is-visible::after {
    transform: scaleX(1);
}

.profesionales-reveal {
    opacity: 0;
    transform: translateY(16px);
    transition: opacity 0.55s ease, transform 0.55s var(--ease-out-soft);
}

.profesionales-reveal.is-visible,
.profesionales-reveal-group.is-visible .profesionales-reveal {
    opacity: 1;
    transform: translateY(0);
}

.profesionales-reveal-group.is-visible .profesionales-hero-subtitle {
    transition-delay: 0.1s;
}

.profesionales-reveal-group.is-visible .profesionales-hero-content .btn-primary {
    transition-delay: 0.22s;
}

.profesionales-zigzag-item.is-visible .profesionales-block-text,
.profesionales-zigzag-item.is-visible .profesionales-steps,
.profesionales-zigzag-item.is-visible .profesionales-cta-text {
    transition-delay: 0.12s;
}

.profesionales-zigzag-item.is-visible .profesionales-cta .btn-primary {
    transition-delay: 0.2s;
}

.profesionales-line-heading {
    position: relative;
}

.profesionales-hero-subtitle.profesionales-line-heading {
    padding-bottom: var(--space-5);
}

.profesionales-block-title.profesionales-line-heading,
.profesionales-cta-title.profesionales-line-heading {
    padding-bottom: var(--space-4);
}

.profesionales-line-heading::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    height: 1px;
    width: 100%;
    max-width: 7.5rem;
    background: var(--color-border);
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 0.55s var(--ease-out-soft);
}

.profesionales-line-heading.is-visible::after,
.profesionales-reveal-group.is-visible .profesionales-line-heading::after,
.is-visible .profesionales-line-heading::after {
    transform: scaleX(1);
}

.profesionales-reveal-group.is-visible .profesionales-line-heading::after {
    transition-delay: 0.14s;
}

.profesionales-zigzag-item.is-visible .profesionales-line-heading::after {
    transition-delay: 0.08s;
}

.profesionales-steps {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: var(--space-3);
}

.profesionales-steps li {
    font-size: var(--text-body-18);
    color: var(--color-text);
    line-height: 1.5;
}

.profesionales-cta {
    text-align: left;
    max-width: 760px;
}

.profesionales-cta-title {
    font-size: var(--text-section-48);
    font-weight: var(--font-weight-light);
    line-height: var(--text-section-48-lh);
    letter-spacing: var(--tracking-tight);
    margin-bottom: var(--space-4);
}

.profesionales-cta-text {
    font-size: var(--text-body-18);
    color: var(--color-text-soft);
    margin-bottom: var(--space-7);
}

@media (max-width: 768px) {
    .header-container {
        padding-left: var(--header-padding-x);
        padding-right: var(--header-padding-x);
    }

    .nav-mobile-bar {
        gap: 0;
    }

    .nav-mobile-logo {
        justify-content: center;
        gap: 10px;
    }

    .nav-mobile-logo .logo {
        width: 34px;
        height: 34px;
    }

    .nav-mobile-logo-text {
        font-size: 0.92rem;
    }

    .product-hero .breadcrumb-nav,
    .collection-page-intro .breadcrumb-nav,
    .category-page-body .collection-page-intro .breadcrumb-nav {
        margin-top: 0;
        margin-bottom: 16px;
    }

    .product-lead--mobile {
        display: block;
        margin-bottom: var(--space-4);
    }

    .product-lead--mobile .product-category--mobile {
        display: block;
        margin-bottom: 14px;
    }

    .product-lead--mobile .product-title--mobile {
        display: block;
        margin-bottom: var(--space-6);
    }

    .product-title--desktop,
    .product-category--desktop {
        display: none;
    }

    .collection-hero-banner__media {
        min-height: 180px;
    }

    .section-products1 {
        padding: var(--space-10) 0;
    }

    .collection-page-intro.section-products,
    .collection-page-intro.section-products1 {
        padding-top: var(--space-10);
        padding-bottom: 0;
    }

    .product-container {
        padding: 0 24px;
    }

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

    .breadcrumb-nav {
        font-size: 11px;
        gap: 6px;
        margin-bottom: 16px;
    }

    .category-page-body .category-products-section {
        padding-top: var(--space-8);
    }

    .product-info {
        justify-content: flex-start;
        max-height: none;
        gap: 28px;
    }

    .gallery-nav {
        width: 38px;
        height: 38px;
    }

    .gallery-nav--prev {
        left: 8px;
    }

    .gallery-nav--next {
        right: 8px;
    }

    .product-lead--mobile .product-title--mobile {
        font-size: 48px;
        line-height: 1;
        margin-bottom: var(--space-6);
    }

    .product-cta {
        margin-top: 8px;
    }

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

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

    .footer-bottom {
        flex-direction: column;
        gap: 24px;
    }

    .contact-layout {
        grid-template-columns: 1fr;
    }

    .contact-image-card,
    .contact-image-card img {
        min-height: 320px;
    }

    .contact-image-card {
        margin-left: 0;
        width: 100%;
    }

    .contact-form__grid {
        grid-template-columns: 1fr;
    }

    .contact-quick-info {
        grid-template-columns: 1fr;
    }

    .contact-map-wrapper iframe {
        min-height: 340px;
    }

    .nosotros-grid {
        grid-template-columns: 1fr;
        gap: var(--space-8);
    }

    .nosotros-title {
        font-size: 40px;
        line-height: 48px;
    }

    .nosotros-frame-inner {
        padding: var(--space-6);
    }

    .nosotros-video {
        min-height: 240px;
    }

    .materiales-zigzag {
        grid-template-columns: 1fr;
        gap: var(--space-7);
        padding-block: 0;
    }

    .nosotros-materials-row {
        padding-block: 48px;
    }

    /* Nosotros materiales: eyebrow → título → media → textos (solo mobile) */
    .nosotros-materials .materiales-zigzag {
        align-items: stretch;
    }

    .nosotros-materials .materiales-zigzag:not(.materiales-zigzag--intro) {
        display: flex;
        flex-direction: column;
    }

    .nosotros-materials .materiales-zigzag:not(.materiales-zigzag--intro) .materiales-zigzag__content {
        display: contents;
    }

    .nosotros-materials .materiales-eyebrow,
    .nosotros-materials .materiales-heading {
        width: 100%;
        text-align: left;
        align-self: stretch;
    }

    .nosotros-materials .materiales-zigzag:not(.materiales-zigzag--intro) .materiales-eyebrow {
        order: 1;
    }

    .nosotros-materials .materiales-zigzag:not(.materiales-zigzag--intro) .materiales-heading {
        order: 2;
    }

    .nosotros-materials .materiales-zigzag:not(.materiales-zigzag--intro) .materiales-zigzag__media {
        order: 3;
    }

    .nosotros-materials .materiales-zigzag:not(.materiales-zigzag--intro) .materiales-text {
        order: 4;
    }

    .nosotros-materials .materiales-zigzag:not(.materiales-zigzag--intro) .materiales-swatches-group {
        order: 5;
    }

    .materiales-zigzag__media img,
    .materiales-zigzag__media video {
        height: auto;
        min-height: 280px;
        max-height: none;
        aspect-ratio: 4 / 3;
    }

    .materiales-heading {
        font-size: var(--text-section-48);
        line-height: var(--text-section-48-lh);
    }

    .materiales-features {
        grid-template-columns: 1fr;
        padding: var(--space-8) 0;
    }

    .materiales-feature {
        padding: var(--space-8) var(--space-6);
    }

    .materiales-feature + .materiales-feature {
        border-left: none;
        border-top: 1px solid var(--color-border);
    }

    .profesionales-hero-card {
        grid-template-columns: 1fr;
    }

    .profesionales-hero-content {
        padding: var(--space-7);
    }

    .profesionales-zigzag-item {
        grid-template-columns: 1fr;
        gap: var(--space-6);
        min-width: 0;
    }

    .profesionales-zigzag-item > * {
        min-width: 0;
    }

    .profesionales-zigzag-item--reverse .profesionales-zigzag-media,
    .profesionales-zigzag-item--reverse .profesionales-block {
        order: initial;
    }

    .profesionales-page .section-title,
    .profesionales-block-title,
    .profesionales-cta-title,
    .personalizable-hero__title {
        font-size: clamp(28px, 8.5vw, 36px);
        line-height: 1.08;
        letter-spacing: -0.02em;
    }

    .profesionales-hero-card {
        padding-top: 0;
    }

    .profesionales-hero {
        padding-bottom: var(--space-10);
    }

    .profesionales-hero-content {
        padding: 0;
        gap: var(--space-5);
    }

    .profesionales-hero-subtitle,
    .personalizable-hero__subtitle {
        font-size: 15px;
        line-height: 1.5;
    }

    .personalizable-page .profesionales-content > .container > .breadcrumb-nav {
        margin-top: var(--space-4);
        margin-bottom: var(--space-8);
    }

    .personalizable-page .profesionales-content > .container > .profesionales-zigzag-item,
    .profesionales-content-row,
    .nosotros-materials-row {
        padding-block: 32px;
    }

    .content-band--muted {
        padding-block: var(--space-8);
    }

    .personalizable-final-cta .btn-primary,
    .profesionales-hero-content .btn-primary,
    .profesionales-cta .btn-primary {
        width: 100%;
        justify-content: center;
    }

    .profesionales-main,
    .personalizable-main,
    .profesionales-hero,
    .personalizable-hero,
    .profesionales-content,
    .profesionales-hero-card,
    .profesionales-hero-content,
    .profesionales-block,
    .personalizable-hero__inner,
    .personalizable-hero__text {
        max-width: 100%;
        box-sizing: border-box;
    }

    .profesionales-zigzag-media,
    .profesionales-hero-media {
        max-width: 100%;
    }

    .profesionales-zigzag-media img,
    .profesionales-hero-media img {
        max-width: 100%;
    }

    .profesionales-block-title,
    .profesionales-block-text,
    .profesionales-hero-subtitle,
    .personalizable-hero__title,
    .personalizable-hero__subtitle,
    .personalizable-copy p {
        overflow-wrap: break-word;
        word-wrap: break-word;
    }

    body.profesionales-page .profesionales-hero.section-products {
        padding-top: var(--space-8);
        padding-bottom: var(--space-8);
    }

    body.personalizable-page .profesionales-content.section-products {
        padding-top: var(--space-8);
        padding-bottom: 0;
    }
}

/* ==========================================================================
   Ajustes mobile globales de UI (home + páginas internas)
   ========================================================================== */
@media (max-width: 768px) {
    .hero-image img {
        object-position: 72% center;
    }

    .section-products,
    .section-collections,
    .section-categories,
    .section-about,
    .section-customization {
        padding: 56px 0;
    }

    .section-header {
        margin-bottom: 32px;
    }

    .section-title {
        font-size: 32px;
        line-height: 1.1;
        letter-spacing: -0.4px;
    }

    .section-subtitle {
        font-size: 12px;
        line-height: 1.35;
        letter-spacing: 0.06em;
    }

    .hero {
        min-height: 72vh;
    }

    body.profesionales-page:not(.personalizable-page) .profesionales-page-hero {
        min-height: calc(100vh + var(--header-bar-height));
        min-height: calc(100dvh + var(--header-bar-height));
        min-height: calc(100svh + var(--header-bar-height));
        height: calc(100vh + var(--header-bar-height));
        height: calc(100dvh + var(--header-bar-height));
        height: calc(100svh + var(--header-bar-height));
    }

    body.profesionales-page:not(.personalizable-page) .profesionales-page-hero .hero-content {
        min-height: 100%;
        height: 100%;
    }

    .hero-content {
        padding-top: 128px;
        padding-bottom: 56px;
    }

    body.profesionales-page:not(.personalizable-page) .profesionales-page-hero .hero-content {
        align-items: center;
        justify-content: center;
        padding-top: 0;
        padding-bottom: 0;
    }

    .hero-title {
        font-size: clamp(38px, 12vw, 52px);
        line-height: 0.95;
        letter-spacing: -0.02em;
    }

    .hero-subtitle {
        font-size: 12px;
        line-height: 1.35;
    }

    .hero-description {
        font-size: 15px;
        line-height: 1.5;
        max-width: 38ch;
    }

    .products-grid {
        grid-auto-columns: 86%;
        gap: var(--space-4);
    }

    .product-image {
        height: clamp(240px, 58vw, 360px);
        margin-bottom: var(--space-4);
    }

    .product-name {
        font-size: 1.375rem;
        line-height: 1.2;
        letter-spacing: -0.02em;
    }

    .btn-primary,
    .btn-primary-dark,
    .btn-secondary-large,
    a.btn-secondary-large {
        width: 100%;
        justify-content: center;
    }

    .btn-primary,
    .btn-primary-dark,
    .btn-secondary,
    .btn-secondary-large,
    a.btn-secondary-large {
        box-sizing: border-box;
        height: 40px;
        min-height: 40px;
        padding: 0 16px;
        font-size: 0.82rem;
        line-height: 1;
        letter-spacing: 0.05em;
    }

    .btn-secondary,
    .btn-secondary-large,
    a.btn-secondary-large,
    a.btn-secondary-large:link,
    a.btn-secondary-large:visited,
    a.btn-secondary-large:active,
    button.btn-secondary-large {
        color: var(--color-text);
        -webkit-text-fill-color: var(--color-text);
    }

    .btn-icon {
        width: 16px;
        height: 16px;
    }

    .btn-icon-small {
        width: 14px;
        height: 14px;
    }

    .product-cta .btn-primary {
        height: 40px !important;
        min-height: 40px !important;
        padding: 0 16px !important;
    }

    .collections-container {
        gap: 14px;
    }

    .collection-card {
        aspect-ratio: 16 / 9;
        min-height: 150px;
    }

    .collection-content {
        inset: 0;
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
        padding: 12px 14px;
    }

    .collection-name {
        font-size: clamp(24px, 7.5vw, 30px);
        line-height: 1.02;
        letter-spacing: 0.06em;
        margin-bottom: 4px;
    }

    .collection-link {
        font-size: 13px;
        line-height: 1.2;
        letter-spacing: 0.06em;
    }

    .categories-grid {
        gap: 16px;
        margin-bottom: 16px;
    }

    .categories-left,
    .categories-right {
        gap: 16px;
    }

    .category-tall,
    .category-medium,
    .category-small {
        height: auto;
        min-height: 188px;
    }

    .categories-bottom {
        gap: 12px;
    }

    .category-content {
        padding: 12px;
    }

    .category-name {
        font-size: clamp(18px, 6.2vw, 24px);
        line-height: 1.08;
        letter-spacing: 0.04em;
        margin-bottom: 4px;
    }

    .category-link {
        font-size: 13px;
        line-height: 1.2;
        letter-spacing: 0.05em;
    }

    .categories-featured .category-card {
        min-height: 220px;
    }

    .about-content {
        gap: 22px;
    }

    .about-image img {
        height: 260px;
    }

    .about-title {
        font-size: clamp(32px, 10vw, 40px);
        line-height: 1.08;
    }

    .about-description {
        font-size: 15px;
        line-height: 1.55;
    }

    .customization-wrapper {
        height: auto;
    }

    .customization-content {
        max-width: 100%;
    }

    .customization-title {
        font-size: clamp(32px, 10vw, 40px);
        line-height: 1.08;
    }

    .customization-description,
    .feature-description {
        font-size: 15px;
        line-height: 1.5;
    }

    .contact-card {
        padding: 20px;
    }

    .contact-card__title {
        font-size: 28px;
        line-height: 1.15;
    }

    .contact-quick-item {
        padding: 16px;
    }

    .contact-quick-value {
        word-break: break-word;
    }

    .nosotros-title {
        font-size: clamp(30px, 9.8vw, 40px);
        line-height: 1.08;
    }

    .nosotros-subtitle,
    .nosotros-description,
    .materiales-lead,
    .materiales-text,
    .materiales-feature__text,
    .profesionales-block-text,
    .profesionales-steps li,
    .profesionales-cta-text {
        font-size: 15px;
        line-height: 1.55;
    }

    .profesionales-hero-card,
    .profesionales-zigzag-item {
        gap: 18px;
    }

    .personalizable-page .personalizable-copy p {
        font-size: 15px;
        line-height: 1.55;
    }

    .profesionales-cta-title,
    .profesionales-block-title {
        margin-bottom: var(--space-4);
    }

    .profesionales-line-heading.profesionales-block-title,
    .profesionales-line-heading.profesionales-cta-title {
        padding-bottom: var(--space-3);
    }

    .product-hero {
        padding-top: calc(var(--header-bar-height) + var(--space-8));
        padding-bottom: 56px;
    }

    .product-lead--mobile .product-title--mobile {
        font-size: clamp(36px, 11vw, 48px);
        line-height: 1.03;
        letter-spacing: -0.02em;
    }

    .product-description {
        font-size: 15px;
        line-height: 1.55;
    }

    .product-details {
        gap: 20px;
    }
}

@media (max-width: 480px) {
    :root {
        --padding-x: 16px;
        --header-padding-x: 16px;
    }

    .hero-content {
        padding-top: 120px;
        padding-bottom: 48px;
    }

    .btn-primary,
    .btn-primary-dark,
    .btn-secondary,
    .btn-secondary-large,
    a.btn-secondary-large {
        height: 40px;
        min-height: 40px;
        padding: 0 14px;
        font-size: 0.78rem;
    }

    .nav-mobile-logo-text {
        font-size: 0.84rem;
        letter-spacing: 0.035em;
    }

    .products-grid {
        grid-auto-columns: 90%;
    }

    .collection-card {
        min-height: 132px;
    }

    .collection-content,
    .category-content {
        padding: 10px 12px;
    }

    .categories-bottom {
        gap: 10px;
    }

    .category-tall,
    .category-medium,
    .category-small,
    .categories-featured .category-card {
        min-height: 170px;
    }

    .contact-card {
        padding: 16px;
    }

    .product-container {
        padding: 0 16px;
    }
}

/* Arma tu living — hero imagen centrado */
.personalizable-main > .personalizable-hero:first-child {
    margin-top: calc(-1 * var(--header-bar-height));
}

.personalizable-hero {
    position: relative;
    height: 500px;
    width: 100%;
    max-width: 100%;
    overflow: hidden;
}

.personalizable-hero__media {
    position: absolute;
    inset: 0;
}

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

.personalizable-hero__overlay {
    position: absolute;
    inset: 0;
    background: var(--overlay-hero);
    pointer-events: none;
}

.personalizable-hero__inner {
    position: relative;
    z-index: 1;
    box-sizing: border-box;
    height: 100%;
    width: 100%;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: var(--header-bar-height) var(--padding-x) var(--space-8);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.personalizable-hero__text {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: var(--space-6);
    max-width: 40rem;
    color: var(--color-text-on-dark);
}

.personalizable-hero__title {
    margin: 0;
    color: inherit;
}

.personalizable-hero__subtitle {
    margin: 0;
    font-size: var(--text-body-18);
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.92);
    max-width: 36rem;
}

.personalizable-hero__subtitle.profesionales-line-heading {
    padding-bottom: var(--space-5);
}

.personalizable-hero__subtitle.profesionales-line-heading::after {
    left: 50%;
    transform: translateX(-50%) scaleX(0);
    transform-origin: center center;
    max-width: 7.5rem;
    background: rgba(255, 255, 255, 0.45);
}

.profesionales-reveal-group.is-visible .personalizable-hero__subtitle.profesionales-line-heading::after,
.personalizable-hero__text.is-visible .personalizable-hero__subtitle.profesionales-line-heading::after,
.personalizable-hero__subtitle.profesionales-line-heading.is-visible::after {
    transform: translateX(-50%) scaleX(1);
}

.profesionales-reveal-group.is-visible .personalizable-hero__subtitle {
    transition-delay: 0.1s;
}

.profesionales-reveal-group.is-visible .personalizable-hero__text .btn-primary {
    transition-delay: 0.22s;
}

@media (min-width: 769px) and (max-width: 900px) {
    .personalizable-hero {
        height: 100vh;
        height: 100dvh;
    }
}

@media (max-width: 768px) {
    .personalizable-hero {
        height: min(68vh, 480px);
        height: min(68dvh, 480px);
    }

    .personalizable-hero__inner {
        padding: calc(var(--header-bar-height) + 12px) var(--padding-x) var(--space-6);
        width: 100%;
        max-width: 100%;
        min-width: 0;
    }

    .personalizable-hero__text {
        gap: var(--space-5);
        width: 100%;
        max-width: 100%;
        min-width: 0;
        padding-inline: 0;
    }

    .personalizable-hero__title {
        font-size: clamp(28px, 8.5vw, 36px);
        line-height: 1.08;
        letter-spacing: -0.02em;
        max-width: 100%;
        overflow-wrap: break-word;
        word-wrap: break-word;
    }

    .personalizable-hero__subtitle {
        font-size: 15px;
        line-height: 1.5;
        max-width: 100%;
        overflow-wrap: break-word;
        word-wrap: break-word;
    }

    .personalizable-hero__text .btn-primary {
        width: 100%;
        max-width: 100%;
        justify-content: center;
        box-sizing: border-box;
    }

    .personalizable-hero__subtitle.profesionales-line-heading {
        padding-bottom: var(--space-4);
    }
}

/* Sin líneas divisorias (personalizable, profesionales) */
.personalizable-page .profesionales-divider,
.profesionales-page .profesionales-divider {
    display: none;
}

/* Banda full-bleed con fondo muted (personalizable, nosotros, profesionales) */
.content-band--muted,
.personalizable-project-band {
    background: var(--color-surface-muted);
    width: 100%;
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
    padding-block: var(--space-12);
    box-sizing: border-box;
}

/* Fallback si la banda quedara dentro de .container (no usar 100vw en iOS) */
.container > .content-band--muted {
    width: calc(100% + 2 * var(--padding-x));
    max-width: none;
    margin-left: calc(-1 * var(--padding-x));
    margin-right: calc(-1 * var(--padding-x));
}

.content-band--muted .profesionales-zigzag-media,
.content-band--muted .materiales-zigzag__media,
.personalizable-project-band .profesionales-zigzag-media {
    background: transparent;
}

.content-band--muted > .container,
.personalizable-project-band .container {
    padding-left: var(--padding-x);
    padding-right: var(--padding-x);
}

/* Filas zigzag sobre fondo blanco */
.nosotros-materials-row,
.profesionales-content-row,
.personalizable-page .profesionales-content > .container > .profesionales-zigzag-item {
    padding-block: 48px;
}

.profesionales-content-row--cta {
    padding-bottom: var(--space-16);
}

/* Profesionales + Arma tu living: una columna hasta tablet (incl. landscape ~844px) */
@media (max-width: 900px) {
    .profesionales-main .profesionales-hero-card {
        grid-template-columns: 1fr;
        padding-top: 0;
    }

    .profesionales-main .profesionales-hero-content {
        padding: 0;
        gap: var(--space-5);
    }

    .profesionales-main .profesionales-zigzag-item {
        grid-template-columns: 1fr;
        gap: var(--space-6);
        min-width: 0;
    }

    .profesionales-main .profesionales-zigzag-item--reverse .profesionales-zigzag-media,
    .profesionales-main .profesionales-zigzag-item--reverse .profesionales-block {
        order: initial;
    }

    .profesionales-main .section-title,
    .profesionales-main .profesionales-block-title,
    .profesionales-main .profesionales-cta-title,
    .profesionales-main .personalizable-hero__title {
        font-size: clamp(28px, 8.5vw, 36px);
        line-height: 1.08;
        letter-spacing: -0.02em;
    }

    .profesionales-main .profesionales-hero-subtitle,
    .profesionales-main .personalizable-hero__subtitle {
        font-size: 15px;
        line-height: 1.5;
    }

    .profesionales-main .profesionales-hero-content .btn-primary,
    .profesionales-main .profesionales-cta .btn-primary,
    .profesionales-main .personalizable-final-cta .btn-primary {
        width: 100%;
        max-width: 100%;
        justify-content: center;
        box-sizing: border-box;
    }

    .profesionales-main,
    .profesionales-main .profesionales-hero,
    .profesionales-main .profesionales-content,
    .profesionales-main .profesionales-hero-card,
    .profesionales-main .profesionales-hero-content,
    .profesionales-main .profesionales-block {
        max-width: 100%;
        box-sizing: border-box;
    }

    .profesionales-main .profesionales-zigzag-media,
    .profesionales-main .profesionales-hero-media {
        max-width: 100%;
    }

    .profesionales-main .profesionales-zigzag-media img,
    .profesionales-main .profesionales-hero-media img {
        max-width: 100%;
        width: 100%;
    }

    .profesionales-main .profesionales-block-title,
    .profesionales-main .profesionales-block-text,
    .profesionales-main .profesionales-hero-subtitle,
    .profesionales-main .personalizable-copy p {
        overflow-wrap: break-word;
        word-wrap: break-word;
    }

    .personalizable-hero {
        height: min(68vh, 480px);
        height: min(68dvh, 480px);
    }

    .personalizable-hero__inner {
        width: 100%;
        max-width: 100%;
        min-width: 0;
        padding: calc(var(--header-bar-height) + 12px) var(--padding-x) var(--space-6);
    }

    .personalizable-hero__text {
        gap: var(--space-5);
        width: 100%;
        max-width: 100%;
        min-width: 0;
    }

    .personalizable-hero__title {
        font-size: clamp(28px, 8.5vw, 36px);
        line-height: 1.08;
        letter-spacing: -0.02em;
        max-width: 100%;
        overflow-wrap: break-word;
        word-wrap: break-word;
    }

    .personalizable-hero__subtitle {
        font-size: 15px;
        line-height: 1.5;
        max-width: 100%;
        overflow-wrap: break-word;
        word-wrap: break-word;
    }

    .personalizable-hero__text .btn-primary {
        width: 100%;
        max-width: 100%;
        justify-content: center;
        box-sizing: border-box;
    }
}

/* Imágenes 704px (personalizable, profesionales, nosotros) */
.personalizable-page .profesionales-content .profesionales-zigzag-media img,
.profesionales-page .profesionales-hero-media img,
.profesionales-page .profesionales-content .profesionales-zigzag-media img,
.nosotros-page .materiales-zigzag__media img,
.nosotros-page .materiales-zigzag__media video {
    width: 100%;
    height: 704px;
    min-height: 704px;
    max-height: 704px;
    object-fit: cover;
}

.personalizable-page .personalizable-copy {
    display: grid;
    gap: var(--space-4);
}

.personalizable-page .personalizable-copy p {
    margin: 0;
    font-weight: 300;
    font-size: var(--text-body-18);
    line-height: 1.3;
    color: var(--color-text-body);
}
.personalizable-page .profesionales-zigzag-item.is-visible .personalizable-copy {
    transition-delay: 0.12s;
}

/* CTA final — misma altura y tipografía que .personalizable-hero, texto a la izquierda */
.personalizable-page .section-cta.personalizable-final-cta {
    width: 100%;
    max-width: none;
    height: 500px;
    margin-top: var(--space-8);
}

.personalizable-page .section-cta.personalizable-final-cta .cta-overlay {
    background: var(--overlay-hero);
}

.personalizable-page .section-cta.personalizable-final-cta .cta-content {
    height: 100%;
    align-items: center;
    justify-content: flex-start;
    padding: var(--space-8) var(--padding-x);
}

.personalizable-page .section-cta.personalizable-final-cta .personalizable-final-cta__text {
    max-width: 40rem;
    text-align: left;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-6);
    color: var(--color-text-on-dark);
}

.personalizable-page .section-cta.personalizable-final-cta .personalizable-final-cta__label {
    margin: 0;
    font-size: var(--text-overline-13);
    font-weight: var(--font-weight-regular);
    line-height: 1.4;
    letter-spacing: var(--tracking-label-wide);
    text-transform: uppercase;
    opacity: 0.9;
    color: rgba(255, 255, 255, 0.85);
}

.personalizable-page .section-cta.personalizable-final-cta .personalizable-hero__title {
    margin: 0;
    color: inherit;
}

.personalizable-page .section-cta.personalizable-final-cta .personalizable-hero__subtitle {
    margin: 0;
    max-width: 36rem;
    text-align: left;
}

.personalizable-page .section-cta.personalizable-final-cta .personalizable-hero__subtitle.profesionales-line-heading {
    padding-bottom: var(--space-5);
}

.personalizable-page .section-cta.personalizable-final-cta .personalizable-hero__subtitle.profesionales-line-heading::after {
    left: 0;
    transform: scaleX(0);
    transform-origin: left center;
    max-width: 7.5rem;
    background: rgba(255, 255, 255, 0.45);
}

.profesionales-reveal-group.is-visible .personalizable-final-cta .personalizable-hero__subtitle.profesionales-line-heading::after,
.personalizable-final-cta__text.is-visible .personalizable-hero__subtitle.profesionales-line-heading::after,
.personalizable-page .section-cta.personalizable-final-cta .personalizable-hero__subtitle.profesionales-line-heading.is-visible::after {
    transform: scaleX(1);
}

@media (max-width: 768px) {
    .personalizable-page .section-cta.personalizable-final-cta {
        height: min(68vh, 480px);
        height: min(68dvh, 480px);
    }

    .personalizable-page .section-cta.personalizable-final-cta .cta-content {
        padding: var(--space-6) var(--padding-x);
    }

    .personalizable-page .section-cta.personalizable-final-cta .personalizable-final-cta__text {
        gap: var(--space-5);
        width: 100%;
        max-width: 100%;
        min-width: 0;
    }

    .personalizable-page .section-cta.personalizable-final-cta .personalizable-hero__title {
        font-size: clamp(28px, 8.5vw, 36px);
        line-height: 1.08;
        letter-spacing: -0.02em;
        max-width: 100%;
        overflow-wrap: break-word;
        word-wrap: break-word;
    }

    .personalizable-page .section-cta.personalizable-final-cta .personalizable-hero__subtitle {
        font-size: 15px;
        line-height: 1.5;
        max-width: 100%;
        overflow-wrap: break-word;
        word-wrap: break-word;
    }

    .personalizable-page .section-cta.personalizable-final-cta .personalizable-hero__subtitle.profesionales-line-heading {
        padding-bottom: var(--space-4);
    }

    .personalizable-page .section-cta.personalizable-final-cta .personalizable-final-cta__text .btn-primary {
        width: 100%;
        max-width: 100%;
        justify-content: center;
        box-sizing: border-box;
    }
}

@media (max-width: 900px) {
    .personalizable-page .section-cta.personalizable-final-cta {
        height: min(68vh, 480px);
        height: min(68dvh, 480px);
    }
}

@media (max-width: 480px) {
    .personalizable-page .section-cta.personalizable-final-cta {
        height: min(62vh, 420px);
        height: min(62dvh, 420px);
    }
}

@media (max-width: 900px) {
    .personalizable-page .profesionales-content .profesionales-zigzag-media img,
    .profesionales-page .profesionales-hero-media img,
    .profesionales-page .profesionales-content .profesionales-zigzag-media img,
    .nosotros-page .materiales-zigzag__media img,
    .nosotros-page .materiales-zigzag__media video {
        height: auto;
        min-height: 280px;
        max-height: none;
        aspect-ratio: 4 / 3;
    }
}

@media (max-width: 480px) {
    .personalizable-hero {
        height: min(62vh, 420px);
        height: min(62dvh, 420px);
    }

    .personalizable-page .profesionales-content > .container > .profesionales-zigzag-item,
    .profesionales-content-row,
    .nosotros-materials-row {
        padding-block: 24px;
    }

    .content-band--muted {
        padding-block: var(--space-6);
    }

    .profesionales-hero-media img,
    .personalizable-page .profesionales-content .profesionales-zigzag-media img,
    .profesionales-page .profesionales-content .profesionales-zigzag-media img {
        min-height: 220px;
        aspect-ratio: 5 / 4;
    }
}

/* ==========================================================================
   Profesionales — layout desktop (UI referencia)
   ========================================================================== */
body.profesionales-page:not(.personalizable-page) > main.profesionales-main {
    padding-top: 0;
}

/* + header-bar-height compensa margin-top negativo (hero bajo navbar) */
body.profesionales-page:not(.personalizable-page) .profesionales-page-hero {
    margin-top: calc(-1 * var(--header-bar-height));
    min-height: calc(100vh + var(--header-bar-height));
    min-height: calc(100dvh + var(--header-bar-height));
    min-height: calc(100svh + var(--header-bar-height));
    height: calc(100vh + var(--header-bar-height));
    height: calc(100dvh + var(--header-bar-height));
    height: calc(100svh + var(--header-bar-height));
    box-sizing: border-box;
}

body.profesionales-page:not(.personalizable-page) .profesionales-page-hero .hero-content {
    min-height: 100%;
    height: 100%;
    box-sizing: border-box;
}

body.profesionales-page:not(.personalizable-page) .profesionales-page-hero .section-title.personalizable-hero__title {
    font-size: var(--text-section-48);
    line-height: var(--text-section-48-lh);
    letter-spacing: var(--tracking-tight);
    font-weight: var(--font-weight-light);
    margin: 0 0 var(--space-6);
    color: var(--color-text-on-dark);
}

body.profesionales-page:not(.personalizable-page) .profesionales-page-hero .section-title.personalizable-hero__title .hero-title-line-inner {
    line-height: var(--text-section-48-lh);
}

body.profesionales-page:not(.personalizable-page) .profesionales-content > .container > .breadcrumb-nav {
    margin-top: var(--space-6);
    margin-bottom: var(--space-10);
}

@media (min-width: 901px) {
    body.profesionales-page:not(.personalizable-page) .profesionales-content > .container > .breadcrumb-nav {
        margin-bottom: var(--space-12);
    }
}

/* Secciones full-width: no usar grid zigzag 50/50 del section */
.profesionales-pillars.profesionales-zigzag-item,
.profesionales-process.profesionales-zigzag-item {
    display: block;
}

.profesionales-pillars {
    padding-block: var(--space-12) var(--space-16);
}

.profesionales-pillars__grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-10);
    width: 100%;
}

@media (min-width: 901px) {
    .profesionales-pillars__grid {
        gap: var(--space-12);
    }
}

.profesionales-pillar {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
    min-width: 0;
}

.profesionales-pillar__icon {
    color: var(--color-text);
    line-height: 0;
}

.profesionales-pillar__title {
    margin: 0;
    font-size: 24px;
    font-weight: var(--font-weight-medium);
    line-height: 1.35;
    letter-spacing: -0.02em;
    color: var(--color-text);
}

.profesionales-pillar__text {
    margin: 0;
    font-size: var(--text-body-14);
    line-height: 1.6;
    color: var(--color-text-soft);
}

/* Banner central — fondo gris full-bleed, texto alineado al container */
.profesionales-split-banner {
    position: relative;
    width: 100%;
    max-width: 100%;
    height: 450px;
    min-height: 450px;
    max-height: 450px;
    margin-block: var(--space-4) var(--space-16);
    background: var(--color-surface-muted);
    overflow: hidden;
}

.profesionales-split-banner__inner {
    position: relative;
    z-index: 2;
    height: 100%;
    display: flex;
    align-items: center;
}

.profesionales-split-banner__text {
    display: flex;
    align-items: center;
    max-width: 26rem;
    padding: 0;
    background: transparent;
    box-sizing: border-box;
}

.profesionales-split-banner__title {
    margin: 0;
    max-width: 22rem;
    font-size: var(--text-section-48);
    font-weight: var(--font-weight-light);
    line-height: var(--text-section-48-lh);
    letter-spacing: var(--tracking-tight);
    color: var(--color-text);
}

.profesionales-split-banner__title.profesionales-line-heading {
    padding-bottom: var(--space-6);
}

.profesionales-split-banner__title.profesionales-line-heading::after {
    max-width: 4rem;
    background: var(--color-text);
}

.profesionales-split-banner__media {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 1;
    width: min(52%, 980px);
    height: 100%;
    clip-path: polygon(14% 0, 100% 0, 100% 100%, 0 100%);
}

.profesionales-split-banner__media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

/* Cómo trabajamos */
.profesionales-process {
    padding-block: var(--space-16) var(--space-20);
    background: var(--color-white);
}

.profesionales-process__eyebrow {
    margin: 0 0 var(--space-12);
    font-size: var(--text-overline-13);
    font-weight: var(--font-weight-regular);
    letter-spacing: var(--tracking-label-wide);
    text-transform: uppercase;
    color: var(--color-text-soft);
}

.profesionales-process__eyebrow.profesionales-line-heading {
    padding-bottom: var(--space-5);
}

.profesionales-process__eyebrow.profesionales-line-heading::after {
    max-width: 5rem;
}

.profesionales-process__grid {
    list-style: none;
    margin: 0 auto;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-10);
    width: 100%;
}

@media (min-width: 901px) {
    .profesionales-process__grid {
        gap: var(--space-12);
    }
}

.profesionales-process__step {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    min-width: 0;
}

.profesionales-process__head {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    width: 100%;
}

.profesionales-process__num {
    flex-shrink: 0;
    font-size: 24px;
    font-weight: var(--font-weight-regular);
    letter-spacing: 0.08em;
    color: var(--color-text-soft);
}

.profesionales-process__line {
    flex: 1;
    height: 1px;
    min-width: 0;
    background: var(--color-border);
}

.profesionales-process__title {
    margin: 0;
    font-size: 24px;
    font-weight: var(--font-weight-medium);
    line-height: 1.35;
    color: var(--color-text);
}

.profesionales-process__text {
    margin: 0;
    font-size: var(--text-body-14);
    line-height: 1.6;
    color: var(--color-text-soft);
}

/* Tipos de proyecto */
.profesionales-segments {
    padding-block: var(--space-12) var(--space-16);
    background: var(--color-surface-muted);
}

.profesionales-segments__grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--space-8) var(--space-6);
}

.profesionales-segment {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-4);
    flex: 1 1 7rem;
    min-width: 7rem;
    max-width: 10rem;
    text-align: center;
}

.profesionales-segment__icon {
    color: var(--color-text);
    line-height: 0;
}

.profesionales-segment__label {
    font-size: var(--text-body-14);
    line-height: 1.35;
    color: var(--color-text);
}

/* CTA final — mismos estilos que personalizable */
.profesionales-page .section-cta.profesionales-final-cta {
    width: 100%;
    max-width: none;
    height: 500px;
    margin-top: var(--space-8);
}

.profesionales-page .section-cta.profesionales-final-cta .cta-overlay {
    background: var(--overlay-hero);
}

.profesionales-page .section-cta.profesionales-final-cta .cta-content {
    height: 100%;
    align-items: center;
    justify-content: flex-start;
    padding: var(--space-8) var(--padding-x);
}

.profesionales-page .section-cta.profesionales-final-cta .personalizable-final-cta__text {
    max-width: 40rem;
    text-align: left;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-6);
    color: var(--color-text-on-dark);
}

.profesionales-page .section-cta.profesionales-final-cta .personalizable-hero__title {
    margin: 0;
    color: inherit;
}

.profesionales-page .section-cta.profesionales-final-cta .personalizable-hero__subtitle {
    margin: 0;
    max-width: 36rem;
    text-align: left;
    font-size: var(--text-body-18);
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.92);
}

.profesionales-page .section-cta.profesionales-final-cta .personalizable-hero__subtitle.profesionales-line-heading {
    padding-bottom: var(--space-5);
}

.profesionales-page .section-cta.profesionales-final-cta .personalizable-hero__subtitle.profesionales-line-heading::after {
    left: 0;
    transform: scaleX(0);
    transform-origin: left center;
    max-width: 7.5rem;
    background: rgba(255, 255, 255, 0.45);
}

.profesionales-reveal-group.is-visible .profesionales-final-cta .personalizable-hero__subtitle.profesionales-line-heading::after,
.profesionales-page .section-cta.profesionales-final-cta .personalizable-hero__subtitle.profesionales-line-heading.is-visible::after {
    transform: scaleX(1);
}

body.profesionales-page:not(.personalizable-page) .profesionales-content {
    padding-top: var(--space-8);
    padding-bottom: 0;
}

@media (max-width: 900px) {
    body.profesionales-page:not(.personalizable-page) .profesionales-page-hero .hero-content {
        align-items: center;
        justify-content: center;
        padding-top: 0;
        padding-bottom: 0;
    }

    body.profesionales-page:not(.personalizable-page) .profesionales-page-hero .hero-text {
        max-width: 100%;
    }

    body.profesionales-page:not(.personalizable-page) .profesionales-page-hero .section-title.personalizable-hero__title {
        font-size: clamp(28px, 8.5vw, 36px);
        line-height: 1.08;
        letter-spacing: -0.02em;
        max-width: 100%;
        overflow-wrap: break-word;
        word-wrap: break-word;
        margin-bottom: var(--space-5);
    }

    body.profesionales-page:not(.personalizable-page) .profesionales-page-hero .section-title.personalizable-hero__title .hero-title-line-inner {
        line-height: 1.08;
    }

    body.profesionales-page:not(.personalizable-page) .profesionales-page-hero .hero-description {
        font-size: 15px;
        line-height: 1.5;
        margin-bottom: var(--space-6);
    }

    body.profesionales-page:not(.personalizable-page) .profesionales-page-hero .btn-primary {
        width: 100%;
        max-width: 100%;
        justify-content: center;
        box-sizing: border-box;
    }

    body.profesionales-page:not(.personalizable-page) .profesionales-content > .container > .breadcrumb-nav {
        margin-top: var(--space-4);
        margin-bottom: var(--space-8);
    }

    /* Pilares — una columna */
    .profesionales-pillars {
        padding-block: var(--space-8) var(--space-10);
    }

    .profesionales-pillars__grid {
        grid-template-columns: 1fr;
        gap: var(--space-10);
    }

    .profesionales-pillar__title {
        font-size: clamp(20px, 5.5vw, 24px);
    }

    /* Banner — texto arriba, imagen abajo */
    .profesionales-split-banner {
        display: flex;
        flex-direction: column;
        height: auto;
        min-height: 0;
        max-height: none;
        margin-block: var(--space-6) var(--space-10);
    }

    .profesionales-split-banner__inner {
        height: auto;
        padding-block: var(--space-10);
    }

    .profesionales-split-banner__text {
        max-width: 100%;
    }

    .profesionales-split-banner__title {
        font-size: clamp(28px, 8.5vw, 36px);
        line-height: 1.08;
        letter-spacing: -0.02em;
        max-width: 100%;
    }

    .profesionales-split-banner__media {
        position: static;
        width: 100%;
        max-width: none;
        height: auto;
        min-height: 0;
        max-height: none;
        margin-left: 0;
        clip-path: none;
    }

    .profesionales-split-banner__media img {
        width: 100%;
        min-height: 220px;
        max-height: none;
        aspect-ratio: 4 / 3;
        border-radius: 0;
    }

    /* Proceso — una columna */
    .profesionales-process {
        padding-block: var(--space-10) var(--space-12);
    }

    .profesionales-process__grid {
        grid-template-columns: 1fr;
        gap: var(--space-8);
    }

    .profesionales-process__title {
        font-size: clamp(18px, 4.5vw, 20px);
    }

    /* Segmentos — grilla 2 columnas */
    .profesionales-segments {
        padding-block: var(--space-10) var(--space-12);
    }

    .profesionales-segments__grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-8) var(--space-6);
        justify-items: center;
    }

    .profesionales-segment {
        flex: none;
        min-width: 0;
        max-width: none;
        width: 100%;
    }

    /* CTA final */
    .profesionales-page .section-cta.profesionales-final-cta {
        height: min(68vh, 480px);
        height: min(68dvh, 480px);
        margin-top: var(--space-6);
    }

    .profesionales-page .section-cta.profesionales-final-cta .personalizable-hero__title {
        font-size: clamp(28px, 8.5vw, 36px);
        line-height: 1.08;
        letter-spacing: -0.02em;
    }

    .profesionales-page .section-cta.profesionales-final-cta .personalizable-hero__subtitle {
        font-size: 15px;
        line-height: 1.5;
    }

    .profesionales-page .section-cta.profesionales-final-cta .personalizable-final-cta__text .btn-primary {
        width: 100%;
        max-width: 100%;
        justify-content: center;
        box-sizing: border-box;
    }
}

@media (max-width: 768px) {
    .profesionales-page .section-cta.profesionales-final-cta .cta-content {
        padding: var(--space-6) var(--padding-x);
    }

    .profesionales-page .section-cta.profesionales-final-cta .personalizable-final-cta__text {
        gap: var(--space-5);
        width: 100%;
        max-width: 100%;
        min-width: 0;
    }
}

@media (max-width: 480px) {
    .profesionales-page .section-cta.profesionales-final-cta {
        height: min(62vh, 420px);
        height: min(62dvh, 420px);
    }
}