/**
 * WooCommerce Sales Counter - Frontend Styles
 *
 * Note: Using high-specificity selectors and !important to override
 * page builders like Elementor, Divi, and theme styles.
 */

/* ==========================================================================
   CSS Variables (set dynamically via PHP)
   ========================================================================== */

:root {
    --wsc-bg-color: #1a1a2e;
    --wsc-text-color: #ffffff;
    --wsc-icon-color: #ffffff;
    --wsc-border-radius: 20px;
    --wsc-font-size: 14px;
    --wsc-padding-v: 8px;
    --wsc-padding-h: 16px;
}

/* ==========================================================================
   Sales Badge - High Specificity Selectors
   ========================================================================== */

.woocommerce div.product .wsc-badge,
.woocommerce-page div.product .wsc-badge,
.single-product .wsc-badge,
div.wsc-badge,
.wsc-badge {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    background-color: var(--wsc-bg-color) !important;
    color: var(--wsc-text-color) !important;
    border-radius: var(--wsc-border-radius) !important;
    padding: var(--wsc-padding-v) var(--wsc-padding-h) !important;
    font-size: var(--wsc-font-size) !important;
    font-weight: 500 !important;
    line-height: 1.4 !important;
    margin: 12px 0 !important;
    font-family: inherit !important;
    box-sizing: border-box !important;
    text-decoration: none !important;
    box-shadow: none !important;
    text-transform: none !important;
    letter-spacing: normal !important;
}

.woocommerce div.product .wsc-badge .wsc-badge__text,
.woocommerce-page div.product .wsc-badge .wsc-badge__text,
.single-product .wsc-badge .wsc-badge__text,
div.wsc-badge .wsc-badge__text,
.wsc-badge .wsc-badge__text,
.wsc-badge__text {
    white-space: nowrap !important;
    display: inline !important;
    color: inherit !important;
    font-size: inherit !important;
    font-weight: inherit !important;
    line-height: inherit !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ==========================================================================
   Info Button - Complete Reset & High Specificity
   ========================================================================== */

/* Full reset for the info button */
.woocommerce div.product .wsc-badge button.wsc-badge__info,
.woocommerce-page div.product .wsc-badge button.wsc-badge__info,
.single-product .wsc-badge button.wsc-badge__info,
div.wsc-badge button.wsc-badge__info,
.wsc-badge button.wsc-badge__info,
button.wsc-badge__info,
.wsc-badge__info {
    /* Reset all inherited styles */
    all: unset !important;

    /* Apply our styles */
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 20px !important;
    min-width: 20px !important;
    max-width: 20px !important;
    height: 20px !important;
    min-height: 20px !important;
    max-height: 20px !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    border: 1px solid var(--wsc-icon-color) !important;
    border-radius: 50% !important;
    color: var(--wsc-icon-color) !important;
    cursor: pointer !important;
    transition: opacity 0.2s ease !important;
    flex-shrink: 0 !important;
    box-sizing: border-box !important;

    /* Reset common overrides */
    box-shadow: none !important;
    text-shadow: none !important;
    text-decoration: none !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    font-size: 14px !important;
    font-weight: normal !important;
    line-height: 1 !important;
    vertical-align: middle !important;
    outline: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;

    /* Touch behavior */
    touch-action: manipulation !important;
    -webkit-tap-highlight-color: transparent !important;
    user-select: none !important;
    -webkit-user-select: none !important;
}

/* Hover/Focus states */
.woocommerce div.product .wsc-badge button.wsc-badge__info:hover,
.woocommerce-page div.product .wsc-badge button.wsc-badge__info:hover,
.single-product .wsc-badge button.wsc-badge__info:hover,
div.wsc-badge button.wsc-badge__info:hover,
.wsc-badge button.wsc-badge__info:hover,
button.wsc-badge__info:hover,
.wsc-badge__info:hover,
.woocommerce div.product .wsc-badge button.wsc-badge__info:focus,
.woocommerce-page div.product .wsc-badge button.wsc-badge__info:focus,
.single-product .wsc-badge button.wsc-badge__info:focus,
div.wsc-badge button.wsc-badge__info:focus,
.wsc-badge button.wsc-badge__info:focus,
button.wsc-badge__info:focus,
.wsc-badge__info:focus {
    opacity: 0.8 !important;
    background: transparent !important;
    background-color: transparent !important;
    border-color: var(--wsc-icon-color) !important;
    color: var(--wsc-icon-color) !important;
    box-shadow: none !important;
    transform: none !important;
}

/* Focus visible for accessibility */
.wsc-badge__info:focus-visible {
    outline: 2px solid var(--wsc-icon-color) !important;
    outline-offset: 2px !important;
}

/* SVG inside button */
.woocommerce div.product .wsc-badge button.wsc-badge__info svg,
.woocommerce-page div.product .wsc-badge button.wsc-badge__info svg,
.single-product .wsc-badge button.wsc-badge__info svg,
div.wsc-badge button.wsc-badge__info svg,
.wsc-badge button.wsc-badge__info svg,
button.wsc-badge__info svg,
.wsc-badge__info svg {
    width: 14px !important;
    height: 14px !important;
    display: block !important;
    fill: none !important;
    stroke: currentColor !important;
    stroke-width: 2 !important;
    flex-shrink: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ==========================================================================
   Info Panel - Base Styles with High Specificity
   ========================================================================== */

body .wsc-panel,
html .wsc-panel,
.wsc-panel {
    position: fixed !important;
    inset: 0 !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    left: 0 !important;
    z-index: 999999 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
}

body .wsc-panel.is-open,
html .wsc-panel.is-open,
.wsc-panel.is-open {
    visibility: visible !important;
    pointer-events: auto !important;
}

body .wsc-panel .wsc-panel__backdrop,
html .wsc-panel .wsc-panel__backdrop,
.wsc-panel .wsc-panel__backdrop,
.wsc-panel__backdrop {
    position: absolute !important;
    inset: 0 !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    left: 0 !important;
    background: rgba(0, 0, 0, 0.5) !important;
    opacity: 0 !important;
    transition: opacity 0.3s ease !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    /* Prevent any default touch behaviors */
    touch-action: none !important;
    -webkit-tap-highlight-color: transparent !important;
    /* Ensure pointer events work correctly */
    pointer-events: inherit !important;
}

body .wsc-panel.is-open .wsc-panel__backdrop,
html .wsc-panel.is-open .wsc-panel__backdrop,
.wsc-panel.is-open .wsc-panel__backdrop {
    opacity: 1 !important;
}

body .wsc-panel .wsc-panel__container,
html .wsc-panel .wsc-panel__container,
.wsc-panel .wsc-panel__container,
.wsc-panel__container {
    background: #fff !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    box-sizing: border-box !important;
}

body .wsc-panel .wsc-panel__header,
html .wsc-panel .wsc-panel__header,
.wsc-panel .wsc-panel__header,
.wsc-panel__header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 20px 24px !important;
    border-bottom: 1px solid #e5e5e5 !important;
    position: sticky !important;
    top: 0 !important;
    background: #fff !important;
    z-index: 1 !important;
    margin: 0 !important;
}

body .wsc-panel .wsc-panel__title,
html .wsc-panel .wsc-panel__title,
.wsc-panel .wsc-panel__title,
.wsc-panel__title {
    font-size: 20px !important;
    font-weight: 600 !important;
    color: #1a1a2e !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1.3 !important;
}

/* Close button in panel */
body .wsc-panel button.wsc-panel__close,
html .wsc-panel button.wsc-panel__close,
.wsc-panel button.wsc-panel__close,
button.wsc-panel__close,
.wsc-panel__close {
    all: unset !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 40px !important;
    min-width: 40px !important;
    height: 40px !important;
    min-height: 40px !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    border-radius: 50% !important;
    color: #666 !important;
    cursor: pointer !important;
    transition: background 0.2s ease, color 0.2s ease !important;
    box-sizing: border-box !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    /* Touch behavior */
    touch-action: manipulation !important;
    -webkit-tap-highlight-color: transparent !important;
    user-select: none !important;
    -webkit-user-select: none !important;
}

body .wsc-panel button.wsc-panel__close:hover,
html .wsc-panel button.wsc-panel__close:hover,
.wsc-panel button.wsc-panel__close:hover,
button.wsc-panel__close:hover,
.wsc-panel__close:hover,
body .wsc-panel button.wsc-panel__close:focus,
html .wsc-panel button.wsc-panel__close:focus,
.wsc-panel button.wsc-panel__close:focus,
button.wsc-panel__close:focus,
.wsc-panel__close:focus {
    background: #f5f5f5 !important;
    background-color: #f5f5f5 !important;
    color: #1a1a2e !important;
    border: none !important;
    box-shadow: none !important;
}

.wsc-panel__close:focus-visible {
    outline: 2px solid #1a1a2e !important;
    outline-offset: 2px !important;
}

body .wsc-panel button.wsc-panel__close svg,
html .wsc-panel button.wsc-panel__close svg,
.wsc-panel button.wsc-panel__close svg,
button.wsc-panel__close svg,
.wsc-panel__close svg {
    width: 24px !important;
    height: 24px !important;
    display: block !important;
    fill: none !important;
    stroke: currentColor !important;
    stroke-width: 2 !important;
}

body .wsc-panel .wsc-panel__content,
html .wsc-panel .wsc-panel__content,
.wsc-panel .wsc-panel__content,
.wsc-panel__content {
    padding: 24px !important;
    font-size: 16px !important;
    line-height: 1.6 !important;
    color: #333 !important;
    margin: 0 !important;
}

body .wsc-panel .wsc-panel__content p,
html .wsc-panel .wsc-panel__content p,
.wsc-panel .wsc-panel__content p,
.wsc-panel__content p {
    margin: 0 0 16px 0 !important;
    padding: 0 !important;
    font-size: inherit !important;
    line-height: inherit !important;
    color: inherit !important;
}

body .wsc-panel .wsc-panel__content p:last-child,
html .wsc-panel .wsc-panel__content p:last-child,
.wsc-panel .wsc-panel__content p:last-child,
.wsc-panel__content p:last-child {
    margin-bottom: 0 !important;
}

/* ==========================================================================
   Info Panel - Mobile (Bottom Sheet)
   ========================================================================== */

body .wsc-panel--mobile .wsc-panel__container,
html .wsc-panel--mobile .wsc-panel__container,
.wsc-panel--mobile .wsc-panel__container {
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    top: auto !important;
    max-height: 90vh !important;
    border-radius: 16px 16px 0 0 !important;
    transform: translateY(100%) !important;
    transition: transform 0.3s cubic-bezier(0.32, 0.72, 0, 1) !important;
}

body .wsc-panel--mobile.is-open .wsc-panel__container,
html .wsc-panel--mobile.is-open .wsc-panel__container,
.wsc-panel--mobile.is-open .wsc-panel__container {
    transform: translateY(0) !important;
}

body .wsc-panel--mobile .wsc-panel__handle,
html .wsc-panel--mobile .wsc-panel__handle,
.wsc-panel--mobile .wsc-panel__handle,
.wsc-panel__handle {
    width: 36px !important;
    height: 4px !important;
    background: #e0e0e0 !important;
    background-color: #e0e0e0 !important;
    border-radius: 2px !important;
    margin: 8px auto 0 !important;
    padding: 0 !important;
    border: none !important;
    display: block !important;
}

/* ==========================================================================
   Info Panel - Desktop (Side Panel)
   ========================================================================== */

body .wsc-panel--desktop .wsc-panel__container,
html .wsc-panel--desktop .wsc-panel__container,
.wsc-panel--desktop .wsc-panel__container {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    left: auto !important;
    width: 400px !important;
    max-width: 90vw !important;
    box-shadow: -4px 0 20px rgba(0, 0, 0, 0.15) !important;
    transform: translateX(100%) !important;
    transition: transform 0.3s cubic-bezier(0.32, 0.72, 0, 1) !important;
    border-radius: 0 !important;
}

body .wsc-panel--desktop.is-open .wsc-panel__container,
html .wsc-panel--desktop.is-open .wsc-panel__container,
.wsc-panel--desktop.is-open .wsc-panel__container {
    transform: translateX(0) !important;
}

body .wsc-panel--desktop .wsc-panel__handle,
html .wsc-panel--desktop .wsc-panel__handle,
.wsc-panel--desktop .wsc-panel__handle {
    display: none !important;
}

/* ==========================================================================
   Accessibility & Motion
   ========================================================================== */

/* Reduce motion for users who prefer it */
@media (prefers-reduced-motion: reduce) {
    .wsc-panel__backdrop,
    .wsc-panel--mobile .wsc-panel__container,
    .wsc-panel--desktop .wsc-panel__container,
    .wsc-badge__info {
        transition: none !important;
    }
}

/* ==========================================================================
   Print Styles
   ========================================================================== */

@media print {
    .wsc-badge__info,
    .wsc-panel {
        display: none !important;
    }
}
