/* =========================
   BFI THEME V2
========================= */

/* CHECKOUT PLACE ORDER BUTTON */

.wc-block-components-checkout-place-order-button,
.wc-block-components-checkout-place-order-button:hover{
    background:#9CC400 !important;
    color:#000000 !important;
    border:none !important;
}

a.wc-block-cart__submit-button.contained,
a.wc-block-cart__submit-button.contained:hover{
    background-color:#9CC400 !important;
    background:#9CC400 !important;
    color:#000000 !important;
}
a{
    color:#FFFFFF;
}
.wp-block-woocommerce-cart.alignwide,
.wp-block-woocommerce-checkout.alignwide{
    max-width:1400px !important;
    margin:0 auto !important;
    padding:0 40px !important;
}
@media(max-width:768px){

    .wp-block-woocommerce-cart.alignwide,
    .wp-block-woocommerce-checkout.alignwide{
        max-width:100% !important;
        padding:0 15px !important;
        margin:0 !important;
    }

}

/* FORCE CHECKOUT LABELS */

.wc-block-components-text-input__label{
    color:#FFFFFF !important;
    opacity:1 !important;
    visibility:visible !important;
    display:block !important;
}


body{
    margin:0;
    background:#000;
    color:#fff;
    font-family:Arial,sans-serif;
}

/* TRUST BAR */

.trust-bar{
    background:#000;
    color:#fff;
    text-align:center;
    font-size:11px;
    font-weight:700;
    letter-spacing:1px;
    text-transform:uppercase;
    padding:10px;
}

.trust-bar span{
    margin:0 12px;
}

/* HEADER */

.site-header{
    background:#000;
    border-bottom:1px solid rgba(255,255,255,.08);
    position:relative;
    z-index:9999;
}

.header-inner{
    max-width:1400px;
    margin:0 auto;
    padding:15px 30px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    position:relative;
}

.site-logo img,
.custom-logo{
    max-height:90px;
    width:auto;
}

.main-navigation{
    display:block;
}

.main-menu{
    list-style:none;
    display:flex;
    gap:18px;
    margin:0;
    padding:0;
}

.main-menu li{
    list-style:none;
}

.main-menu a{
    color:#fff;
    text-decoration:none;
    text-transform:uppercase;
    font-size:11px;
    font-weight:700;
    letter-spacing:1px;
}

.main-menu a:hover{
    color:#9CC400;
}

.mobile-toggle{
    display:none;
    background:none;
    border:none;
    cursor:pointer;
    padding:0;
}

.mobile-toggle span{
    display:block;
    width:28px;
    height:3px;
    background:#fff;
    margin:5px 0;
}


/* PRODUCT */

.bfi-product-wrap{
    max-width:1400px;
    margin:60px auto;
    padding:0 30px;
}

.bfi-product-container{
    display:flex;
    gap:70px;
    align-items:flex-start;
}

.bfi-product-image{
    flex:0 0 48%;
}

.bfi-product-content{
    flex:0 0 52%;
}

/* WOOCOMMERCE GALLERY */

.bfi-product-image .woocommerce-product-gallery{
    width:100%;
}

.bfi-product-image .woocommerce-product-gallery__wrapper{
    background:#f2f2f2;
}

.bfi-product-image .woocommerce-product-gallery__image{
    background:#f2f2f2;
}

.bfi-product-image .woocommerce-product-gallery__image img{
    width:100%;
    height:auto;
    display:block;
}

.bfi-product-image img{
    width:100%;
    height:auto;
    display:block;
}

/* THUMBNAILS */

.bfi-product-image ol.flex-control-nav,
.bfi-product-image ol.flex-control-thumbs{
    list-style:none !important;
    display:flex !important;
    gap:12px;
    margin:15px 0 0 0 !important;
    padding:0 !important;
    flex-wrap:wrap;
}

.bfi-product-image ol.flex-control-nav li,
.bfi-product-image ol.flex-control-thumbs li{
    list-style:none !important;
    margin:0 !important;
    width:90px;
}

.bfi-product-image ol.flex-control-nav li::marker,
.bfi-product-image ol.flex-control-thumbs li::marker{
    display:none !important;
    content:"";
}

.bfi-product-image ol.flex-control-nav img,
.bfi-product-image ol.flex-control-thumbs img{
    width:90px;
    height:90px;
    object-fit:contain;
    background:#f2f2f2;
    border:2px solid transparent;
    cursor:pointer;
    display:block;
}

.bfi-product-image ol.flex-control-nav .flex-active,
.bfi-product-image ol.flex-control-thumbs .flex-active{
    border-color:#9CC400;
}

/* PRODUCT CONTENT */

.bfi-breadcrumbs{
    margin-bottom:20px;
    font-size:13px;
    opacity:.7;
}

.bfi-product-content h1{
    font-size:64px;
    line-height:.95;
    margin-bottom:25px;
}

.bfi-price{
    color:#9CC400;
    font-size:42px;
    font-weight:800;
    margin-bottom:30px;
}

.bfi-description{
    color:#ddd;
    line-height:2;
    margin-bottom:25px;
}

/* FEATURE BOX */

.bfi-feature-box{
    border:1px solid rgba(255,255,255,.12);
    padding:20px;
    margin-bottom:30px;
    background:#0a0a0a;
}

.bfi-feature-box div{
    padding:6px 0;
    color:#ddd;
}

/* BUTTONS */

.bfi-actions{
    display:flex;
    gap:15px;
    align-items:center;
    flex-wrap:wrap;
}

.bfi-btn{
    padding:16px 30px;
    font-weight:800;
    text-decoration:none;
    text-transform:uppercase;
    display:inline-block;
}

.bfi-btn-dealer{
    background:#9CC400;
    color:#000;
}

.bfi-btn-buy{
    background:transparent;
    color:#fff;
    border:2px solid #fff;
}

.bfi-btn-buy:hover{
    background:#fff;
    color:#000;
}

.bfi-buy-note{
    margin-top:20px;
    color:#999;
}

/* PRODUCT DETAILS */

.bfi-product-details{
    margin-top:100px;
}

.bfi-product-details h2{
    color:#FFFFFF;
    font-size:42px;
    font-weight:800;
    margin-bottom:30px;
    text-transform:none;
}

.bfi-product-details p,
.bfi-product-details li{
    color:#ddd;
    line-height:1.9;
}

/* RELATED PRODUCTS */

.bfi-related{
    margin-top:100px;
}

.bfi-related h2{
    color:#fff;
    font-size:42px;
    font-weight:800;
}

/* KEEP ORIGINAL WOOCOMMERCE LAYOUT */

.bfi-related ul.products{
    display:grid !important;
    grid-template-columns:repeat(4,1fr);
    gap:30px;
}

.bfi-related ul.products li.product{
    width:100% !important;
    margin:0 !important;
    background:#111;
    padding:20px;
}

.bfi-related ul.products li.product img{
    width:100%;
    aspect-ratio:1/1;
    object-fit:contain;
}

/* PRODUCT TITLES */

.woocommerce ul.products li.product .woocommerce-loop-product__title{
    color:#FFFFFF !important;
    font-size:18px !important;
    font-weight:700 !important;
    line-height:1.4 !important;
    margin-top:12px !important;
    margin-bottom:12px !important;
}

/* PRICES */

.woocommerce ul.products li.product .price{
    color:#9CC400 !important;
    font-size:22px !important;
    font-weight:800 !important;
    margin-bottom:15px !important;
}

/* BUTTONS */

.woocommerce ul.products li.product .button,
.bfi-related .button{
    background:#9CC400 !important;
    color:#000 !important;
    border:none !important;
    font-weight:800 !important;
    text-transform:uppercase !important;
    padding:12px 20px !important;
}

.woocommerce ul.products li.product .button:hover{
    opacity:.9;
}
/* SHOP CATALOG */

.bfi-shop-wrap{
    max-width:1400px;
    margin:60px auto;
    padding:0 30px;
    box-sizing:border-box;
}

.bfi-shop-header{
    margin-bottom:40px;
}

.bfi-shop-title{
    font-size:64px;
    line-height:.95;
    margin-bottom:20px;
    color:#fff;
}
/* PRODUCT CATALOG CARDS */

.bfi-product-card{
    background:#111111;
    border:1px solid rgba(255,255,255,.08);
    padding:15px;
    transition:.3s ease;
    box-sizing:border-box;
}

.bfi-product-card:hover{
    border-color:#9CC400;
}

.bfi-product-link{
    text-decoration:none;
}

.bfi-product-image-wrap{
    background:#EFEFEF;
    aspect-ratio:1/1;
    overflow:hidden;
    margin-bottom:10px;
}
@media(min-width:992px){

    .bfi-product-image-wrap{
        aspect-ratio:1/0.9;
    }

}

.bfi-product-image-wrap img{
    width:100%;
    height:100%;
    object-fit:contain;
    display:block;
}

.bfi-product-title{
    color:#FFFFFF;
    font-size:20px;
    font-weight:700;
    line-height:1.4;
    margin:0 0 5px;
    min-height:112px;
}

.bfi-product-price{
    color:#9CC400;
    font-size:22px;
    font-weight:800;
    margin-bottom:18px;
}

.bfi-product-button .button{
    display:block;
    width:100%;
    text-align:center;
    background:#9CC400 !important;
    color:#000 !important;
    border:none !important;
    padding:14px !important;
    font-size:13px !important;
    font-weight:800 !important;
    text-transform:uppercase;
}
.bfi-product-button a{
    color:#9CC400 !important;
    text-decoration:none !important;
}

.bfi-product-button a:hover{
    color:#FFFFFF !important;
}
a.added_to_cart{
    color:#9CC400 !important;
    text-decoration:none !important;
    font-weight:700 !important;
}

a.added_to_cart:hover{
    color:#FFFFFF !important;
}
/* PAGINATION */

.woocommerce nav.woocommerce-pagination ul{
    border:none;
}

.woocommerce nav.woocommerce-pagination ul li{
    border:1px solid rgba(255,255,255,.15);
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span{
    background:#000;
    color:#FFFFFF !important;
    font-weight:700;
}

.woocommerce nav.woocommerce-pagination ul li span.current{
    background:#9CC400;
    color:#000 !important;
}

.woocommerce nav.woocommerce-pagination ul li a:hover{
    background:#9CC400;
    color:#000 !important;
}
/* =========================
   WPFORMS
========================= */

.wpforms-container{
    max-width:1100px;
    margin:0 auto;
}

/* ALL FIELD LABELS */

.wpforms-container label,
.wpforms-container legend.wpforms-field-label{
    color:#FFFFFF !important;
    font-size:14px !important;
    font-weight:600 !important;
    opacity:1 !important;
}

/* REQUIRED ASTERISK */

.wpforms-required-label{
    color:#9CC400 !important;
}

/* INPUTS */

.wpforms-container input,
.wpforms-container textarea,
.wpforms-container select{
    width:100% !important;
    background:#111111 !important;
    border:1px solid rgba(255,255,255,.15) !important;
    color:#FFFFFF !important;
    padding:14px 16px !important;
    font-size:15px !important;
    border-radius:0 !important;
    box-sizing:border-box !important;
}

.wpforms-container textarea{
    min-height:180px !important;
}

.wpforms-container input:focus,
.wpforms-container textarea:focus,
.wpforms-container select:focus{
    border-color:#9CC400 !important;
    outline:none !important;
}

/* DROPDOWNS */

.wpforms-container select{
    appearance:auto !important;
    -webkit-appearance:menulist !important;
    -moz-appearance:menulist !important;
    padding-right:40px !important;
}

.wpforms-container option{
    background:#111 !important;
    color:#fff !important;
}

.wpforms-field-select select{
    min-height:52px !important;
}

.wpforms-field-select option{
    padding:8px !important;
}

/* PLACEHOLDERS */

.wpforms-container ::placeholder{
    color:#888 !important;
}

/* SUBMIT BUTTON */

.wpforms-submit{
    background:#9CC400 !important;
    color:#000 !important;
    border:none !important;
    padding:18px 40px !important;
    font-size:14px !important;
    font-weight:800 !important;
    text-transform:uppercase !important;
    letter-spacing:1px !important;
}

.wpforms-submit:hover{
    opacity:.9;
}

/* CONFIRMATION MESSAGE */

.wpforms-confirmation-container{
    background:#111 !important;
    color:#fff !important;
    border-left:4px solid #9CC400 !important;
    padding:20px !important;
}


/* FOOTER */

.site-footer{
    padding:40px;
    text-align:center;
    border-top:1px solid rgba(255,255,255,.1);
    margin-top:100px;
}

/* MOBILE */

@media (max-width: 991px) {

    html,
    body {
        overflow-x: hidden !important;
        width: 100% !important;
    }

    .trust-bar {
        display: none !important;
    }

    .bfi-product-container {
        flex-direction: column;
    }

    .bfi-product-image,
    .bfi-product-content {
        width: 100%;
        flex: 100%;
    }

    .bfi-product-content h1 {
        font-size: 42px;
    }

    .bfi-related ul.products {
        grid-template-columns: 1fr;
    }

    .wpforms-container {
        max-width: 100%;
    }

    .mobile-toggle {
        display: block;
        background: none;
        border: none;
        cursor: pointer;
        padding: 0;
        z-index: 9999;
    }

    .mobile-toggle span {
        display: block;
        width: 28px;
        height: 3px;
        background: #fff;
        margin: 5px 0;
    }

    .main-navigation {
        display: none;
    }

    .main-navigation.active {
        display: block !important;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background: #000;
        z-index: 99999;
        border-top: 1px solid rgba(255,255,255,.08);
    }

    .main-navigation.active .main-menu {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 0;
        margin: 0;
        padding: 20px 0;
    }

    .main-navigation.active .main-menu li {
        width: 100%;
        text-align: center;
    }

    .main-navigation.active .main-menu a {
        display: block;
        width: 100%;
        padding: 15px;
        text-align: center;
        color: #fff;
        font-size: 14px;
    }

}

@media (max-width: 768px) {

    .bfi-product-card {
        padding: 12px;
    }

    .bfi-product-title {
        font-size: 18px;
        min-height: 145px;
        margin: 0 0 10px;
    }

    .bfi-product-price {
        font-size: 18px;
        margin-bottom: 12px;
    }

}


/* PAGE WRAPPER */

.bfi-page-wrap{
    max-width:1400px;
    margin:60px auto;
    padding:0 30px;
}
/* CART BLOCK */

.wc-block-cart,
.wp-block-woocommerce-cart{
    color:#FFFFFF;
}

.wc-block-components-product-name{
    color:#FFFFFF !important;
    text-decoration:none !important;
}

.wc-block-components-product-name:hover{
    color:#9CC400 !important;
}

.wc-block-components-button{
    background:#9CC400 !important;
    color:#000000 !important;
    border:none !important;
    font-weight:800 !important;
}

.wc-block-components-button:hover{
    opacity:.9;
}
/* CHECKOUT BUTTON */

.wc-block-components-button,
.wc-block-components-button.wp-element-button{
    background:#9CC400 !important;
    color:#000000 !important;
    border:none !important;
    font-weight:800 !important;
    text-transform:uppercase !important;
}

.wc-block-components-button:hover,
.wc-block-components-button.wp-element-button:hover{
    opacity:.9;
}

/* FORM INPUTS */

.wc-block-components-text-input input,
.wc-block-components-combobox-control input,
.wc-block-components-select select{
    background:#111111 !important;
    color:#FFFFFF !important;
    border:1px solid rgba(255,255,255,.15) !important;
}



/* MOBILE CHECKOUT */

@media(max-width:768px){

    .wc-block-components-sidebar{
        width:100% !important;
    }

    .wc-block-components-product-name{
        white-space:normal !important;
        word-break:normal !important;
    }
}
/* FORCE CART BUTTON TEST */

a.wc-block-cart__submit-button.contained,
a.wc-block-cart__submit-button.contained:hover{
    background:#9CC400 !important;
    color:#000000 !important;
    border:none !important;
}

/* SHOW FLOATING LABELS */

.wc-block-components-text-input label{
    position:static !important;
    transform:none !important;
    opacity:1 !important;
    visibility:visible !important;
    display:block !important;
    color:#9CC400 !important;
    font-size:12px !important;
    margin-bottom:4px !important;
}

.wc-block-components-text-input input{
    padding-top:0 !important;
}

/* FORCE DESKTOP CHECKOUT LABELS */

@media(min-width:769px){

    .wc-block-components-text-input__label{
        display:block !important;
        position:static !important;
        transform:none !important;
        opacity:1 !important;
        visibility:visible !important;
        height:auto !important;
        overflow:visible !important;
        color:#FFFFFF !important;
        margin-bottom:6px !important;
    }

}

/* DESKTOP LABEL WRAPPER TEST */

@media(min-width:769px){

    .wc-block-components-text-input{
        display:flex !important;
        flex-direction:column !important;
        gap:6px !important;
    }

}

/* FORCE DESKTOP FLOATING LABEL COLOR */

@media(min-width:769px){

    .wc-block-components-text-input__label{
        color:#FF0000 !important;
    }

}