:root {
    --theme-color: #000000;
    --theme-color-light: rgba(6,87,60, 0.15);
    --theme-color-lighter: rgba(6,87,60, 0.08);
    --theme-color-dark: rgba(6,87,60, 1.2);
}

.theme-color {color: #000000;}
.theme-color-light {color: rgba(6,87,60, 0.15);}
.theme-color-dark {color: rgba(6,87,60, 1.2);}
.theme-color-alt {color: #7fa092;}

.theme-bg {background-color: #000000 !important;}
.theme-bg-dark {background-color: rgba(6,87,60, 1.2);}
.theme-bg-light {background-color: rgba(0,0,0, 0.15);}
.theme-bg-alt {background-color: #7fa092;}

.theme-br {border-color: #06573C;}
.theme-brl {border-left-color: #06573C !important;}

.bg-active {
    background-color: var(--theme-color);
    color: #FFFFFF;
}


*:not(i), .poppins {
    font-family: "Poppins", sans-serif !important;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;

    -webkit-font-smoothing: antialiased;   /* Chrome, Safari */
    -moz-osx-font-smoothing: grayscale;    /* Firefox on macOS */
    text-rendering: optimizeLegibility;
}


/**/

html, body {
    height: 100%;
    min-height: 100vh;
}



.central {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    float: none;
}

.header-outline-none {border-bottom: none !important;}
.footer-outline-none {border-top: none !important;}

.sw-breadcrumb-link {color: var(--theme-color)}
.phone-cascade {max-height: 20rem !important; overflow-y: auto}


.google-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: .5rem .75rem;
    border: 1px solid #dcdcdc;
    border-radius: 4px;
    background-color: white;
    color: #5f6368;
    font-size: 14px;
    cursor: pointer;
    transition: background-color 0.2s ease-in-out;
    text-decoration: none;
    box-sizing: border-box;
}

.google-btn:hover {
    background-color: #f7f7f7;
}

.google-icon {
    width: 20px;
    height: 20px;
    margin-right: 12px;
}

.auth-bg {
    background: linear-gradient(135deg, #000000 0%, #1c1c1c 50%, #000000 100%);
    height: 100vh;
}

.centered {
    display: grid;
    place-items: center;
    height: 100%;
}

/*.search-input {
    width: 375px !important;
}*/

.sw-carousel-captions {
    position: absolute;
}

.caption-left {
    top: 50%;
    left: 20px;
    padding: 10px;
    transform: translateY(-50%);
}

.caption-right {
    position: absolute;
    top: 50%;
    right: 20px;
    padding: 10px;
    transform: translateY(-50%);
    text-align: right;
}

.caption-center {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
}

.caption-bottom {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    padding: 10px;
    text-align: center;
}

.carousel-item-height {
    max-height: 450px !important;
}

.carousel-item-height img {
    height: 450px !important;
    width: 100%;
    object-fit: cover;
}

/*

 */

/* Ensure the dropdown content can hold absolute children */


.sw-dropdown-show {
    display: flex;
    flex-direction: column;
}


/* Position the nested dropdown relative to its parent link/container */
.sw-dropdown[data-placement="right"] {
    position: relative;
}

/* Push sub-menus to the right of the current dropdown */
.sw-dropdown[data-placement="right"] > .sw-dropdown-content {
    top: 0;
    left: 100%; /* Positions it exactly to the right */
    margin-left: 0;
    display: none; /* Keep hidden until toggled/hovered */
}

/* Show on hover (if your JS doesn't handle the 'open' class) */
.sw-dropdown[data-placement="right"]:hover > .sw-dropdown-content {
    display: block;
}



/* Visual cue for subcategories (arrow) */
.sw-dropdown-link.sw-dropdown-toggler::after {

    float: right;
    margin-left: 10px;
}

.navbar-fixed {
    position: fixed;
    top: 0;
    left: 0;
}

.admin-slide-panel {
    height: 450px;
}

.admin-slide-panel img {
    height: 200px;
    object-fit: cover;
}

/**/

.product-card img {
    width: 100% !important;
    height: 200px !important;
    object-fit: cover !important;
}


.product-icon-overlay {
    background: none;
    position: absolute;
    top: 55%;
    width: 100%;
    transform: translate(-50%, -50%);
    opacity: 0;
    z-index: 10; /* make sure it appears above content */
    transition: all 0.48s ease;
    text-align: center; /* if you have icons/text inside */
}

.product-icon-overlay li {
    display: inline-block
}


.product-icon-overlay li:not(:last-child) {
    margin-right: 5px
}


.product-card:hover .product-icon-overlay {
    opacity: 1;
    z-index: 1;
    transform: translateY(0)
}

.soldOut {
    opacity: 0.5;
    pointer-events: none;
    position: relative;
}

.soldOut::before {
    content: "SOLD OUT";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 1.25rem;
    font-weight: bold;
    color: #fff;
    background-color: rgba(0, 0, 0, 0.7);
    padding: 10px 20px;
    border-radius: 5px;
    text-align: center;
    z-index: 10;
}

.soldOut .product-card img {
    filter: grayscale(100%) blur(2px);
}

.soldOut .aval-heading {
    font-size: 1.5rem;
    font-weight: bold;
    color: red;
}

.cart-img {
    width: 100px;
    height: 100px;
    object-fit: cover;
}

.cart-img-soldOut {
    filter: grayscale(100%)
}

/*div[data-thumb] {position: relative}*/
/*div[data-thumb] img {width: 100%; height: 445px; object-fit: fill}*/

div[data-thumb] {
    position: relative;
    width: 100%;
    height: 120px; /* choose your thumbnail height */
    overflow: hidden;
    margin-bottom: 10px;
}

div[data-thumb] img {
    width: 100%;
    height: 445px;
    object-fit: cover; /* keeps proportions, crops nicely */
    display: block;
}



/*.product-card:hover .card-product__title a {
    color: #384aeb
}*/

.badge:empty {display: none;}
.sw-modal-scroll-v .sw-modal-content {
    overflow-y: auto;
    max-height: 80%;
    height: 70vh;
}

/*

 */

.qty-wrapper {
    display: inline-flex;
    align-items: center;
    border: 1px solid #ccc;
    /*border-radius: 6px;*/
    overflow: hidden;
    width: fit-content;
    background: #fff;
}

.qty-btn {
    width: 38px;
    height: 38px;
    border: none;
    background: #f5f5f5;
    font-size: 20px;
    cursor: pointer;
    user-select: none;
}

.qty-btn:hover {
    background: #e9e9e9;
}

.qty-input {
    width: 50px;
    height: 38px;
    text-align: center;
    border: none;
    outline: none;
    font-size: 16px;
}

/* Remove number arrows */
.qty-input::-webkit-inner-spin-button,
.qty-input::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
.qty-input {
    -moz-appearance: textfield;
}


/*

 */

.search-field {
    /*display: none;*/
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 100%;
    max-width: 500px;
    list-style: none;
    background: #fff;
    border-top: none;
    z-index: 999;
    box-shadow: 0 8px 12px rgba(0, 0, 0, 0.1);
}

.search-field ul {
    margin: 0;
    padding: 0;
}

.search-field li {
    padding: 10px 15px;
    cursor: pointer;
    border-bottom: 1px solid #f1f1f1;
}

.search-field li a {
    text-decoration: none;
    color: #333;
}

.search-field li:hover {background-color: #f9f9f9;}

.add-to-cart:disabled {
    background-color: #868e96 !important;
    color: #FFFFFF !important;
    cursor: not-allowed;
}

.sw-rating i {
    color: #ccc;
    cursor: pointer;
    transition: color 0.2s;
}

.sw-rating i.filled {
    color: gold;
}

.cat-block img {
    margin-left: auto;
    margin-right: auto;
    width: 100%;
    height: 145px;
    object-fit: cover;
    transition: transform 0.35s ease
}

.cat-block:hover img {
    transform: translateY(-14px)
}

.cat-block:hover figure span:after {
    opacity: 1
}

.panel-min-height {
    min-height: 200px;
}

.sw-overlay {
    position: absolute;
    z-index: 3;
    top: 0;
    left: 0;
    display: inline-block;
    transform:translateY(-135%); -webkit-transform:translateY(-135%);
    background:rgba(255,255,255,0.8);
    width: 300px;
    margin-top: 0;
}


@media screen and (max-width: 764px) {

    .carousel-item-height {
        max-height: 375px !important;
    }

    .carousel-item-height img {
        height: 375px !important;
    }


    .product-card img {
        height: 185px !important;
    }
    .cart-img {
        width: 50px;
        height: 50px;
    }

    .rp3-flex-col {
        flex-direction: column !important;
        -ms-flex-direction: column !important;
    }
}
