/* =========================================================================
   Arletex Design System v3.3 — Tela para decorar salones de fiestas
   Hoja editorial por página (prefijo dsf-). Tokens locales → var(--ax-*).
   ─────────────────────────────────────────────────────────────────────────
   SECCIÓN 01 · Intro
     Registro: Manifiesto · Apertura: ManifestoClaim
     Marco: Top-rule orange · Hover dominante: press-chunky (CTA WhatsApp)
   ========================================================================= */

/* ─── Tokens locales (fallback a hex si --ax-* no está cargado) ─────────── */
.dsf-section {
    --dsf-ink:           var(--ax-ink, #1F2530);
    --dsf-paper:         var(--ax-paper, #FAF6EE);
    --dsf-cream:         var(--ax-cream, #F2EDE4);
    --dsf-white:         var(--ax-white, #FFFFFF);
    --dsf-orange:        var(--ax-orange, #F15A29);
    --dsf-orange-deep:   var(--ax-orange-deep, #B0401A);
    --dsf-purple:        var(--ax-purple, #6A52A2);
    --dsf-muted:         var(--ax-muted, #6E6A60);
    --dsf-muted-dark:    var(--ax-muted-dark, #A8A39A);
    --dsf-rule:          rgba(31, 37, 48, 0.16);
    --dsf-rule-on-dark:  rgba(250, 246, 238, 0.18);
    --dsf-whatsapp:      var(--ax-whatsapp, #25D366);
    --dsf-whatsapp-deep: #0F8C40;
    --dsf-font-display:  var(--ax-font-display, 'Anton', 'Arial Narrow', sans-serif);
    --dsf-font-accent:   var(--ax-font-accent, 'Fraunces', Georgia, serif);
    --dsf-font-body:     var(--ax-font-body, 'Lato', system-ui, sans-serif);
    --dsf-font-mono:     var(--ax-font-mono, 'JetBrains Mono', ui-monospace, monospace);

    --dsf-ease:          cubic-bezier(0.22, 1, 0.36, 1);
    --dsf-motion-fast:   0.16s;
}

/* ─── Section base (reutilizable por las próximas secciones) ───────────── */
.dsf-section {
    width: 100%;
    position: relative;
    background: var(--dsf-white);
    color: var(--dsf-ink);
    font-family: var(--dsf-font-body);
    padding: clamp(48px, 8vw, 96px) 0;
}
.dsf-container {
    width: 100%;
    max-width: 1180px;
    margin: 0 auto;
    padding: 0 clamp(20px, 4vw, 48px);
}

/* ─── Eyebrow stamp (rectángulo recto, NO pill — la firma editorial) ───── */
.dsf-eyebrow {
    font-family: var(--dsf-font-accent);
    font-style: italic;
    font-weight: 400;
    font-size: clamp(0.95rem, 1.1vw, 1.15rem);
    color: var(--dsf-muted);
    line-height: 1.4;
    margin: 0 0 clamp(16px, 2vw, 22px);
    display: inline-flex;
    align-items: baseline;
    gap: 0.65rem;
    flex-wrap: wrap;
}
.dsf-eyebrow::before {
    content: attr(data-stamp);
    font-family: var(--dsf-font-display);
    font-style: normal;
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 0.25rem 0.6rem;
    line-height: 1;
    border: 1px solid var(--dsf-orange);
    color: var(--dsf-orange);
    flex-shrink: 0;
}

/* ─── Display title Anton + <em> Fraunces (voz humana) ─────────────────── */
.dsf-title {
    font-family: var(--dsf-font-display);
    font-weight: 400;
    text-transform: uppercase;
    color: var(--dsf-ink);
    line-height: 0.92;
    letter-spacing: -0.005em;
    margin: 0;
}
.dsf-title--xl { font-size: clamp(2.6rem, 7vw, 5.5rem) !important; }
.dsf-title em {
    font-family: var(--dsf-font-accent);
    font-style: italic;
    font-weight: 400;
    text-transform: lowercase;     /* explícito — la <em> Fraunces va recta y minúscula */
    letter-spacing: -0.025em;
    color: var(--dsf-orange);
}

/* ─── Lead / prosa ──────────────────────────────────────────────────────── */
.dsf-lead {
    font-family: var(--dsf-font-body);
    font-size: clamp(1.05rem, 1.5vw, 1.25rem);
    line-height: 1.65;
    color: var(--dsf-ink);
    max-width: 66ch;
    margin: 0;
}
.dsf-lead strong { font-weight: 800; }

/* ─── Acciones ──────────────────────────────────────────────────────────── */
.dsf-actions {
    margin-top: clamp(28px, 4vw, 40px);
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
}

/* ─── CTA WhatsApp chunky (press-chunky · sombra sólida offset · radius 0) ─ */
.dsf-cta {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 16px 30px;
    min-height: 44px;
    font-family: var(--dsf-font-display);
    font-size: clamp(1.05rem, 1.6vw, 1.35rem);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    line-height: 1.05;
    text-decoration: none;
    border: 2px solid var(--dsf-ink);
    border-radius: 0;
    cursor: pointer;
    transition: transform var(--dsf-motion-fast) var(--dsf-ease),
                box-shadow var(--dsf-motion-fast) var(--dsf-ease);
}
.dsf-cta--whatsapp {
    background: var(--dsf-whatsapp);
    color: #fff;
    box-shadow: 8px 8px 0 var(--dsf-ink);   /* el borde ink + sombra ancla el verde */
}
.dsf-cta--whatsapp i { font-size: 1.3em; line-height: 1; }
.dsf-cta--whatsapp:hover {
    transform: translate(-3px, -3px);
    box-shadow: 11px 11px 0 var(--dsf-ink);
    color: #fff;
    text-decoration: none;
}
.dsf-cta--whatsapp:active {
    transform: translate(2px, 2px);
    box-shadow: 4px 4px 0 var(--dsf-ink);
}
.dsf-cta:focus-visible {
    outline: 3px solid var(--dsf-orange);
    outline-offset: 3px;
}

/* ─── Intro · Marco Top-rule ────────────────────────────────────────────── */
.dsf-section--intro {
    border-top: 3px solid var(--dsf-orange);
    padding-top: clamp(40px, 6vw, 72px);
}
.dsf-section--intro .dsf-header { margin-bottom: clamp(20px, 3vw, 32px); }

/* ─── Responsive ────────────────────────────────────────────────────────── */
@media (max-width: 575px) {
    .dsf-cta--whatsapp { box-shadow: 6px 6px 0 var(--dsf-ink); }
    .dsf-cta--whatsapp:hover { box-shadow: 8px 8px 0 var(--dsf-ink); }
}

/* ─── Motion safe ───────────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    .dsf-cta { transition: none; }
    .dsf-cta--whatsapp:hover,
    .dsf-cta--whatsapp:active { transform: none; }
}


/* =========================================================================
   SECCIÓN 02 · Telas populares (prosa) + Banner envíos
     Prosa  → Registro: Periódico · Apertura: RunInHeadline · Marco: hairline
     Banner → Registro: Galería   · Marco: frame-chunky (sombra offset, radius 0)
   ========================================================================= */

/* ── RunInHeadline (eyebrow inline + em-dash + título, hairline inferior) ── */
.dsf-runin {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: clamp(0.5rem, 1.5vw, 1rem);
    margin-bottom: clamp(22px, 3vw, 34px);
    padding-bottom: clamp(14px, 2vw, 20px);
    border-bottom: 1px solid var(--dsf-rule);
}
.dsf-eyebrow--inline { margin: 0; }
.dsf-runin__divider {
    font-family: var(--dsf-font-accent);
    font-style: italic;
    color: var(--dsf-orange);
    font-size: 1.5em;
    line-height: 1;
    flex-shrink: 0;
}
.dsf-title--md { font-size: clamp(1.9rem, 4.4vw, 3.3rem) !important; }

/* ── Prosa Periódico (columna legible + enlaces side-shift) ─────────────── */
.dsf-prose { max-width: 74ch; }
.dsf-prose p {
    font-family: var(--dsf-font-body);
    font-size: clamp(1rem, 1.25vw, 1.12rem);
    line-height: 1.7;
    color: var(--dsf-ink);
    margin: 0 0 1.1em;
}
.dsf-prose p:last-child { margin-bottom: 0; }
.dsf-prose strong { font-weight: 800; }
.dsf-prose a {
    color: var(--dsf-ink);
    text-decoration: underline;
    text-decoration-color: var(--dsf-orange);
    text-decoration-thickness: 2px;
    text-underline-offset: 2px;
    transition: text-underline-offset var(--dsf-motion-fast) var(--dsf-ease),
                color var(--dsf-motion-fast) var(--dsf-ease);
}
.dsf-prose a:hover { color: var(--dsf-orange); text-underline-offset: 4px; }

/* ── Banner figura editorial (Galería · frame-chunky · radius 0) ────────── */
.dsf-figure {
    margin: 0;
    background: var(--dsf-white);
    border: 2px solid var(--dsf-ink);
    border-top: 3px solid var(--dsf-orange);
    box-shadow: 10px 10px 0 var(--dsf-ink);
    line-height: 0;
}
.dsf-figure img { display: block; width: 100%; height: auto; }
.dsf-figure--banner { margin-top: clamp(40px, 6vw, 72px); }

@media (max-width: 575px) {
    .dsf-figure { box-shadow: 6px 6px 0 var(--dsf-ink); }
}
@media (prefers-reduced-motion: reduce) {
    .dsf-prose a { transition: none; }
}


/* =========================================================================
   SECCIÓN 03 · Telas para eventos sociales (prosa)
     Registro: Dossier · Apertura: Dossier (eyebrow + título + rule 2px ink)
     Fondo: paper (alternancia cálida) · Hover: side-shift enlaces + press CTA
   ========================================================================= */
.dsf-section--paper { background: var(--dsf-paper); }

.dsf-header--dossier {
    margin-bottom: clamp(28px, 4vw, 44px);
    padding-bottom: clamp(16px, 2.5vw, 24px);
    border-bottom: 2px solid var(--dsf-ink);
}


/* =========================================================================
   SECCIÓN 04 · Telas para decoración de eventos (grid de productos)
     Registro: Galería (los productos mandan) · Apertura: NumberProtagonist
     Marco: Bleed-edge (sin frame de sección) · Hover dominante: lift-orange
     ── Reemplaza el bloque legacy .tarjeta-comfy (#edeced, radius 20, blur).
        Es la sección de conversión: las 6 telas son el contenido.
   ========================================================================= */

/* ── Apertura NumberProtagonist (número Anton + eyebrow + título) ───────── */
.dsf-numhead {
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(0.75rem, 2vw, 1.25rem);
    align-items: end;
    margin-bottom: clamp(24px, 3.5vw, 40px);
    padding-bottom: clamp(18px, 2.5vw, 26px);
    border-bottom: 1px solid var(--dsf-rule);
}
@media (min-width: 768px) {
    .dsf-numhead {
        grid-template-columns: minmax(0, auto) minmax(0, 1fr);
        gap: clamp(1.75rem, 4vw, 3.5rem);
    }
}
.dsf-numhead__num {
    font-family: var(--dsf-font-display);
    font-size: clamp(4.25rem, 13vw, 8.5rem);
    line-height: 0.8;
    letter-spacing: -0.04em;
    color: var(--dsf-orange);
    font-variant-numeric: tabular-nums;
    display: inline-flex;
    align-items: baseline;
    gap: 0.35em;
}
.dsf-numhead__num small {
    font-family: var(--dsf-font-accent);
    font-style: italic;
    font-size: 0.2em;
    letter-spacing: 0;
    text-transform: lowercase;
    color: var(--dsf-muted);
}
.dsf-numhead__body { min-width: 0; }
.dsf-numhead__body .dsf-eyebrow { margin-bottom: clamp(10px, 1.4vw, 14px); }
.dsf-numhead__body .dsf-title { line-height: 0.95; }

/* La intro y el CTA respiran bajo el header, antes del grid */
.dsf-section--catalog .dsf-lead { max-width: 78ch; }
.dsf-section--catalog .dsf-actions { margin-bottom: clamp(40px, 5vw, 60px); }

/* ── Grid de productos (3 / 2 / 1) ─────────────────────────────────────── */
.dsf-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(20px, 2.4vw, 32px);
}
@media (max-width: 900px) { .dsf-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .dsf-grid { grid-template-columns: 1fr; } }

/* ── Card de producto · lift-orange (sombra ink en reposo → orange al hover) ─ */
.dsf-card {
    display: flex;
    flex-direction: column;
    background: var(--dsf-white);
    color: var(--dsf-ink);
    border: 1px solid var(--dsf-rule);
    border-top: 3px solid var(--dsf-orange);
    border-radius: 0;
    box-shadow: 4px 4px 0 var(--dsf-ink);
    text-decoration: none;
    overflow: hidden;
    transition: transform var(--dsf-motion-fast) var(--dsf-ease),
                box-shadow var(--dsf-motion-fast) var(--dsf-ease);
}
.dsf-card:hover,
.dsf-card:focus-visible {
    transform: translate(-4px, -4px);
    box-shadow: 8px 8px 0 var(--dsf-orange);
    text-decoration: none;
    color: var(--dsf-ink);
}
.dsf-card:focus-visible { outline: 3px solid var(--dsf-orange); outline-offset: 3px; }

.dsf-card__media {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    line-height: 0;
    border-bottom: 1px solid var(--dsf-rule);
    background: var(--dsf-cream);
}
.dsf-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.45s var(--dsf-ease);
}
.dsf-card:hover .dsf-card__media img { transform: scale(1.045); }

.dsf-card__body {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: clamp(18px, 2vw, 24px);
}
.dsf-card__title {
    font-family: var(--dsf-font-display);
    font-weight: 400;
    text-transform: uppercase;
    font-size: clamp(1.4rem, 2.4vw, 1.85rem);
    line-height: 1;
    letter-spacing: 0.005em;
    color: var(--dsf-ink);
    margin: 0;
}
.dsf-card__desc {
    font-family: var(--dsf-font-body);
    font-size: clamp(0.92rem, 1.05vw, 1rem);
    line-height: 1.55;
    color: var(--dsf-muted);
    margin: 0;
}
.dsf-card__cta {
    margin-top: auto;
    padding-top: 6px;
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    font-family: var(--dsf-font-display);
    text-transform: uppercase;
    font-size: 0.95rem;
    letter-spacing: 0.06em;
    line-height: 1;
    color: var(--dsf-orange);
}
.dsf-card__cta i { transition: transform var(--dsf-motion-fast) var(--dsf-ease); }
.dsf-card:hover .dsf-card__cta i { transform: translateX(4px); }

/* ── Responsive (xs colapso de sombras) ────────────────────────────────── */
@media (max-width: 575px) {
    .dsf-card { box-shadow: 3px 3px 0 var(--dsf-ink); }
    .dsf-card:hover,
    .dsf-card:focus-visible { box-shadow: 6px 6px 0 var(--dsf-orange); }
}

/* ── Motion safe ───────────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    .dsf-card,
    .dsf-card__media img,
    .dsf-card__cta i { transition: none; }
    .dsf-card:hover,
    .dsf-card:focus-visible { transform: none; }
    .dsf-card:hover .dsf-card__media img { transform: none; }
    .dsf-card:hover .dsf-card__cta i { transform: none; }
}

/* ── Variante OSCURA (ink) · puntuación dramática de la landing ──────────
     Voltea el catálogo a fondo ink: las cards blancas flotan, el "06"
     naranja golpea, y rompe la monotonía claro-claro-claro de la página.
   ───────────────────────────────────────────────────────────────────── */
.dsf-section--ink {
    background: var(--dsf-ink);
    color: var(--dsf-paper);
    overflow: hidden;                 /* contiene la textura full-bleed */
}
/* Textura de grilla 48px — profundidad sin ruido (§9.3 texture-dark) */
.dsf-section--ink::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(to right, rgba(250, 246, 238, 0.045) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(250, 246, 238, 0.045) 1px, transparent 1px);
    background-size: 48px 48px;
    pointer-events: none;
}
.dsf-section--ink > .dsf-container { position: relative; z-index: 1; }

/* Header sobre dark */
.dsf-section--ink .dsf-numhead { border-bottom-color: var(--dsf-rule-on-dark); }
.dsf-section--ink .dsf-numhead__num small { color: rgba(250, 246, 238, 0.55); }
.dsf-section--ink .dsf-title { color: var(--dsf-paper); }
.dsf-section--ink .dsf-eyebrow { color: rgba(250, 246, 238, 0.6); }
/* el stamp ::before es outline naranja — ya contrasta sobre ink */

/* Lead: paper suavizado para lectura larga, strong a paper pleno */
.dsf-section--ink .dsf-lead { color: rgba(250, 246, 238, 0.82); }
.dsf-section--ink .dsf-lead strong { color: var(--dsf-paper); }

/* Cards blancas flotando: sin sombra ink (invisible sobre ink) → orange al hover */
.dsf-section--ink .dsf-card {
    border-color: transparent;
    border-top-color: var(--dsf-orange);
    box-shadow: none;
}
.dsf-section--ink .dsf-card:hover,
.dsf-section--ink .dsf-card:focus-visible {
    box-shadow: 8px 8px 0 var(--dsf-orange);
}

/* CTA WhatsApp: el borde ink desaparece sobre ink → reancla con paper + sombra orange */
.dsf-section--ink .dsf-cta--whatsapp {
    border-color: var(--dsf-paper);
    box-shadow: 8px 8px 0 var(--dsf-orange);
}
.dsf-section--ink .dsf-cta--whatsapp:hover  { box-shadow: 11px 11px 0 var(--dsf-orange); }
.dsf-section--ink .dsf-cta--whatsapp:active { box-shadow: 4px 4px 0 var(--dsf-orange); }

@media (max-width: 575px) {
    .dsf-section--ink .dsf-card:hover,
    .dsf-section--ink .dsf-card:focus-visible { box-shadow: 6px 6px 0 var(--dsf-orange); }
    .dsf-section--ink .dsf-cta--whatsapp { box-shadow: 6px 6px 0 var(--dsf-orange); }
    .dsf-section--ink .dsf-cta--whatsapp:hover { box-shadow: 8px 8px 0 var(--dsf-orange); }
}


/* =========================================================================
   SECCIÓN 05 · Muestrario de colores Tafetán (swatch picker)
     Registro: Técnico · Apertura: LabelLateral (riel mono vertical)
     Marco: Side-rule (3px orange a la izquierda) · Hover: lift-orange
     ── Reemplaza el carrusel Slick legacy (.catalogo-slick, .ratio-1x1).
        Muestra las 8 muestras de golpe, sin dependencia de jQuery.
   ========================================================================= */

/* Marco Side-rule: línea naranja al borde izquierdo del container */
.dsf-section--swatches .dsf-container {
    border-left: 3px solid var(--dsf-orange);
}
@media (max-width: 640px) {
    .dsf-section--swatches .dsf-container {
        border-left: 0;
        border-top: 3px solid var(--dsf-orange);
        padding-top: clamp(22px, 5vw, 30px);
    }
}

/* ── Apertura LabelLateral (riel mono vertical + cuerpo) ────────────────── */
.dsf-lathead {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: clamp(1rem, 3vw, 2.5rem);
    align-items: start;
    margin-bottom: clamp(32px, 5vw, 52px);
}
.dsf-lathead__rail {
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    display: flex;
    align-items: center;
    align-self: stretch;
}
.dsf-lathead__rail-mono {
    font-family: var(--dsf-font-mono);
    font-size: 0.72rem;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: var(--dsf-muted);
    white-space: nowrap;
}
.dsf-lathead__body { min-width: 0; }
.dsf-lathead__note {
    font-family: var(--dsf-font-accent);
    font-style: italic;
    font-size: clamp(1rem, 1.4vw, 1.18rem);
    line-height: 1.5;
    color: var(--dsf-muted);
    margin: clamp(12px, 1.6vw, 16px) 0 clamp(20px, 2.6vw, 28px);
    max-width: 54ch;
}
.dsf-lathead__note span { color: var(--dsf-ink); font-weight: 600; font-style: normal; }
@media (max-width: 640px) {
    .dsf-lathead { grid-template-columns: 1fr; gap: 0.5rem; }
    .dsf-lathead__rail { writing-mode: horizontal-tb; transform: none; align-self: start; }
}

/* ── Botón outline (CTA secundario, no-WhatsApp) ───────────────────────── */
.dsf-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    padding: 13px 26px;
    min-height: 44px;
    font-family: var(--dsf-font-body);
    font-weight: 700;
    font-size: 0.92rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    line-height: 1.1;
    text-decoration: none;
    border: 2px solid var(--dsf-ink);
    border-radius: 0;
    background: transparent;
    color: var(--dsf-ink);
    cursor: pointer;
    transition: transform var(--dsf-motion-fast) var(--dsf-ease),
                box-shadow var(--dsf-motion-fast) var(--dsf-ease),
                background var(--dsf-motion-fast) var(--dsf-ease),
                color var(--dsf-motion-fast) var(--dsf-ease);
}
.dsf-btn i { transition: transform var(--dsf-motion-fast) var(--dsf-ease); }
.dsf-btn--outline:hover {
    background: var(--dsf-ink);
    color: var(--dsf-white);
    text-decoration: none;
}
.dsf-btn--outline:hover i { transform: translateX(4px); }
.dsf-btn:focus-visible { outline: 3px solid var(--dsf-orange); outline-offset: 3px; }

/* ── Grid de muestras (4 / 3 / 2) ──────────────────────────────────────── */
.dsf-swatch-grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: clamp(14px, 1.8vw, 22px);
}
@media (max-width: 900px) { .dsf-swatch-grid { grid-template-columns: repeat(3, 1fr); } }

/* Móvil: carrusel horizontal con scroll-snap (ahorra alto vertical, sin JS) */
@media (max-width: 768px) {
    .dsf-swatch-grid {
        display: flex;
        grid-template-columns: none;
        flex-wrap: nowrap;
        overflow-x: auto;
        overscroll-behavior-x: contain;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        gap: 14px;
        padding-bottom: 12px;                 /* aire para la sombra + scrollbar */
        scrollbar-width: thin;
        scrollbar-color: var(--dsf-orange) var(--dsf-rule);
    }
    .dsf-swatch-grid > li {
        flex: 0 0 clamp(150px, 44%, 230px);   /* ~2 muestras + peek en teléfono, ~3 en phablet */
        scroll-snap-align: start;
    }
    .dsf-swatch { width: 100%; }
    /* sin lift vertical en el carrusel: evita clipping/scroll vertical del overflow-x */
    .dsf-swatch:hover,
    .dsf-swatch:focus-visible { transform: none; box-shadow: 4px 4px 0 var(--dsf-orange); }
    .dsf-swatch-grid::-webkit-scrollbar { height: 6px; }
    .dsf-swatch-grid::-webkit-scrollbar-thumb { background: var(--dsf-orange); border-radius: 0; }
    .dsf-swatch-grid::-webkit-scrollbar-track { background: var(--dsf-rule); }
}

/* ── Swatch (chip de color + meta) · lift-orange ───────────────────────── */
.dsf-swatch {
    display: flex;
    flex-direction: column;
    height: 100%;
    background: var(--dsf-white);
    border: 1px solid var(--dsf-rule);
    text-decoration: none;
    color: var(--dsf-ink);
    transition: transform var(--dsf-motion-fast) var(--dsf-ease),
                box-shadow var(--dsf-motion-fast) var(--dsf-ease);
}
.dsf-swatch:hover,
.dsf-swatch:focus-visible {
    transform: translate(-3px, -3px);
    box-shadow: 6px 6px 0 var(--dsf-orange);
    text-decoration: none;
    color: var(--dsf-ink);
}
.dsf-swatch:focus-visible { outline: 3px solid var(--dsf-orange); outline-offset: 3px; }

.dsf-swatch__chip { display: block; aspect-ratio: 1 / 1; overflow: hidden; line-height: 0; }
.dsf-swatch__chip img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.45s var(--dsf-ease);
}
.dsf-swatch:hover .dsf-swatch__chip img { transform: scale(1.06); }

.dsf-swatch__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 12px 14px;
    border-top: 2px solid var(--dsf-ink);
}
.dsf-swatch__name {
    font-family: var(--dsf-font-body);
    font-weight: 800;
    font-size: clamp(0.82rem, 1vw, 0.95rem);
    line-height: 1.2;
    color: var(--dsf-ink);
    margin: 0;
}
.dsf-swatch__arrow {
    flex-shrink: 0;
    font-size: 0.85rem;
    color: var(--dsf-orange);
    transition: transform var(--dsf-motion-fast) var(--dsf-ease);
}
.dsf-swatch:hover .dsf-swatch__arrow { transform: translateX(3px); }

@media (max-width: 575px) {
    .dsf-swatch:hover,
    .dsf-swatch:focus-visible { box-shadow: 4px 4px 0 var(--dsf-orange); }
}
@media (prefers-reduced-motion: reduce) {
    .dsf-btn, .dsf-btn i,
    .dsf-swatch, .dsf-swatch__chip img, .dsf-swatch__arrow { transition: none; }
    .dsf-swatch:hover, .dsf-swatch:focus-visible { transform: none; }
    .dsf-swatch:hover .dsf-swatch__chip img { transform: none; }
    .dsf-swatch:hover .dsf-swatch__arrow,
    .dsf-btn--outline:hover i { transform: none; }
}


/* =========================================================================
   SECCIÓN 06 · Telas por superficie (eventos / paredes / techos)
     Registro: Periódico · Apertura: Dossier numerado (stamp 01·02·03)
     Marco: Brick-stack (zigzag alternado) · imágenes frame-chunky (.dsf-figure)
     Fondo: paper · Hover: side-shift en prosa, press-chunky compacto en CTA
     ── Reemplaza 3× .tarjeta-beneficio legacy (imágenes redondeadas border-15).
   ========================================================================= */
.dsf-zigzag .dsf-zz {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(28px, 5vw, 64px);
    align-items: center;
}
.dsf-zigzag .dsf-zz + .dsf-zz { margin-top: clamp(48px, 8vw, 100px); }

/* Alternancia (desktop): media a la derecha por defecto, a la izquierda en --rev */
.dsf-zz__text  { min-width: 0; }
.dsf-zz__media { order: 2; margin: 0; }
.dsf-zz--rev .dsf-zz__text  { order: 2; }
.dsf-zz--rev .dsf-zz__media { order: 1; }

.dsf-zz__text .dsf-title  { margin-bottom: clamp(16px, 2vw, 22px); }
.dsf-zz__text .dsf-prose  { max-width: 60ch; }
.dsf-zz__text .dsf-actions { margin-top: clamp(22px, 3vw, 30px); }

@media (max-width: 860px) {
    .dsf-zigzag .dsf-zz { grid-template-columns: 1fr; gap: clamp(22px, 5vw, 32px); }
    /* en móvil: orden de origen (texto, luego imagen) sin importar --rev */
    .dsf-zz__media, .dsf-zz--rev .dsf-zz__media,
    .dsf-zz__text,  .dsf-zz--rev .dsf-zz__text { order: 0; }
    .dsf-zigzag .dsf-zz + .dsf-zz { margin-top: clamp(40px, 9vw, 56px); }
}

/* Título compacto para filas (3 títulos en una sección) */
.dsf-title--sm { font-size: clamp(1.55rem, 3.4vw, 2.5rem) !important; }

/* CTA WhatsApp compacto: evita 3 botones gigantes idénticos */
.dsf-cta--sm { padding: 12px 22px; font-size: clamp(0.95rem, 1.3vw, 1.12rem); box-shadow: 6px 6px 0 var(--dsf-ink); }
.dsf-cta--sm:hover  { box-shadow: 8px 8px 0 var(--dsf-ink); }
.dsf-cta--sm:active { box-shadow: 3px 3px 0 var(--dsf-ink); }

@media (max-width: 575px) {
    .dsf-cta--sm { box-shadow: 5px 5px 0 var(--dsf-ink); }
    .dsf-cta--sm:hover { box-shadow: 7px 7px 0 var(--dsf-ink); }
}


/* =========================================================================
   SECCIÓN 07 · Deep-dive: techos · beneficios · viaje textil · ideas
     07a Techos        → Periódico / DropCap / Double-rule / white (prosa narrow)
     07b Beneficios    → Galería / figura editorial / paper tight
     07c Viaje Textil  → statement OSCURO / INK (2ª puntuación de la página)
     07d Ideas+Sociales→ Dossier / dúo de features con imagen frame-chunky
   ========================================================================= */

/* Utilidades de sección */
.dsf-section--tight { padding: clamp(28px, 4vw, 48px) 0; }
.dsf-container--narrow { max-width: 760px; }
.dsf-section--double-rule {
    border-top: 1px solid var(--dsf-rule);
    border-bottom: 1px solid var(--dsf-rule);
}

/* Header de artículo (eyebrow + título, alineado a la izquierda) */
.dsf-arthead { margin-bottom: clamp(22px, 3vw, 32px); }
.dsf-arthead .dsf-title { margin-top: 8px; }

/* Títulos extra pequeños (features, columnas) */
.dsf-title--xs { font-size: clamp(1.3rem, 2.6vw, 1.95rem) !important; }

/* Listas dentro de prosa (guion naranja en vez de bullet) */
.dsf-prose ul { margin: 0 0 1.1em; padding: 0; list-style: none; }
.dsf-prose li {
    position: relative;
    padding-left: 1.6em;
    margin-bottom: 0.7em;
    font-family: var(--dsf-font-body);
    font-size: clamp(1rem, 1.2vw, 1.1rem);
    line-height: 1.6;
    color: var(--dsf-ink);
}
.dsf-prose li::before {
    content: "";
    position: absolute;
    left: 0; top: 0.62em;
    width: 0.8em; height: 3px;
    background: var(--dsf-orange);
}
.dsf-prose li strong { font-weight: 800; }

/* 07b · Beneficios (logo + infografía, radius 0) */
.dsf-benefits {
    display: grid;
    grid-template-columns: minmax(0, 0.32fr) minmax(0, 1fr);
    gap: clamp(20px, 3vw, 44px);
    align-items: center;
}
.dsf-benefits__logo img,
.dsf-benefits__art img { width: 100%; height: auto; display: block; border-radius: 0; }
.dsf-benefits__art { margin: 0; }
@media (max-width: 640px) {
    .dsf-benefits { grid-template-columns: 1fr; gap: 22px; justify-items: center; }
    .dsf-benefits__logo { max-width: 220px; }
}

/* 07c · banda oscura "Viaje Textil": kicker + overrides de prosa/lead sobre ink */
.dsf-viaje__kicker {
    display: block;
    font-family: var(--dsf-font-body);
    font-weight: 700;
    font-size: clamp(0.8rem, 1.3vw, 1rem);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--dsf-muted-dark);
    margin-bottom: 0.6em;
}
.dsf-section--ink .dsf-lead a {
    color: var(--dsf-paper);
    text-decoration: underline;
    text-decoration-color: var(--dsf-orange);
    text-decoration-thickness: 2px;
    text-underline-offset: 2px;
}
.dsf-section--ink .dsf-lead a:hover { color: var(--dsf-orange); }
.dsf-section--ink .dsf-prose p { color: rgba(250, 246, 238, 0.82); }
.dsf-section--ink .dsf-prose strong { color: var(--dsf-paper); }
.dsf-section--ink .dsf-prose li { color: rgba(250, 246, 238, 0.82); }
.dsf-section--ink .dsf-prose a { color: var(--dsf-paper); }
.dsf-section--ink .dsf-prose a:hover { color: var(--dsf-orange); }

/* 07d · dúo de features (imagen frame-chunky + h3 + prosa + CTA) */
.dsf-duo {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(28px, 4vw, 56px);
}
@media (max-width: 768px) { .dsf-duo { grid-template-columns: 1fr; gap: clamp(34px, 7vw, 46px); } }
.dsf-feat { display: flex; flex-direction: column; }
.dsf-feat .dsf-figure { margin: 0 0 clamp(18px, 2.5vw, 26px); }
.dsf-feat .dsf-title { margin-bottom: clamp(12px, 1.6vw, 16px); }
.dsf-feat .dsf-actions { margin-top: auto; padding-top: clamp(18px, 2.5vw, 24px); }


/* =========================================================================
   SECCIÓN 08 · Carrusel de banners "Manteles para tablón"
     MISMO diseño que el carrusel del catálogo (telas-catalogo.css §14.b):
     frame ink + sombra 6px, controles chunky salidos con sombra naranja
     offset, flechas chevron CSS, sin radios. Markup: .catalogo-banner-strip.
     Port verbatim con fallbacks var(--ax-*, #hex) para que funcione en el blog.
   ========================================================================= */
.catalogo-banner-strip {
    margin-top: clamp(32px, 5vw, 56px);
    margin-bottom: clamp(32px, 5vw, 56px);
}
.catalogo-banner-strip .slider-nav {
    margin: 0 !important;
    width: 100% !important;
}
.catalogo-banner-strip .carousel.slide {
    border: 2px solid var(--ax-ink, #1F2530);
    box-shadow: 6px 6px 0 var(--ax-ink, #1F2530);
    background: var(--ax-white, #FFFFFF);
    position: relative;
}
.catalogo-banner-strip .carousel-inner { overflow: hidden; }
.catalogo-banner-strip .carousel-item { transition: transform .5s ease-in-out; }
.catalogo-banner-strip .banner-round { border-radius: 0 !important; display: block; overflow: hidden; }
.catalogo-banner-strip .banner-round img { border-radius: 0 !important; display: block; width: 100%; }

/* Controles prev/next — chunky brutales (salen del marco con sombra naranja) */
.catalogo-banner-strip .carousel-control-prev,
.catalogo-banner-strip .carousel-control-next {
    width: clamp(40px, 5vw, 56px);
    height: clamp(40px, 5vw, 56px);
    top: 50%;
    bottom: auto;
    transform: translateY(-50%);
    opacity: 1;
    background: var(--ax-ink, #1F2530);
    border: 2px solid var(--ax-ink, #1F2530);
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
    z-index: 5;
}
.catalogo-banner-strip .carousel-control-prev { left: -14px; box-shadow: -4px 4px 0 var(--ax-orange, #F15A29); }
.catalogo-banner-strip .carousel-control-next { right: -14px; box-shadow: 4px 4px 0 var(--ax-orange, #F15A29); }
.catalogo-banner-strip .carousel-control-prev:hover,
.catalogo-banner-strip .carousel-control-next:hover {
    background: var(--ax-orange, #F15A29);
    transform: translateY(-50%) translateX(-2px);
}
.catalogo-banner-strip .carousel-control-next:hover { transform: translateY(-50%) translateX(2px); }

.catalogo-banner-strip .carousel-control-prev-icon,
.catalogo-banner-strip .carousel-control-next-icon {
    width: 20px;
    height: 20px;
    background-image: none;
    position: relative;
}
.catalogo-banner-strip .carousel-control-prev-icon::before,
.catalogo-banner-strip .carousel-control-next-icon::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 12px;
    height: 12px;
    border-top: 3px solid var(--ax-white, #FFFFFF);
    border-right: 3px solid var(--ax-white, #FFFFFF);
}
.catalogo-banner-strip .carousel-control-prev-icon::before { transform: translate(-30%, -50%) rotate(-135deg); }
.catalogo-banner-strip .carousel-control-next-icon::before { transform: translate(-70%, -50%) rotate(45deg); }

@media (max-width: 767px) {
    .catalogo-banner-strip .carousel-control-prev { left: 8px; box-shadow: -3px 3px 0 var(--ax-orange, #F15A29); }
    .catalogo-banner-strip .carousel-control-next { right: 8px; box-shadow: 3px 3px 0 var(--ax-orange, #F15A29); }
    .catalogo-banner-strip .carousel.slide { box-shadow: 4px 4px 0 var(--ax-ink, #1F2530); }
}


/* =========================================================================
   SECCIÓN 09 · Intro "Tela para decoración de eventos" + "Dónde comprar"
     09a → MegaTextBg (palabra faint) / cream / centrado
     09b → Dossier / split texto+imagen (reusa .dsf-zz) / white / chip Maps
   ========================================================================= */
.dsf-section--cream { background: var(--dsf-cream); color: var(--dsf-ink); }
.dsf-section--center { overflow: hidden; }   /* contiene el mega-text */

/* Apertura MegaTextBg (palabra gigante tenue detrás del header) */
.dsf-megahead {
    position: relative;
    isolation: isolate;
    padding-top: clamp(24px, 6vw, 64px);
    margin-bottom: clamp(20px, 3vw, 32px);
}
.dsf-megahead__bg {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    font-family: var(--dsf-font-display);
    font-size: clamp(4.5rem, 17vw, 12rem);
    line-height: 0.78;
    letter-spacing: -0.03em;
    text-transform: uppercase;
    color: var(--dsf-rule);
    white-space: nowrap;
    pointer-events: none;
    z-index: -1;
}
.dsf-megahead__fg { position: relative; }

/* Sección centrada */
.dsf-section--center .dsf-megahead,
.dsf-section--center .dsf-title { text-align: center; }
.dsf-section--center .dsf-eyebrow { justify-content: center; }
.dsf-prose--center { margin-left: auto; margin-right: auto; }
.dsf-actions--center { justify-content: center; }

/* Callout (cierre Fraunces italic antes del CTA) */
.dsf-callout {
    text-align: center;
    font-family: var(--dsf-font-accent);
    font-style: italic;
    font-size: clamp(1.15rem, 2vw, 1.5rem);
    line-height: 1.4;
    color: var(--dsf-ink);
    max-width: 60ch;
    margin: clamp(24px, 3.5vw, 36px) auto 0;
}

/* Chip Google Maps (ubicación) · hover lift-orange */
.dsf-maps {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin: clamp(8px, 1.6vw, 14px) 0 clamp(18px, 2.5vw, 26px);
    padding: 8px 16px;
    border: 2px solid var(--dsf-ink);
    background: var(--dsf-white);
    text-decoration: none;
    color: var(--dsf-ink);
    transition: transform var(--dsf-motion-fast) var(--dsf-ease),
                box-shadow var(--dsf-motion-fast) var(--dsf-ease);
}
.dsf-maps:hover {
    transform: translate(-2px, -2px);
    box-shadow: 4px 4px 0 var(--dsf-orange);
    color: var(--dsf-ink);
    text-decoration: none;
}
.dsf-maps:focus-visible { outline: 3px solid var(--dsf-orange); outline-offset: 2px; }
.dsf-maps picture { display: block; line-height: 0; }
.dsf-maps img { height: 24px; width: auto; display: block; }
.dsf-maps span {
    font-family: var(--dsf-font-body);
    font-weight: 700;
    font-size: 0.82rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

@media (prefers-reduced-motion: reduce) {
    .dsf-maps { transition: none; }
    .dsf-maps:hover { transform: none; }
}

/* Bloque de prosa/acciones que sigue a un split .dsf-zz (nota al pie de sección) */
.dsf-after { margin-top: clamp(28px, 4vw, 44px); }

/* Enlaces dentro de títulos (cards de producto, features con título enlazado) */
.dsf-title a { color: inherit; text-decoration: none; transition: color var(--dsf-motion-fast) var(--dsf-ease); }
.dsf-title a:hover { color: var(--dsf-orange); }

/* Cards de producto en grid: media uniforme 4:3 (no afecta splits/dúos) */
.dsf-grid .dsf-feat .dsf-figure { aspect-ratio: 4 / 3; overflow: hidden; }
.dsf-grid .dsf-feat .dsf-figure img { width: 100%; height: 100%; object-fit: cover; }

/* Carrusel framed dentro de un split .dsf-zz (frame chunky + controles chevron inset) */
.dsf-zz__media .carousel.slide { position: relative; }
.dsf-zz__media .carousel-inner {
    border: 2px solid var(--dsf-ink);
    border-top: 3px solid var(--dsf-orange);
    box-shadow: 8px 8px 0 var(--dsf-ink);
    overflow: hidden;
    line-height: 0;
}
.dsf-zz__media .carousel .banner-round,
.dsf-zz__media .carousel-item img { border-radius: 0 !important; display: block; width: 100%; }
.dsf-zz__media .carousel-control-prev,
.dsf-zz__media .carousel-control-next {
    width: 44px;
    height: 44px;
    top: 50%;
    bottom: auto;
    transform: translateY(-50%);
    background: var(--dsf-ink);
    border: 2px solid var(--dsf-paper);
    opacity: 1;
    transition: background var(--dsf-motion-fast) var(--dsf-ease);
}
.dsf-zz__media .carousel-control-prev { left: 12px; }
.dsf-zz__media .carousel-control-next { right: 12px; }
.dsf-zz__media .carousel-control-prev:hover,
.dsf-zz__media .carousel-control-next:hover { background: var(--dsf-orange); }
.dsf-zz__media .carousel-control-prev-icon,
.dsf-zz__media .carousel-control-next-icon { width: 18px; height: 18px; background-image: none; position: relative; }
.dsf-zz__media .carousel-control-prev-icon::before,
.dsf-zz__media .carousel-control-next-icon::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 11px;
    height: 11px;
    border-top: 3px solid var(--dsf-paper);
    border-right: 3px solid var(--dsf-paper);
}
.dsf-zz__media .carousel-control-prev-icon::before { transform: translate(-30%, -50%) rotate(-135deg); }
.dsf-zz__media .carousel-control-next-icon::before { transform: translate(-70%, -50%) rotate(45deg); }
@media (max-width: 575px) {
    .dsf-zz__media .carousel-inner { box-shadow: 5px 5px 0 var(--dsf-ink); }
}
