/* SFX Variation Manager – Frontend Styles */

/* --- Variation Content Container --- */
.sfx-vm-variation-content {
    margin-top: 20px;
    clear: both;
}

/* --- Variation Gallery --- */
.sfx-vm-variation-gallery-wrap {
    margin-bottom: 20px;
}

.sfx-vm-variation-gallery {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.sfx-vm-variation-gallery li {
    width: calc(25% - 6px);
    border: 1px solid #e0e0e0;
    border-radius: 3px;
    overflow: hidden;
    cursor: pointer;
    transition: border-color 0.2s;
}

.sfx-vm-variation-gallery li:hover {
    border-color: #0073aa;
}

.sfx-vm-variation-gallery li img {
    width: 100%;
    height: auto;
    display: block;
}

/* Lightbox-like full image preview */
.sfx-vm-gallery-lightbox {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 100000;
    background: rgba(0, 0, 0, 0.85);
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.sfx-vm-gallery-lightbox.active {
    display: flex;
}

.sfx-vm-gallery-lightbox img {
    max-width: 90vw;
    max-height: 90vh;
    border-radius: 4px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5);
}

/* --- Variation Description --- */
.sfx-vm-variation-description-wrap {
    margin-top: 15px;
}

.sfx-vm-variation-description {
    line-height: 1.7;
}

.sfx-vm-variation-description p {
    margin-bottom: 1em;
}

/* Video embeds */
.sfx-vm-variation-description iframe,
.sfx-vm-variation-description .wp-video {
    max-width: 100%;
    margin: 15px 0;
}

.sfx-vm-variation-description .wp-video-shortcode {
    max-width: 100% !important;
}

/* --- Responsive --- */
@media (max-width: 600px) {
    .sfx-vm-variation-gallery li {
        width: calc(50% - 4px);
    }
}

/* --- Variation Selector Fix (works with Divi, Storefront, Astra, etc.) --- */

/* Reset the table layout completely so we control it */
.variations_form table.variations {
    display: block !important;
    width: 100% !important;
    border: none !important;
    border-collapse: collapse !important;
    box-shadow: none !important;
    background: transparent !important;
    margin: 0 0 15px !important;
    padding: 0 !important;
}

.variations_form table.variations thead {
    display: none !important;
}

.variations_form table.variations tbody {
    display: block !important;
    width: 100% !important;
}

.variations_form table.variations tr {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    gap: 12px;
    margin-bottom: 12px !important;
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
}

/* Label cell */
.variations_form table.variations td.label,
.variations_form table.variations th.label {
    display: flex !important;
    align-items: center !important;
    flex-shrink: 0 !important;
    width: auto !important;
    min-width: 80px !important;
    max-width: 160px !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    background: transparent !important;
    text-align: left !important;
    vertical-align: middle !important;
    white-space: nowrap !important;
}

.variations_form table.variations td.label label,
.variations_form table.variations th.label label {
    font-size: 1em !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
    margin: 0 !important;
    padding: 0 !important;
    display: inline !important;
    float: none !important;
    width: auto !important;
}

/* Value cell */
.variations_form table.variations td.value {
    display: flex !important;
    align-items: center !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    background: transparent !important;
    position: relative !important;
}

/* Native select */
.variations_form table.variations td.value select {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 38px !important;
    box-sizing: border-box !important;
    margin: 0 !important;
    padding: 6px 30px 6px 10px !important;
    position: relative !important;
    top: auto !important;
    left: auto !important;
    float: none !important;
    font-size: 14px !important;
    line-height: 1.4 !important;
    border: 1px solid #bbb !important;
    border-radius: 4px !important;
    background-color: #fff !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23555' stroke-width='1.5' fill='none'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 10px center !important;
    background-size: 12px 8px !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
}

/* Remove any theme-injected arrows (Divi, etc.) */
.variations_form table.variations td.value::after,
.variations_form table.variations td.value::before,
.variations_form .variations td.value::after,
.variations_form .variations td.value::before,
form.variations_form .variations td.value::after,
form.variations_form .variations td.value::before,
.et_pb_wc_add_to_cart form.variations_form .variations td.value::after,
.et_pb_wc_add_to_cart form.variations_form .variations td.value::before,
.et-db #et-boc .et_pb_module form.variations_form .variations td.value::after,
.et-db #et-boc .et_pb_module form.variations_form .variations td.value::before {
    display: none !important;
    content: "" !important;
    width: 0 !important;
    height: 0 !important;
    border: none !important;
    background: none !important;
    visibility: hidden !important;
    position: absolute !important;
    pointer-events: none !important;
}

/* Select2 / selectWoo override (Divi often wraps these differently) */
.variations_form table.variations td.value .select2-container,
.variations_form table.variations td.value .select2-container--default {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    margin: 0 !important;
    position: relative !important;
    top: auto !important;
    left: auto !important;
    float: none !important;
    display: inline-block !important;
}

.variations_form table.variations td.value .select2-container .select2-selection--single {
    min-height: 38px !important;
    height: auto !important;
    border: 1px solid #bbb !important;
    border-radius: 4px !important;
    display: flex !important;
    align-items: center !important;
    padding: 0 8px !important;
}

.variations_form table.variations td.value .select2-container .select2-selection__rendered {
    line-height: 36px !important;
    padding-left: 0 !important;
}

.variations_form table.variations td.value .select2-container .select2-selection__arrow {
    height: 36px !important;
    top: 0 !important;
}

/* Hide the reset variations link – aggressive selectors for Divi */
.variations_form .reset_variations,
.variations_form a.reset_variations,
form.variations_form .reset_variations,
form.variations_form a.reset_variations,
.variations_form .variations .reset_variations,
.et_pb_wc_add_to_cart .reset_variations,
.et_pb_wc_add_to_cart a.reset_variations,
.et-db #et-boc .et_pb_module .reset_variations,
.et-db #et-boc .et_pb_module a.reset_variations,
table.variations + .reset_variations,
table.variations ~ a.reset_variations {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    overflow: hidden !important;
    font-size: 0 !important;
    line-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* --- Divi-specific overrides --- */

/* Divi adds transforms and absolute positioning to form elements */
.et-db #et-boc .et_pb_module .variations_form table.variations td,
.et-db #et-boc .et_pb_module .variations_form table.variations th,
.et_pb_wc_add_to_cart .variations_form table.variations td,
.et_pb_wc_add_to_cart .variations_form table.variations th {
    border: none !important;
    padding: 0 !important;
    background: transparent !important;
    text-align: left !important;
}

.et_pb_wc_add_to_cart .variations_form table.variations tr,
.et-db #et-boc .et_pb_module .variations_form table.variations tr {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    margin-bottom: 12px !important;
    border: none !important;
    background: transparent !important;
}

.et_pb_wc_add_to_cart .variations_form table.variations td.label,
.et-db #et-boc .et_pb_module .variations_form table.variations td.label {
    width: auto !important;
    flex-shrink: 0 !important;
    min-width: 80px !important;
}

.et_pb_wc_add_to_cart .variations_form table.variations td.value,
.et-db #et-boc .et_pb_module .variations_form table.variations td.value {
    flex: 1 1 auto !important;
}

.et_pb_wc_add_to_cart .variations_form table.variations td.value select,
.et-db #et-boc .et_pb_module .variations_form table.variations td.value select {
    width: 100% !important;
    position: relative !important;
    opacity: 1 !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
}

/* Remove Divi's injected select arrows (additional specificity) */
.et_pb_wc_add_to_cart .variations_form table.variations td.value select + .et-pb-arrow-down,
.et-db #et-boc .et_pb_module .variations_form table.variations td.value select + .et-pb-arrow-down {
    display: none !important;
    visibility: hidden !important;
}
