/* ==========================================
   KRUMPLD PRODUCT PAGE - WORKING VERSION
   ========================================== */

/* WOOCOMMERCE RESETS */
body.single-product .woocommerce div.product,
body.single-product .woocommerce #content div.product,
body.single-product .woocommerce-page div.product {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 20px !important;
    float: none !important;
    box-sizing: border-box !important;
}

body.single-product .woocommerce div.product div.images,
body.single-product .woocommerce div.product div.summary {
    float: none !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}

/* ==========================================
   IMAGES - LET WOOCOMMERCE HANDLE SWITCHING
   ========================================== */

.woocommerce div.product div.images {
    margin-bottom: 30px !important;
}

/* Don't force display on gallery images - let WooCommerce control */
.woocommerce div.product div.images img {
    width: 100%;
    max-width: 100%;
    height: auto;
    border-radius: 4px;
}

/* Hide thumbnails on mobile */
.woocommerce div.product div.images .flex-control-thumbs {
    display: none !important;
}

/* ==========================================
   PRODUCT INFO
   ========================================== */

.woocommerce div.product .product_title {
    font-size: 24px !important;
    font-weight: 500 !important;
    line-height: 1.2 !important;
    margin: 0 0 12px 0 !important;
    color: #000 !important;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
    font-size: 20px !important;
    font-weight: 400 !important;
    color: #333 !important;
    margin: 0 0 16px 0 !important;
}

.woocommerce div.product .woocommerce-product-details__short-description {
    font-size: 15px !important;
    line-height: 1.5 !important;
    color: #666 !important;
    margin: 0 0 24px 0 !important;
}

/* VARIATIONS */
.woocommerce div.product form.cart .variations {
    margin-bottom: 24px !important;
}

.woocommerce div.product form.cart .variations td,
.woocommerce div.product form.cart .variations th {
    display: block !important;
    width: 100% !important;
    padding: 0 0 8px 0 !important;
}

.woocommerce div.product form.cart .variations .label {
    font-size: 12px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    color: #666 !important;
}

.woocommerce div.product form.cart .variations select {
    width: 100% !important;
    padding: 14px !important;
    font-size: 15px !important;
    border: 1px solid #ddd !important;
    border-radius: 2px !important;
    margin-bottom: 16px !important;
}

/* ADD TO CART */
.woocommerce div.product form.cart .button,
.woocommerce div.product form.cart button.single_add_to_cart_button {
    width: 100% !important;
    padding: 16px 24px !important;
    background: #000 !important;
    color: #fff !important;
    border: none !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    border-radius: 2px !important;
    text-transform: none !important;
    margin: 0 0 20px 0 !important;
}

.woocommerce div.product form.cart .button:hover {
    background: #1a1a1a !important;
}

/* TRUST SIGNALS */
.krumpld-trust-signals {
    margin: 0 0 40px 0 !important;
}

.trust-signal {
    display: flex !important;
    align-items: flex-start !important;
    gap: 8px !important;
    margin: 0 0 10px 0 !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    color: #666 !important;
}

.trust-signal::before {
    content: '✓' !important;
    color: #000 !important;
    font-weight: 600 !important;
    flex-shrink: 0 !important;
}

/* PRODUCT CONTENT */
.krumpld-product-content {
    margin-top: 40px !important;
    width: 100% !important;
}

.krumpld-product-story {
    max-width: 100% !important;
    margin: 0 auto 40px auto !important;
    text-align: center !important;
}

.story-section {
    margin: 0 0 40px 0 !important;
}

.section-header {
    font-size: 12px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 2px !important;
    color: #999 !important;
    margin: 0 0 16px 0 !important;
}

.story-section p {
    font-size: 15px !important;
    line-height: 1.6 !important;
    color: #333 !important;
    margin: 0 0 12px 0 !important;
}

.story-section ul {
    text-align: left !important;
    margin: 0 auto !important;
    list-style: none !important;
    padding: 0 !important;
}

.story-section ul li {
    padding: 6px 0 6px 20px !important;
    position: relative !important;
    font-size: 14px !important;
    line-height: 1.6 !important;
    color: #333 !important;
}

.story-section ul li::before {
    content: '•' !important;
    position: absolute !important;
    left: 0 !important;
    color: #000 !important;
}

.specs-section {
    display: block !important;
}

.specs-column {
    margin-bottom: 30px !important;
}

/* CREDIBILITY ICONS */
.credibility-icons {
    display: flex !important;
    justify-content: space-around !important;
    gap: 20px !important;
    margin: 40px 0 !important;
}

.cred-icon {
    text-align: center !important;
    flex: 1 1 30% !important;
}

.icon-circle {
    width: 40px !important;
    height: 40px !important;
    border-radius: 50% !important;
    border: 2px solid #ddd !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 auto 8px auto !important;
    font-size: 16px !important;
    color: #000 !important;
}

.cred-icon p {
    font-size: 11px !important;
    color: #666 !important;
    margin: 0 !important;
    line-height: 1.3 !important;
}

/* ACCORDION */
.krumpld-accordion {
    margin: 30px 0 !important;
    border-top: 1px solid #e5e5e5 !important;
}

.accordion-item {
    border-bottom: 1px solid #e5e5e5 !important;
}

.accordion-header {
    width: 100% !important;
    display: flex !important;
    justify-content: space-between !important;
    padding: 18px 0 !important;
    background: none !important;
    border: none !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    cursor: pointer !important;
    color: #666 !important;
    text-align: left !important;
}

.accordion-header:hover,
.accordion-header.active {
    color: #000 !important;
}

.accordion-arrow {
    font-size: 20px !important;
    transition: transform 0.3s !important;
}

.accordion-header.active .accordion-arrow {
    transform: rotate(90deg) !important;
}

.accordion-content {
    max-height: 0;
    overflow: hidden !important;
    transition: max-height 0.3s ease !important;
}

.accordion-content.active {
    padding-bottom: 20px !important;
}

.accordion-content p {
    margin: 0 0 10px 0 !important;
    font-size: 14px !important;
    line-height: 1.6 !important;
    color: #333 !important;
}

.accordion-content ul {
    margin: 8px 0 10px 20px !important;
}

.accordion-content ul li {
    margin: 4px 0 !important;
    font-size: 14px !important;
    line-height: 1.6 !important;
    color: #333 !important;
}

/* SIZE CHART */
.size-chart {
    width: 100% !important;
    border-collapse: collapse !important;
    margin: 16px 0 !important;
    font-size: 13px !important;
}

.size-chart th,
.size-chart td {
    padding: 10px 8px !important;
    text-align: left !important;
    border-bottom: 1px solid #e5e5e5 !important;
}

.size-chart th {
    font-weight: 600 !important;
    text-transform: uppercase !important;
    font-size: 11px !important;
    color: #666 !important;
}

.size-note {
    font-size: 12px !important;
    color: #999 !important;
    font-style: italic !important;
    margin: 10px 0 0 0 !important;
}

/* ==========================================
   DESKTOP (1200px+) - TWO COLUMNS
   ========================================== */

@media (min-width: 1200px) {
    
    /* TWO COLUMN LAYOUT */
    .woocommerce div.product,
    .woocommerce #content div.product,
    .woocommerce-page div.product,
    body.woocommerce div.product,
    body.woocommerce-page div.product {
        display: flex !important;
        flex-wrap: wrap !important;
        max-width: 1200px !important;
        margin: 60px auto !important;
        padding: 0 40px !important;
        gap: 60px !important;
    }
    
    /* LEFT - IMAGES */
    .woocommerce div.product div.images {
        flex: 0 0 calc(50% - 30px) !important;
        width: calc(50% - 30px) !important;
        max-width: calc(50% - 30px) !important;
        margin: 0 !important;
    }
    
    /* RIGHT - INFO */
    .woocommerce div.product div.summary {
        flex: 0 0 calc(50% - 30px) !important;
        width: calc(50% - 30px) !important;
        max-width: calc(50% - 30px) !important;
        margin: 0 !important;
    }
    
    /* CONTENT BELOW */
    .krumpld-product-content {
        flex: 0 0 100% !important;
        width: 100% !important;
        margin-top: 60px !important;
    }
    
    /* SHOW THUMBNAILS */
    .woocommerce div.product div.images .flex-control-thumbs {
        display: flex !important;
        gap: 12px !important;
        margin-top: 16px !important;
    }
    
    .woocommerce div.product div.images .flex-control-thumbs li {
        width: 80px !important;
        cursor: pointer !important;
    }
    
    .woocommerce div.product div.images .flex-control-thumbs li img {
        height: 100px !important;
        object-fit: cover !important;
        border: 2px solid transparent !important;
    }
    
    .woocommerce div.product div.images .flex-control-thumbs li img.flex-active,
    .woocommerce div.product div.images .flex-control-thumbs li:hover img {
        border-color: #000 !important;
    }
    
    /* LARGER FONTS */
    .woocommerce div.product .product_title {
        font-size: 32px !important;
    }
    
    .woocommerce div.product p.price {
        font-size: 24px !important;
    }
    
    /* CENTERED CONTENT */
    .krumpld-product-story {
        max-width: 800px !important;
        margin: 0 auto 60px auto !important;
    }
    
    .story-section {
        margin: 0 0 60px 0 !important;
    }
    
    .specs-section {
        display: flex !important;
        gap: 60px !important;
        max-width: 800px !important;
        margin: 0 auto 60px auto !important;
    }
    
    .specs-column {
        flex: 1 !important;
        margin: 0 !important;
    }
    
    .credibility-icons {
        gap: 60px !important;
    }
    
    .icon-circle {
        width: 50px !important;
        height: 50px !important;
        font-size: 20px !important;
    }
    
    .cred-icon p {
        font-size: 14px !important;
    }
    
    .krumpld-accordion {
        max-width: 1200px !important;
        margin: 40px auto !important;
    }
    
    .accordion-header {
        padding: 20px 0 !important;
        font-size: 14px !important;
    }
    
    .accordion-content p,
    .accordion-content ul li {
        font-size: 15px !important;
    }
}

/* ==========================================
   SIZE SELECTOR
========================================== */

.krumpld-size-selector {
    margin-bottom: 24px;
}

.size-label {
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: #666;
    margin-bottom: 10px;
}

.size-options {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.size-btn {
    min-width: 44px;
    height: 44px;
    border: 1px solid #ddd;
    background: #fff;
    color: #000;
    font-size: 14px;
    cursor: pointer;
    transition: all 0.2s ease;
}

/* Hover */
.size-btn:hover {
    border-color: #000;
}

/* Selected */
.size-btn.active {
    background: #000;
    color: #fff;
    border-color: #000;
}

/* Disabled */
.size-btn.disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

/* Hide WooCommerce variation UI completely (keep logic intact) */
.woocommerce div.product form.cart .variations {
    display: none !important;
}

/* ==========================================
   COLOR SWATCHES
========================================== */

.krumpld-color-selector {
    margin-bottom: 20px;
}

.color-label {
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: #666;
    margin-bottom: 10px;
}

.color-options {
    display: flex;
    gap: 12px;
}

.color-swatch {
    width: 28px;
    height: 28px;

    border-radius: 50% !important;

    border: 1px solid #ddd;
    cursor: pointer;

    /* 🔴 CRITICAL FIXES */
    padding: 0 !important;
    min-width: 0 !important;
    line-height: 0 !important;

    display: inline-block;
    box-sizing: border-box;

    /* Reset theme button styles */
    appearance: none;
    -webkit-appearance: none;

    transition: all 0.2s ease;
}

/* Hover */
.color-swatch:hover {
    border-color: #000;
}

/* Selected */
.color-swatch.active {
    border: 1px solid #111;
    box-shadow: 0 0 0 2px #fff, 0 0 0 3px #111;
}

/* Disabled */
.color-swatch.disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

/* ==========================================
   FORCE CLEAN ADD TO CART (KADENCE OVERRIDE)
========================================== */

/* Break Kadence layout */
body.single-product form.variations_form.cart {
    display: block !important;
}

/* Reset Woo container */
body.single-product .single_variation_wrap {
    display: block !important;
    width: 100% !important;
    overflow: visible !important;
}

/* Stack elements */
body.single-product .woocommerce-variation-add-to-cart {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    width: 100% !important;
}

/* Quantity */
body.single-product .woocommerce-variation-add-to-cart .quantity {
    width: 80px !important;
    float: none !important;
}

/* Button */
body.single-product .single_add_to_cart_button {
    display: block !important;
    width: 100% !important;
    height: auto !important;           /* no fixed height */
    min-height: 52px !important;
    line-height: 1.4 !important;
    overflow: visible !important;
    padding: 16px 24px !important;
    box-sizing: border-box !important;
    background: #000 !important;
    color: #fff !important;
    border: none !important;
    text-align: center !important;
    font-size: 14px !important;
    letter-spacing: 0.05em !important;
    float: none !important;
}

/* Kill all float conflicts */
body.single-product .woocommerce-variation-add-to-cart * {
    float: none !important;
}

/* Trust signals */
body.single-product .krumpld-trust-signals {
    clear: both !important;
    display: block !important;
    width: 100% !important;
}

/* Prevent clipping */
body.single-product .summary {
    overflow: visible !important;
}