/* ==========================================================================
   PRIDO Footer System — v4.0.0 (rediseño estructural 2026-06-09, mockup "Footer PRIDO v3")
   --------------------------------------------------------------------------
   Layout del mockup: masthead con marca anclada a la IZQUIERDA + tarjeta de
   contacto destacada a la derecha · banda de links (Tienda/Empresas/Ayuda) sobre
   superficie tintada · franja pagos+redes · barra legal. Superficies en capas.

   Lenguaje del sitio (NO el del mockup): --ck-* → teal #2DC6C1, banda B2B ink,
   título Noto Serif, eyebrows Noto Sans, tokens de tema --prido-theme-* para que
   el footer acompañe SIEMPRE el tema de la página (claro/oscuro vía [data-theme]
   + fallback prefers-color-scheme). Sin @import de fuentes (Noto Serif cae a
   Georgia donde la página no la cargue).
   ========================================================================== */

.prido-fs {
    --prido-fs-max: 1180px;
    --prido-fs-gutter: clamp(20px, 4vw, 40px);

    /* Acentos del rediseño (--ck-*) */
    --fs-teal: var(--prido-secondary, #2dc6c1);
    --fs-teal-deep: #0E7E7A;        /* teal oscuro: texto/íconos sobre superficie clara (≈4.8:1) */
    --fs-teal-on-ink: #5FD0CB;      /* teal claro del rediseño (--ck-teal-700 dark) sobre panel ink */
    --fs-teal-tint: #EEF9F8;        /* chip de ícono de contacto (≈ --ck-teal-50) */
    --fs-teal-tint-border: rgba(45, 198, 193, 0.28);
    --fs-card-surface: var(--prido-theme-surface);
    --fs-card-border: var(--prido-theme-border);
    --fs-ink: #0B1E2E;              /* ink del rediseño: banda B2B */
    --fs-serif: 'Noto Serif', Georgia, 'Times New Roman', serif;
    --fs-sans: 'Noto Sans', -apple-system, sans-serif;

    /* Color de eyebrows/labels (sigue el tema) */
    --prido-fs-eyebrow: var(--fs-teal-deep);
    /* Muted scopeado al footer: en claro un punto más oscuro que el token global
       para pasar AA (≈4.6:1); en oscuro vuelve al muted del tema (ya pasa). */
    --prido-fs-muted: #5d6e80;

    /* Escala tipográfica reducida */
    --prido-fs-fs-eyebrow: 0.6875rem; /* 11px — eyebrows / títulos de columna / labels */
    --prido-fs-fs-body: 0.8125rem;    /* 13px — copy secundario, bottom bar */
    --prido-fs-fs-link: 0.875rem;     /* 14px — links de columnas y valores de contacto */

    position: relative;
    margin-top: clamp(38px, 5vw, 78px);
    background: var(--prido-theme-canvas);
    color: var(--prido-theme-ink);
    font-family: var(--fs-sans);
    line-height: var(--prido-leading-copy);
    overflow: clip;
}

/* En tema oscuro: el teal de acento usa el teal de marca, el muted vuelve al del
   tema y el tinte de chips pasa a alpha sobre superficie oscura. */
:root[data-theme="dark"] .prido-fs {
    --fs-teal-deep: var(--prido-secondary, #2dc6c1);
    --prido-fs-muted: var(--prido-theme-muted);
    --fs-teal-tint: rgba(45, 198, 193, 0.14);
    --fs-teal-tint-border: rgba(45, 198, 193, 0.3);
    /* La tarjeta de contacto usa superficie OPACA en oscuro (surface-alt #18202a)
       para despegarse del canvas; la translúcida se funde con el fondo. */
    --fs-card-surface: var(--prido-theme-surface-alt, #18202a);
    --fs-card-border: var(--prido-theme-border-strong);
}
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .prido-fs {
        --fs-teal-deep: var(--prido-secondary, #2dc6c1);
        --prido-fs-muted: var(--prido-theme-muted);
        --fs-teal-tint: rgba(45, 198, 193, 0.14);
        --fs-teal-tint-border: rgba(45, 198, 193, 0.3);
        --fs-card-surface: var(--prido-theme-surface-alt, #18202a);
        --fs-card-border: var(--prido-theme-border-strong);
    }
}

body.home .prido-fs,
body.post-type-archive-product .prido-fs,
body.tax-product_cat .prido-fs,
body.tax-product_tag .prido-fs,
body.tax-pa_color .prido-fs,
body.tax-pa_tapizado .prido-fs,
body.tax-pa_estructura .prido-fs {
    margin-top: 0;
}

/* Contenedor centrado compartido por cada sección full-bleed */
.prido-fs-b2b__inner,
.prido-fs-main__inner,
.prido-fs-links__inner,
.prido-fs-strip__inner,
.prido-fs-bottom__inner {
    width: min(100% - (var(--prido-fs-gutter) * 2), var(--prido-fs-max));
    margin-inline: auto;
}

/* Eyebrows / títulos de columna (Noto Sans mayúsculas teal, un solo tamaño) */
.prido-fs-menu-col__title,
.prido-fs-b2b__eyebrow,
.prido-fs-strip__label {
    margin: 0;
    font-family: var(--fs-sans);
    font-size: var(--prido-fs-fs-eyebrow);
    font-weight: 700;
    letter-spacing: 0.14em;
    line-height: 1.3;
    text-transform: uppercase;
    color: var(--prido-fs-eyebrow);
}

/* ───────────────────────────── Banda B2B (panel ink) ───────────────────────────── */
.prido-fs-b2b {
    background: linear-gradient(135deg, var(--fs-ink) 0%, #102a3a 100%);
    color: #fff;
}
:root[data-theme="dark"] .prido-fs-b2b {
    background: linear-gradient(135deg, #14222e 0%, #1d3445 100%);
}
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .prido-fs-b2b {
        background: linear-gradient(135deg, #14222e 0%, #1d3445 100%);
    }
}
.prido-fs-b2b__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
    padding: clamp(20px, 2.4vw, 30px) 0;
}
.prido-fs-b2b__lead { display: flex; align-items: center; gap: 16px; min-width: 0; flex: 1 1 360px; }
.prido-fs-b2b__icon {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 46px;
    border-radius: 9px;
    background: rgba(45, 198, 193, 0.16);   /* tinte teal del rediseño */
    color: var(--fs-teal);
}
.prido-fs-b2b__text { min-width: 0; }
.prido-fs-b2b__eyebrow { display: block; margin-bottom: 5px; color: var(--fs-teal-on-ink); }
.prido-fs-b2b__title {
    margin: 0;
    font-family: var(--fs-serif);
    font-size: clamp(1.25rem, 1.05rem + 0.8vw, 1.6rem);
    font-weight: 600;
    line-height: 1.18;
    letter-spacing: -0.01em;
    color: #fff;
}
.prido-fs-b2b__actions { display: flex; align-items: center; gap: 10px; flex-shrink: 0; flex-wrap: wrap; }
.prido-fs-b2b__cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 22px;
    border-radius: 8px;
    background: #fff;
    color: var(--fs-ink);
    font-family: var(--fs-sans);
    font-weight: 700;
    font-size: var(--prido-fs-fs-body);
    text-decoration: none;
    transition: background 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease, color 0.18s ease;
}
.prido-fs-b2b__cta:hover,
.prido-fs-b2b__cta:focus-visible {
    background: var(--fs-teal);
    color: var(--fs-ink);
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.22);
}
.prido-fs-b2b__cta svg { flex: 0 0 auto; }
.prido-fs-b2b__phone {
    padding: 11px 14px;
    color: #fff;
    font-family: var(--fs-sans);
    font-weight: 600;
    font-size: var(--prido-fs-fs-body);
    text-decoration: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.45);
    transition: border-color 0.18s ease, color 0.18s ease;
}
.prido-fs-b2b__phone:hover { color: var(--fs-teal-on-ink); border-bottom-color: var(--fs-teal-on-ink); }

/* ──────────────── Masthead: marca a la izquierda + tarjeta contacto ──────────────── */
.prido-fs-main { padding: clamp(40px, 4.5vw, 56px) 0 clamp(36px, 4vw, 48px); }

.prido-fs-mast {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 400px);
    gap: clamp(36px, 5vw, 64px);
    align-items: start;
}

.prido-fs-identity {
    display: block;
    text-align: left;
    min-width: 0;
}
.prido-fs-brand__logo { display: inline-flex; align-items: center; margin-bottom: 24px; }
.prido-fs-logo-img { display: block; width: auto; height: 46px; max-width: 200px; object-fit: contain; }
.prido-fs-logo-text {
    font-family: var(--fs-serif);
    font-size: var(--prido-type-h4);
    font-weight: 600;
    letter-spacing: 0;
    color: var(--prido-theme-ink);
}
.prido-fs-identity__tagline {
    margin: 0;
    max-width: 440px;
    color: var(--prido-fs-muted);
    /* Dos niveles de texto: tagline un punto más tinta que los badges (fallback = muted) */
    color: color-mix(in srgb, var(--prido-theme-ink) 72%, var(--prido-fs-muted));
    font-size: 0.9375rem;
    line-height: 1.65;
}
.prido-fs-identity__meta {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    margin-top: 26px;
    padding-top: 24px;
    border-top: 1px solid var(--prido-theme-border);
    color: var(--prido-fs-muted);
    font-size: var(--prido-fs-fs-body);
}
.prido-fs-identity__meta-item { display: inline-flex; align-items: center; gap: 8px; }
.prido-fs-identity__meta-icon { display: inline-flex; flex: 0 0 auto; color: var(--prido-primary, #5e81a2); }
.prido-fs-identity__meta-dot {
    width: 4px;
    height: 4px;
    border-radius: 999px;
    background: var(--prido-theme-border-strong);
    flex: 0 0 auto;
}

/* Tarjeta de contacto (bloque ascendido del mockup) */
.prido-fs-contact {
    background: var(--fs-card-surface);
    border: 1px solid var(--fs-card-border);
    border-radius: 14px;
    padding: 26px 28px;
    box-shadow: 0 1px 3px rgba(15, 30, 45, 0.08), 0 1px 2px rgba(15, 30, 45, 0.04);
    min-width: 0;
}
.prido-fs-contact .prido-fs-menu-col__title { display: block; margin-bottom: 18px; }
.prido-fs-contact-list { list-style: none; margin: 0; padding: 0; display: block; }
.prido-fs-contact-list__item { border-top: 1px solid var(--prido-theme-border); }
.prido-fs-contact-list__item:first-child { border-top: none; }
.prido-fs-contact-list__link {
    display: flex;
    align-items: center;
    gap: 13px;
    padding: 12px 0;
    text-decoration: none;
    color: var(--prido-theme-ink);
}
/* Ritmo del mockup: la 1ª fila pega con el eyebrow y la última con el borde de la card */
.prido-fs-contact-list__item:first-child .prido-fs-contact-list__link { padding-top: 0; }
.prido-fs-contact-list__item:last-child .prido-fs-contact-list__link { padding-bottom: 0; }
.prido-fs-contact-list__icon {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 9px;
    border: 1px solid var(--fs-teal-tint-border);
    background: var(--fs-teal-tint);
    color: var(--fs-teal-deep);
    transition: border-color 0.18s ease;
}
a.prido-fs-contact-list__link:hover .prido-fs-contact-list__icon { border-color: var(--fs-teal); }
a.prido-fs-contact-list__link:hover .prido-fs-contact-list__value { color: var(--fs-teal-deep); }
.prido-fs-contact-list__text { display: grid; gap: 1px; min-width: 0; }
.prido-fs-contact-list__label { font-size: var(--prido-fs-fs-eyebrow); color: var(--prido-fs-muted); line-height: 1.3; }
.prido-fs-contact-list__value {
    font-size: var(--prido-fs-fs-link);
    font-weight: 700;
    color: var(--prido-theme-ink);
    line-height: 1.35;
    word-break: break-word;
    font-variant-numeric: tabular-nums;
    transition: color 0.18s ease;
}

/* ─────────────── Banda de links (Tienda · Empresas · Ayuda) ─────────────── */
.prido-fs-links {
    background: var(--prido-theme-canvas-soft);
    border-top: 1px solid var(--prido-theme-border);
    border-bottom: 1px solid var(--prido-theme-border);
}
.prido-fs-links__inner { padding: clamp(32px, 4vw, 44px) 0; }
.prido-fs-cols {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(32px, 4vw, 48px);
    align-items: start;
}
.prido-fs-menu-col { min-width: 0; display: grid; gap: 16px; align-content: start; }
.prido-fs-menu,
.prido-fs-legal-menu { list-style: none; margin: 0; padding: 0; }
.prido-fs-menu { display: grid; gap: 12px; }
.prido-fs-menu a {
    color: var(--prido-fs-muted);
    font-size: var(--prido-fs-fs-link);
    font-weight: 500;
    line-height: 1.4;
    text-decoration: none;
    transition: color 0.18s ease;
}
.prido-fs-menu a:hover,
.prido-fs-menu a:focus-visible { color: var(--fs-teal-deep); }

/* ─────────────────────── Strip pagos + redes ─────────────────────── */
.prido-fs-strip { border-bottom: 1px solid var(--prido-theme-border); background: var(--prido-theme-canvas); }
.prido-fs-strip__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    flex-wrap: wrap;
    padding: 16px 0;
}
.prido-fs-strip__label { color: var(--prido-fs-muted); }
.prido-fs-strip__payment { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.prido-fs-payment__chips { display: flex; flex-wrap: wrap; gap: 8px; }
.prido-fs-payment__chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 12px;
    background: var(--prido-theme-surface);
    border: 1px solid var(--prido-theme-border);
    border-radius: 6px;
    color: var(--prido-theme-ink);
    font-size: 0.78rem;
    font-weight: 600;
}
.prido-fs-payment__chip-icon { display: inline-flex; flex: 0 0 auto; color: var(--prido-primary, #5e81a2); }
.prido-fs-payment__chip-icon svg { width: 14px; height: 14px; }   /* el helper los emite a 18px; el mockup usa 14 */
.prido-fs-social { list-style: none; margin: 0; padding: 0; display: flex; align-items: center; gap: 8px; }
.prido-fs-social__item { display: block; }
.prido-fs-social__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 9px;
    background: var(--prido-theme-surface);
    border: 1px solid var(--prido-theme-border-strong);
    color: var(--prido-fs-muted);
    text-decoration: none;
    transition: color 0.18s ease, border-color 0.18s ease;
}
.prido-fs-social__link:hover,
.prido-fs-social__link:focus-visible {
    color: var(--fs-teal-deep);
    border-color: var(--fs-teal);
}

/* ───────────────── Bottom bar (tamaño de letra homogéneo) ───────────────── */
.prido-fs-bottom { background: var(--prido-theme-canvas-soft); }
/* Si el footer solo renderiza la barra legal (sections.main off), conserva un hairline
   separador; en el footer completo el primer hijo es la banda B2B → no-op. */
.prido-fs-bottom:first-child { border-top: 1px solid var(--prido-theme-border); }
.prido-fs-bottom__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px 18px;
    flex-wrap: wrap;
    padding: 18px 0;
    font-size: var(--prido-fs-fs-body);
    color: var(--prido-fs-muted);
}
.prido-fs-bottom__legal { display: flex; align-items: center; gap: 8px 18px; flex-wrap: wrap; }
.prido-fs-legal-menu { display: flex; align-items: center; gap: 8px 18px; flex-wrap: wrap; }
.prido-fs-legal-menu li { display: block; }
/* Todo el bottom bar al mismo tamaño y familia (sin mono) */
.prido-fs-bottom__copy,
.prido-fs-bottom__legal a,
.prido-fs-legal-menu a,
.prido-fs-bottom__region {
    font-size: var(--prido-fs-fs-body);
    font-family: var(--fs-sans);
    letter-spacing: 0;
}
.prido-fs-bottom__legal a,
.prido-fs-legal-menu a { color: inherit; text-decoration: none; transition: color 0.18s ease; }
.prido-fs-bottom__legal a:hover,
.prido-fs-legal-menu a:hover { color: var(--fs-teal-deep); }
.prido-fs-bottom__region { display: flex; align-items: center; gap: 8px; white-space: nowrap; font-variant-numeric: tabular-nums; }
.prido-fs-bottom__flag {
    display: inline-flex;
    width: 21px;
    height: 14px;
    border-radius: 2px;
    overflow: hidden;
    box-shadow: 0 0 0 1px var(--prido-theme-border);
}
.prido-fs-bottom__flag svg { display: block; width: 100%; height: 100%; }

/* ───────────────────────────── Responsive ───────────────────────────── */

/* Tablet: masthead apilado (tarjeta de contacto debajo de la marca) */
@media (max-width: 1023px) {
    .prido-fs-mast { grid-template-columns: 1fr; gap: 32px; }
    .prido-fs-contact { max-width: 520px; }
    .prido-fs-cols { gap: 28px 32px; }
}

/* Mobile: links a 2 columnas, strips apilados */
@media (max-width: 599px) {
    .prido-fs-main { padding: 34px 0 30px; }
    .prido-fs-cols { grid-template-columns: 1fr 1fr; gap: 26px 22px; }
    .prido-fs-contact { max-width: none; padding: 20px 18px; }

    .prido-fs-b2b__inner { flex-direction: column; align-items: flex-start; gap: 14px; }
    .prido-fs-b2b__actions { width: 100%; flex-direction: column; align-items: stretch; }
    .prido-fs-b2b__cta { justify-content: center; }
    .prido-fs-b2b__phone { text-align: center; }

    .prido-fs-strip__inner { flex-direction: column; align-items: flex-start; gap: 16px; }
    .prido-fs-social { flex-wrap: wrap; }

    .prido-fs-bottom__inner { flex-direction: column; align-items: flex-start; }
}

/* Viewports muy angostos (≤359px): sin punto separador entre badges (evita el dot huérfano al envolver) */
@media (max-width: 359px) {
    .prido-fs-identity__meta-dot { display: none; }
}
