\/*
Theme Name: True Valor Supply
Theme URI: https://truevalorsupply.com/
Author: True Valor Supply
Author URI: https://truevalorsupply.com/
Description: Bold, patriotic WooCommerce theme for True Valor Supply. Yellow announcement bar, sticky red/black header, gold camo accents, and matching footer. Compatible with WooCommerce, including HPOS. Update-safe Â uses standard WP/WC hooks and template hierarchy.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: true-valor-supply
Tags: e-commerce, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* Self-hosted Black Ops One â€” absolute URL so it still resolves when WP-Optimize
   serves a combined/minified stylesheet from a different directory. */
@font-face {
    font-family: 'Black Ops One';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url('/wp-content/themes/true-valor-supply/assets/fonts/BlackOpsOne-Regular.woff2') format('woff2');
}

*,*::before,*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}
 
:root {
    --red: #cc0000;
    --black: #0d0d0d;
    --dark: #141414;
    --card: #1a1a1a;
    --border: #2a2a2a;
    --white: #fff;
    --gray: #aaa;
    --gold: #c9a020;
    --camo1: #2d3b1e;
    --camo2: #4b5320;
    --camo3: #3d4e28;
    --camod: #1e2b12;
    --H: 'Oswald',sans-serif;
    --B: 'Roboto',sans-serif
}
 
html {
    scroll-behavior: smooth
}
 
body {
    font-family: var(--B);
    background: var(--black);
    color: var(--white);
    overflow-x: hidden
}
 
a {
    text-decoration: none;
    color: inherit
}
 
img {
    max-width: 100%;
    display: block
}
 
ul {
    list-style: none
}
 
/* WARM CAMO OVERLAY ON DARK */
.bg-camo {
    background-color: var(--black);
    background-image: radial-gradient(ellipse 200px 130px at 8% 18%,rgba(201,160,32,.10) 0%,transparent 60%),radial-gradient(ellipse 140px 200px at 62% 12%,rgba(150,75,20,.07) 0%,transparent 60%),radial-gradient(ellipse 170px 110px at 38% 68%,rgba(180,130,45,.08) 0%,transparent 60%),radial-gradient(ellipse 150px 180px at 82% 52%,rgba(201,160,32,.06) 0%,transparent 55%),radial-gradient(ellipse 120px 150px at 50% 40%,rgba(90,55,20,.12) 0%,transparent 50%),radial-gradient(ellipse 180px 100px at 18% 82%,rgba(201,160,32,.07) 0%,transparent 60%),radial-gradient(ellipse 100px 160px at 92% 88%,rgba(170,95,30,.09) 0%,transparent 55%),radial-gradient(ellipse 130px 90px at 75% 80%,rgba(60,35,10,.18) 0%,transparent 60%)
}
 
/* ANNOUNCEMENT BAR (yellow/gold with camo) */
.ann {
    background-color: var(--gold);
    background-image: radial-gradient(ellipse 90px 30px at 12% 50%,rgba(0,0,0,.14) 0%,transparent 60%),radial-gradient(ellipse 70px 25px at 42% 50%,rgba(75,83,32,.28) 0%,transparent 60%),radial-gradient(ellipse 80px 28px at 72% 50%,rgba(30,43,18,.22) 0%,transparent 60%),radial-gradient(ellipse 60px 22px at 92% 50%,rgba(0,0,0,.12) 0%,transparent 60%);
    color: #0d0d0d;
    text-align: center;
    padding: 9px 20px;
    font-family: var(--H);
    font-size: .82rem;
    letter-spacing: .1em;
    font-weight: 700;
    text-transform: uppercase;
    position: relative;
    z-index: 1001
}
 
.ann a {
    color: #0d0d0d;
    text-decoration: underline;
    margin-left: 8px;
    font-weight: 700
}
 
/* STICKY TOP WRAPPER (announcement + header) */
.topstick {
    position: sticky;
    top: 0;
    z-index: 1000
}
 
/* HEADER */
.site-header {
    background: var(--black);
    border-bottom: 2px solid var(--red);
    transition: box-shadow .25s;
}
 
.site-header.scrolled {
    box-shadow: 0 4px 24px rgba(0,0,0,.6)
}
 
.hdr-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 0 48px;
    background: #0f0f0f;
    border-bottom: 1px solid var(--border);
    flex-wrap: nowrap;
}

/* WWP announcement strip Ã¢â‚¬â€ now inline between logo and account links */
.hdr-center {
    flex: 1 1 auto;
    display: flex;
    justify-content: center;
    align-items: center;
    min-width: 0;
}
.hdr-center .ann {
    background-color: var(--gold);
    background-image: radial-gradient(ellipse 90px 30px at 12% 50%,rgba(0,0,0,.14) 0%,transparent 60%),radial-gradient(ellipse 70px 25px at 42% 50%,rgba(75,83,32,.28) 0%,transparent 60%),radial-gradient(ellipse 80px 28px at 72% 50%,rgba(30,43,18,.22) 0%,transparent 60%),radial-gradient(ellipse 60px 22px at 92% 50%,rgba(0,0,0,.12) 0%,transparent 60%);
    color: #0d0d0d;
    padding: 8px 22px;
    font-size: .82rem;
    letter-spacing: .12em;
    font-weight: 700;
    text-transform: uppercase;
    z-index: auto;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    line-height: 1.3;
    margin-left: 16%;
}
.hdr-center .ann a {
    background: var(--red);
    color: #fff !important;
    padding: 6px 14px;
    text-decoration: none !important;
    font-weight: 700;
    margin-left: 6px;
    transition: background .25s;
    border-radius: 0;
}
.hdr-center .ann a:hover { background: #aa0000; }
@media (max-width: 1100px) {
    .hdr-center .ann { font-size: .72rem; letter-spacing: .08em; padding: 6px 14px; }
    .hdr-center .ann a { padding: 5px 10px; }
}
@media (max-width: 900px) {
    .hdr-center { display: none; }
}
 
.logo {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
}
.logo img,.custom-logo {
    height: 90px !important;
    width: auto !important;
    margin-bottom: 0;
    display: block;
}
 
.hdr-right {
    display: flex;
    align-items: center;
    gap: 22px;
    flex: 0 0 auto;
}
 
.hdr-links {
    display: flex;
    align-items: center;
    gap: 14px;
    font-size: .78rem;
    font-family: var(--H);
    letter-spacing: .06em;
    text-transform: uppercase
}
 
.hdr-links a {
    color: var(--gray);
    transition: color .2s
}
 
.hdr-links a:hover {
    color: var(--white)
}
 
.hdr-links .sep {
    color: #333
}
 
.hdr-icons {
    display: flex;
    align-items: center;
    gap: 18px
}
 
.hdr-icons a {
    color: var(--gray);
    display: flex;
    align-items: center;
    transition: color .2s
}
 
.hdr-icons a:hover {
    color: #fff
}
 
.cart-wrap {
    position: relative
}
 
.cart-badge {
    position: absolute;
    top: -8px;
    right: -10px;
    background: var(--red);
    color: #fff;
    border-radius: 50%;
    width: 17px;
    height: 17px;
    font-size: .62rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--H)
}
 
/* NAV (works with wp_nav_menu output) */
.main-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 2px;
    padding: 0 48px;
    background: var(--black)
}
 
.main-nav ul {
    display: flex;
    align-items: center;
    gap: 2px;
    list-style: none;
    margin: 0;
    padding: 0
}
 
.main-nav li {
    position: relative
}
 
.main-nav li>a {
    display: block;
    padding: 13px 19px;
    font-family: var(--H);
    font-size: .88rem;
    font-weight: 500;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: #fff;
    transition: color .2s
}
 
.main-nav li>a:hover,.main-nav li:hover>a,.main-nav .current-menu-item>a {
    color: var(--red)
}
 
.main-nav li.menu-item-has-children>a::after {
    content: ' \25BE';
    font-size: .7em;
    opacity: .8
}
 
.main-nav .sub-menu {
    position: absolute;
    top: 100%;
    left: 0;
    background: #191919;
    border: 1px solid var(--border);
    border-top: 2px solid var(--red);
    min-width: 230px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-6px);
    transition: all .2s;
    z-index: 200;
    display: block;
    padding: 0;
    margin: 0;
    list-style: none
}
 
.main-nav li:hover>.sub-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0)
}
 
.main-nav .sub-menu li {
    display: block
}
 
.main-nav .sub-menu a {
    display: block;
    padding: 10px 20px;
    font-size: .84rem;
    color: var(--gray);
    border-bottom: 1px solid #222;
    transition: all .15s;
    text-transform: none;
    letter-spacing: .04em;
    font-weight: 400
}
 
.main-nav .sub-menu li:last-child a {
    border-bottom: none
}
 
.main-nav .sub-menu a:hover {
    background: #222;
    color: #fff;
    padding-left: 26px
}
 
.mob-btn {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    flex-direction: column;
    gap: 5px;
    padding: 5px
}
 
.mob-btn span {
    display: block;
    width: 23px;
    height: 2px;
    background: #fff
}
 
/* SITE BACKGROUND orange-edge image behind content area */
.camo-wrap {
    background-color: #0d0d0d;
    background-image:
        radial-gradient(ellipse 220px 140px at 8% 12%, rgba(201,160,32,.06) 0%, transparent 60%),
        radial-gradient(ellipse 180px 220px at 88% 20%, rgba(150,75,20,.05) 0%, transparent 60%),
        radial-gradient(ellipse 200px 140px at 50% 80%, rgba(201,160,32,.04) 0%, transparent 60%);
    background-size: cover;
    background-position: center top;
    background-repeat: no-repeat;
    background-attachment: fixed;
    min-height: 60vh
}

/* SHOP + PRODUCT PAGES Ã¢â‚¬â€ camo image background */
body.woocommerce,
body.woocommerce-page,
body.single-product,
body.archive.tax-product_brand,
body.archive.tax-product_cat,
body.post-type-archive-product {
    background-image: url('assets/img/shop-camo-bg.jpg') !important;
    background-color: #0d0d0d !important;
    background-size: cover !important;
    background-position: center top !important;
    background-attachment: fixed !important;
    background-repeat: no-repeat !important;
}
/* Let the camo show through the content wrappers on shop/product pages */
body.woocommerce .camo-wrap,
body.woocommerce-page .camo-wrap,
body.single-product .camo-wrap,
body.single-product .site-main,
body.single-product main.site-main {
    background: transparent !important;
}
 
#site-content {
    background: transparent;
    max-width: 1400px;
    margin: 0 auto;
    min-height: 60vh;
    background-color: rgb(0 0 0 / 50%);
}
 
body.home #site-content {
    max-width: 100%
}
 
/* GENERIC PAGE / POST CONTENT WRAPPER */
.site-main {
    min-height: 60vh;
    padding: 56px 48px;
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
    color: #222
}
 
.site-main .entry,.site-main .woocommerce,.site-main .entry>.woocommerce {
    width: 100% !important;
    max-width: 100% !important;
    float: none !important
}
 
.site-main .entry::after {
    content: '';
    display: table;
    clear: both
}
 
.entry,.page,.post,.type-page,.type-post {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
    color: #222
}
 
.entry h1,.entry h2,.entry h3,.entry h4 {
    font-family: var(--H);
    text-transform: uppercase;
    line-height: 1.15;
    margin: 1.2em 0 .55em;
    color: #222
}
 
.entry h1 {
    font-size: 2.4rem
}
 
.entry h2 {
    font-size: 1.9rem
}
 
.entry h2::after {
    content: '';
    display: block;
    width: 44px;
    height: 3px;
    background: var(--red);
    margin-top: 7px
}
 
.entry h3 {
    font-size: 1.35rem
}
 
.entry p {
    color: #444;
    line-height: 1.75;
    margin-bottom: 1em;
    font-size: .98rem
}
 
.entry a {
    color: var(--red);
    text-decoration: underline
}
 
.entry a:hover {
    color: #222
}
 
.entry ul,.entry ol {
    margin: 0 0 1.2em 1.4em;
    color: #444;
    line-height: 1.75
}
 
.entry ul li,.entry ol li {
    margin-bottom: .4em
}
 
.entry blockquote {
    border-left: 3px solid var(--red);
    padding: 8px 18px;
    margin: 1.5em 0;
    color: #ddd;
    background: rgba(255,255,255,.04);
    font-style: italic
}
 
.entry img {
    margin: 1em 0
}
 
.entry table {
    width: 100%;
    border-collapse: collapse;
    margin: 1.2em 0
}
 
.entry table th,.entry table td {
    border: 1px solid var(--border);
    padding: 10px 12px;
    text-align: left
}
 
.entry table th {
    background: #181818;
    font-family: var(--H);
    text-transform: uppercase;
    font-size: .85rem;
    letter-spacing: .06em
}
 
.entry code {
    background: #1c1c1c;
    padding: 2px 6px;
    border: 1px solid var(--border);
    border-radius: 3px;
    color: #f0c674;
    font-size: .9em
}
 
.entry pre {
    background: #0c0c0c;
    border: 1px solid var(--border);
    padding: 14px;
    overflow-x: auto;
    margin: 1.2em 0
}
 
/* PAGE TITLE BAR */
.page-hero {
    background: rgba(13,13,13,.55);
    border-top: 3px solid var(--red);
    border-bottom: 1px solid var(--border);
    padding: 48px 48px 36px;
    text-align: center;
    color: #fff !important;
}
 
.page-hero h1 {
    font-family: var(--H);
    font-size: 2.2rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #fff
}
 
.page-hero h1::after {
    content: '';
    display: block;
    width: 60px;
    height: 3px;
    background: var(--red);
    margin: 12px auto 0
}
 
.page-hero .breadcrumbs,.page-hero nav {
    font-family: var(--H);
    font-size: .78rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--gray);
    margin-top: 12px
}
 
.page-hero .breadcrumbs a,.page-hero nav a {
    color: var(--gold)
}
 
.page-hero .breadcrumbs a:hover,.page-hero nav a:hover {
    color: #fff
}
 
/* BUTTONS (shared) */
.btn-red,.btn,button.button,input[type=submit],.wp-block-button__link {
    display: inline-block;
    background: var(--red);
    color: #fff !important;
    font-family: var(--H);
    font-size: .88rem;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    padding: 14px 34px;
    border: none;
    cursor: pointer;
    transition: background .2s,transform .15s;
    text-decoration: none
}
 
.btn-red:hover,.btn:hover,button.button:hover,input[type=submit]:hover,.wp-block-button__link:hover {
    background: #aa0000;
    transform: translateY(-2px)
}
 
/* FORMS */
input[type=text],input[type=email],input[type=password],input[type=tel],input[type=number],input[type=search],input[type=url],textarea,select {
    background: #fff;
    border: 1px solid #ccc;
    color: #222;
    padding: 11px 13px;
    font-family: var(--B);
    font-size: .95rem;
    width: 100%;
    max-width: 480px;
    transition: border-color .2s
}
 
input:focus,textarea:focus,select:focus {
    outline: none;
    border-color: var(--red)
}
 
label {
    display: block;
    font-family: var(--H);
    font-size: .82rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #333;
    margin-bottom: 6px
}
 
/* SECTIONS (utility, used on archives etc.) */
.sec {
    padding: 68px 48px
}
 
.sec-alt {
    background: var(--dark)
}
 
.sec-hd {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 36px;
    padding-bottom: 13px;
    border-bottom: 1px solid var(--border)
}
 
.sec-hd h2 {
    font-family: var(--H);
    font-size: 1.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em
}
 
.sec-hd h2::after {
    content: '';
    display: block;
    width: 44px;
    height: 3px;
    background: var(--red);
    margin-top: 7px
}
 
.sec-hd a {
    font-family: var(--H);
    font-size: .78rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--red);
    transition: color .2s
}
 
.sec-hd a:hover {
    color: #fff
}
 
.bg-camo .sec-hd a {
    color: var(--gold)
}
 
.bg-camo .sec-hd a:hover {
    color: #fff
}
 
/* WOOCOMMERCE base overrides matching site theme */
/* WC GRID NAV BAR (result count + ordering) */
.site-main .woocommerce-result-count,.site-main .woocommerce-ordering,.woocommerce .woocommerce-result-count,.woocommerce .woocommerce-ordering {
    background: var(--black);
    color: #fff !important;
    padding: 14px 20px;
    font-family: var(--H);
    font-size: .82rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    margin: 0 0 24px;
    float: none !important;
    width: auto;
    margin-top: -50px !important;
}
 
.site-main .woocommerce-result-count,.woocommerce .woocommerce-result-count {
    float: left !important
}
 
.site-main .woocommerce-ordering,.woocommerce .woocommerce-ordering {
    float: right !important
}
 
.woocommerce-ordering select {
    background: var(--black);
    color: #fff;
    border: 1px solid #555;
    padding: 8px 14px;
    font-family: var(--H);
    font-size: .82rem;
    max-width: 240px;
    width: auto
}
 
.woocommerce-notices-wrapper {
    margin-bottom: 24px
}
 
.woocommerce-message,.woocommerce-info,.woocommerce-error {
    background: #181818 !important;
    color: #fff !important;
    border-top: 3px solid var(--gold) !important;
    padding: 14px 18px 14px 50px !important;
    font-family: var(--B);
    font-size: .92rem;
    list-style: none
}
 
.woocommerce-error {
    border-top-color: var(--red) !important
}
 
.woocommerce-message {
    border-top-color: #5cb85c !important
}
 
.woocommerce-message a,.woocommerce-info a,.woocommerce-error a {
    color: var(--gold) !important;
    text-decoration: underline
}
 
.woocommerce ul.products {
    display: grid !important;
    grid-template-columns: repeat(4,1fr) !important;
    gap: 18px;
    list-style: none;
    margin: 0;
    padding: 0;
    width: 165%;
    clear: both
}
 
@media(max-width: 1280px) {
    .woocommerce ul.products {
        grid-template-columns: repeat(3,1fr) !important
    }
}
 
@media(max-width: 768px) {
    .woocommerce ul.products {
        grid-template-columns: repeat(2,1fr) !important
    }
 
    body.single-product .site-main,body.single-product main.site-main {
        padding: 28px 20px
    }
}
 
@media(max-width: 480px) {
    .woocommerce ul.products {
        grid-template-columns: 1fr !important
    }
}
 
/* WC CART / CHECKOUT */
.woocommerce table.shop_table {
    background: #fff;
    border: 1px solid #e5e5e5;
    color: #222;
    border-radius: 0;
    border-collapse: collapse;
    width: 100%
}
 
.woocommerce table.shop_table th {
    background: #f5f5f5;
    color: #222;
    font-family: var(--H);
    text-transform: uppercase;
    letter-spacing: .06em;
    padding: 12px
}
 
.woocommerce table.shop_table td {
    border-top: 1px solid #e5e5e5;
    padding: 14px 12px;
    color: #222
}
 
.woocommerce-cart .cart-collaterals,.woocommerce-checkout #order_review_heading,.woocommerce-checkout #order_review {
    margin-top: 30px
}
 
.woocommerce-cart .cart-collaterals .cart_totals h2,.woocommerce #order_review_heading,.woocommerce-checkout h3 {
    font-family: var(--H);
    text-transform: uppercase;
    color: #222
}
 
.select2-container .select2-selection--single {
    background: #fff !important;
    border: 1px solid #ccc !important;
    color: #222 !important;
    height: 42px !important
}
 
.select2-container--default .select2-selection--single .select2-selection__rendered {
    color: #222 !important;
    line-height: 42px !important;
    padding-left: 13px !important
}
 
/* WC ACCOUNT */
.woocommerce-account .woocommerce-MyAccount-navigation {
    float: left;
    width: 24%
}
 
.woocommerce-account .woocommerce-MyAccount-content {
    float: right;
    width: 72%
}
 
.woocommerce-MyAccount-navigation ul {
    list-style: none;
    margin: 0;
    padding: 0;
    background: #f9f9f9;
    border: 1px solid #e5e5e5
}
 
.woocommerce-MyAccount-navigation ul li a {
    display: block;
    padding: 12px 16px;
    color: #555;
    border-bottom: 1px solid #e5e5e5;
    font-family: var(--H);
    text-transform: uppercase;
    font-size: .82rem;
    letter-spacing: .08em
}
 
.woocommerce-MyAccount-navigation ul li.is-active a,.woocommerce-MyAccount-navigation ul li a:hover {
    background: #fff;
    color: var(--red)
}
 
@media(max-width: 768px) {
    .woocommerce-account .woocommerce-MyAccount-navigation,.woocommerce-account .woocommerce-MyAccount-content {
        float:none;
        width: 100%
    }
}
 
/* WC BREADCRUMBS */
.woocommerce-breadcrumb {
    font-family: var(--H);
    font-size: .78rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: #888;
    margin-bottom: 24px
}
 
.woocommerce-breadcrumb a {
    color: var(--red)
}
 
.woocommerce-breadcrumb a:hover {
    color: #222
}
 
/* PAGINATION */
.woocommerce nav.woocommerce-pagination ul,.pagination {
    border: none !important;
    display: flex;
    gap: 6px;
    list-style: none;
    padding: 0
}
 
.woocommerce nav.woocommerce-pagination ul li,.pagination li {
    border: none !important;
    margin: 0
}
 
.woocommerce nav.woocommerce-pagination ul li a,.woocommerce nav.woocommerce-pagination ul li span,.pagination a,.pagination span {
    padding: 10px 14px !important;
    background: #f5f5f5;
    border: 1px solid #e5e5e5 !important;
    color: #222 !important;
    font-family: var(--H);
    font-size: .85rem !important;
    display: block
}
 
.woocommerce nav.woocommerce-pagination ul li a:hover,.woocommerce nav.woocommerce-pagination ul li span.current,.pagination a:hover,.pagination .current {
    background: var(--red) !important;
    border-color: var(--red) !important
}
 
/* COMMENTS */
.comments-area {
    margin-top: 50px;
    border-top: 1px solid #e5e5e5;
    padding-top: 32px
}
 
.comments-area h2,.comments-area h3 {
    font-family: var(--H);
    text-transform: uppercase;
    color: #222;
    margin-bottom: 18px
}
 
.comment-list {
    list-style: none;
    margin: 0;
    padding: 0
}
 
.comment-list li {
    background: #f9f9f9;
    border: 1px solid #e5e5e5;
    padding: 18px;
    margin-bottom: 14px
}
 
.comment-list .comment-author,.comment-meta {
    font-family: var(--H);
    font-size: .82rem;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--red);
    margin-bottom: 8px
}
 
.comment-list .comment-content {
    color: #444;
    line-height: 1.7
}
 
/* 404 */
.error-404 {
    text-align: center;
    padding: 90px 48px;
    background: #fff
}
 
.error-404 h1 {
    font-family: var(--H);
    font-size: 5rem;
    color: var(--red);
    text-transform: uppercase;
    line-height: 1
}
 
.error-404 h2 {
    font-family: var(--H);
    font-size: 1.6rem;
    color: #222;
    text-transform: uppercase;
    letter-spacing: .08em;
    margin: 14px 0 24px
}
 
.error-404 p {
    color: #666;
    margin-bottom: 24px
}
 
/* SEARCH FORM */
.search-form {
    display: flex;
    gap: 0;
    max-width: 520px;
    margin: 0 auto
}
 
.search-form input[type=search] {
    flex: 1;
    max-width: none;
    border-right: none
}
 
.search-form button {
    padding: 11px 22px;
    font-size: .82rem
}
 
/* FOOTER */
.site-footer {
    background: #080808;
    border-top: 3px solid var(--red)
}
 
.foot-grid {
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr 1fr;
    gap: 44px;
    padding: 58px 48px 36px
}
 
.fcol img.flogo {
    height: 66px;
    margin-bottom: 14px
}
 
.fcol p {
    color: var(--gray);
    font-size: .84rem;
    line-height: 1.7;
    margin-bottom: 16px
}
 
.fcol img.fsocial {
    max-width: 195px
}
 
.fcol h4,.fcol .widget-title {
    font-family: var(--H);
    font-size: .85rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    margin-bottom: 13px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--border);
    color: #fff
}
 
.fcol ul {
    list-style: none;
    margin: 0;
    padding: 0
}
 
.fcol ul li {
    margin-bottom: 8px
}
 
.fcol ul li a {
    color: var(--gray);
    font-size: .84rem;
    transition: color .2s;
    text-decoration: none
}
 
.fcol ul li a:hover {
    color: var(--red)
}
 
.foot-btm {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 17px 48px;
    border-top: 1px solid var(--border)
}
 
.foot-btm span {
    color: #555;
    font-size: .78rem
}
 
.foot-btm img {
    max-width: 175px;
    opacity: .65
}
 
/* SCREEN-READER UTILITY */
.screen-reader-text {
    position: absolute !important;
    clip: rect(1px,1px,1px,1px);
    width: 1px;
    height: 1px;
    overflow: hidden;
    word-wrap: normal !important
}
 
/* RESPONSIVE */
@media(max-width: 1024px) {
    .foot-grid {
        grid-template-columns:1fr 1fr
    }
 
    .sec {
        padding: 52px 32px
    }
 
    .site-main {
        padding: 42px 32px
    }
}
 
@media(max-width: 768px) {
    .main-nav {
        display:none;
        flex-direction: column;
        align-items: flex-start;
        padding: 0 24px 12px
    }
 
    .main-nav.open {
        display: flex
    }
 
    .main-nav ul {
        flex-direction: column;
        align-items: stretch;
        width: 100%;
        gap: 0
    }
 
    .main-nav li>a {
        padding: 10px 0;
        border-bottom: 1px solid var(--border)
    }
 
    .main-nav .sub-menu {
        position: static;
        opacity: 1;
        visibility: visible;
        transform: none;
        border: none;
        background: #111;
        display: none;
        margin-left: 12px
    }
 
    .main-nav li:hover>.sub-menu,.main-nav li.open>.sub-menu {
        display: block
    }
 
    .mob-btn {
        display: flex
    }
 
    .hdr-top {
        padding: 10px 20px
    }
 
    .hdr-links {
        display: none
    }
 
    .foot-grid {
        grid-template-columns: 1fr;
        padding: 36px 20px 20px
    }
 
    .foot-btm {
        flex-direction: column;
        gap: 12px;
        padding: 16px 20px;
        text-align: center
    }
 
    .sec,.site-main {
        padding: 32px 20px
    }
}
 
/* WC ARCHIVE GRID handles Elementor wc-archive-products widget (no ul.products) */
.woocommerce.columns-4,.elementor-wc-products .woocommerce {
    width: 100%;
    max-width: 100%;
    display: grid !important;
    grid-template-columns: repeat(4,1fr) !important;
    gap: 18px !important;
    list-style: none;
    margin: 0;
    padding: 0
}
 
.elementor-wc-products {
    width: 100%;
    max-width: 100%
}
 
.woocommerce.columns-4>.product,.elementor-wc-products .woocommerce>.product,.woocommerce.columns-4 li.product,.elementor-wc-products .woocommerce li.product {
    width: auto !important;
    margin: 0 !important;
    padding: 0;
    background: #000;
    border: 1px solid #e5e5e5;
    transition: transform .25s,border-color .25s;
    float: none !important;
    display: block;
    position: relative;
    box-shadow: 0 1px 4px rgba(0,0,0,.06)
}
 
.woocommerce.columns-4>.product:hover,.elementor-wc-products .woocommerce>.product:hover {
    transform: translateY(-5px);
    border-color: var(--red)
}
 
.woocommerce.columns-4>.product a,.elementor-wc-products .woocommerce>.product a {
    color: #222;
    text-decoration: none;
    display: block
}
 
.woocommerce.columns-4>.product img,.elementor-wc-products .woocommerce>.product img {
    aspect-ratio: 310/370;
    object-fit: cover;
    width: 100%;
    margin: 0 !important;
    background: #fff;
    display: block
}
 
.woocommerce.columns-4 .woocommerce-loop-product__title,.elementor-wc-products .woocommerce-loop-product__title {
    padding: 13px 15px 6px !important;
    font-family: var(--H);
    font-size: .9rem !important;
    font-weight: 500 !important;
    text-transform: uppercase;
    line-height: 1.3;
    color: #fff;
}
 
.woocommerce.columns-4 .price,.elementor-wc-products .price {
    padding: 0 15px 13px;
    color: green !important;
    font-family: var(--H);
    font-size: 1.2rem !important;
    display: block
}
 
.woocommerce.columns-4 .price ins,.elementor-wc-products .price ins {
    background: none;
    color: var(--red);
    text-decoration: none
}
 
.woocommerce.columns-4 .price del,.elementor-wc-products .price del {
    font-size: 0.8em;
    margin-right: 6px;
    color: #fff !important;
}
 
.woocommerce.columns-4 .button,.elementor-wc-products .button {
    display: block;
    margin: 0 15px 15px;
    text-align: center;
    font-size: .92rem !important;
    padding: 9px 14px !important;
    background-color: #a31111;
    color: #fff;
    font-weight: 500 !important;
}
 
.woocommerce.columns-4 .onsale,.elementor-wc-products .onsale {
    background: var(--red) !important;
    color: #fff !important;
    border-radius: 0 !important;
    font-family: var(--H);
    letter-spacing: .08em;
    text-transform: uppercase;
    font-size: .7rem;
    font-weight: 700;
    min-height: auto;
    min-width: auto;
    padding: 3px 9px;
    line-height: 1.2;
    margin: 0 !important;
    top: 11px !important;
    left: 11px !important;
    right: auto !important;
    position: absolute !important
}
 
/* The WPC Filters button container is a sibling keep it out of the grid flow */
.woocommerce.columns-4 .wpc-filters-open-button-container {
    grid-column: 1/-1
}
 
/* Grid navigation elements span full width */
.woocommerce.columns-4>.woocommerce-result-count,.woocommerce.columns-4>.woocommerce-ordering,.woocommerce.columns-4 .woocommerce-notices-wrapper,.woocommerce.columns-4 .woocommerce-pagination,.woocommerce.columns-4 nav.woocommerce-pagination,.elementor-wc-products .woocommerce-result-count,.elementor-wc-products .woocommerce-ordering,.elementor-wc-products .woocommerce-notices-wrapper,.elementor-wc-products .woocommerce-pagination,.elementor-wc-products nav.woocommerce-pagination {
    grid-column: 1/-1;
}
 
@media(max-width: 1280px) {
    .woocommerce.columns-4,.elementor-wc-products .woocommerce {
        grid-template-columns:repeat(3,1fr) !important
    }
}
 
@media(max-width: 768px) {
    .woocommerce.columns-4,.elementor-wc-products .woocommerce {
        grid-template-columns:repeat(2,1fr) !important
    }
}
 
@media(max-width: 480px) {
    .woocommerce.columns-4,.elementor-wc-products .woocommerce {
        grid-template-columns:1fr !important
    }
}
 
/* SINGLE PRODUCT light/white theme override (only on single product pages) */
body.single-product {
    background-image: url('assets/img/shop-camo-bg.jpg') !important;
    background-color: #0d0d0d !important;
    background-size: cover !important;
    background-position: center top !important;
    background-attachment: fixed !important;
    background-repeat: no-repeat !important;
    color: #fff
}
 
body.single-product .site-main,body.single-product main.site-main {
    background: #fff !important;
    color: #222;
    padding: 42px 48px;
    max-width: 1400px;
    margin: 40px auto;
    box-shadow: 0 10px 40px rgba(0,0,0,.5)
}
 
body.single-product .entry {
    color: #222
}
 
body.single-product .page-hero {
    background: #000;
    border-top: 3px solid var(--red);
    border-bottom: 1px solid darkgoldenrod;
    color: #fff !important;
}
 
body.single-product .page-hero h1 {
    color: #fff;
}
 
body.single-product .woocommerce-breadcrumb {
    color: #FDFBD4
}
 
body.single-product .woocommerce-breadcrumb a {
    color: var(--red)
}
 
body.single-product .woocommerce-breadcrumb a:hover {
    color: #222
}
 
body.single-product .woocommerce div.product .product_title {
    color: #222
}
 
body.single-product .woocommerce div.product p.price,body.single-product .woocommerce div.product span.price {
    color: var(--red) !important
}
 
body.single-product .woocommerce div.product .price del {
    color: #999
}
 
body.single-product .woocommerce div.product .woocommerce-product-details__short-description {
    color: #444
}
 
body.single-product .woocommerce div.product .quantity input {
    background: #fff;
    border: 1px solid #ccc;
    color: #222
}
 
body.single-product .woocommerce div.product label {
    color: #222
}
 
body.single-product .woocommerce div.product .variations th,body.single-product .woocommerce div.product .variations td {
    color: #222;
    background: transparent
}
 
body.single-product .woocommerce div.product table.variations select {
    background: #fff;
    border: 1px solid #ccc;
    color: #222
}
 
/* Variation swatches (size/color buttons) readable on white */
body.single-product .cfvsw-swatches-option,body.single-product .variable-items-wrapper li,body.single-product .woo-variation-swatches .variable-items-wrapper li {
    background: #fff !important;
    border: 1px solid #ccc !important;
    color: #222 !important
}
 
body.single-product .cfvsw-swatches-option.cfvsw-selected,body.single-product .variable-items-wrapper li.selected,body.single-product .woo-variation-swatches .variable-items-wrapper li.selected {
    background: #000 !important;
    color: #fff !important;
    border-color: #a31111 !important
}
 
body.single-product .cfvsw-swatches-option:hover,body.single-product .variable-items-wrapper li:hover {
    border-color: var(--red) !important;
    background: #000 !important;
    color: #fff !important

}
 
body.single-product .product_meta,body.single-product .product_meta a,body.single-product .sku_wrapper,body.single-product .posted_in,body.single-product .tagged_as {
    color: #fff;
    width: 100%;
    font-size: 14px;
}
 
body.single-product .product_meta a {color: gold;}
 
body.single-product .product_meta a:hover {
    color: #222
}
 
body.single-product .woocommerce-tabs ul.tabs {
    border-bottom: 1px solid #e5e5e5 !important
}
 
body.single-product .woocommerce-tabs ul.tabs li a {
    color: #fff !important;
}
 
body.single-product .woocommerce-tabs ul.tabs li.active {
    border-bottom-color: var(--red) !important;
    background: #a31111 !important;
    color: #fff !important;
}
 
body.single-product .woocommerce-tabs .panel {
    color: #000 !important;
    background: rgb(255 255 255 / 50%);
    padding: 10px 20px !important;
    font-family: 'Black Ops One';
}
 
body.single-product .woocommerce-tabs .panel h2,body.single-product .woocommerce-tabs .panel h3 {
    color: #000 !important;
    font-family: 'Black Ops One';
}
 
body.single-product .related>h2,body.single-product .upsells>h2 {
    color: #fff;
margin-left:1.5%

}
 
body.single-product .related .product,body.single-product .upsells .product {
    background: #fff !important;
    border: 1px solid #e5e5e5 !important
}
 
body.single-product .related .product .woocommerce-loop-product__title,body.single-product .upsells .product .woocommerce-loop-product__title {
    color: #222 !important
}
 
body.single-product .related .product .price,body.single-product .upsells .product .price {
    color: #444 !important
}
 
body.single-product .related .product .price ins,body.single-product .upsells .product .price ins {
    color: var(--red)
}
 
body.single-product .woocommerce-product-gallery {
    background: #fff
}
 
body.single-product .woocommerce-product-gallery img {
    background: #fff
}
 
/* --- Option A: full product content as a floating white card --- */
body.single-product .site-main,body.single-product main.site-main {
    border-radius: 6px;
    overflow: hidden
}
 
/* Keep summary, tabs, and related products contained within the card */
body.single-product .woocommerce div.product,body.single-product .woocommerce-tabs,body.single-product .related,body.single-product .upsells {
    width: 100%;
    max-width: 100%;
}
 
/* Card-internal section dividers for visual rhythm on white */
body.single-product .woocommerce-tabs {
    margin-top: 48px;
    padding-top: 32px;
    border-top: 1px solid #e5e5e5
}
 
body.single-product .related,body.single-product .upsells {
    margin-top: 48px;
    padding-top: 32px;
    border-top: 1px solid #e5e5e5;
    clear: both
}
 
body.single-product .related>h2,body.single-product .upsells>h2 {
    font-family: var(--H);
    text-transform: uppercase;
    letter-spacing: .04em
}
 
/* Stock status, ratings, and misc text must stay readable on white */
body.single-product .woocommerce div.product .stock,body.single-product .woocommerce div.product .woocommerce-product-rating,body.single-product .woocommerce div.product .woocommerce-review-link,body.single-product .woocommerce-Reviews,body.single-product .woocommerce-Reviews .comment-text,body.single-product .woocommerce #reviews #comments h2 {
    color: #444
}
 
body.single-product .woocommerce div.product .stock.in-stock {
    color: #2e7d32
}
 
body.single-product .woocommerce div.product .stock.out-of-stock {
    color: var(--red)
}
 
/* ============================================
   SHOP SIDEBAR LAYOUT (archive / category pages)
   ============================================ */
.shop-layout {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 36px;
    padding: 56px 48px;
    min-height: 60vh;
    width: 100%;
    max-width: 100%;
    color: #eee
}
 
.shop-layout .shop-sidebar {
    position: sticky;
    top: 120px;
    align-self: start;
    max-height: calc(100vh - 140px);
    overflow-y: auto
}
 
.shop-layout .shop-sidebar .widget {
    margin-bottom: 24px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--border)
}
 
.shop-layout .shop-sidebar .widget:last-child {
    border-bottom: none
}
 
.shop-layout .shop-sidebar .widget-title {
    font-family: var(--H);
    font-size: .82rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--gold);
    margin-bottom: 12px
}
 
.shop-layout .shop-sidebar ul {
    list-style: none;
    padding: 0;
    margin: 0
}
 
.shop-layout .shop-sidebar ul li {
    padding: 5px 0;
    font-family: var(--B);
    font-size: .9rem;
    color: #ccc
}
 
.shop-layout .shop-sidebar ul li a {
    color: #ccc;
    text-decoration: none;
    transition: color .2s
}
 
.shop-layout .shop-sidebar ul li a:hover {
    color: var(--red)
}
 
.shop-layout .shop-content {
    min-width: 0
}
 
.shop-layout .shop-content .site-main {
    padding: 0
}
 
@media (max-width: 1024px) {
    .shop-layout {
        grid-template-columns: 220px 1fr;
        gap: 24px;
        padding: 36px 32px
    }
}
 
@media (max-width: 768px) {
    .shop-layout {
        grid-template-columns: 1fr;
        padding: 32px 20px
    }
 
    .shop-layout .shop-sidebar {
        position: static;
        max-height: none;
        border-bottom: 2px solid var(--border);
        padding-bottom: 24px;
        margin-bottom: 12px
    }
}
 
/* ============================================
   HOME PAGE bg image fills behind NicePage content
   ============================================ */
body.home .site-main {
    background: transparent;
    padding-left: 0;
    padding-right: 0;
    padding-top: 0;
}

/* ============================================
   BRAND DESCRIPTION ([custom_brand_description])
   Readable card on the camo brand-archive background
   ============================================ */
.tvs-brand-description {
    background: rgba(13,13,13,.78);
    border-left: 3px solid var(--gold);
    padding: 18px 22px;
    margin: 0 0 28px;
    color: #e8e8e8;
    line-height: 1.7;
    border-radius: 4px
}

.tvs-brand-description p {
    color: #e8e8e8;
    margin-bottom: .8em
}

.tvs-brand-description p:last-child {
    margin-bottom: 0
}

.tvs-brand-description a {
    color: var(--gold);
    text-decoration: underline
}

.tvs-brand-description a:hover {
    color: #fff
}

/* ============================================
   CUSTOMIZE PRODUCT TITLES 
   ============================================ */
.woocommerce div.product .product_title {
    clear: none;
    margin-top: 0;
    padding: 0;
    /* box-shadow: inset 0px 20px 20px 5px rgba(255, 255, 255, 0.5); */
    color: #fff!important;
    font-weight: 700 !important;
   -webkit-text-stroke: .5px #C9A020;
    font-family: 'Black Ops One', 'Oswald', sans-serif;
    letter-spacing: normal;
    padding: 10px 5px;
}

/* ============================================
   CUSTOMIZE SALES PRICE COLOR
   ============================================ */
.custom-sale-price{
    color: lawngreen;
    font-size: 20px;
}





.woocommerce div.product .woocommerce-tabs ul.tabs li {
    border: 1px solid #cfc8d8;
    background-color: #000;
    color: #fff;
    display: inline-block;
    position: relative;
    z-index: 0;
    border-radius: 4px 4px 0 0;
    margin: 0 -5px;
    padding: 0 1em;
}
.woocommerce:where(body:not(.woocommerce-block-theme-has-button-styles)) button.button.alt {
background-color:green !important;
}


/* ============================================================================
   SINGLE PRODUCT PAGE ENHANCEMENTS  (scoped to body.single-product only)
   - framed product gallery
   - persistent selected variation swatches
   - Black Ops One product title
   - related products as a horizontal slider (overrides the global 165% grid)
   ============================================================================ */

/* 1) Transparent product images, floating on the camo --------------------- */
/* Backgrounds are now removed (transparent PNGs), so the gallery sits directly
   on the camo. No frame/fill/vignette â€” any background here would show THROUGH
   the cut-out shirts. Just a soft drop-shadow so the product lifts off the bg. */
body.single-product .woo-variation-gallery-slider-wrapper,
body.single-product .woocommerce div.product .woocommerce-product-gallery {
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
}

body.single-product .woo-variation-gallery-slider .wvg-single-gallery-image-container img,
body.single-product .woocommerce div.product .woocommerce-product-gallery__image img {
    filter: drop-shadow(0 6px 14px rgba(0,0,0,.45));
}

/* Thumbnail strip: gold highlight on the active / hovered thumbnail */
body.single-product .woo-variation-gallery-thumbnail-wrapper {
    margin-top: 14px;
}

body.single-product .woo-variation-gallery-thumbnail-image img,
body.single-product .woocommerce div.product .flex-control-thumbs li img {
    border: 2px solid transparent;
    border-radius: 3px;
    transition: border-color .2s;
}

body.single-product .woo-variation-gallery-thumbnail-slider .slick-current .wvg-gallery-thumbnail-image img,
body.single-product .woo-variation-gallery-thumbnail-image img:hover,
body.single-product .woocommerce div.product .flex-control-thumbs li img.flex-active,
body.single-product .woocommerce div.product .flex-control-thumbs li img:hover {
    border-color: var(--gold);
}

/* 2) Variation swatches (CFVSW) â€” keep the hover look when SELECTED -------- */
/* The selected swatch gets the class .cfvsw-selected-swatch. Match the hover
   styling: black fill, white text, red border. */
body.single-product .cfvsw-swatches-container .cfvsw-swatches-option.cfvsw-selected-swatch,
body.single-product .cfvsw-swatches-option.cfvsw-selected-swatch {
    background: #000 !important;
    border-color: var(--red) !important;
    box-shadow: 0 0 0 1px var(--red) !important;
}

body.single-product .cfvsw-swatches-option.cfvsw-selected-swatch,
body.single-product .cfvsw-swatches-option.cfvsw-selected-swatch .cfvsw-swatch-inner {
    color: #fff !important;
}

/* Keep the inner label white on hover too. */
body.single-product .cfvsw-swatches-option:hover,
body.single-product .cfvsw-swatches-option:hover .cfvsw-swatch-inner {
    background: #000 !important;
    color: #fff !important;
    border-color: var(--red) !important;
}

/* 3) Product title in Black Ops One (matches the homepage brand title) ----- */
body.single-product .woocommerce div.product .product_title {
    font-family: 'Black Ops One', var(--H), sans-serif !important;
    letter-spacing: normal !important;
}

/* 4) Related / up-sells â€” auto-scrolling carousel on a dark band ----------- */
/* Breaks out of the white product card into a full-width dark strip; items are
   transparent (no white boxes), light text. theme.js auto-scrolls + pauses on
   hover. (.site-main has overflow:hidden, so the negative margins clip cleanly
   to the card edges.) */
body.single-product .related,
body.single-product .up-sells,
body.single-product .upsells {
    background: #111;
    padding: 30px 40px 34px;
    border-top: 3px solid var(--red);
    clear: both;
    overflow: hidden;
}

body.single-product .related > h2,
body.single-product .up-sells > h2,
body.single-product .upsells > h2 {
    color: #fff !important;
    font-family: 'Black Ops One';
    text-transform: uppercase;
    letter-spacing: .04em;
    margin: 0 0 18px !important;
    padding: 0 !important;
}

body.single-product .related ul.products,
body.single-product .up-sells ul.products,
body.single-product .upsells ul.products {
    display: flex !important;
    grid-template-columns: none !important;
    width: 100% !important;
    max-width: 100%;
    margin: 0 !important;
    padding: 4px 0 8px;
    gap: 16px;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: var(--red) #333;
}

body.single-product .related ul.products > li.product,
body.single-product .up-sells ul.products > li.product,
body.single-product .upsells ul.products > li.product {
    flex: 0 0 190px;
    width: 190px;
    min-width: 190px;
    margin: 0 !important;
    padding: 0 0 12px !important;
    float: none !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

body.single-product .related ul.products > li.product img,
body.single-product .up-sells ul.products > li.product img,
body.single-product .upsells ul.products > li.product img {
    width: 100%;
    margin: 0 0 10px !important;
    display: block;
    background: transparent !important;
    filter: drop-shadow(0 5px 10px rgba(0,0,0,.5));
}

body.single-product .related ul.products > li.product .woocommerce-loop-product__title,
body.single-product .up-sells ul.products > li.product .woocommerce-loop-product__title,
body.single-product .upsells ul.products > li.product .woocommerce-loop-product__title {
    padding: 0 4px 6px;
    font-family: var(--H);
    font-size: .86rem;
    text-transform: uppercase;
    line-height: 1.3;
    color: #eee !important;
}

body.single-product .related ul.products > li.product .price,
body.single-product .up-sells ul.products > li.product .price,
body.single-product .upsells ul.products > li.product .price {
    padding: 0 4px 10px;
    display: block;
    color: #ccc !important;
}

body.single-product .related ul.products > li.product .custom-regular-price,
body.single-product .related ul.products > li.product .custom-regular-price del {
    color: #999 !important;
}

body.single-product .related ul.products > li.product .button,
body.single-product .up-sells ul.products > li.product .button,
body.single-product .upsells ul.products > li.product .button {
    display: block;
    margin: 0 4px;
    text-align: center;
    background: var(--red);
    color: #fff !important;
    font-family: var(--H);
    text-transform: uppercase;
    letter-spacing: .06em;
    font-size: .78rem;
    padding: 9px 10px;
}

body.single-product .related ul.products::-webkit-scrollbar,
body.single-product .up-sells ul.products::-webkit-scrollbar,
body.single-product .upsells ul.products::-webkit-scrollbar {
    height: 8px;
}

body.single-product .related ul.products::-webkit-scrollbar-track,
body.single-product .up-sells ul.products::-webkit-scrollbar-track,
body.single-product .upsells ul.products::-webkit-scrollbar-track {
    background: #333;
    border-radius: 4px;
}

body.single-product .related ul.products::-webkit-scrollbar-thumb,
body.single-product .up-sells ul.products::-webkit-scrollbar-thumb,
body.single-product .upsells ul.products::-webkit-scrollbar-thumb {
    background: var(--red);
    border-radius: 4px;
}

@media (max-width: 768px) {
    body.single-product .related,
    body.single-product .up-sells,
    body.single-product .upsells {
        margin: 32px -20px -28px;
        padding: 24px 20px;
    }
}








.woocommerce #content div.product div.summary, .woocommerce div.product div.summary, .woocommerce-page #content div.product div.summary, .woocommerce-page div.product div.summary {
    width: 65%;
}

.woo-variation-product-gallery {
    max-width: 35% !important;
    width: 100%;
}

/* Single product: replace the WooCommerce "Sale!" ribbon with sale.png */
body.single-product span.onsale {
    background: transparent url('assets/img/sale.png') center / contain no-repeat !important;
    width: 90px;
    height: 90px;
    min-width: 0 !important;
    min-height: 0 !important;
    margin-left: 8% !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    font-size: 0 !important;      /* hides the "Sale!" text */
    line-height: 0 !important;
    color: transparent !important;
    text-indent: -9999px;
    overflow: hidden;
}

