/* ============================================================
 * Audit fixes — solo estilos para clases NUEVAS añadidas
 * Tokens reales del handoff: --forest-deep --accent --accent-dark
 * --accent-soft --accent-pastel --brown --brown-deep --hairline
 * --hairline-strong --off-white --cream --ink-warm-deep --ink-warm --sans --serif
 * NO redefinir .hero/.hero-img/.hero-content — el handoff ya las tiene.
 * ============================================================ */

/* ===== TRUST BAR (.trust > .trust-grid > .trust-card) ===== */
.trust { background: var(--off-white); padding: 36px 32px; border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); }
.trust-grid { max-width: 1320px; margin: 0 auto; display: grid; grid-template-columns: repeat(6, 1fr); gap: 24px; align-items: center; }
.trust-card { display: flex; align-items: center; gap: 12px; min-width: 0; }
.trust-card .trust-icon { width: 42px; height: 42px; border-radius: 999px; background: var(--accent-soft); color: var(--accent-dark); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.trust-card .trust-icon svg { width: 20px; height: 20px; }
.trust-rating { font-family: var(--sans); font-weight: 800; font-size: 24px; color: var(--accent-dark); letter-spacing: -0.02em; line-height: 1; }
.trust-text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.trust-label { font-family: var(--sans); font-weight: 600; font-size: 13px; color: var(--forest-deep); line-height: 1.2; letter-spacing: -0.01em; }
.trust-sub { font-family: var(--sans); font-weight: 400; font-size: 11.5px; color: var(--ink-warm); letter-spacing: 0.01em; }
.trust-card--rating .trust-icon { background: transparent; width: auto; height: auto; }
@media (max-width: 1200px) { .trust-grid { grid-template-columns: repeat(3, 1fr); gap: 22px; } }
@media (max-width: 680px) {
    .trust { padding: 24px 18px; }
    .trust-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; }
    .trust-label { font-size: 12px; }
    .trust-sub { font-size: 11px; }
}

/* ===== PRODUCT CARD: price-old / price-now / rating-row / sold / stock ===== */
.product-card .product-meta { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 10px; }
.product-card .product-price { display: inline-flex; align-items: baseline; gap: 8px; }
.product-card .price-old { font-family: var(--sans); font-size: 13px; color: var(--ink-warm); text-decoration: line-through; font-weight: 500; }
.product-card .price-now { font-family: var(--sans); font-size: 18px; font-weight: 700; color: var(--forest-deep); letter-spacing: -0.01em; }
.product-card .product-rating-row { font-family: var(--sans); font-size: 11.5px; color: var(--ink-warm); display: inline-flex; align-items: center; gap: 6px; }
.product-card .product-rating-row .stars { color: #d4a73c; letter-spacing: -1px; font-size: 13px; }
.product-card .product-sold,
.product-card .product-stock { font-family: var(--sans); font-size: 10.5px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; margin-top: 8px; padding: 5px 10px; border-radius: 999px; display: inline-block; }
.product-card .product-sold { color: var(--accent-dark); background: var(--accent-soft); }
.product-card .product-stock { color: #b3411f; background: #fcebe1; }

/* ===== NEWSLETTER PERKS (en final CTA dark) ===== */
.newsletter-perks { list-style: none; padding: 0; margin: 22px auto 0; display: flex; flex-wrap: wrap; gap: 12px 28px; justify-content: center; max-width: 760px; }
.newsletter-perks li { font-family: var(--sans); font-size: 13px; color: rgba(255,255,255,0.82); letter-spacing: 0.02em; }

/* ===== SUBSCRIBE MODAL extras ===== */
.sub-modal-newvisitor { display: inline-block; font-family: var(--sans); font-size: 10px; font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase; color: rgba(255,255,255,0.78); padding: 5px 14px; border: 1px solid rgba(255,255,255,0.32); border-radius: 999px; margin: 0 auto 16px; }
.sub-modal-timer { margin-top: 14px; text-align: center; font-family: var(--sans); font-size: 12px; color: var(--ink-warm); letter-spacing: 0.04em; }
.sub-modal-timer strong { font-family: var(--sans); font-variant-numeric: tabular-nums; color: var(--accent-dark); font-weight: 700; margin-left: 4px; }

/* ===== HEADER sticky state ===== */
.header { transition: box-shadow 220ms ease, background 220ms ease; }
.header.header--stuck { position: sticky; top: 0; z-index: 100; background: rgba(255,255,255,0.96); backdrop-filter: saturate(140%) blur(10px); -webkit-backdrop-filter: saturate(140%) blur(10px); box-shadow: 0 1px 0 var(--hairline), 0 6px 24px rgba(28,43,26,0.06); }
.announce { transition: opacity 220ms ease; }

/* ===== WHOLESALE FORM (B2B aplicación) ===== */
.ws-final { padding: clamp(60px, 8vw, 120px) 32px; background: var(--off-white); }
.ws-final-inner { max-width: 760px; margin: 0 auto; }
.ws-final-head { text-align: center; margin-bottom: 36px; }
.ws-final-head .eyebrow { display: inline-block; font-family: var(--sans); font-size: 11px; font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase; color: var(--accent); margin-bottom: 14px; }
.ws-final-head h2 { font-family: var(--sans); font-size: clamp(34px, 4vw, 52px); font-weight: 600; color: var(--forest-deep); margin: 0 0 12px; line-height: 1.05; letter-spacing: -0.025em; }
.ws-final-head p { font-family: var(--serif); font-style: italic; font-size: 17px; color: var(--ink-warm); line-height: 1.5; max-width: 600px; margin: 0 auto; }

.ws-form { background: #fff; border: 1px solid var(--hairline); border-radius: 20px; padding: 36px; }
.ws-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-bottom: 18px; }
.ws-field { display: block; margin-bottom: 18px; }
.ws-field-label { display: block; font-family: var(--sans); font-size: 12px; font-weight: 600; color: var(--forest-deep); letter-spacing: 0.04em; margin-bottom: 8px; }
.ws-field input,
.ws-field select,
.ws-field textarea { width: 100%; padding: 13px 16px; font-family: var(--sans); font-size: 14px; color: var(--ink-warm-deep); background: #fff; border: 1.5px solid var(--hairline-strong); border-radius: 10px; outline: none; transition: border-color 180ms ease, box-shadow 180ms ease; }
.ws-field input:focus,
.ws-field select:focus,
.ws-field textarea:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.ws-field textarea { resize: vertical; min-height: 100px; line-height: 1.5; font-family: var(--sans); }
.ws-form-submit { display: inline-flex; align-items: center; gap: 10px; margin-top: 8px; }
.ws-form-foot { margin-top: 18px; font-family: var(--sans); font-size: 13px; color: var(--ink-warm); text-align: center; }
.ws-form-foot a { color: var(--accent); text-decoration: underline; text-underline-offset: 3px; }

.ws-form-success { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 48px 36px; background: #fff; border: 1.5px solid var(--accent-soft); border-radius: 20px; }
.ws-form-success-ico { width: 64px; height: 64px; border-radius: 999px; background: var(--accent-soft); color: var(--accent-dark); display: inline-flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.ws-form-success h3 { font-family: var(--sans); font-size: 26px; font-weight: 700; color: var(--forest-deep); margin: 0 0 10px; letter-spacing: -0.01em; }
.ws-form-success p { font-family: var(--serif); font-style: italic; font-size: 16px; color: var(--ink-warm); margin: 0; line-height: 1.5; }
.ws-form-success strong { font-family: var(--sans); font-style: normal; font-weight: 700; color: var(--accent-dark); }

@media (max-width: 680px) {
    .ws-form { padding: 24px 20px; border-radius: 16px; }
    .ws-form-row { grid-template-columns: 1fr; gap: 0; margin-bottom: 0; }
    .ws-final-head h2 { font-size: clamp(28px, 8vw, 40px); }
}

/* ===== COLLECTION genérica (cuando no es dedicada sc-*) ===== */
.collection-hero {
    position: relative;
    padding: 0;
    background-size: cover;
    background-position: center;
    color: var(--forest-deep);
    text-align: left;
}
.collection-hero .overlay {
    background: linear-gradient(180deg, rgba(245,240,235,0.0) 0%, rgba(245,240,235,0.78) 60%, var(--off-white) 100%);
    padding: clamp(90px, 12vw, 160px) 0 60px;
}
.collection-hero .container { max-width: 1320px; margin: 0 auto; padding: 0 24px; }
.collection-hero .collection-title {
    font-family: var(--sans);
    font-weight: 500;
    color: var(--forest-deep);
    font-size: clamp(44px, 6vw, 76px);
    line-height: 0.96;
    letter-spacing: -0.032em;
    text-transform: capitalize;
    margin: 0 0 14px;
    max-width: 900px;
}
.collection-hero .collection-desc {
    font-family: var(--serif);
    font-size: 17px;
    line-height: 1.5;
    color: var(--ink-warm);
    max-width: 620px;
    margin: 0;
}
.collection-grid-section { padding: 32px 0 80px; background: var(--off-white); }
.collection-grid-section .container { max-width: 1320px; margin: 0 auto; padding: 0 24px; }
.collection-toolbar {
    display: flex; justify-content: space-between; align-items: center;
    padding: 14px 0 22px;
    border-bottom: 1px solid var(--hairline);
    margin-bottom: 28px;
    font-family: var(--sans);
}
.collection-toolbar .collection-count { font-size: 12px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-warm); margin: 0; }
.collection-toolbar .collection-sort { display: flex; align-items: center; gap: 10px; }
.collection-toolbar .collection-sort label { font-size: 12px; font-weight: 600; letter-spacing: 0.04em; color: var(--ink-warm); }
.collection-toolbar .collection-sort select {
    padding: 10px 14px;
    border: 1.5px solid var(--hairline-strong);
    border-radius: 8px;
    font-family: var(--sans);
    font-size: 13px;
    color: var(--forest-deep);
    background: #fff;
    cursor: pointer;
    transition: border-color 180ms ease;
}
.collection-toolbar .collection-sort select:hover { border-color: var(--accent); }
.collection-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 28px;
}
.collection-empty {
    text-align: center;
    padding: 80px 24px;
    color: var(--ink-warm);
    font-family: var(--serif);
    font-style: italic;
    font-size: 17px;
}
@media (max-width: 1024px) { .collection-grid { grid-template-columns: repeat(3, 1fr); gap: 22px; } }
@media (max-width: 768px)  { .collection-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; } }
@media (max-width: 480px)  { .collection-grid { grid-template-columns: 1fr; } }

/* ===== ANNOUNCE rotate ===== */
.announce [data-announce-msg] { display: inline-block; transition: opacity 220ms ease; opacity: 1; }

/* ============================================================
 * Tweaks pedidos por usuario (5 dic 2026):
 * 1. Hero +30px de altura para que se vea completo
 * 2. Quitar borde/box-shadow de cards de producto
 * ============================================================ */

/* ===== HERO +30px ===== */
.hero { min-height: 570px !important; }
@media (max-width: 980px) {
    .hero { min-height: auto !important; padding-bottom: 30px; }
}

/* ===== Cards de producto SIN borde ni shadow ===== */
/* Cards en collections dedicadas (sc-card) */
.sc-card {
    border: none !important;
    background: transparent !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}
.sc-card:hover {
    transform: translateY(-4px);
    box-shadow: none !important;
    border-color: transparent !important;
    background: transparent !important;
}
.sc-card .sc-card-img {
    background: transparent !important;
    border-radius: 0 !important;
    overflow: hidden;
}
.sc-card .sc-card-info { padding: 16px 4px 8px; }
.sc-card .sc-card-meta { border-top: 1px solid var(--hairline); padding-top: 12px; }

/* Cards genéricas (product-card del home/related) */
.product-card {
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
}
.product-card:hover {
    transform: translateY(-4px);
    box-shadow: none !important;
    border-color: transparent !important;
}
.product-card .product-img {
    background: transparent !important;
    border-radius: 0 !important;
    overflow: hidden;
}
.product-card .product-info { padding: 16px 4px 8px; }

/* Cards de all-products (pa-card) */
.pa-card {
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
}
.pa-card:hover {
    box-shadow: none !important;
    border-color: transparent !important;
}
.pa-card .sc-card-img {
    background: transparent !important;
    border-radius: 0 !important;
}

/* ===== PDP gallery sin recuadro ===== */
.pdp-gallery-main {
    background: transparent !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}
.pdp-gallery-main img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain;
    cursor: pointer;
}
/* PDP thumbnails — SÍ deben tener borde visible para que se note que son clickeables */
.pdp-thumbs {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 10px !important;
    margin-top: 14px !important;
}
.pdp-thumb {
    background: #ffffff !important;
    border: 1.5px solid var(--hairline-strong, #E8E0D8) !important;
    border-radius: 10px !important;
    aspect-ratio: 1 / 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
    cursor: pointer !important;
    transition: border-color 200ms ease, transform 200ms ease !important;
    padding: 0 !important;
}
.pdp-thumb img {
    width: 86% !important;
    height: 86% !important;
    object-fit: contain !important;
    pointer-events: none !important;
}
.pdp-thumb:hover { border-color: var(--accent, #6E8A4E) !important; transform: translateY(-2px); }
.pdp-thumb.is-active { border-color: var(--accent-dark, #566F39) !important; border-width: 2px !important; }

/* ============================================================
 * MOBILE OVERHAUL — mobile-first refinado, <=768px solamente
 * NO afecta desktop. Solo arregla tamaños, padding y touch targets.
 * ============================================================ */
@media (max-width: 768px) {

    /* === Global typography reset para móvil === */
    html { -webkit-text-size-adjust: 100%; }
    body { font-size: 15px; }
    h1, h2, h3, h4 { letter-spacing: -0.02em; }

    /* Evitar scroll horizontal por culpa de algún elemento mal posicionado */
    body, main, section { max-width: 100vw; overflow-x: hidden; }

    /* === ANNOUNCE bar más compacta === */
    .announce { font-size: 10.5px; padding: 8px 12px; letter-spacing: 0.06em; }

    /* === HEADER más compacto === */
    .header-inner { padding: 14px 16px !important; flex-wrap: wrap; gap: 10px; }
    .brand-img { height: 32px !important; width: auto !important; }
    .nav { width: 100%; order: 3; overflow-x: auto; gap: 14px !important; padding: 2px 0; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
    .nav::-webkit-scrollbar { display: none; }
    .nav a { font-size: 10.5px !important; letter-spacing: 0.12em !important; white-space: nowrap; padding: 6px 0 !important; }
    .actions { gap: 8px !important; }
    .actions .icon-btn { width: 36px; height: 36px; padding: 0 !important; display: inline-flex; align-items: center; justify-content: center; }
    .actions .icon-btn svg { width: 17px; height: 17px; }

    /* === HERO mobile === */
    .hero { min-height: auto !important; padding: 70px 20px 30px !important; aspect-ratio: auto !important; }
    .hero-img, .hero-stage { position: relative !important; inset: auto !important; height: auto !important; aspect-ratio: 1.6/1 !important; transform: none !important; object-position: center !important; margin-bottom: 18px; }
    .hero-content { position: relative !important; width: 100% !important; padding: 0 4px !important; align-items: flex-start !important; }
    .hero h1 { font-size: clamp(38px, 11vw, 58px) !important; line-height: 0.96 !important; gap: 6px !important; margin-bottom: 18px !important; }
    .hero-title-line { white-space: normal !important; }
    .hero-title-line--mixed { gap: 8px !important; }
    .hero-sub { font-size: 14.5px !important; margin-bottom: 22px !important; max-width: 100% !important; line-height: 1.5 !important; }
    .hero-ctas { gap: 12px !important; flex-direction: column !important; align-items: stretch !important; }
    .hero-ctas .btn { width: 100% !important; padding: 16px 24px !important; font-size: 12px !important; min-height: 48px; justify-content: center; }
    .hero-ctas .link-text { font-size: 12px !important; padding: 8px 0 !important; }

    /* === MARQUEE / VALUES === */
    .marquee { padding: 10px 0 !important; }
    .marquee-track { gap: 28px !important; }
    .marquee-item { font-size: 11px !important; letter-spacing: 0.1em !important; }

    /* === CATEGORIES (Shop by Routine) === */
    .categories { padding: 50px 18px !important; }
    .categories-grid { grid-template-columns: 1fr !important; gap: 18px !important; }
    .cat-card { aspect-ratio: 1.6/1 !important; min-height: 200px !important; }
    .cat-card h3 { font-size: 22px !important; }
    .cat-card-cta { font-size: 11px !important; padding: 10px 18px !important; }

    /* === BEST SELLERS === */
    .bestsellers { padding: 50px 16px !important; }
    .bestsellers-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 14px !important; }
    .bestsellers .section-head h2 { font-size: clamp(28px, 8vw, 40px) !important; }
    .product-card .product-img { aspect-ratio: 1 !important; }
    .product-card .product-name { font-size: 12.5px !important; min-height: 32px; }
    .product-card .product-price { font-size: 17px !important; }
    .product-card .product-actions .btn { padding: 11px 14px !important; font-size: 10.5px !important; min-height: 42px; }

    /* === WHOLESALE banner home === */
    .wholesale-home { padding: 50px 18px !important; }
    .wholesale-home h2 { font-size: clamp(30px, 9vw, 44px) !important; line-height: 1.05 !important; }
    .ws-h2-small, .ws-h2-big, .ws-h2-mid, .ws-h2-box { font-size: inherit !important; }

    /* === HAIRCARE BANNER === */
    .haircare-banner { padding: 50px 18px !important; flex-direction: column !important; gap: 28px !important; }
    .haircare-banner h2 { font-size: clamp(28px, 8vw, 40px) !important; }
    .haircare-banner .hc-list { font-size: 14px !important; }

    /* === TESTIMONIOS CARRUSEL === */
    .testimonials--carousel { padding-bottom: 50px !important; }
    .testimonials .section-head h2 { font-size: clamp(28px, 8vw, 38px) !important; }
    .testi-marquee { padding: 8px 0 18px !important; }
    .testi-track { gap: 14px !important; animation-duration: 50s !important; }
    .testi-track .testi-card { flex: 0 0 260px !important; width: 260px !important; padding: 20px !important; min-height: 200px !important; border-radius: 14px !important; }
    .testi-quote { font-size: 13.5px !important; line-height: 1.5 !important; }
    .testi-avatar { width: 36px !important; height: 36px !important; }
    .testi-name { font-size: 12px !important; }
    .testi-loc { font-size: 10.5px !important; }
    .testi-stars { font-size: 12px !important; }

    /* === FINAL CTA / Newsletter === */
    .final-cta { padding: 60px 20px !important; }
    .final-cta h2 { font-size: clamp(30px, 9vw, 44px) !important; line-height: 1.05 !important; }
    .final-cta .newsletter-form { flex-direction: column !important; gap: 12px !important; }
    .final-cta .newsletter-form input { width: 100% !important; padding: 14px 16px !important; font-size: 15px !important; }
    .final-cta .newsletter-form button { width: 100% !important; padding: 14px 24px !important; min-height: 48px; }

    /* === FOOTER === */
    .footer-inner { grid-template-columns: 1fr !important; padding: 40px 20px 20px !important; gap: 32px !important; }
    .footer-col h4 { font-size: 13px !important; margin-bottom: 12px !important; }
    .footer-col ul li { padding: 4px 0 !important; }
    .footer-col ul li a { font-size: 13.5px !important; }
    .footer-bottom { flex-direction: column !important; gap: 12px !important; text-align: center !important; padding: 18px 20px !important; }
    .footer-copy, .footer-legal { font-size: 11px !important; }
    .footer-legal { flex-wrap: wrap; justify-content: center !important; gap: 14px !important; }
    .footer-socials { gap: 12px !important; }
    .footer-socials a { width: 36px; height: 36px; }

    /* === COLLECTIONS (sc-*) === */
    .sc-hero { padding: 50px 18px !important; }
    .sc-label { font-size: 9.5px !important; }
    .sc-hero h1 { font-size: clamp(28px, 9vw, 40px) !important; }
    .sc-hero h1 .t-box { padding: 3px 14px 8px !important; }
    .sc-hero-sub { font-size: 14px !important; }
    .sc-grid-head { padding: 0 18px !important; margin-bottom: 24px !important; }
    .sc-grid-head h2 { font-size: clamp(24px, 7.5vw, 32px) !important; }
    .sc-grid-head p { font-size: 13.5px !important; }
    .sc-grid { grid-template-columns: repeat(2, 1fr) !important; padding: 0 14px !important; gap: 12px !important; }
    .sc-card-img { height: 180px !important; }
    .sc-card-info { padding: 12px 4px !important; gap: 5px !important; }
    .sc-card-name { font-size: 12.5px !important; min-height: 32px !important; }
    .sc-card-benefit { font-size: 11.5px !important; }
    .sc-card-meta { padding-top: 10px !important; gap: 8px !important; flex-wrap: wrap; }
    .sc-card-price { font-size: 16px !important; }
    .sc-card-cta { font-size: 10px !important; padding: 6px 10px !important; letter-spacing: 0.12em !important; }
    .sc-card-tag { font-size: 9px !important; padding: 4px 8px !important; top: 10px !important; left: 10px !important; }
    .sc-card-fav { width: 30px !important; height: 30px !important; top: 10px !important; right: 10px !important; }

    /* === ALL PRODUCTS === */
    .pa-hero { padding: 40px 18px 24px !important; }
    .pa-hero h1 { font-size: clamp(26px, 8vw, 36px) !important; line-height: 1.06 !important; }
    .pa-hero .sc-hero-sub { font-size: 14px !important; }
    .pa-filters-inner { padding: 12px 14px !important; gap: 10px !important; flex-wrap: wrap !important; }
    .pa-chips { gap: 6px !important; flex-wrap: wrap; }
    .pa-chip { font-size: 10.5px !important; padding: 7px 12px !important; letter-spacing: 0.04em !important; }
    .pa-chip-count { font-size: 9.5px !important; padding: 2px 5px !important; }
    .pa-sort-form { width: 100%; justify-content: flex-end; }
    .pa-grid { grid-template-columns: repeat(2, 1fr) !important; padding: 0 14px !important; gap: 12px !important; }
    .pa-card-cat { font-size: 8.5px !important; padding: 3px 7px !important; top: 8px !important; right: 8px !important; }
    .pa-grid-section { padding: 32px 0 60px !important; }

    /* === PDP === */
    .pdp-crumb-inner { padding: 12px 16px !important; font-size: 11.5px !important; }
    .pdp-main { padding: 16px 16px 40px !important; }
    .pdp-grid { grid-template-columns: 1fr !important; gap: 24px !important; }
    .pdp-gallery { position: static !important; top: auto !important; }
    .pdp-gallery-main { aspect-ratio: 1 !important; }
    .pdp-gallery-tag { font-size: 9px !important; padding: 5px 10px !important; top: 12px !important; left: 12px !important; }
    .pdp-thumbs { grid-template-columns: repeat(4, 1fr) !important; gap: 8px !important; }
    .pdp-info { padding-top: 0 !important; }
    .pdp-cat { font-size: 9.5px !important; padding: 4px 9px !important; }
    .pdp-title { font-size: clamp(26px, 8vw, 36px) !important; line-height: 1.08 !important; margin-bottom: 10px !important; }
    .pdp-rating { font-size: 12.5px !important; margin-bottom: 14px !important; }
    .pdp-price { font-size: 26px !important; }
    .pdp-desc { font-size: 14.5px !important; margin-bottom: 18px !important; }
    .pdp-bundle-label { font-size: 12px !important; margin-bottom: 10px !important; }
    .pdp-bundle-label .hint { display: block; font-size: 11px; margin-top: 4px; }
    .pdp-bundle { gap: 8px !important; }
    .pdp-bundle-opt { padding: 12px 14px !important; }
    .pdp-bundle-name { font-size: 13px !important; }
    .pdp-bundle-sub { font-size: 11px !important; }
    .pdp-bundle-total { font-size: 15px !important; }
    .pdp-benefits { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; }
    .pdp-benefit { padding: 10px 12px !important; }
    .pdp-benefit-lbl { font-size: 11px !important; }
    .pdp-buy { flex-direction: column !important; gap: 10px !important; align-items: stretch !important; }
    .pdp-qty { align-self: center; }
    .pdp-buy-btn { width: 100%; min-height: 50px; font-size: 12.5px !important; }
    .pdp-cart-btn { width: 100% !important; min-height: 50px; font-size: 12px !important; }
    .pdp-reassure { flex-direction: column !important; gap: 8px !important; align-items: flex-start !important; padding: 14px !important; }
    .pdp-reassure-item { font-size: 12px !important; }
    .pdp-details { padding: 30px 16px !important; }
    .pdp-acc-item summary { font-size: 13px !important; padding: 16px 0 !important; }
    .pdp-acc-body { font-size: 13.5px !important; padding: 4px 0 18px !important; }
    .pdp-acc-html { font-size: 13.5px !important; }
    .pdp-acc-html li { font-size: 13px !important; }
    .pdp-related { padding: 40px 14px !important; }
    .pdp-related .section-head h2 { font-size: clamp(24px, 7vw, 32px) !important; }

    /* === SUBSCRIBE MODAL === */
    .sub-modal { padding: 14px !important; }
    .sub-modal-card { padding: 32px 20px 26px !important; max-width: 100% !important; }
    .sub-modal-h1 { font-size: clamp(28px, 9vw, 38px) !important; }
    .sub-modal-sub { font-size: 14px !important; }
    .sub-modal-form input { padding: 14px 16px !important; font-size: 15px !important; }
    .sub-modal-form button { padding: 14px 22px !important; font-size: 12px !important; min-height: 48px; }

    /* === QUIZ === */
    .quiz { padding: 24px 14px 60px !important; }

    /* === WHOLESALE PAGE === */
    .ws-hero { padding: 50px 18px !important; }
    .ws-hero h1 { font-size: clamp(30px, 9vw, 44px) !important; }
    .ws-hero-sub { font-size: 14px !important; }
    .ws-hero-ctas { flex-direction: column !important; gap: 12px !important; align-items: stretch !important; }
    .ws-hero-ctas .btn { width: 100% !important; min-height: 48px; justify-content: center; }
    .ws-benefits { padding: 40px 18px !important; }
    .ws-benefits-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; }
    .ws-benefit { padding: 14px 12px !important; }
    .ws-benefit-name { font-size: 11.5px !important; }
    .ws-benefits-checks { flex-direction: column !important; gap: 10px !important; align-items: flex-start !important; padding: 16px !important; }

    /* === SUPPORT page === */
    .sup-hero { padding: 40px 18px !important; }
    .sup-hero h1 { font-size: clamp(28px, 8vw, 40px) !important; }
}

/* ============================================================
 * MOBILE — secciones nuevas (concern, deal, quiz-cta, bestsellers, account, checkout)
 * ============================================================ */
@media (max-width: 768px) {
    /* ConcernShop */
    .concern { padding: 48px 14px !important; }
    .concern .section-head h2 { font-size: clamp(26px, 8vw, 36px) !important; }
    .concern-chips { gap: 6px !important; margin-bottom: 22px !important; }
    .concern-chip { font-size: 10.5px !important; padding: 8px 13px !important; letter-spacing: 0.04em !important; }
    .concern-panel { padding: 20px !important; gap: 20px !important; border-radius: 14px !important; }
    .concern-img { border-radius: 12px !important; }
    .concern-img img { width: 78% !important; height: 78% !important; }
    .concern-name { font-size: clamp(22px, 6vw, 28px) !important; }
    .concern-desc { font-size: 13.5px !important; }
    .concern-price { font-size: 22px !important; margin-bottom: 16px !important; }
    .concern-actions { gap: 10px !important; }
    .concern-actions .btn { width: 100% !important; min-height: 48px; justify-content: center; padding: 13px 18px !important; }
    .concern-actions .link-text { width: 100% !important; justify-content: center !important; text-align: center !important; }

    /* CountdownDeal */
    .deal { padding: 48px 14px !important; }
    .deal-inner { gap: 22px !important; }
    .deal-visual-inner { max-width: 250px !important; }
    .deal-eyebrow { font-size: 10px !important; letter-spacing: 0.18em !important; margin-bottom: 10px !important; }
    .deal-timer { gap: 4px !important; margin-bottom: 18px !important; }
    .deal-unit { padding: 8px 10px !important; min-width: 56px !important; border-radius: 9px !important; }
    .deal-num { font-size: 20px !important; }
    .deal-lbl { font-size: 9px !important; letter-spacing: 0.14em !important; }
    .deal-colon { font-size: 18px !important; }
    .deal-product-name { font-size: clamp(19px, 6vw, 26px) !important; margin-bottom: 10px !important; }
    .deal-product-price { gap: 8px !important; margin-bottom: 16px !important; }
    .deal-product-price .price-now { font-size: 24px !important; }
    .deal-product-price .price-old { font-size: 14px !important; }
    .deal-save { font-size: 9.5px !important; padding: 3px 8px !important; }
    .deal-btn { padding: 14px 22px !important; font-size: 11.5px !important; letter-spacing: 0.12em !important; }
    .deal-note { font-size: 11.5px !important; }
    .deal-badge { width: 64px !important; height: 64px !important; font-size: 18px !important; top: -14px !important; left: -14px !important; }
    .deal-badge span { font-size: 8px !important; }

    /* QuizCTA */
    .quiz-cta { padding: 50px 18px !important; }
    .quiz-cta-title { font-size: clamp(26px, 8vw, 38px) !important; }
    .quiz-cta-sub { font-size: 14px !important; }
    .quiz-cta-btn { padding: 14px 26px !important; font-size: 12px !important; letter-spacing: 0.12em !important; width: 100%; max-width: 320px; justify-content: center; }
    .quiz-cta-meta { font-size: 11.5px !important; margin-top: 14px !important; }

    /* Bestsellers infinite — cards 240px en mobile, info más compacta */
    .bestsellers--infinite { padding: 48px 0 !important; }
    .bestsellers--infinite .section-head { margin-bottom: 28px !important; padding: 0 18px !important; }
    .bs-card { flex: 0 0 240px !important; width: 240px !important; min-height: 460px !important; }
    .bs-card .product-info { padding: 14px 4px 4px !important; gap: 10px !important; }
    .bs-card .product-info-top { gap: 6px !important; }
    .bs-card .product-cat { font-size: 9px !important; padding: 3px 8px !important; }
    .bs-card .product-name { font-size: 13.5px !important; }
    .bs-card .product-desc { font-size: 11.5px !important; }
    .bs-card .price-now { font-size: 17px !important; }
    .bs-card .price-old { font-size: 12px !important; }
    .bs-card .product-rating-row { font-size: 10.5px !important; }
    .bs-card .product-actions .btn { padding: 11px 14px !important; font-size: 11px !important; letter-spacing: 0.12em !important; min-height: 42px; }

    /* Account dashboard mobile */
    .acc-page { padding: 40px 14px !important; }
    .acc-head { flex-direction: column; align-items: stretch; gap: 14px; margin-bottom: 22px !important; }
    .acc-head h1 { font-size: clamp(24px, 7vw, 30px) !important; }
    .acc-head p { font-size: 14px !important; }
    .acc-logout { align-self: flex-start; padding: 10px 18px !important; font-size: 11px !important; }
    .acc-grid { grid-template-columns: 1fr !important; gap: 16px !important; }
    .acc-card { padding: 20px 18px !important; border-radius: 14px !important; }
    .acc-card h2 { font-size: 16px !important; margin-bottom: 14px !important; }
    .acc-orders { font-size: 12px !important; }
    .acc-orders th { padding: 8px 6px !important; font-size: 10px !important; }
    .acc-orders td { padding: 10px 6px !important; }
    .acc-status { font-size: 9.5px !important; padding: 3px 7px !important; }

    /* Checkout mobile */
    .ck-page { padding: 36px 14px !important; }
    .ck-head { margin-bottom: 22px !important; }
    .ck-head h1 { font-size: clamp(24px, 7vw, 32px) !important; }
    .ck-head p { font-size: 13.5px !important; }
    .ck-grid { grid-template-columns: 1fr !important; gap: 16px !important; }
    .ck-form, .ck-summary { padding: 22px 18px !important; border-radius: 14px !important; }
    .ck-form h2, .ck-summary h2 { font-size: 16px !important; }
    .ck-field span { font-size: 11px !important; }
    .ck-field input { padding: 12px 14px !important; font-size: 14.5px !important; }
    .ck-submit { padding: 15px 24px !important; font-size: 12.5px !important; min-height: 50px; }
    .ck-secure { font-size: 11.5px !important; }
    .ck-item-info strong { font-size: 13px !important; }
    .ck-item-price { font-size: 14px !important; }
    .ck-row { font-size: 13px !important; }
    .ck-row--total { font-size: 15.5px !important; }

    /* Auth pages (login/register) */
    .auth-page { padding: 40px 14px !important; }
    .auth-card { padding: 28px 20px !important; border-radius: 14px !important; }
    .auth-head h1 { font-size: 22px !important; }
    .auth-head p { font-size: 13.5px !important; }
    .auth-field span { font-size: 11px !important; }
    .auth-field input { padding: 12px 14px !important; font-size: 14.5px !important; }
    .auth-submit { padding: 14px 22px !important; font-size: 12px !important; min-height: 50px; }
    .auth-alt { font-size: 12.5px !important; }
}

/* === EXTRA SMALL (<=420px): refinos finales === */
@media (max-width: 420px) {
    .hero h1 { font-size: clamp(32px, 10.5vw, 44px) !important; }
    .bestsellers-grid { grid-template-columns: 1fr !important; gap: 18px !important; }
    .sc-grid { grid-template-columns: 1fr !important; padding: 0 18px !important; gap: 16px !important; }
    .sc-card-img { height: 240px !important; }
    .sc-card-name { font-size: 13.5px !important; }
    .pa-grid { grid-template-columns: 1fr !important; padding: 0 16px !important; gap: 16px !important; }
    .pdp-benefits { grid-template-columns: 1fr !important; }
    .ws-benefits-grid { grid-template-columns: 1fr !important; }
    .testi-track .testi-card { flex: 0 0 240px !important; width: 240px !important; padding: 18px !important; }
}

/* ============================================================
 * MOBILE GLOBAL — afinaciones extra (<=720px y <=480px)
 * ============================================================ */
@media (max-width: 720px) {
    /* Newsletter perks compactos */
    .newsletter-perks { gap: 8px 16px; margin-top: 16px; }
    .newsletter-perks li { font-size: 12px; }

    /* Subscribe modal */
    .sub-modal-newvisitor { font-size: 9px; letter-spacing: 0.18em; padding: 4px 10px; }
    .sub-modal-timer { font-size: 11px; margin-top: 10px; }

    /* Header mobile spacing */
    .header.header--stuck { backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); }

    /* Trust bar mobile: subtítulos más legibles */
    .trust { padding: 22px 16px; }
    .trust-card { gap: 10px; }
    .trust-card .trust-icon { width: 36px; height: 36px; }
    .trust-card .trust-icon svg { width: 17px; height: 17px; }
    .trust-rating { font-size: 20px; }

    /* Wholesale form mobile */
    .ws-final { padding: 60px 18px; }
    .ws-form { padding: 22px 18px; }
    .ws-field-label { font-size: 11px; }
    .ws-field input, .ws-field select, .ws-field textarea { font-size: 14px; padding: 12px 14px; border-radius: 9px; }
    .ws-form-submit { width: 100%; justify-content: center; }
    .ws-form-success { padding: 36px 22px; }
    .ws-form-success h3 { font-size: 22px; }
    .ws-form-success p { font-size: 14.5px; }

    /* Collection genérica mobile */
    .collection-hero .collection-title { font-size: clamp(32px, 9vw, 48px); }
    .collection-hero .collection-desc { font-size: 15px; }
    .collection-hero .overlay { padding: 70px 0 40px; }
    .collection-grid-section { padding: 24px 0 60px; }
    .collection-toolbar { flex-wrap: wrap; gap: 10px; padding: 12px 0 18px; }
    .collection-toolbar .collection-count { font-size: 11px; }
    .collection-toolbar .collection-sort select { padding: 8px 12px; font-size: 12px; }
    .collection-grid { gap: 14px; }

    /* Product card mobile: más compacta */
    .product-card { border-radius: 8px; }
    .product-card .product-info { padding: 14px 14px 16px; gap: 7px; }
    .product-card .product-name { font-size: 13px; min-height: 32px; }
    .product-card .product-name a { letter-spacing: -0.005em; }
    .product-card .product-desc { font-size: 12px; }
    .product-card .product-price { font-size: 18px; }
    .product-card .product-price small { font-size: 10px; }
    .product-card .product-rating { font-size: 11px; }
    .product-card .product-rating .stars { font-size: 12px; }
    .product-card .product-cat { font-size: 9px; padding: 4px 9px; letter-spacing: 0.1em; }
    .product-card .product-tag { font-size: 9px; padding: 4px 8px; top: 10px; left: 10px; }
    .product-card .product-fav { width: 30px; height: 30px; top: 10px; right: 10px; }
    .product-card .product-fav svg { width: 13px; height: 13px; }
    .product-card .product-actions { padding-top: 10px; gap: 8px; }
    .product-card .product-actions .btn { padding: 10px 14px; font-size: 10.5px; letter-spacing: 0.12em; }
    .product-card .product-actions .link-text { font-size: 10.5px; }

    /* Botones generales más toqueables */
    .btn-sm { padding: 10px 18px; font-size: 10.5px; }
}

@media (max-width: 480px) {
    /* Trust bar a 2 columnas con menos padding */
    .trust { padding: 18px 12px; }
    .trust-grid { gap: 14px; }
    .trust-label { font-size: 11.5px; }
    .trust-sub { font-size: 10.5px; }

    /* Newsletter perks una sola columna */
    .newsletter-perks { flex-direction: column; align-items: center; gap: 6px; }

    /* Footer mobile compacto */
    .footer-inner { padding: 40px 18px 24px; }
    .footer-bottom { padding: 18px 0; flex-direction: column; gap: 10px; text-align: center; }

    /* Form B2B una sola col */
    .ws-form { padding: 18px 14px; border-radius: 12px; }
    .ws-final-head { margin-bottom: 24px; }
    .ws-final-head h2 { font-size: clamp(26px, 9vw, 36px); }
    .ws-final-head p { font-size: 14px; padding: 0 8px; }
}
