/* ToniFunni Viralstyle-Inspired Layout
   Goal: clean POD ecommerce UX with search-left / logo-center / menu-right.
   Does not copy Viralstyle branding/assets.
*/

:root {
    --tf-vs-mint: #55b7aa;
    --tf-vs-text: #1d2939;
    --tf-vs-muted: #667085;
    --tf-vs-border: #e5e7eb;
    --tf-vs-soft: #f7f8fa;
    --tf-vs-white: #ffffff;
}

/* Hide theme default header so our custom header controls the shop look */
#header,
.ct-header,
.site-header,
header#masthead {
    display: none !important;
}

body {
    background: #fff !important;
    color: var(--tf-vs-text);
}

.tf-vs-header {
    display: block !important;
    width: 100%;
    background: #fff;
    border-bottom: 1px solid var(--tf-vs-border);
    z-index: 999;
}

.tf-vs-header__inner {
    max-width: 1280px;
    min-height: 70px;
    margin: 0 auto;
    padding: 0 24px;
    display: grid;
    grid-template-columns: 330px 1fr 430px;
    align-items: center;
    gap: 24px;
}

.tf-vs-header__search {
    justify-self: start;
    width: 100%;
    max-width: 315px;
}

.tf-vs-search {
    display: flex;
    align-items: center;
    height: 42px;
    border: 1px solid #cfd8e3;
    background: #fff;
}

.tf-vs-search__field {
    flex: 1;
    min-width: 0;
    height: 40px;
    border: 0 !important;
    outline: 0 !important;
    padding: 0 14px;
    font-size: 16px;
    color: var(--tf-vs-text);
    background: transparent !important;
    box-shadow: none !important;
}

.tf-vs-search__field::placeholder {
    color: #9aa5b1;
}

.tf-vs-search__button {
    width: 46px;
    height: 40px;
    border: 0;
    background: transparent;
    color: var(--tf-vs-mint);
    font-size: 25px;
    line-height: 1;
    cursor: pointer;
}

.tf-vs-header__brand {
    justify-self: center;
    text-align: center;
}

.tf-vs-logo,
.tf-vs-logo:hover {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: var(--tf-vs-text);
}

.tf-vs-logo img,
.tf-vs-logo .custom-logo {
    max-height: 44px;
    width: auto;
}

.tf-vs-logo-text {
    font-size: 30px;
    line-height: 1;
    font-weight: 800;
    letter-spacing: -0.04em;
    color: var(--tf-vs-text);
}

.tf-vs-header__nav {
    justify-self: end;
    display: flex;
    align-items: center;
    gap: 24px;
    min-width: 0;
}

.tf-vs-menu,
.tf-vs-menu ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.tf-vs-menu {
    display: flex;
    align-items: center;
    gap: 30px;
}

.tf-vs-menu > li {
    position: relative;
    margin: 0;
}

.tf-vs-menu a {
    display: inline-flex;
    align-items: center;
    color: var(--tf-vs-text);
    text-decoration: none;
    font-size: 20px;
    line-height: 1;
    font-weight: 400;
    white-space: nowrap;
}

.tf-vs-menu a:hover {
    color: var(--tf-vs-mint);
}

.tf-vs-menu .menu-item-has-children > a::after {
    content: "⌄";
    display: inline-block;
    margin-left: 7px;
    font-size: 16px;
    color: var(--tf-vs-mint);
}

.tf-vs-menu .sub-menu {
    display: none;
    position: absolute;
    top: calc(100% + 18px);
    right: 0;
    min-width: 220px;
    background: #fff;
    border: 1px solid var(--tf-vs-border);
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.12);
    padding: 10px 0;
    z-index: 1000;
}

.tf-vs-menu li:hover > .sub-menu {
    display: block;
}

.tf-vs-menu .sub-menu a {
    display: block;
    padding: 12px 18px;
    font-size: 15px;
    line-height: 1.2;
}

.tf-vs-cart {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--tf-vs-text);
    text-decoration: none;
    font-size: 20px;
}

.tf-vs-cart__count {
    position: absolute;
    top: -9px;
    right: -12px;
    min-width: 18px;
    height: 18px;
    border-radius: 999px;
    background: var(--tf-vs-mint);
    color: #fff;
    font-size: 11px;
    line-height: 18px;
    text-align: center;
    font-weight: 700;
}

.tf-vs-mobile-toggle {
    display: none;
    justify-self: end;
    border: 0;
    background: transparent;
    color: var(--tf-vs-text);
    font-size: 28px;
    cursor: pointer;
}

/* Site container spacing */
.site-main,
#main,
main {
    background: #fff;
}

.woocommerce .ct-container,
.woocommerce-page .ct-container,
.woocommerce .site-main > .ct-container,
.woocommerce-page .site-main > .ct-container {
    max-width: 1280px !important;
}

/* Shop/category title */
.woocommerce-products-header__title,
.woocommerce .page-title,
.archive.woocommerce .page-title {
    font-size: 32px !important;
    font-weight: 700 !important;
    color: var(--tf-vs-text) !important;
    letter-spacing: -0.02em;
    margin: 22px 0 44px !important;
}

.woocommerce-result-count,
.woocommerce-ordering {
    display: none !important;
}

/* Product archive grid */
.woocommerce ul.products,
.woocommerce-page ul.products {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 64px 56px;
    margin: 0 !important;
}

.woocommerce ul.products::before,
.woocommerce ul.products::after {
    display: none !important;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
    float: none !important;
    width: auto !important;
    clear: none !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    border: none !important;
    text-align: left !important;
}

.woocommerce ul.products li.product a.woocommerce-LoopProduct-link,
.woocommerce ul.products li.product a.woocommerce-loop-product__link {
    display: block;
    text-decoration: none;
}

.woocommerce ul.products li.product a img {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    aspect-ratio: 1 / 1;
    object-fit: contain;
    background: #fff;
    margin: 0 0 24px !important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce-loop-product__title {
    font-size: 21px !important;
    line-height: 1.18 !important;
    font-weight: 400 !important;
    color: var(--tf-vs-text) !important;
    padding: 0 !important;
    margin: 0 0 12px !important;
    text-transform: none !important;
    letter-spacing: normal !important;
}

.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price {
    display: block;
    font-size: 18px !important;
    line-height: 1.2 !important;
    font-weight: 500 !important;
    color: var(--tf-vs-mint) !important;
}

.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .added_to_cart {
    display: none !important;
}

.woocommerce span.onsale {
    background: #ff4d4f !important;
    color: #fff !important;
    border-radius: 999px !important;
    min-width: 52px !important;
    min-height: 52px !important;
    line-height: 52px !important;
    padding: 0 !important;
    font-size: 12px !important;
    font-weight: 800 !important;
}

/* Single product page */
.single-product .woocommerce-breadcrumb {
    max-width: 1280px;
    margin: 0 auto 24px !important;
    padding: 0 24px;
    font-size: 13px;
    color: #98a2b3;
}

.single-product div.product {
    max-width: 1280px;
    margin: 38px auto 0 !important;
    padding: 0 24px;
    display: grid !important;
    grid-template-columns: minmax(0, 1.05fr) minmax(420px, 0.95fr);
    gap: 56px;
    align-items: start;
}

.single-product div.product::before,
.single-product div.product::after {
    display: none !important;
}

.single-product div.product div.images,
.single-product div.product div.summary {
    float: none !important;
    width: 100% !important;
    clear: none !important;
}

/* Gallery: vertical thumbs when possible */
.single-product div.product div.images.woocommerce-product-gallery {
    display: grid;
    grid-template-columns: 74px minmax(0, 1fr);
    gap: 22px;
    align-items: start;
}

.single-product .woocommerce-product-gallery__wrapper {
    grid-column: 2;
    grid-row: 1;
}

.single-product div.product div.images .flex-control-thumbs {
    grid-column: 1;
    grid-row: 1;
    display: flex !important;
    flex-direction: column;
    gap: 14px;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none;
}

.single-product div.product div.images .flex-control-thumbs li {
    width: 74px !important;
    height: 74px;
    margin: 0 !important;
    padding: 0 !important;
    border: 1px solid transparent;
}

.single-product div.product div.images .flex-control-thumbs li img {
    width: 72px !important;
    height: 72px !important;
    object-fit: contain;
    border: 1px solid transparent;
    background: #fff;
    padding: 4px;
}

.single-product div.product div.images .flex-control-thumbs li img.flex-active,
.single-product div.product div.images .flex-control-thumbs li img:hover {
    border-color: var(--tf-vs-mint);
}

.single-product div.product div.images img {
    width: 100%;
    height: auto;
    object-fit: contain;
    background: #fff;
}

/* Purchase card */
.single-product div.product div.summary {
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 3px 22px rgba(15, 23, 42, 0.10);
    padding: 36px 42px 42px;
    position: sticky;
    top: 28px;
}

.woocommerce div.product .product_title,
.single-product .product_title {
    font-size: 26px !important;
    line-height: 1.25 !important;
    font-weight: 400 !important;
    color: var(--tf-vs-text) !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    margin: 0 0 14px !important;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price,
.single-product .summary .price {
    display: block;
    font-size: 36px !important;
    line-height: 1.1 !important;
    font-weight: 700 !important;
    color: var(--tf-vs-mint) !important;
    margin: 0 0 28px !important;
}

.woocommerce div.product p.price ins,
.woocommerce div.product span.price ins {
    text-decoration: none !important;
}

.woocommerce div.product p.price del,
.woocommerce div.product span.price del {
    opacity: 0.35;
    font-size: 20px !important;
    color: var(--tf-vs-muted) !important;
}

.woocommerce-product-details__short-description {
    font-size: 16px;
    line-height: 1.6;
    color: var(--tf-vs-muted);
    margin-bottom: 24px;
}

.single-product .product_meta,
.single-product .posted_in,
.single-product .tagged_as,
.single-product .sku_wrapper {
    display: none !important;
}

/* Variations */
.woocommerce div.product form.cart .variations {
    width: 100%;
    margin-bottom: 24px;
}

.woocommerce div.product form.cart .variations tbody,
.woocommerce div.product form.cart .variations tr,
.woocommerce div.product form.cart .variations th,
.woocommerce div.product form.cart .variations td {
    display: block;
    width: 100%;
}

.woocommerce div.product form.cart .variations tr {
    margin-bottom: 24px;
}

.woocommerce div.product form.cart .variations th,
.woocommerce div.product form.cart .variations td {
    padding: 0 !important;
}

.woocommerce div.product form.cart .variations label {
    display: block;
    font-size: 13px;
    line-height: 1;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--tf-vs-text);
    margin: 0 0 10px;
}

.woocommerce div.product form.cart .variations select {
    width: 100%;
    height: 52px;
    border: 1px solid #d0d5dd;
    border-radius: 0;
    padding: 0 16px;
    font-size: 16px;
    color: var(--tf-vs-text);
    background: #fff;
    box-shadow: none !important;
}

.woocommerce div.product form.cart .reset_variations {
    display: inline-block;
    margin-top: 8px;
    color: var(--tf-vs-muted);
    font-size: 13px;
}

.woocommerce-variation-price {
    margin: 0 0 18px;
}

.woocommerce .quantity .qty {
    width: 72px !important;
    height: 52px !important;
    border: 1px solid #d0d5dd !important;
    border-radius: 0 !important;
    font-size: 16px !important;
    box-shadow: none !important;
}

.woocommerce div.product form.cart .button,
.woocommerce button.button,
.woocommerce a.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
    height: 52px !important;
    padding: 0 36px !important;
    background: var(--tf-vs-mint) !important;
    color: #fff !important;
    border-radius: 0 !important;
    border: none !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    box-shadow: none !important;
}

.woocommerce div.product form.cart .button:hover,
.woocommerce button.button:hover,
.woocommerce a.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover {
    background: var(--tf-vs-text) !important;
    color: #fff !important;
}

.woocommerce div.product .woocommerce-tabs {
    max-width: 1280px;
    margin: 70px auto 0 !important;
    padding: 30px 24px 0;
    border-top: 1px solid var(--tf-vs-border);
}

.woocommerce div.product .related.products,
.woocommerce div.product .upsells.products {
    max-width: 1280px;
    margin: 70px auto 0 !important;
    padding: 0 24px;
}

/* Cart & checkout simple */
.woocommerce-cart .entry-content,
.woocommerce-checkout .entry-content,
.woocommerce-account .entry-content {
    max-width: 1100px;
    margin: 0 auto;
    padding: 32px 24px;
}

.woocommerce-cart table.cart,
.woocommerce-checkout form.checkout,
.woocommerce-checkout-review-order,
.woocommerce .cart-collaterals .cart_totals {
    border-color: var(--tf-vs-border) !important;
}

/* Mobile */
@media (max-width: 1024px) {
    .tf-vs-header__inner {
        grid-template-columns: 1fr auto;
        min-height: 64px;
    }

    .tf-vs-header__search,
    .tf-vs-header__nav {
        display: none;
    }

    .tf-vs-header__brand {
        justify-self: start;
    }

    .tf-vs-mobile-toggle {
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    body.tf-vs-menu-open .tf-vs-header__nav {
        display: flex;
        position: fixed;
        top: 64px;
        left: 0;
        right: 0;
        bottom: 0;
        background: #fff;
        z-index: 1001;
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start;
        padding: 28px 24px;
        border-top: 1px solid var(--tf-vs-border);
    }

    body.tf-vs-menu-open .tf-vs-menu {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 24px;
    }

    body.tf-vs-menu-open .tf-vs-menu a {
        font-size: 22px;
    }

    body.tf-vs-menu-open .tf-vs-menu .sub-menu {
        position: static;
        display: block;
        box-shadow: none;
        border: 0;
        padding: 12px 0 0 18px;
    }

    .woocommerce ul.products,
    .woocommerce-page ul.products {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 38px 22px;
    }

    .single-product div.product {
        display: block !important;
        margin-top: 24px !important;
        padding: 0 18px;
    }

    .single-product div.product div.summary {
        position: static;
        box-shadow: none;
        padding: 28px 0;
    }

    .single-product div.product div.images.woocommerce-product-gallery {
        display: block;
    }

    .single-product div.product div.images .flex-control-thumbs {
        display: flex !important;
        flex-direction: row;
        margin-top: 14px !important;
    }

    .woocommerce div.product .product_title,
    .single-product .product_title {
        font-size: 24px !important;
    }

    .woocommerce div.product p.price,
    .woocommerce div.product span.price,
    .single-product .summary .price {
        font-size: 30px !important;
    }
}

@media (max-width: 540px) {
    .tf-vs-header__inner {
        padding: 0 16px;
    }

    .tf-vs-logo-text {
        font-size: 26px;
    }

    .woocommerce ul.products li.product .woocommerce-loop-product__title,
    .woocommerce-loop-product__title {
        font-size: 16px !important;
    }

    .woocommerce ul.products li.product .price,
    .woocommerce-page ul.products li.product .price {
        font-size: 15px !important;
    }

    .woocommerce div.product form.cart .button {
        width: calc(100% - 84px);
    }
}
