/* ═══════════════════════════════════════════════════
   CR Scroll Tienda Flexible - Compatible Elementor
   Prefijos .cr- y #crsf- para no interferir con el tema
═══════════════════════════════════════════════════ */

:root {
    --crsf-primary: #05346A;
    --crsf-primary-light: rgba(5, 52, 106, 0.12);
}

/* ══════════════════════════════════
   SELECTOR DE MODO — Diseño mejorado
══════════════════════════════════ */
.cr-scroll-mode-switcher {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
    -ms-flex-wrap: wrap !important;
    flex-wrap: wrap !important;
    -webkit-box-align: center !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 10px 14px !important;
    background: #fff !important;
    border: 1px solid #dde3ec !important;
    border-radius: 50px !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06) !important;
    font-size: 13px !important;
    box-sizing: border-box !important;
    width: fit-content !important;
    margin: 0 auto !important;
}

.cr-scroll-mode-switcher-top    { margin-bottom: 20px !important; }
.cr-scroll-mode-switcher-bottom { margin-top: 20px !important; margin-bottom: 10px !important; }

.cr-scroll-mode-label {
    color: #94a3b8 !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .08em !important;
    margin-right: 4px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
}

/* Botones del selector */
.cr-scroll-mode-switcher .cr-scroll-mode-btn {
    display: -webkit-inline-box !important;
    display: -ms-inline-flexbox !important;
    display: inline-flex !important;
    -webkit-box-align: center !important;
    align-items: center !important;
    gap: 6px !important;
    margin: 0 !important;
    padding: 7px 16px !important;
    border-radius: 999px !important;
    border: none !important;
    background: transparent !important;
    color: #64748b !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    line-height: 1.3 !important;
    text-decoration: none !important;
    box-shadow: none !important;
    transition: all 0.2s ease !important;
    -webkit-transition: all 0.2s ease !important;
    width: auto !important;
    height: auto !important;
    min-height: auto !important;
    white-space: nowrap !important;
}

.cr-scroll-mode-switcher .cr-scroll-mode-btn:hover {
    background: var(--crsf-primary-light) !important;
    color: var(--crsf-primary) !important;
}

.cr-scroll-mode-switcher .cr-scroll-mode-btn.is-active {
    background: var(--crsf-primary) !important;
    color: #fff !important;
    font-weight: 600 !important;
    box-shadow: 0 2px 10px rgba(5,52,106,0.30) !important;
}

/* Iconos SVG dentro de botones */
.cr-scroll-mode-switcher .cr-scroll-mode-btn svg {
    flex-shrink: 0 !important;
    opacity: 0.75 !important;
}

.cr-scroll-mode-switcher .cr-scroll-mode-btn.is-active svg {
    opacity: 1 !important;
}

/* ══════════════════════════════════
   ÁREA DE CARGA
══════════════════════════════════ */
.cr-load-more-wrap {
    text-align: center !important;
    margin: 32px 0 16px !important;
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
    -webkit-box-orient: vertical !important;
    -webkit-box-direction: normal !important;
    -ms-flex-direction: column !important;
    flex-direction: column !important;
    -webkit-box-align: center !important;
    align-items: center !important;
    gap: 12px !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

/* Botón Mostrar Más */
.cr-load-more-wrap .cr-load-more-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 12px 32px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    border-radius: 999px !important;
    border: 2px solid var(--crsf-primary) !important;
    background: var(--crsf-primary) !important;
    color: #fff !important;
    cursor: pointer !important;
    text-decoration: none !important;
    box-shadow: 0 4px 16px rgba(5,52,106,0.25) !important;
    line-height: 1.4 !important;
    width: auto !important;
    height: auto !important;
    min-height: auto !important;
    transition: transform 0.18s ease, box-shadow 0.18s ease, opacity 0.18s !important;
}

.cr-load-more-wrap .cr-load-more-btn:hover:not(:disabled) {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(5,52,106,0.35) !important;
}

.cr-load-more-wrap .cr-load-more-btn:active:not(:disabled) {
    transform: translateY(0) !important;
}

.cr-load-more-wrap .cr-load-more-btn:disabled {
    opacity: .5 !important;
    cursor: not-allowed !important;
}

/* Spinner */
.cr-load-more-wrap .cr-load-more-spinner {
    display: none !important;
    margin: 0 auto !important;
}

.cr-load-more-wrap .cr-spinner-ring {
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    border: 3px solid rgba(5,52,106,0.12) !important;
    border-top-color: var(--crsf-primary) !important;
    animation: crsf-spin 0.75s linear infinite !important;
    margin: 0 auto !important;
    display: block !important;
}

@keyframes crsf-spin {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}

/* Estado */
.cr-load-more-wrap .cr-load-more-status {
    font-size: 13px !important;
    color: #94a3b8 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ── Mensaje final "no hay más productos" ── */
.cr-no-more-msg {
    display: inline-flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 12px 24px !important;
    background: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 50px !important;
    font-size: 13px !important;
    color: #475569 !important;
    font-weight: 500 !important;
    animation: crsf-fadein 0.5s ease both !important;
}

.cr-no-more-msg::before {
    content: '' !important;
    display: inline-block !important;
    width: 28px !important;
    height: 2px !important;
    background: #cbd5e1 !important;
    border-radius: 2px !important;
}

.cr-no-more-msg::after {
    content: '' !important;
    display: inline-block !important;
    width: 28px !important;
    height: 2px !important;
    background: #cbd5e1 !important;
    border-radius: 2px !important;
}

/* ══════════════════════════════════
   ANIMACIONES NUEVOS PRODUCTOS
══════════════════════════════════ */
.cr-product-new {
    animation: crsf-slideup 0.45s ease both !important;
}

/* Aplicar delay escalonado a cada producto nuevo */
.cr-product-new:nth-child(1)  { animation-delay: 0.00s !important; }
.cr-product-new:nth-child(2)  { animation-delay: 0.05s !important; }
.cr-product-new:nth-child(3)  { animation-delay: 0.10s !important; }
.cr-product-new:nth-child(4)  { animation-delay: 0.15s !important; }
.cr-product-new:nth-child(5)  { animation-delay: 0.20s !important; }
.cr-product-new:nth-child(6)  { animation-delay: 0.25s !important; }
.cr-product-new:nth-child(7)  { animation-delay: 0.28s !important; }
.cr-product-new:nth-child(8)  { animation-delay: 0.30s !important; }
.cr-product-new:nth-child(9)  { animation-delay: 0.32s !important; }
.cr-product-new:nth-child(10) { animation-delay: 0.34s !important; }
.cr-product-new:nth-child(n+11) { animation-delay: 0.36s !important; }

@keyframes crsf-fadein {
    from { opacity: 0; }
    to   { opacity: 1; }
}

@keyframes crsf-slideup {
    from { opacity: 0; transform: translateY(28px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ══════════════════════════════════
   OCULTAR PAGINACIÓN SEGÚN MODO
══════════════════════════════════ */
body.cr-scroll-mode-load_more .woocommerce-pagination,
body.cr-scroll-mode-infinite  .woocommerce-pagination {
    display: none !important;
}

body.cr-scroll-mode-pagination .cr-load-more-wrap {
    display: none !important;
}

/* ══════════════════════════════════
   RESPONSIVE
══════════════════════════════════ */
@media (max-width: 600px) {
    .cr-scroll-mode-switcher {
        border-radius: 12px !important;
        width: 100% !important;
        justify-content: center !important;
    }
    .cr-scroll-mode-switcher .cr-scroll-mode-btn {
        padding: 6px 12px !important;
        font-size: 12px !important;
    }
}

/* ══════════════════════════════════
   MODO INFINITO: ocultar botón, mostrar solo spinner
══════════════════════════════════ */
body.cr-scroll-mode-infinite .cr-load-more-btn,
body.cr-scroll-mode-infinite .cr-load-more-wrap .cr-load-more-btn,
body.cr-scroll-mode-infinite button.cr-load-more-btn {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}
