/* LC BBQ Style */

/* 1. MODERN RESET & BOX MODEL */
*, *::before, *::after { 
    box-sizing: border-box; 
    -webkit-tap-highlight-color: transparent; 
}

* { 
    margin: 0; 
    padding: 0; 
    font: inherit; 
}

/* 2. DESIGN TOKENS (Variables) */
:root {
    --gold: #DDCA61;
    --dark-gold: #B29B35;
    --light-yellow: #FFF799;
    --black: #000;
    --white: #FFF;
    --red: #FF0013;
    --light-tan: #DBCC91;
    --ember: #FF8C00;
    --dark-ember: #FF4500;
    --font-main: 'Libre Caslon Text', Georgia, serif;
    --font-display: 'Libre Caslon Display', Georgia, serif;
    --base-font-size: clamp(1rem, 0.95rem + 0.25vi, 1.25rem);
    --true-height: 100dvb; 
    --space-md: 1rem;
    --border-thick: 0.125rem;
}

/* 3. GLOBAL HTML/BODY ENGINE */
html {
    scroll-behavior: auto;
    -webkit-text-size-adjust: 100%;
    scrollbar-gutter: stable;
}

html:has(dialog[open]) {
    overflow: hidden;
    overscroll-behavior: contain;
}

body {
    background-color: var(--white);
    color: var(--black);
    font-family: var(--font-main);
    font-size: var(--base-font-size);
    line-height: 1.5;
    min-block-size: var(--true-height);
    display: flex;
    flex-direction: column;
}

main#main-content {
    display: block;
    width: 100%;
}

/* 4. UTILITIES (A11Y & Performance) */
.skip-link {
    position: absolute;
    inset-block-start: -5rem;
    inset-inline-start: var(--space-md);
    background: var(--gold);
    color: var(--black);
    padding: var(--space-md);
    z-index: 1000;
    transition: inset-block-start 0.2s ease;

    &:focus {
        inset-block-start: var(--space-md);
        outline: var(--border-thick) solid var(--gold);
    }
}

.sr-only {
    position: absolute;
    inline-size: 0.0625rem;
    block-size: 0.0625rem;
    padding: 0;
    margin: -0.0625rem;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* 5. HEADER & BRANDING */
.header {
    background: url('img/BlurBG.jpg') no-repeat center 0% / cover;
    width: 100%;
    padding-inline: max(0.375rem, (100% - 85rem) / 2);
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    position: relative;
    z-index: 9999;
    isolation: isolate;
    padding-block: 0.375rem; 
    min-inline-size: 17.5rem;

    .brand-group {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        flex: 0 1 auto;
        padding-inline-start: 0.25rem;
    }

    .nav-actions {
        display: flex;
        align-items: center;
        gap: 0.25rem;
        margin-block-start: -0.5rem;
        margin-inline-end: -0.375rem;
        margin-inline-start: auto; 
    }
}

.site-title {
    margin: 0;
    padding: 0;
    line-height: 0;
    font-size: 1rem;
}

.logo-link {
    display: inline-block;
    line-height: 0;
    text-decoration: none;
    position: relative;
}

.logo-img { 
    block-size: clamp(5rem, 20vi, 7rem); 
    inline-size: auto; 
    display: block; 
    aspect-ratio: 1 / 1;
    will-change: transform, filter;
}

#smokeCanvas, 
.shimmer-layers {
    display: none;
}

.sub-logo-img {
    block-size: clamp(2.5rem, 10vi, 3.5rem);
    inline-size: auto;
    display: block;
    aspect-ratio: 260 / 54;
    margin-block-start: 0.375rem;
}

.tagline {
    color: var(--light-tan);
    font-size: clamp(0.8rem, 3vi, 1rem);
    line-height: 1.2;
    max-inline-size: 25ch;
    text-wrap: balance;
}

/* 6. BUTTONS: TACTILE GOLD ENGINE */
.btn-gold, 
.btn-gold-cat {
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(
        60deg,
        var(--dark-gold) 0%,      
        var(--gold) 35%,          
        var(--light-yellow) 45%,  
        var(--gold) 55%,          
        var(--dark-gold) 100%
    );
    color: var(--black);
    text-decoration: none;
    font-weight: 800;
    font-size: 1.1rem;
    border-radius: 0.5rem;
    border: var(--border-thick) solid var(--dark-gold);
    box-shadow: 
        inset 0.2rem 0.2rem 0.4rem rgb(255 255 255 / 80%), 
        inset -0.2rem -0.2rem 0.4rem rgb(0 0 0 / 30%), 
        0 0.5rem 1rem rgb(0 0 0 / 50%); 
    transition: 
        transform 0.2s cubic-bezier(0.175, 0.885, 0.32, 1.275), 
        filter 0.3s ease, 
        box-shadow 0.2s ease;

    &:active {
        background: linear-gradient(50deg, #8B7B27 0%, var(--dark-gold) 35%, var(--gold) 45%, var(--dark-gold) 55%, #8B7B27 100%);
        transform: scale(0.96) translateY(0.125rem);
        box-shadow: inset 0.3rem 0.3rem 0.6rem rgb(0 0 0 / 50%), 0 0.1rem 0.2rem rgb(0 0 0 / 30%);
        transition: transform 0s;
        filter: brightness(0.9);
    }

    &:focus-visible {
        outline: 0.125rem solid var(--light-yellow);
        outline-offset: 0.1875rem;
    }
}

.btn-gold {
    margin-block-start: 0.75rem;
    padding-block: 0.2rem;
    padding-inline: 0.8rem;
}

.btn-gold-cat {
    inline-size: 7rem;
    block-size: 1.75rem;
    padding-inline: 0;
}

/* 7. NAVIGATION: HAMBURGER & DROPDOWN */
.menu-toggle {
    position: absolute;
    inset-block-start: 0rem;
    inset-inline-end: 3rem;
    z-index: 1001;
    
    background: none;
    border: none;
    padding: 0rem;
    margin-block: 0.5rem;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
    align-self: flex-start;

    &::before {
        content: "";
        position: absolute;
        inset: -0.5rem;
        pointer-events: auto; 
    }
}

.hamburger-line {
    inline-size: 1.7rem;
    block-size: 0.1875rem;
    background-color: var(--gold);
    transition: transform 0.3s ease, opacity 0.3s ease;
    border-radius: 0.125rem;
    filter: drop-shadow(0 0 0.0625rem var(--black)) drop-shadow(0 0 0.0625rem var(--black));
}

.menu-toggle[aria-expanded="true"] {
    .hamburger-line:nth-child(1) { transform: translateY(0.5625rem) rotate(45deg); }
    .hamburger-line:nth-child(2) { opacity: 0; }
    .hamburger-line:nth-child(3) { transform: translateY(-0.5625rem) rotate(-45deg); }
}

.menu-dropdown {
    display: none;
    position: absolute;
    inset-block-start: 2.5rem;       
    inset-inline-end: 0.5rem;   
    background: var(--black);
    border: var(--border-thick) solid var(--gold);
    border-radius: 0.75rem;
    padding: var(--space-md);
    min-inline-size: 12.5rem;
    z-index: 1000;

    &:has(~ .menu-toggle[aria-expanded="true"]),
    .header:has(.menu-toggle[aria-expanded="true"]) & {
        display: block;
    }
}

.menu-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 1rem;

    a, .submenu-toggle {
        color: var(--gold);
        text-decoration: none;
        font-size: 1.1rem;
        transition: color 0.2s;

        &:active { color: var(--light-tan); }
    }
}

.submenu-toggle {
    color: var(--red) !important;
    font-weight: bold;
    background: none;
    border: none;
    text-align: start;
    inline-size: 100%;
    cursor: pointer;
}

.submenu {
    display: none;
    list-style: none;
    padding-inline-start: 1rem;
    margin-block-start: 0.5rem;
    flex-direction: column;
    gap: 0.75rem;

    .submenu-toggle[aria-expanded="true"] + & {
        display: flex;
    }
}

/* 8. Ecwid LC Bag */
.ec-cart-widget { 
    position: fixed;
    inset-block-start: 0rem;
    inset-inline-end: 0rem;
    z-index: 10001;
    margin: 0; 
    transform: scale(1.2);
    display: flex;
    align-items: center;
    justify-content: center;

    &::before {
        content: "";
        position: absolute;
        inset: 0;
        z-index: -1;
        background: rgb(0 0 0 / 70%);
        backdrop-filter: blur(0.25rem);
    clip-path: polygon(
        calc(7% - .0625rem) 0%, 
        calc(93% + .0625rem) 0%, 
        calc(100% + .0625rem) 100%, 
        calc(0% - .0625rem) 100%);
        padding: 0.25rem;
        border-radius: 15%;
        display: flex;
        align-items: center;
        justify-content: center;
        opacity: 0; 
        animation: fade-trapezoid linear forwards;
        animation-timeline: scroll();
        animation-range: 0 20rem;
    }

    img {
        pointer-events: none;
    }
}

@keyframes fade-trapezoid {
    to { opacity: 1; }
}

.nav-actions {
    display: contents;
}

.store-section {
    background-color: var(--light-tan);
    padding-inline: max(0.375rem, (100% - 85rem) / 2);
    padding-block: 2rem;
    display: block;
    width: 100%;
}

/* Rounded Images */
.ec-size .ec-store .details-gallery__thumb-img-wrapper-inner,
.ec-size .ec-store .details-gallery__images-container,
.ec-size .ec-store .grid-product__image,
.ec-size .ec-store .grid-category__image {
    border-radius: 0.75rem !important;
    overflow: hidden !important;
}

/* Rounded Gold Borders */
.ec-size .ec-store .details-gallery__picture,
.ec-size .ec-store .details-gallery__thumb-img-wrapper-inner,
.ec-size .ec-store .grid-product__image,
.ec-size .ec-store .grid-category__image {
    border: var(--border-thick) solid #000000 !important;
    border-radius: 0.75rem !important;
    background: transparent !important;
    overflow: hidden !important;
    box-shadow: 0 0.375rem 0.25rem rgba(0, 0, 0, 0.25) !important;
}

/* Category & Product Titles */
.ec-size .ec-store .grid-category__title-inner {
    font-family: var(--font-main) !important;
    color: var(--black) !important;
    font-weight: 600 !important;
}

/* Product Titles (e.g., HenDrench Brine) */
.ec-size .ec-store .grid-product__title-inner {
    font-family: var(--font-main) !important;
    color: var(--black) !important;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
}

/* Product Prices */
.ec-size .ec-store .grid-product__price-amount {
    font-family: var(--font-main) !important;
    color: var(--black) !important;
    font-size: 1rem !important;
}

/* Rating & Star */
.ec-size .ec-store .grid-product__rating {
    display: flex !important;
    align-items: center !important;
    height: auto !important;
    line-height: 1 !important;
}

.ec-size .ec-store svg path[d^="M5.73 5.735H0"] {
    fill: var(--dark-gold) !important;
}

.ec-size .ec-store .grid-product__rating-text--medium-text {
    color: var(--black) !important;
}

/* Product Page Title */
.ec-size .ec-store .product-details__product-title,
.ec-size .ec-store .ec-header-h3 {
    font-family: var(--font-main) !important;
    color: var(--black) !important;
    font-weight: 600 !important;
    line-height: 1.2 !important;
}

/* Product Details Rating Text Color */
.ec-size .ec-store .product-details__rating-text {
    color: var(--black) !important;
    font-family: var(--font-main) !important;
    font-weight: 700 !important;
}

/* Product Page Star Color */
.ec-size .ec-store .star-rating__item--foreground svg path[d^="M7.64 7.646H0"] {
    fill: var(--dark-gold) !important;
}

/* Ensure the background 'empty' stars stay subtle */
.ec-size .ec-store .star-rating__item--background svg path {
    fill: #e6e6e6 !important;
}

/* 1. Breadcrumb Link Styling (e.g., Store) */
.ec-size .ec-store .breadcrumbs__link.ec-link {
    font-family: var(--font-main) !important;
    color: var(--black) !important;
    font-weight: 700 !important;
    text-decoration: none !important;
}

/* 2. Breadcrumb Delimiter (the > or / separator) */
.ec-size .ec-store .breadcrumbs__delimiter {
    color: var(--black) !important;
    font-weight: bold !important;
    margin-inline: 0.5rem;
}

/* COMBINED RED TEXT + BLACK HOVER */
.ec-size .ec-store [class*="rating-reviews-text"] {
    color: var(--red) !important;
    font-family: var(--font-main) !important;
    font-weight: 500 !important;
    text-decoration: none !important;
}

/* HOVER FOR "SHOW ALL" REVIEWS LINK */
.ec-size .ec-store a.ec-link.review-block__show-reviews[tabindex="0"]:hover {
    color: var(--black) !important;
    cursor: pointer !important;
}

/* KILL DEFAULT BLUE ON "SHOW MORE" LINK */
a.ec-link[href="javascript:;"] {
    font-family: var(--font-main) !important;
    color: var(--red) !important;
    text-decoration: none !important;
    font-weight: 500 !important;
}

a.ec-link[href="javascript:;"]:hover {
    color: var(--black) !important;
}

/* Product Page Price Styling */
.ec-size .ec-store .details-product-price__value.ec-price-item {
    font-family: var(--font-main) !important;
    color: var(--black) !important;
    font-weight: 700 !important;
}

/* Gold Add More & Checkout Buttons */
.ec-size .ec-store .form-control--button .form-control__button {
    cursor: pointer;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-block-size: 2.25rem !important;
    padding: 0 1.25rem !important;
    min-inline-size: auto !important;
    background: linear-gradient(60deg, var(--dark-gold) 0%, var(--gold) 35%, var(--light-yellow) 45%, var(--gold) 55%, var(--dark-gold) 100%) !important;
    color: var(--black) !important;
    font-family: var(--font-main) !important;
    font-weight: 800 !important;
    font-size: 0.8rem !important;
    border-radius: 0.5rem !important;
    border: var(--border-thick) solid var(--dark-gold) !important;
    box-shadow: inset 0.2rem 0.2rem 0.4rem rgb(255 255 255 / 80%), inset -0.2rem -0.2rem 0.4rem rgb(0 0 0 / 30%), 0 0.5rem 1rem rgb(0 0 0 / 50%) !important;
    transition: transform 0.2s cubic-bezier(0.175, 0.885, 0.32, 1.275), filter 0.3s ease, box-shadow 0.2s ease !important;
    text-transform: none !important;
    width: auto !important;
    display: inline-block !important;
}

.ec-size .ec-store .form-control__button-text {
    color: var(--black) !important;
    line-height: 1 !important;
    margin: 0 !important;
}

.ec-size .ec-store .form-control--button .form-control__button:active {
    background: linear-gradient(50deg, #8B7B27 0%, var(--dark-gold) 35%, var(--gold) 45%, var(--dark-gold) 55%, #8B7B27 100%) !important;
    transform: scale(0.96) translateY(0.125rem) !important;
    box-shadow: inset 0.3rem 0.3rem 0.6rem rgb(0 0 0 / 50%), 0 0.1rem 0.2rem rgb(0 0 0 / 30%) !important;
    filter: brightness(0.9) !important;
}

/* Item in the bag & #Available */
.ec-size .ec-store .details-product-purchase__in-bag-text,
.ec-size .ec-store .details-product-purchase__in-bag-text span,
.ec-size .ec-store .details-product-purchase__in-bag-text * {
    color: var(--black) !important;
}

.ec-size .ec-store .details-product-purchase span:not(.details-product-purchase__in-stock-qty) {
    color: var(--black) !important;
}

.ec-size .ec-store .details-product-purchase__in-stock-qty.ec-text-muted {
    color: var(--black) !important;
}

/* Product Details */
.ec-size .ec-store .product-details-module__title,
.ec-size .ec-store .ec-header-h6 {
    font-family: var(--font-main) !important;
    color: var(--black) !important;
    font-weight: 700 !important;
}

/* Product Description */
.ec-size .ec-store .product-details__product-description,
.ec-size .ec-store .product-details__product-description p,
.ec-size .ec-store .product-details__product-description div,
.ec-size .ec-store .product-details__product-description li {
    font-family: var(--font-main) !important;
    color: var(--black) !important;
    line-height: 1.5 !important;
    font-weight: 400 !important;
}

/* 1. Review Section Titles (Main & Subtitle) */
.ec-size .ec-store .review-block__title,
.ec-size .ec-store .review-block__sub-title.ec-text-muted {
    font-family: var(--font-main) !important;
    color: var(--black) !important;
    font-weight: 700 !important;
}

/* 2. Review Description/Comment Text */
.ec-size .ec-store .review-block__description {
    font-family: var(--font-main) !important;
    color: var(--black) !important;
    line-height: 1.5 !important;
    font-weight: 400 !important;
}

/* Target the Review Verification Badge by its path data */
.ec-size .ec-store svg path[d^="M1 2H1.98249"] {
    fill: var(--red) !important;
}

/* Reviewer Info & Review Body Styling */
.ec-size .ec-store .review-item__name,
.ec-size .ec-store .review-item__review,
.ec-size .ec-store .review-item__city,
.ec-size .ec-store .review-item__country,
.ec-size .ec-store .review-item__date {
    font-family: var(--font-main) !important;
    color: var(--white) !important;
    font-weight: 400 !important;
    line-height: 1.4 !important;
}

/* Make the Name bold to stand out */
.ec-size .ec-store .review-item__name {
    font-weight: 700 !important;
}

/* Review Block */
.ec-size .ec-store .review-block {
    background: none !important;
    border: none !important;
    padding: 0 !important;
}

.ec-size .ec-store .review-item {
    background-color: var(--black) !important;
    border: var(--border-thick) solid var(--dark-gold) !important;
    border-radius: 0.75rem !important;
    padding: 1rem !important;
    margin-block: 1rem !important;
    box-shadow: 0 0.25rem 0.75rem rgb(0 0 0 / 10%) !important;
}

.ec-size .ec-store .review-item__name,
.ec-size .ec-store .review-item__review,
.ec-size .ec-store .review-item__city,
.ec-size .ec-store .review-item__country,
.ec-size .ec-store .review-item__date {
    color: var(--white) !important;
    font-family: var(--font-main) !important;
}

/* 1. BASE COLORS (RED) */
.ec-size .ec-store .ec-link.review-block__show-reviews,
.ec-size .ec-store [class*="rating-reviews-text"] {
    color: var(--red) !important;
    font-family: var(--font-main) !important;
    font-weight: 500 !important;
    text-decoration: none !important;
}

/* 2. HOVER STATES (BLACK) */
.ec-size .ec-store .ec-link.review-block__show-reviews:hover,
.ec-size .ec-store [class*="rating-reviews-text"]:hover,
.ec-size .ec-store [class*="rating-reviews"]:hover [class*="rating-reviews-text"] {
    color: var(--black) !important;
    cursor: pointer !important;
    text-decoration: none !important;
}

/* Slimmer Featured Products Header */
.ec-size .ec-store .page-title__name,
.ec-size .ec-store .ec-header-h1 {
    font-family: var(--font-main) !important;
    color: var(--black) !important;
    font-weight: 600 !important;
    font-size: 1.5rem !important;
    line-height: 1.2 !important;
    margin-bottom: 1rem !important;
}

/* Targets every piece of text and price in the Ecwid cart */
.ec-size .ec-store .ec-cart,
.ec-size .ec-store .ec-cart-summary,
.ec-size .ec-store .ec-cart-item,
.ec-size .ec-store .ec-cart-email {
    color: var(--black) !important;
}

/* Forces all links (titles) and prices specifically to black */
.ec-size .ec-store .ec-cart a,
.ec-size .ec-store .ec-cart span,
.ec-size .ec-store .ec-cart div,
.ec-size .ec-store .ec-cart td {
    color: var(--black) !important;
}

/* Ensures all SVG icons (like the lock and close 'X') are black */
.ec-size .ec-store .ec-cart svg,
.ec-size .ec-store .ec-cart svg path {
    fill: var(--black) !important;
    stroke: var(--black) !important;
}

/* Specifically target the Coupon and Continue Shopping links */
.ec-size .ec-store .ec-cart .ec-link,
.ec-size .ec-store .ec-cart-summary .ec-link {
    color: var(--red) !important;
}

/* Ensure they stay red on hover */
.ec-size .ec-store .ec-cart .ec-link:hover {
    color: var(--black) !important;
}

/* Change only the breadcrumbs to black */
.ec-size .ec-store .ec-breadcrumbs .ec-link {
    color: var(--black) !important;
}

/* Change only the breadcrumbs to black */
.ec-size .ec-store .ec-breadcrumbs .ec-link:hover {
    color: var(--red) !important;
}

/* Targets only the specific top-level wrapper divs, ignoring product cards */
[id^="my-store"], 
[id^="my-store"] > div, 
[id^="my-store"] > div > div, 
[id^="my-store"] > div > div > div,
.ec-size .ec-store .grid-product__wrap-inner, 
.ec-size .ec-store .grid-product__card { 
    background-color: transparent !important; 
    background: none !important; 
    box-shadow: none !important; 
}

/* 9. CATEGORIES: 2-COLUMN GRID */
.categories {
    background-color: var(--light-tan);
    padding-block: 0.5rem;
    padding-inline: max(0.375rem, (100% - 85rem) / 2);
}

.category-header, 
.therapy-header {
    display: flex;
    align-items: center;
    inline-size: 100%;
    gap: 1rem;
    margin-inline: auto;

    &::before, &::after {
        content: "";
        block-size: 0.125rem;
        flex-grow: 1;
        background-color: var(--dark-gold);
    }
}

.category-title, 
.therapy-title {
    color: var(--black);
    font-family: var(--font-main);
    font-size: clamp(1rem, 5vi, 1.5rem);
    font-weight: 800;
    white-space: nowrap;
}

.category-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.75rem 0;
    margin-block: 0.5rem 2rem;
    inline-size: 100%;
    justify-items: center;
}

.category-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    inline-size: 100%;
    font-size: 0.8rem;
    padding: 0.2rem 0.5rem;
}

.img-frame {
    position: relative;
    inline-size: 100%;
    aspect-ratio: 1 / 1;
    border-radius: 0.75rem;
    padding: 0.125rem;
    background: #000;
    overflow: hidden;
    margin-block-end: 0.75rem;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);

    img {
        inline-size: 100%;
        block-size: 100%;
        object-fit: cover;
        border-radius: 0.5625rem;
        display: block;
    }
}

/* 10. FIVE-STAR & THERAPY */
.five-star {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    min-block-size: 7rem;
    padding-block: 1rem;
    z-index: 10;
    pointer-events: none;
    background: url('img/Strip1.avif') no-repeat center / cover;
    margin-block: -2rem; 
}

.star-group {
    padding-block: 0.5rem 0;
    display: flex;
    gap: 0.5rem;
}

h3.star-text {
    color: var(--light-tan);
    font-size: clamp(.5rem, 4vi, 1.5rem);
    font-weight: 500;
}

.meat-therapy {
    position: relative;
    inline-size: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding-block: 1.5rem 1rem;
    padding-inline: max(0.375rem, (100% - 85rem) / 2);
    z-index: 5;
    background-image: url('img/LCBGWhite.avif');
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    margin-block-start: -2rem;
}

.meat-therapy .therapy-header {
    margin-inline: auto;
    margin-block-end: 2rem;
}

/* 11. INFINITE SCROLLER: GPU-ACCELERATED */
.scroller-container {
    inline-size: 100%;
    overflow: hidden;
    mask-image: linear-gradient(to right, transparent, rgb(0 0 0) 15%, rgb(0 0 0) 85%, transparent);
    margin-block-start: -1rem;
}

.scroller-track {
    display: flex;
    inline-size: max-content;
    animation: scroll-loop 40s linear infinite;
    will-change: transform;
    transform: translateZ(0);
    &.is-paused { animation-play-state: paused; }
}

@keyframes scroll-loop {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); } 
}

.scroller-item {
    padding-inline: 0.5rem;
    cursor: pointer;

    img {
        block-size: clamp(7rem, 22dvb, 11.5rem);
        inline-size: auto;
        filter: drop-shadow(0 0.125rem 0.25rem rgb(0 0 0 / 50%));
        transition: transform 0.3s;
    }

    &:active img { transform: scale(1.05); }
}

.btn-pause {
    cursor: pointer;
    inline-size: 1.5rem;
    block-size: 1.5rem;
    padding: 0;
    border-radius: 0.5rem;
    border: 0.0625rem solid var(--dark-gold);
    box-shadow: inset 0 0.125rem 0.0625rem rgb(255 255 255 / 60%), 0 0.25rem 0.75rem rgb(0 0 0 / 30%);
    font-family: var(--font-display);
    margin-block-start: 0rem;

    img {
        inline-size: 1.5rem;
        block-size: auto;
        display: block;
        filter: drop-shadow(0 0.0625rem 0.0625rem rgb(0 0 0 / 20%));
    }
}

/* 12. PASSION: ART-DIRECTED BACKGROUNDS */
.passion {
    position: relative;
    inline-size: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding-block: 0.5rem 0.1rem;
    padding-inline: max(0.375rem, (100% - 85rem) / 2);
    background: url('img/BlurBG2.avif') no-repeat 70% 50% / cover;
    background-attachment: scroll;

    .passion-content {
        max-inline-size: 75rem;
        inline-size: 100%;
    }

    .passion-text {
        color: #FFFFFF;
        font-size: clamp(0.85rem, 4vi, 1.25rem);
        line-height: 1.3;
        text-wrap: pretty;
        inline-size: 100%;
        max-inline-size: clamp(30ch, 100%, 80ch); 

        .highlight {
            color: var(--gold);
            font-weight: 700;
        }
    }
}

/* 13. SIGNATURE BLOCK */
.phil-signature-block {
    display: flex;
    flex-direction: row;
    align-items: flex-end;
    justify-content: flex-end;
    margin-inline-start: auto;
    margin-block-start: -1.5rem; 
    inline-size: fit-content;
}

.phil-sig {
    inline-size: clamp(3rem, 10vi, 4.8rem);
    block-size: auto;
    transform: translate(0.5rem, -1rem); 
    z-index: 3;
}

.phil-portrait {
    inline-size: clamp(4rem, 20vi, 9.6rem);
    block-size: auto;
    margin-inline-end: -0.5rem;
}

.slim-divider { 
    background: url('img/LCBGWhite.avif') no-repeat center/cover; 
    padding-block: 0.5rem; 
    min-block-size: 0.4375rem; 
    inline-size: 100%; 
}

/* 14. CONTACT: #LCNATION VIGNETTE ENGINE */
#lcnation.contact {
    background: linear-gradient(to bottom, #000 0%, #000 5%, rgb(0 0 0 / 60%) 20%, transparent 45%, transparent 55%, rgb(0 0 0 / 60%) 80%, #000 95%, #000 100%), url('img/LCBG.avif') no-repeat center/cover, #000;
    padding-block: 2rem;
    display: grid;
    place-items: center;
    inline-size: 100%;
}

.contactbox { 
    inline-size: 17.5rem; 
    margin-inline: auto; 
    background-color: rgb(0 0 0 / 90%); 
    border-radius: 1.5rem; 
    padding: 1rem; 
    display: flex; 
    flex-direction: column; 
    gap: 2rem; 
    border: var(--border-thick) solid var(--dark-gold); 
    color-scheme: dark;

    .contact-left {
        flex: 1;
        display: flex;
        flex-direction: column;
        align-items: start;
    }

    .contact-socials {
        display: flex;
        gap: 0.625rem;
        margin-block-end: 0.1rem;

        img {
            inline-size: 1.5rem;
            block-size: 1.5rem;
        }
    }

    .contact-follow {
        color: #FFF;
        font-size: .8rem;
        margin-block-end: 1.3rem;
    }

    .contact-policy {
        display: flex;
        flex-direction: column;
        gap: 0.4rem;
        margin-block-start: auto;

        a {
            color: #FFF;
            text-decoration: none;
            font-size: 0.85rem;
        }
    }
}

.contact-right {
    flex: 1; 
    display: flex; 
    flex-direction: column;
    align-items: center;

    .contact-form-title {
        color: var(--gold);
        font-size: 1.2rem;
        text-align: center;
        line-height: 0.9;
        padding: 0.75rem; 
    }
}

/* 15. FORM ENGINE */
.contact-form {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.3rem;
    inline-size: 100%;

    input {
        inline-size: 100%;
        max-inline-size: 16.25rem;
        padding: 0.2rem 0.8rem;
        border-radius: 0.75rem;
        border: var(--border-thick) solid var(--gold);
        background: rgb(255 255 255 / 10%);
        color: #FFF;
        text-align: center;
    }
}

.form-stealth {
    position: absolute !important;
    opacity: 0 !important;
    pointer-events: none !important;
    z-index: -1 !important;
    block-size: 0.0625rem;
    inline-size: 0.0625rem;
}

/* 16. FOOTER & PERFORMANCE HINTS */
.footer {
    background: url('img/Strip.avif') no-repeat center / cover, #000;
    margin-top: -.0625rem;
    padding-block: clamp(1rem, 3dvb, 2rem);
    color: var(--gold);
    text-align: center;
    z-index: 1;

    p {
        font-size: clamp(0.8rem, 2.75vi, 0.9rem);
        letter-spacing: 0.05rem;
    }
}

#phil, #lcnation, .footer {
    content-visibility: auto;
    contain-intrinsic-size: auto 30rem;
}

/* 17. MODAL ENGINE: NATIVE DIALOG & BACKDROP */
.modal-box {
    border: var(--border-thick) solid var(--gold);
    border-radius: 1.5rem;
    background: var(--black);
    color: var(--light-tan);
    padding: 0.5rem;
    max-inline-size: 90dvi;
    inline-size: 20rem;
    position: fixed;
    place-self: center;
    box-shadow: 0 0.5rem 2rem rgb(0 0 0 / 80%);

    &::backdrop {
        background: rgb(0 0 0 / 80%);
        backdrop-filter: blur(0.25rem);
    }

    .modal-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-block-end: 0.5rem;
    }

    #modal-title {
        font-size: 1.4rem;
        flex: 1;
        text-align: center;
        color: var(--gold);
    }

    label {
        display: block;
        font-size: 0.85rem;
        margin-block: 0.4rem 0.125rem;
    }

    input, textarea {
        inline-size: 100%;
        padding: 0.5rem 0.75rem;
        border-radius: 1.2rem;
        border: 0.15rem solid var(--gold);
        background: rgb(255 255 255 / 5%);
        color: #FFF;
        
        field-sizing: content;
        resize: none;
        overflow: hidden;
        min-block-size: 3rem;

        &:focus {
            outline: none;
            border-color: var(--light-yellow);
        }
    }

    .btn-gold {
        inline-size: 100%;
        margin-block-start: 0.75rem;
        padding-block: 0.4rem;
    }
}

/* 18. FULLSCREEN OVERLAY */
.fullscreen-overlay {
    background: rgb(0 0 0 / 95%);
    border: none;
    padding: 0;
    inline-size: 100dvi;
    block-size: 100dvb;
    max-inline-size: 100dvi;
    max-block-size: 100dvb;
    display: none;
    align-items: center;
    justify-content: center;

    &[open] { display: flex; }

    .fs-content {
        position: relative;
        display: inline-block;
        max-inline-size: 90dvi;
    }

    #fs-image {
        display: block;
        max-inline-size: 100%;
        max-block-size: 85dvb;
        object-fit: contain;
        border: var(--border-thick) solid var(--dark-gold);
        border-radius: 0.5rem;
    }
}

/* 19. CLOSERS: TACTILE TOUCH TARGETS */
.close-modal, .close-fs {
    background: var(--black);
    border: var(--border-thick) solid var(--gold);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--gold);
    cursor: pointer;
    line-height: 1;
    padding: 0;
    transition: transform 0.2s ease, background 0.2s ease;
    box-shadow: 0 0.125rem 0.5rem rgb(0 0 0 / 50%);

    &:active {
        transform: scale(0.9);
        background: var(--dark-gold);
        color: var(--black);
    }
}

.close-modal {
    inline-size: 2.25rem;
    block-size: 2.25rem;
    font-size: 1.75rem;
    margin-inline-end: -0.2rem;
    margin-block-start: -0.2rem;
}

.close-fs {
    position: absolute;
    inset-block-start: -1.25rem;
    inset-inline-end: -1.25rem;
    z-index: 10;
    inline-size: 2.5rem;
    block-size: 2.5rem;
    font-size: 2rem;
}

/* 20. RETAILER ENGINE & MODAL REFINEMENTS */
.modal-box {
    .modal-label {
        display: block;
        font-family: var(--font-main);
        font-size: 0.85rem;
        color: var(--gold);
        margin-block: 0.75rem 0.25rem;
        font-weight: 700;
        letter-spacing: 0.05rem;
    }
}

.retailer-section {
    padding-block: 1.5rem;
    background-color: var(--black);
    display: flex;
    flex-direction: column;
    align-items: center;
    inline-size: 100%;
}

.retailer-content {
    inline-size: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-inline: auto;
}

.retailer-title {
    font-family: var(--font-main);
    font-size: 2rem;
    color: var(--gold);
    text-align: center;
    font-weight: 800;
    margin-block-end: 0.5rem;
}

.retailer-hero-container {
    display: flex;
    justify-content: center;
    inline-size: 100%;
    margin-block-end: 1.5rem;
}

.retailer-hero-img {
    display: block;
    inline-size: clamp(17.5rem, 85%, 28.125rem);
    border-radius: 0.75rem;
    box-shadow: 0 0.25rem 0.75rem rgb(0 0 0 / 50%);
    object-fit: contain;
}

.retailer-intro {
    font-size: 0.9375rem;
    text-align: center;
    color: var(--light-tan);
    margin-block-end: 1.5rem;
    opacity: 0.9;
    padding-inline: 1rem;
    margin-inline: auto;
    max-inline-size: 37.5rem;
}

.form-wrapper {
    background-color: rgb(0 0 0 / 90%);
    padding: 1.5rem;
    border-radius: 1.25rem;
    border: var(--border-thick) solid var(--dark-gold);
    inline-size: 92%;
    max-inline-size: 37.5rem;
    margin-inline: auto;
    contain: layout;
}

.retailer-form {
    display: flex;
    flex-direction: column;
    gap: 1rem;

    label {
        font-family: var(--font-main);
        font-size: 1rem;
        color: var(--gold);
        margin-block-end: -0.75rem;
        font-weight: 500;
    }

    input:not([type="checkbox"]), 
    select {
        inline-size: 100%;
        block-size: 2.5rem;
        padding-inline: 1rem;
        border-radius: 0;
        border: var(--border-thick) solid var(--dark-gold);
        background: var(--black);
        color: var(--gold);
        font-family: var(--font-main);
        font-size: 1rem;
    }

    select {
        appearance: none;
        background: url("svg/Arrow.svg") no-repeat right 1rem center / 1rem;
        padding-inline-end: 2.5rem;
    }
}

#otherDescriptionContainer {
    max-block-size: 0;
    opacity: 0;
    overflow: hidden;
    transition: all 0.3s ease-in-out;

    &.is-visible {
        max-block-size: 50rem;
        opacity: 1;
        margin-block: 0.75rem 0.5rem;
        overflow: visible;
    }
}

#otherDescription {
    inline-size: 100%;
    min-block-size: 5rem;
    padding: 0.8rem 1rem;
    border-radius: 0;
    border: var(--border-thick) solid var(--dark-gold);
    background: rgb(0 0 0 / 5%);
    color: var(--gold);
    font-family: var(--font-main);
    font-size: 1rem;
    resize: none;
    margin-block-start: 0.5rem;

    &:focus {
        outline: none;
        border-color: var(--gold);
        background: rgb(0 0 0 / 10%);
    }
}

.btn-center {
    display: flex;
    justify-content: center;
    inline-size: 100%;
    margin-block-start: 1.5rem;
}

/* 21. ITI & ABOUT/STORY ENGINE */
.iti {
    inline-size: 100%;
    display: block;
    position: relative;

    input {
        block-size: 2.75rem;
        inline-size: 100% !important;
        padding-inline-start: 3.25rem !important;
        border-radius: 0.25rem;
        border: 0.0625rem solid rgb(216 198 111 / 50%);
        background: rgb(255 255 255 / 5%);
        color: var(--gold);
        font-family: var(--font-main);
        font-size: 1rem;
    }

    &__country-list {
        max-block-size: 13.75rem;
        inline-size: 80%;
        min-inline-size: 13.75rem;
        max-inline-size: 16.25rem;
        background-color: #111;
        color: #fff;
        border: 0.0625rem solid var(--dark-gold);
        box-shadow: 0 0.5rem 1rem rgb(0 0 0 / 50%);
        z-index: 2000 !important;
        overflow-y: auto;

        &::-webkit-scrollbar { inline-size: 0.375rem; display: block; }
        &::-webkit-scrollbar-thumb { background-color: var(--dark-gold); border-radius: 0.625rem; }
    }

    &__country { 
        padding-block: 0.625rem;
        padding-inline: 0.9375rem;
        border-block-end: 0.0625rem solid rgb(216 198 111 / 10%);
        display: flex;
        align-items: center;
        gap: 0.625rem;

        &:hover { background-color: #333; }
    }
}

.about-section {
    padding-block: 1rem;
    background-color: var(--black);
    padding-inline: max(0.375rem, (100% - 85rem) / 2);
}

.about-container {
    color: var(--light-tan);

}

.about-text {
    inline-size: 100%;
    line-height: 1.4;
    color: var(--light-tan);
}

.story-top-wrap {
    overflow: hidden;
    margin-block-end: 2rem;
}

.bio-floating-img {
  float: inline-start;
  inline-size: 55%;
  max-inline-size: 10rem;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  margin-inline-end: 1.2rem;
  margin-block-end: 0.5rem;
  border-radius: 0.75rem;
  border: 0.125rem solid var(--dark-gold);
}

.story-title {
    font-family: var(--font-main);
    font-size: 1.8rem;
    color: var(--gold);
    line-height: 1;
}

.story-subtitle {
    font-family: var(--font-main);
    font-size: 1.1rem;
    color: var(--light-tan);
    font-weight: 400;
    margin-block-end: 0.8rem;
}

.story-pull-quote {
  text-align: center;
  font-style: italic;
  color: #fff;
  border-inline-start: 0.125rem solid var(--dark-gold);
  padding-inline-start: 1rem;
  margin-block-start: -1rem;
  margin-block-end: 2rem;
  inline-size: max-content;
  max-inline-size: 99%;
  margin-inline: auto;
  font-size: clamp(1.1rem, 2.5vi, 1.4rem);
}

.story-quote-attribution {
    text-align: end;
    font-style: italic;
    margin-block-start: 0.5rem;
    color: var(--gold);
    font-size: 1.4rem;
    font-family: var(--font-main);
    inline-size: max-content;
    margin-inline-start: auto;
    margin-inline-end: 2rem;
}

.section-subheadline {
    color: var(--gold);
    margin-block: 0.5rem 1rem;
    font-family: var(--font-main);
    font-size: 1.6rem;
}

.phil-philosophy-margin {
    margin-block: 1.5rem 1rem;
}

.achievement-list {
    line-height: 1.3;
    margin-block-end: 2rem;
}

.achievement-item {
    display: flex;
    gap: 0.8rem;
    margin-block-end: 0.6rem;
}

.achievement-icon {
    flex: 0 0 1.5625rem;
    text-align: center;
}

.achievement-text {
    flex: 1;
}

/* 22. TIMELINE & PRIVACY ENGINE */
.achievements-timeline {
    font-size: 0.95rem;
    line-height: 1.3;

    .timeline-row {
        display: flex;
        gap: 1rem;
        margin-block-end: 0.6rem;
    }

    .timeline-year {
        color: var(--gold);
        font-weight: bold;
        flex: 0 0 2.8125rem;
    }

    .timeline-event { flex: 1; }
}

.certified-tagline {
    text-align: center;
    margin-block-start: 1rem;
    font-family: var(--font-main);
    font-size: 1.5rem;
    color: var(--gold);
    line-height: 1.2;
}

.privacy-returns {
    padding-block: 2rem;
    background-color: var(--light-tan);
    color: var(--black);
    line-height: 1.5;
    font-family: sans-serif;

    .container {
        padding-inline: 1rem;
        max-inline-size: 56.25rem;
        margin-inline: auto;
    }

    h1 {
        font-family: var(--font-main), serif;
        font-size: 1.8rem;
        margin-block-end: 1rem;
        text-transform: uppercase;
    }

    h2 {
        font-family: var(--font-main), serif; 
        font-size: 1.3rem;
        margin-block: 1.5rem 0.5rem;
    }

    p, li {
        font-size: 0.95rem;
        margin-block-end: 1rem;
    }

    ul {
        padding-inline-start: 1.5rem;
        margin-block-end: 1rem;
    }

    a {
        color: var(--black);
        font-weight: bold;
        text-decoration: underline;
    }

    .last-updated {
        font-size: 0.75rem;
        margin-block-start: 2rem;
        border-block-start: 0.0625rem solid rgb(0 0 0 / 10%);
        padding-block-start: 1rem;
        text-align: center;
    }
}

.returns-form {
    .form-group {
        input, textarea {
            background-color: var(--light-yellow);
            border: 0.0625rem solid #ccc;
            border-radius: 0.75rem;
            padding: 0.75rem;
            inline-size: 100%;
            font-family: inherit;
            margin-block-end: 0.9375rem;

            &:focus {
                outline: none;
                border-color: var(--gold);
                box-shadow: 0 0 0.3125rem var(--gold);
            }
        }
    }

    .btn-gold-cat {
        padding: 0;
        min-inline-size: 6.25rem;
        block-size: auto;
    }

    .btn-text {
        font-size: 1rem;
        letter-spacing: 0.0625rem;
    }
}

/* 23. A11Y */
@media (prefers-reduced-motion: reduce) {
    .scroller-track {
        animation: none !important;
        overflow-x: auto;
    }
    
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
}

/* 24. QUERIES */
@media (min-width: 25.875rem) {/* 414px */
    .ec-cart-widget {
        transform: scale(0.9) translate(0.375rem, -0.375rem);
    }

    h3.star-text {
        font-size: clamp(1rem, 3vi, 1.25rem);
    }

    .passion {
        padding-inline-start: .75rem;
    }
}

@media screen and (min-width: 30.8125rem) {/* 493px */
    .bio-floating-img {
      float: inline-start;
      inline-size: 55%;
      max-inline-size: 15rem;
      aspect-ratio: 4 / 3;
      object-fit: cover;
      margin-inline-end: 1.2rem;
      margin-block-end: 0.5rem;
      border-radius: 0.75rem;
      border: 0.125rem solid var(--dark-gold);
    }
}

@media (min-width: 37.5rem) {/* 600px */
    .bio-floating-img {
      float: inline-start;
      inline-size: 55%;
      max-inline-size: 20rem;
      aspect-ratio: 4 / 3;
      object-fit: cover;
      margin-inline-end: 1.2rem;
      margin-block-end: 0.5rem;
      border-radius: 0.75rem;
      border: 0.125rem solid var(--dark-gold);
    }

    .ec-cart-widget { 
        transform: scale(1) translate(0.2rem, -0.2rem); 
    }

    .menu-toggle {
        inset-block-start: 0.125rem;
        gap: 0.375rem; 

        .hamburger-line {
            inline-size: 2rem;       
            block-size: 0.25rem;    
        }
    }

    .menu-toggle[aria-expanded="true"] {
        .hamburger-line:nth-child(1) { transform: translateY(0.625rem) rotate(45deg); }
        .hamburger-line:nth-child(3) { transform: translateY(-0.625rem) rotate(-45deg); }
    }

    .menu-dropdown {
        inset-block-start: 3.25rem; 
        inset-inline-end: 0.75rem; 
    }

    .category-grid {
        grid-template-columns: repeat(3, 1fr);
        margin-block: 0.75rem 2rem;
    }

    .passion {
        padding-inline-start: 1rem;

        .passion-text {
            max-inline-size: clamp(30ch, 80%, 80ch);
            text-shadow: 0 0 0.25rem rgb(0 0 0), 0 0 0.25rem rgb(0 0 0), 0 0 0.5rem rgb(0 0 0), 0 0 0.1rem rgb(0 0 0);
        }
    }

    .phil-signature-block {
        margin-block-start: -11rem;
    }

    #lcnation.contact {
        min-block-size: 60dvb;
        padding-block: 6rem;

        .contactbox { 
            inline-size: 30rem; 
            flex-direction: row; 
        }
    }
}

@media (max-width: 43.6875rem) {/* 699px */
    .ec-size .ec-store .product-details {
        display: flex !important;
        flex-direction: column !important;
        max-width: 100% !important;
        width: 100% !important;
    }

    .ec-size .ec-store .product-details__gallery,
    .ec-size .ec-store .product-details__sidebar {
        width: 100% !important;
        max-width: 100% !important;
    }
}

@media (min-width: 48rem) {/* 768px */
    .header {
        background-position: 45% 0%;
    }

    .logo-img {
        block-size: 8rem;
        inline-size: auto;
        object-fit: contain;
        position: relative;
        z-index: 2;
        pointer-events: none;
    }

    .sub-logo-img { 
        block-size: clamp(3.5rem, 10vi, 5rem);
    }

    .tagline { 
        font-size: clamp(1rem, 2.5vi, 1.25rem);
    }

    .passion {
        padding-inline-start: 3rem;
        padding-block-start: 2rem;
    }
}

@media (min-width: 59.375rem) { /* 950px */
    .header {
        background-position: 60% 50%;
        display: flex;
        align-items: flex-start;
        justify-content: flex-start;
        position: relative; 
        min-block-size: 8rem;
    }

    .brand-group { 
        order: 1; 
        flex: 0 0 auto;
        perspective: 75rem; 
    }

    .nav-actions {
        position: absolute;
        display: flex;
        z-index: 5;
        inset-block-start: 0.5rem;
        inset-inline-start: clamp(12rem, 2.3rem + 16.3vw, 17rem);
    }

    .bio-floating-img {
      float: inline-start;
      inline-size: 55%;
      max-inline-size: 25rem;
      aspect-ratio: 4 / 3;
      object-fit: cover;
      margin-inline-end: 1.2rem;
      margin-block-end: 0.5rem;
      border-radius: 0.75rem;
      border: 0.125rem solid var(--dark-gold);
    }

    .menu-toggle { display: none; }

    .menu-dropdown {
        display: block;
        position: static;
        background: none;
        border: none;
        padding: 0;
        margin-inline-end: 0;
        flex-grow: 1;
    }

    .menu-list {
        display: flex;
        flex-direction: row;
        gap: 2rem;
        align-items: center;
        margin-inline-start: -2.5rem;
        margin-inline-end: auto;
    }

    .menu-list li:not(.has-submenu) a:hover {
        color: var(--light-yellow);
        filter: drop-shadow(0 0 0.5rem var(--gold));
    }

    .has-submenu {
        position: relative;
        padding-block: 1rem;
    }

    .submenu-toggle {
        color: var(--red) !important;
        font-weight: 800;
        padding: 0;
        background: none;
        border: none;
    }

    .submenu {
        display: none;
        position: absolute;
        inset-block-start: 100%;
        inset-inline-start: -0.5rem;
        background: var(--black);
        border: 0.0625rem solid var(--dark-gold);
        border-radius: 0.5rem;
        padding: 1rem;
        min-inline-size: 11rem;
        z-index: 100;
        flex-direction: column;
        gap: 0.5rem;
        box-shadow: 0 0.5rem 1rem rgb(0 0 0 / 80%);
        margin-block-start: -0.5rem; 
        padding-block-start: 1rem;
    }

    .has-submenu:hover .submenu { display: flex; }

    .has-submenu:hover::after {
        content: "";
        position: absolute;
        inset-block-start: 100%; 
        inset-inline-start: 0;
        inline-size: 100%; 
        block-size: 1.5rem; 
        background: transparent;
        z-index: 10;
    }

    .submenu a:hover {
        color: var(--gold);
        padding-inline-start: 0.25rem;
        transition: all 0.2s ease;
    }

.ec-cart-widget {
        transform: scale(1) translate(0rem, 0rem);
        filter: 
        brightness(1) 
        drop-shadow(0 0.5rem 0.5rem rgb(0 0 0 / 50%))
        drop-shadow(0 0 0.5rem transparent) 
        drop-shadow(0 0 1.5rem transparent);

        transition: filter 1s ease-in-out, transform 0.3s ease;
}

.ec-cart-widget:hover {
        transition: filter 0.4s ease-out;
        filter: 
        brightness(1.1)
        drop-shadow(0 0.5rem 0.5rem rgb(0 0 0 / 50%))
        drop-shadow(0 0 0.5rem var(--dark-gold)) 
        drop-shadow(0 0 0.5rem rgb(from var(--dark-ember) r g b / 0.5));
}

    .ec-size .ec-store .form-control--button .form-control__button {
        position: relative !important;
        overflow: hidden !important;
        transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 1s ease-in-out, filter 1s ease-in-out !important;
    }

    .ec-size .ec-store .form-control--button .form-control__button::before {
        content: "";
        position: absolute;
        top: 0;
        left: -150%;
        width: 100%;
        height: 100%;
        background: linear-gradient(60deg, transparent, rgb(255 255 255 / 40%), transparent);
        transition: all 0.8s ease;
        pointer-events: none;
    }

    .ec-size .ec-store .form-control--button .form-control__button:hover {
        filter: brightness(1.05) !important; 
        box-shadow: 
            inset 0.2rem 0.2rem 0.4rem rgb(255 255 255 / 80%), 
            inset -0.2rem -0.2rem 0.4rem rgb(0 0 0 / 30%),
            0 0.5rem 1rem rgb(0 0 0 / 40%),
            0 0 1rem var(--dark-gold),
            0 0 0.25rem rgb(from var(--ember) r g b / 1),
            0 0 0.25rem rgb(from var(--dark-ember) r g b / 1) !important;
    }

    .ec-size .ec-store .form-control--button .form-control__button:hover::before {
        left: 150%;
    }

.btn-gold,
.btn-gold-cat {
        position: relative;
        overflow: hidden;
        
        box-shadow: 
            inset 0.2rem 0.2rem 0.4rem rgb(255 255 255 / 80%), 
            inset -0.2rem -0.2rem 0.4rem rgb(0 0 0 / 30%), 
            0 0.5rem 1rem rgb(0 0 0 / 25%); 

        transition: 
            transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), 
            box-shadow 1s ease-in-out, 
            filter 1s ease-in-out;

        &::before {
            content: "";
            position: absolute;
            inset-block-start: 0;
            inset-inline-start: -150%;
            inline-size: 100%;
            block-size: 100%;
            background: linear-gradient(60deg, transparent, rgb(255 255 255 / 40%), transparent);
            transition: all 0.8s ease;
            pointer-events: none;
        }

        &:active {
            box-shadow: inset 0.3rem 0.3rem 0.6rem rgb(0 0 0 / 50%), 0 0.1rem 0.2rem rgb(0 0 0 / 30%);
            transform: scale(0.96) translateY(0.125rem);
            transition: transform 0.05s ease; 
            filter: brightness(0.9);
        }
    }

.btn-gold:hover {
        transition: box-shadow 0.4s ease-out, filter 0.4s ease-out; 
        filter: brightness(1.1);
        box-shadow: 
            inset 0.2rem 0.2rem 0.4rem rgb(255 255 255 / 80%), 
            inset -0.2rem -0.2rem 0.4rem rgb(0 0 0 / 30%),
            0 0 0.5rem var(--dark-ember), 
            0 0 1.5rem rgb(from var(--ember) r g b / 0.5);

        &::before { inset-inline-start: 150%; }
    }

.btn-gold-cat:hover {
        transition: box-shadow 0.4s ease-out, filter 0.4s ease-out; 
        filter: brightness(1.05); 
        box-shadow: 
        inset 0.2rem 0.2rem 0.4rem rgb(255 255 255 / 80%), 
        inset -0.2rem -0.2rem 0.4rem rgb(0 0 0 / 30%),
        0 0.5rem 1rem rgb(0 0 0 / 40%),
        0 0 1rem var(--dark-gold),
        0 0 0.25rem rgb(from var(--ember) r g b / 1),
        0 0 0.25rem rgb(from var(--dark-ember) r g b / 1);

        &::before { inset-inline-start: 150%; }
    }

.perspective-wrapper {
        perspective: 75rem;
    }

#card {
  position: relative;
  inline-size: clamp(6.5rem, 10vi, 10rem); 
  block-size: clamp(6.5rem, 10vi, 10rem); 
  transform-style: preserve-3d;
  cursor: pointer;
  transition: transform 0.1s ease;
  transform-origin: center center;

  &.active {
    transition: transform 0.1s ease-out;
    .shimmer-layers {
      opacity: 1;
    }
  }
}

    .logo-img {
        inline-size: 100%;
        block-size: 100%;
        object-fit: contain;
        position: relative;
        z-index: 2;
        pointer-events: none;
        animation: 
            igniteGlow 3s ease-out forwards, 
            emberPulse 3s infinite alternate ease-in-out 3s;
        will-change: filter;
    }

    #smokeCanvas {
        display: block;
        position: absolute;
        inset-block-end: -0.375rem;
        inset-inline-start: 50%;
        translate: -50% 0;
        inline-size: 100%;
        block-size: 200%;
        z-index: 1;
        pointer-events: none;
    }

.shimmer-layers {
    display: block;
    position: absolute;
    width: 88%; 
    height: 88%;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto; 
    transform: translate(-7%, 0);
    z-index: 3;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.4s ease;
    border-radius: 7%;
    overflow: hidden;
    mix-blend-mode: color-dodge;
}

    .glitter {
        position: absolute;
        inset: 0;
        z-index: 1;
        background: url("img/glitter.png") repeat center / 25rem;
        opacity: 0.5;
        mix-blend-mode: overlay;
    }

    .shine {
        position: absolute;
        inset: 0;
        z-index: 2;
        background: 
            linear-gradient(var(--shine-angle, 115deg), transparent 45%, rgb(223 212 173 / 40%) 50%, transparent 55%),
            linear-gradient(var(--shine-angle, 115deg), transparent 40%, rgb(255 246 152 / 80%) 50%, transparent 60%),
            conic-gradient(from var(--pivot-angle, 0deg) at var(--mouse-x, 50%) var(--mouse-y, 50%), transparent 0%, rgb(216 198 111 / 20%) 10%, rgb(255 246 152 / 50%) 15%, rgb(177 155 53 / 20%) 20%, transparent 30%);
        background-size: 200% 200%;
        filter: blur(0.15vi) saturate(1.2);
    }

    .sub-logo-img {
        block-size: clamp(4.5rem, 12vi, 5rem);
    }

    .tagline {
      font-size: clamp(1rem, 2.5vi, 1.25rem); 
      max-inline-size: 50ch;
    }

    .five-star {
        flex-direction: row;
        gap: 2rem;
        padding-block: 2rem;
    }

    .star-group {
        padding-block: 0;
        
        img {
            inline-size: 1.5rem;
            block-size: 1.5rem;
        }
    }

    h3.star-text {
        font-size: clamp(1.25rem, 5vi, 1.5rem);
        white-space: nowrap;
    }

    .passion {
        background-position: 50% 50%;
        padding-inline-start: 12.75rem;
    }

    .footer {
    p {
        font-size: clamp(0.9rem, 3vi, 1.1rem);
    }
}

@media (min-width: 66.375rem) { /* 1062px */
    .ec-cart-widget {
        transform: scale(1) translate(0rem, 0.15rem);
    }

    .category-grid { grid-template-columns: repeat(6, 1fr);
    }

  /* 1. MASTER ROW CONTAINER SAFETY BUFFER */
  .ec-size .ec-store .grid__products,
  .ec-size .ec-store .grid__categories,
  .ec-size .ec-store [class*="grid__products"],
  .ec-size .ec-store [class*="grid__categories"],
  .ec-size .ec-store .grid__wrap-inner {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: flex-start !important;
    overflow: visible !important;
    margin-left: 0rem !important;
    margin-right: 0rem !important;
    width: calc(100% + 0.5rem) !important;
  }
  
  /* 2. FORCE EQUAL WIDTH MATRIX FOR PRODUCTS & CATEGORIES */
  .ec-size .ec-store .grid-product,
  .ec-size .ec-store .grid-category {
    width: 16.666% !important;
    max-width: 16.666% !important;
    flex: 0 0 16.666% !important;
    box-sizing: border-box !important;
    padding: 0.5rem !important;
    margin: 0 !important;
  }

  /* 3. STABILIZE INTERNAL CARD WALLS */
  .ec-size .ec-store .grid-product__card,
  .ec-size .ec-store .grid-category__card,
  .ec-size .ec-store .grid-product > div,
  .ec-size .ec-store .grid-category > div {
    padding: 0 !important;
    margin: 0 !important;
    overflow: visible !important;
  }

  /* 4. FORCE CATEGORY IMAGES TO MATCH PRODUCT IMAGE FILL MECHANICS */
  .ec-size .ec-store .grid-category__image-spacer {
    display: none !important;
  }

  .ec-size .ec-store .grid-category__image,
  .ec-size .ec-store .grid-category__image-bg {
    padding-top: 100% !important;
    width: 100% !important;
    height: 0 !important;
    position: relative !important;
  }

  .ec-size .ec-store .grid-category__image-inner {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
  }

}

@media (min-width: 90rem) {/* 1440px */
    .ec-cart-widget { 
        transform: scale(1.2) translate(calc(0rem - max(0rem, (100vw - 85rem) / 2)), 0.25rem); 
    }

    .nav-actions {
        inset-inline-start: calc(50% - 28rem);
    }

.sub-logo-img {
  block-size: clamp(4.25rem, 12vi, 6rem); 
}

.tagline {
  font-size: clamp(1rem, 2.5vi, 1.25rem); 
  max-inline-size: 50ch;
}

    .passion {
        padding-inline-start: clamp(12.75rem, -15rem + 30vw, 30rem);
    }

    section.passion .passion-content .passion-text {
        text-shadow: 
            0.0625rem 0.0625rem 0 rgb(0 0 0),
            -0.0625rem -0.0625rem 0 rgb(0 0 0),
            0.0625rem -0.0625rem 0 rgb(0 0 0),
            -0.0625rem 0.0625rem 0 rgb(0 0 0),
            0 0 0.5rem rgb(0 0 0),
            0 0 5rem rgb(0 0 0),
            0.2rem 0.2rem 1.5rem rgb(0 0 0 / 1),
            0 0 0.5rem rgb(0 0 0 / 1) !important;
    }
}

@media (min-width: 96rem) {/* 1536px min */

}

@media (min-width: 106.25rem) {/* 1700px med-min */

}

@media (min-width: 120rem) {/* 1920px max-min */

}

/* 25. KEYFRAMES */
@keyframes igniteGlow {
    0% { filter: brightness(1) drop-shadow(0 0 0 transparent); }
    50% { filter: brightness(1.5) drop-shadow(0 0 1.5rem var(--ember)); }
    100% { filter: brightness(1.1) drop-shadow(0 0 0.5rem var(--dark-ember)); }
}

@keyframes emberPulse {
    from { filter: brightness(1.1) drop-shadow(0 0 0.5rem var(--dark-ember)); }
    to { filter: brightness(1.3) drop-shadow(0 0 1rem var(--ember)); }
}