/*
 Theme Name:   Mesa
 Theme URI:    https://mesa.co.il
 Description:  Mesa Child Theme for Kadence - High-Performance Drone E-commerce
 Author:       Mesa
 Author URI:   https://mesa.co.il
 Template:     kadence
 Version:      1.3.0
 License:      GNU General Public License v2 or later
 License URI:  http://www.gnu.org/licenses/gpl-2.0.html
 Text Domain:  mesa
*/

/* ============================================
   Global — prevent horizontal scroll
   ============================================ */
html,
body {
    overflow-x: clip;
    max-width: 100%;
}

/* ============================================
   CSS Custom Properties (Brand Variables)
   ============================================ */
:root {
    /* Brand Colors */
    --mesa-black: #08050C;
    --mesa-lime: #CEFE65;
    --mesa-sky-blue: #A3E5FF;
    --mesa-gray: #B4B7BE;
    --mesa-gray-text: #6B7280;
    --mesa-light-gray: #F1F1F1;
    --mesa-white: #FFFFFF;

    /* Semantic Colors */
    --color-primary: var(--mesa-lime);
    --color-secondary: var(--mesa-sky-blue);
    --color-background: var(--mesa-black);
    --color-surface: var(--mesa-light-gray);
    --color-text: var(--mesa-black);
    --color-text-inverse: var(--mesa-white);
    --color-text-muted: var(--mesa-gray-text);

    /* Typography - Font Families */
    --font-heading: 'Inter', sans-serif;
    --font-body: 'Open Sans', sans-serif;
    --font-hebrew: 'Open Sans Hebrew', 'Open Sans', sans-serif;

    /* Typography - Font Sizes (fluid/responsive) */
    --text-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
    --text-sm: clamp(0.875rem, 0.8rem + 0.375vw, 1rem);
    --text-base: clamp(1rem, 0.9rem + 0.5vw, 1.125rem);
    --text-lg: clamp(1.125rem, 1rem + 0.625vw, 1.25rem);
    --text-xl: clamp(1.25rem, 1.1rem + 0.75vw, 1.5rem);
    --text-2xl: clamp(1.5rem, 1.25rem + 1.25vw, 2rem);
    --text-3xl: clamp(1.875rem, 1.5rem + 1.875vw, 2.5rem);
    --text-4xl: clamp(2.25rem, 1.75rem + 2.5vw, 3rem);
    --text-5xl: clamp(3rem, 2.25rem + 3.75vw, 4rem);

    /* Typography - Line Heights */
    --leading-tight: 1.2;
    --leading-normal: 1.6;
    --leading-relaxed: 1.75;

    /* Typography - Font Weights */
    --font-regular: 400;
    --font-medium: 500;
    --font-semibold: 600;
    --font-bold: 700;

    /* Spacing Scale */
    --space-xs: 0.25rem;
    --space-sm: 0.5rem;
    --space-md: 1rem;
    --space-lg: 1.5rem;
    --space-xl: 2rem;
    --space-2xl: 3rem;
    --space-3xl: 4rem;
    --space-4xl: 6rem;

    /* Border Radius */
    --radius-sm: 0.25rem;
    --radius-md: 0.5rem;
    --radius-lg: 1rem;
    --radius-full: 9999px;

    /* Transitions */
    --transition-fast: 150ms ease;
    --transition-base: 300ms ease;
    --transition-slow: 500ms ease;
    /* --ease-soft: cubic-bezier(0.4, 0, 0.2, 1); */
    --ease-soft: cubic-bezier(0.22, 1, 0.36, 1);
    --duration-fast: 0.25s;
    --duration-medium: 0.35s;
    --duration-slow: 0.5s;

    /* Container */
    --container-max: 1512px;
    --container-padding: 3.968%;
}

/* ============================================
   Global Container
   Shared width for all content sections.
   Full-width sections (hero, banners) skip this class.
   ============================================ */
.mesa-container {
    width: 100%;
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-padding);
    box-sizing: border-box;
}

@media screen and (max-width: 1200px) {
    :root {
        --container-padding: 32px;
    }
}

@media screen and (max-width: 768px) {
    :root {
        --container-padding: 16px;
    }
}

/* ============================================
   Base Typography
   ============================================ */
body {
    font-family: var(--font-body);
    font-weight: 400;
    font-size: 16px;
    line-height: 140%;
    letter-spacing: 0%;
    text-align: right;
    color: var(--color-text);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Hebrew RTL Support */
html[lang="he-IL"] body,
html[dir="rtl"] body {
    font-family: var(--font-hebrew);
}

/* Headings */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: var(--font-bold);
    line-height: var(--leading-tight);
    font-style: italic;
}

html[lang="he-IL"] h1,
html[lang="he-IL"] h2,
html[lang="he-IL"] h3,
html[lang="he-IL"] h4,
html[lang="he-IL"] h5,
html[lang="he-IL"] h6,
html[dir="rtl"] h1,
html[dir="rtl"] h2,
html[dir="rtl"] h3,
html[dir="rtl"] h4,
html[dir="rtl"] h5,
html[dir="rtl"] h6 {
    font-family: var(--font-hebrew);
    font-style: normal;
}

h1 { font-size: var(--text-5xl); }
h2 { font-size: var(--text-4xl); }
h3 { font-size: var(--text-3xl); }
h4 { font-size: var(--text-2xl); }
h5 { font-size: var(--text-xl); }
h6 { font-size: var(--text-lg); }

/* ============================================
   Utility Classes
   ============================================ */
.mesa-container {
    width: 100%;
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-padding);
}

.mesa-bg-black { background-color: var(--mesa-black); }
.mesa-bg-lime { background-color: var(--mesa-lime); }
.mesa-bg-sky-blue { background-color: var(--mesa-sky-blue); }

.mesa-text-black { color: var(--mesa-black); }
.mesa-text-lime { color: var(--mesa-lime); }
.mesa-text-white { color: var(--mesa-white); }

/* Button Base */
.mesa-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-lg);
    font-family: var(--font-heading);
    font-weight: var(--font-bold);
    font-style: italic;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: all var(--transition-base);
}

.mesa-btn-primary {
    background-color: var(--mesa-lime);
    color: var(--mesa-black);
}

.mesa-btn-primary:hover {
    background-color: var(--mesa-white);
}

.mesa-btn-secondary {
    background-color: var(--mesa-black);
    color: var(--mesa-lime);
}

.mesa-btn-secondary:hover {
    background-color: var(--mesa-gray-text);
}

/* ============================================
   Theme Engine (Day/Night)
   ============================================ */
[data-theme="dark"] {
    --theme-bg: var(--mesa-black);
    --theme-text: var(--mesa-white);
    --theme-accent: var(--mesa-lime);
}

[data-theme="light"] {
    --theme-bg: var(--mesa-white);
    --theme-text: var(--mesa-black);
    --theme-accent: var(--mesa-lime);
}

/* ============================================
   Component: HeroVideo
   ============================================ */
.mesa-hero {
    position: relative;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    overflow: hidden;
    background-color: var(--mesa-black);
}

.mesa-hero__media {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.mesa-hero__media video,
.mesa-hero__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mesa-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgba(8, 5, 12, 0.3), rgba(8, 5, 12, 0.7));
    z-index: 1;
}

.mesa-hero__content {
    position: relative;
    z-index: 2;
    max-width: 900px;
    padding: var(--space-xl);
}

.mesa-hero__badge {
    display: inline-block;
    padding: var(--space-xs) var(--space-md);
    background-color: var(--mesa-lime);
    color: var(--mesa-black);
    font-size: var(--text-sm);
    font-weight: var(--font-bold);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: var(--space-lg);
}

.mesa-hero__subtitle {
    font-size: var(--text-lg);
    color: var(--mesa-gray-text);
    margin-bottom: var(--space-sm);
}

.mesa-hero__title {
    font-size: var(--text-5xl);
    color: var(--mesa-white);
    margin-bottom: var(--space-md);
}

.mesa-hero__title strong {
    color: var(--mesa-lime);
}

.mesa-hero__buttons {
    display: flex;
    gap: var(--space-md);
    justify-content: center;
    flex-wrap: wrap;
    margin-top: var(--space-xl);
}

.mesa-hero__scroll {
    position: absolute;
    bottom: var(--space-xl);
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
    color: var(--mesa-white);
    animation: bounce 2s infinite;
}

@keyframes bounce {
    0%, 20%, 50%, 80%, 100% { transform: translateX(-50%) translateY(0); }
    40% { transform: translateX(-50%) translateY(-10px); }
    60% { transform: translateX(-50%) translateY(-5px); }
}

/* ============================================
   Component: SectionHeader
   ============================================ */
.mesa-section-header {
    max-width: 800px;
    margin-bottom: var(--space-2xl);
}

.mesa-section-header--center {
    margin-inline: auto;
    text-align: center;
}

.mesa-section-header--right {
    margin-right: 0;
    margin-left: auto;
    text-align: right;
}

.mesa-section-header__eyebrow {
    display: block;
    font-size: var(--text-sm);
    font-weight: var(--font-bold);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--mesa-lime);
    margin-bottom: var(--space-sm);
}

.mesa-section-header__title {
    margin-bottom: var(--space-md);
}

.mesa-section-header__subtitle {
    font-size: var(--text-xl);
    color: var(--mesa-gray-text);
    margin-bottom: var(--space-md);
}

.mesa-section-header__text {
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
}

.mesa-section-header__text mark {
    background-color: var(--mesa-lime);
    color: var(--mesa-black);
    padding: 0.1em 0.3em;
}

/* ============================================
   Component: MediaTextBlock
   ============================================ */
.mesa-media-text {
    display: grid;
    gap: var(--space-2xl);
    align-items: center;
}

.mesa-media-text--left {
    grid-template-columns: 1fr 1fr;
}

.mesa-media-text--right {
    grid-template-columns: 1fr 1fr;
}

.mesa-media-text--right .mesa-media-text__media {
    order: 2;
}

.mesa-media-text--centered {
    grid-template-columns: 1fr;
    text-align: center;
    max-width: 900px;
    margin-inline: auto;
}

.mesa-media-text--stacked {
    grid-template-columns: 1fr;
}

.mesa-media-text__media img,
.mesa-media-text__media video {
    width: 100%;
    height: auto;
    border-radius: var(--radius-lg);
}

.mesa-media-text__title {
    margin-bottom: var(--space-md);
}

.mesa-media-text__text {
    margin-bottom: var(--space-lg);
    line-height: var(--leading-relaxed);
}

.mesa-media-text__highlights {
    list-style: none;
    padding: 0;
    margin: var(--space-lg) 0;
}

.mesa-media-text__highlights li {
    display: flex;
    align-items: flex-start;
    gap: var(--space-sm);
    margin-bottom: var(--space-sm);
}

.mesa-media-text__highlights li::before {
    content: "✓";
    color: var(--mesa-lime);
    font-weight: var(--font-bold);
}

@media (max-width: 768px) {
    .mesa-media-text--left,
    .mesa-media-text--right {
        grid-template-columns: 1fr;
    }

    .mesa-media-text--right .mesa-media-text__media {
        order: 0;
    }
}

/* ============================================
   Component: MediaGrid (Bento)
   ============================================ */
.mesa-media-grid {
    display: grid;
    gap: var(--space-md);
}

.mesa-media-grid--2x3 {
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(2, 300px);
}

.mesa-media-grid--3x2 {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(3, 250px);
}

.mesa-media-grid--bento {
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(2, 300px);
}

.mesa-media-grid--bento .mesa-media-grid__item:first-child {
    grid-column: span 2;
    grid-row: span 2;
}

.mesa-media-grid__item {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-lg);
    background-color: var(--mesa-light-gray);
}

.mesa-media-grid__item img,
.mesa-media-grid__item video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.mesa-media-grid__item:hover img,
.mesa-media-grid__item:hover video {
    transform: scale(1.05);
}

.mesa-media-grid__content {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--space-lg);
    background: linear-gradient(to top, rgba(8, 5, 12, 0.8), transparent);
    color: var(--mesa-white);
}

.mesa-media-grid__title {
    font-size: var(--text-lg);
    margin-bottom: var(--space-xs);
}

.mesa-media-grid__desc {
    font-size: var(--text-sm);
    color: var(--mesa-gray-text);
}

/* Animation */
.mesa-media-grid__item[data-animate] {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.6s ease, transform 0.6s ease;
}

.mesa-media-grid__item[data-animate].is-visible {
    opacity: 1;
    transform: translateY(0);
}

@media (max-width: 768px) {
    .mesa-media-grid--2x3,
    .mesa-media-grid--3x2,
    .mesa-media-grid--bento {
        grid-template-columns: 1fr;
        grid-template-rows: auto;
    }

    .mesa-media-grid--bento .mesa-media-grid__item:first-child {
        grid-column: span 1;
        grid-row: span 1;
    }

    .mesa-media-grid__item {
        min-height: 250px;
    }
}

/* ============================================
   Component: TabbedMedia
   ============================================ */
.mesa-tabbed {
    max-width: 1200px;
    margin-inline: auto;
}

.mesa-tabbed__tabs {
    display: flex;
    gap: var(--space-sm);
    margin-bottom: var(--space-xl);
    border-bottom: 1px solid var(--mesa-gray);
    padding-bottom: var(--space-md);
    overflow-x: auto;
}

.mesa-tabbed__tab {
    padding: var(--space-sm) var(--space-lg);
    background: none;
    border: none;
    font-family: var(--font-heading);
    font-size: var(--text-base);
    font-weight: var(--font-medium);
    color: var(--mesa-gray-text);
    cursor: pointer;
    white-space: nowrap;
    transition: color var(--transition-fast);
}

.mesa-tabbed__tab:hover,
.mesa-tabbed__tab.is-active {
    color: var(--mesa-black);
}

.mesa-tabbed__tab.is-active {
    border-bottom: 3px solid var(--mesa-lime);
    margin-bottom: -1px;
}

.mesa-tabbed__panel {
    display: none;
}

.mesa-tabbed__panel.is-active {
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    gap: var(--space-2xl);
    align-items: center;
}

.mesa-tabbed__media img,
.mesa-tabbed__media video {
    width: 100%;
    border-radius: var(--radius-lg);
}

.mesa-tabbed__desc {
    font-size: var(--text-lg);
    line-height: var(--leading-relaxed);
}

@media (max-width: 768px) {
    .mesa-tabbed__panel.is-active {
        grid-template-columns: 1fr;
    }
}

/* ============================================
   Component: ImageSlider
   ============================================ */
.mesa-slider {
    position: relative;
    overflow: hidden;
}

.mesa-slider__wrapper {
    display: flex;
    gap: var(--space-md);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding: var(--space-md) 0;
}

.mesa-slider__wrapper::-webkit-scrollbar {
    display: none;
}

.mesa-slider__slide {
    flex: 0 0 auto;
    width: 300px;
    scroll-snap-align: start;
}

.mesa-slider__slide img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    border-radius: var(--radius-md);
}

.mesa-slider__nav {
    display: flex;
    justify-content: center;
    gap: var(--space-sm);
    margin-top: var(--space-lg);
}

.mesa-slider__dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: var(--mesa-gray-text);
    border: none;
    cursor: pointer;
    transition: background-color var(--transition-fast);
}

.mesa-slider__dot.is-active {
    background-color: var(--mesa-lime);
}

.mesa-slider__arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    background-color: var(--mesa-black);
    color: var(--mesa-white);
    border: none;
    border-radius: 50%;
    cursor: pointer;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
}

.mesa-slider__arrow--prev {
    left: var(--space-md);
}

.mesa-slider__arrow--next {
    right: var(--space-md);
}

/* ============================================
   Component: ScrollZoomMedia
   ============================================ */
.mesa-scroll-zoom {
    position: relative;
    height: 200vh;
}

.mesa-scroll-zoom__sticky {
    position: sticky;
    top: 0;
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.mesa-scroll-zoom__media {
    width: 50%;
    transition: width 0.1s linear;
}

.mesa-scroll-zoom__media img,
.mesa-scroll-zoom__media video {
    width: 100%;
    height: auto;
    border-radius: var(--radius-lg);
}

.mesa-scroll-zoom__text {
    position: absolute;
    text-align: center;
    max-width: 600px;
    padding: var(--space-xl);
}

.mesa-scroll-zoom__title {
    font-size: var(--text-4xl);
    color: var(--mesa-black);
    margin-bottom: var(--space-md);
}

.mesa-scroll-zoom__subtitle {
    font-size: var(--text-xl);
    color: var(--mesa-gray-text);
}

/* ============================================
   Component: ScrollVideo
   ============================================ */
.mesa-scroll-video {
    position: relative;
    height: 300vh;
}

.mesa-scroll-video__sticky {
    position: sticky;
    top: 0;
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.mesa-scroll-video__media {
    width: 100%;
    height: 100%;
}

.mesa-scroll-video__media video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mesa-scroll-video__overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
}

.mesa-scroll-video__text {
    font-size: var(--text-4xl);
    font-weight: var(--font-bold);
    color: var(--mesa-white);
    text-align: center;
    max-width: 800px;
    padding: var(--space-xl);
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.5s ease, transform 0.5s ease;
}

.mesa-scroll-video__text.is-visible {
    opacity: 1;
    transform: translateY(0);
}

.mesa-scroll-video__text mark {
    background-color: var(--mesa-lime);
    color: var(--mesa-black);
    padding: 0.1em 0.3em;
}

/* ============================================
   Component: ProductSelector
   ============================================ */
.mesa-product-selector {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-2xl);
    align-items: start;
}

.mesa-product-selector__list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
}

.mesa-product-selector__item {
    padding: var(--space-lg);
    border: 2px solid var(--mesa-light-gray);
    border-radius: var(--radius-lg);
    cursor: pointer;
    transition: border-color var(--transition-fast), background-color var(--transition-fast);
    text-align: center;
}

.mesa-product-selector__item:hover {
    border-color: var(--mesa-gray-text);
}

.mesa-product-selector__item.is-selected {
    border-color: var(--mesa-lime);
    background-color: rgba(206, 254, 101, 0.1);
}

.mesa-product-selector__item img {
    width: 100%;
    max-width: 150px;
    height: auto;
    margin-bottom: var(--space-md);
}

.mesa-product-selector__item-title {
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
}

.mesa-product-selector__details {
    padding: var(--space-2xl);
    background-color: var(--mesa-light-gray);
    border-radius: var(--radius-lg);
}

.mesa-product-selector__details img {
    width: 100%;
    max-width: 300px;
    margin-bottom: var(--space-lg);
}

.mesa-product-selector__details-title {
    font-size: var(--text-2xl);
    margin-bottom: var(--space-md);
}

.mesa-product-selector__details-text {
    margin-bottom: var(--space-lg);
    line-height: var(--leading-relaxed);
}

@media (max-width: 768px) {
    .mesa-product-selector {
        grid-template-columns: 1fr;
    }
}

/* ============================================
   Component: CompareTable
   ============================================ */
.mesa-compare {
    overflow-x: auto;
}

.mesa-compare__table {
    width: 100%;
    min-width: 600px;
    border-collapse: collapse;
}

.mesa-compare__header {
    position: sticky;
    top: 0;
    background-color: var(--mesa-white);
    z-index: 1;
}

.mesa-compare__header th {
    padding: var(--space-lg);
    text-align: center;
    border-bottom: 2px solid var(--mesa-light-gray);
}

.mesa-compare__product-img {
    width: 120px;
    height: auto;
    margin-bottom: var(--space-sm);
}

.mesa-compare__product-title {
    font-size: var(--text-lg);
    font-weight: var(--font-bold);
    margin-bottom: var(--space-xs);
}

.mesa-compare__product-price {
    color: var(--mesa-lime);
    font-weight: var(--font-bold);
}

.mesa-compare__row td {
    padding: var(--space-md);
    text-align: center;
    border-bottom: 1px solid var(--mesa-light-gray);
}

.mesa-compare__row td:first-child {
    text-align: right;
    font-weight: var(--font-medium);
    background-color: var(--mesa-light-gray);
}

.mesa-compare__check {
    color: var(--mesa-lime);
    font-size: var(--text-xl);
}

.mesa-compare__cross {
    color: var(--mesa-gray-text);
}

/* ============================================
   Component: SpecsTable
   ============================================ */
.mesa-specs {
    max-width: 800px;
}

.mesa-specs__category {
    margin-bottom: var(--space-2xl);
}

.mesa-specs__category-title {
    font-size: var(--text-xl);
    padding-bottom: var(--space-sm);
    border-bottom: 2px solid var(--mesa-lime);
    margin-bottom: var(--space-lg);
}

.mesa-specs__list {
    display: grid;
    gap: var(--space-md);
}

.mesa-specs__item {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md);
    padding: var(--space-md) 0;
    border-bottom: 1px solid var(--mesa-light-gray);
}

.mesa-specs__label {
    color: var(--mesa-gray-text);
}

.mesa-specs__value {
    font-weight: var(--font-medium);
}

.mesa-specs__note {
    font-size: var(--text-sm);
    color: var(--mesa-gray-text);
    grid-column: span 2;
}

/* ============================================
   Component: Accordion (FAQ)
   ============================================ */
.mesa-accordion {
    max-width: 800px;
}

.mesa-accordion__item {
    border-bottom: 1px solid var(--mesa-light-gray);
}

.mesa-accordion__trigger {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-lg) 0;
    background: none;
    border: none;
    font-family: var(--font-heading);
    font-size: var(--text-lg);
    font-weight: var(--font-medium);
    text-align: right;
    cursor: pointer;
}

.mesa-accordion__icon {
    font-size: var(--text-xl);
    transition: transform var(--transition-fast);
}

.mesa-accordion__item.is-open .mesa-accordion__icon {
    transform: rotate(45deg);
}

.mesa-accordion__content {
    max-height: 0;
    overflow: hidden;
    transition: max-height var(--transition-base);
}

.mesa-accordion__item.is-open .mesa-accordion__content {
    max-height: 500px;
}

.mesa-accordion__answer {
    padding-bottom: var(--space-lg);
    line-height: var(--leading-relaxed);
    color: var(--mesa-gray-text);
}

/* Categorized variant */
.mesa-accordion--categorized .mesa-accordion__category {
    margin-bottom: var(--space-2xl);
}

.mesa-accordion--categorized .mesa-accordion__category-title {
    font-size: var(--text-xl);
    color: var(--mesa-lime);
    margin-bottom: var(--space-lg);
}

/* ============================================
   Component: CTABanner
   ============================================ */
.mesa-cta-banner {
    position: relative;
    padding: var(--space-4xl) var(--space-xl);
    text-align: center;
    overflow: hidden;
}

.mesa-cta-banner__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.mesa-cta-banner__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mesa-cta-banner__overlay {
    position: absolute;
    inset: 0;
    background: rgba(8, 5, 12, 0.7);
    z-index: 1;
}

.mesa-cta-banner__content {
    position: relative;
    z-index: 2;
    max-width: 700px;
    margin-inline: auto;
}

.mesa-cta-banner__title {
    font-size: var(--text-4xl);
    color: var(--mesa-white);
    margin-bottom: var(--space-md);
}

.mesa-cta-banner__text {
    font-size: var(--text-lg);
    color: var(--mesa-gray-text);
    margin-bottom: var(--space-xl);
}

/* ============================================
   Component: ParallaxFloat
   ============================================ */
.mesa-parallax {
    position: relative;
    padding: var(--space-4xl) 0;
}

.mesa-parallax__item {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-2xl);
    align-items: center;
    margin-bottom: var(--space-4xl);
}

.mesa-parallax__item--reverse {
    direction: rtl;
}

.mesa-parallax__item--reverse > * {
    direction: ltr;
}

.mesa-parallax__image {
    position: relative;
}

.mesa-parallax__image img {
    width: 100%;
    border-radius: var(--radius-lg);
    box-shadow: 0 20px 60px rgba(8, 5, 12, 0.2);
}

.mesa-parallax__content {
    padding: var(--space-2xl);
}

.mesa-parallax__title {
    font-size: var(--text-3xl);
    margin-bottom: var(--space-lg);
}

.mesa-parallax__text {
    font-size: var(--text-lg);
    line-height: var(--leading-relaxed);
    color: var(--mesa-gray-text);
}

@media (max-width: 768px) {
    .mesa-parallax__item {
        grid-template-columns: 1fr;
    }
}

/* ============================================
   Component: TypewriterText
   ============================================ */
.mesa-typewriter {
    font-size: var(--text-3xl);
    font-weight: var(--font-bold);
    line-height: var(--leading-tight);
}

.mesa-typewriter__cursor {
    display: inline-block;
    width: 3px;
    height: 1em;
    background-color: var(--mesa-lime);
    margin-right: 2px;
    animation: blink 1s infinite;
}

@keyframes blink {
    0%, 50% { opacity: 1; }
    51%, 100% { opacity: 0; }
}

.mesa-typewriter mark {
    background-color: transparent;
    color: var(--mesa-lime);
}

/* ============================================
   Component: Disclaimer
   ============================================ */
.mesa-disclaimer {
    padding: var(--space-2xl) 0;
    border-top: 1px solid var(--mesa-light-gray);
}

.mesa-disclaimer__list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.mesa-disclaimer__item {
    font-size: var(--text-xs);
    color: var(--mesa-gray-text);
    margin-bottom: var(--space-sm);
    padding-right: var(--space-lg);
    position: relative;
}

.mesa-disclaimer__item::before {
    content: attr(data-num);
    position: absolute;
    right: 0;
    font-size: var(--text-xs);
    color: var(--mesa-gray-text);
}

/* ============================================
   Section Utilities
   ============================================ */
.mesa-section {
    padding: var(--space-4xl) var(--container-padding);
}

.mesa-section--dark {
    background-color: var(--mesa-black);
    color: var(--mesa-white);
}

.mesa-section--dark .mesa-section-header__title,
.mesa-section--dark h1,
.mesa-section--dark h2,
.mesa-section--dark h3 {
    color: var(--mesa-white);
}

.mesa-section--dark .mesa-section-header__text,
.mesa-section--dark p {
    color: var(--mesa-gray);
}

.mesa-section--gray {
    background-color: var(--mesa-light-gray);
}

/* Component Label (for demo page) */
.mesa-component-label {
    display: inline-block;
    padding: var(--space-xs) var(--space-md);
    background-color: var(--mesa-sky-blue);
    color: var(--mesa-black);
    font-size: var(--text-sm);
    font-weight: var(--font-bold);
    margin-bottom: var(--space-lg);
    border-radius: var(--radius-sm);
}

/* ============================================
   WooCommerce: Product Tabs (Mesa Custom)
   ============================================ */

/* Tab Navigation */
.woocommerce-tabs .wc-tabs {
    display: flex;
    gap: var(--space-xs);
    padding: 0;
    margin: 0 0 var(--space-xl) 0;
    list-style: none;
    border-bottom: 1px solid var(--mesa-light-gray);
}

.woocommerce-tabs .wc-tabs li {
    margin: 0;
}

.woocommerce-tabs .wc-tabs li a {
    display: block;
    padding: var(--space-md) var(--space-lg);
    font-family: var(--font-heading);
    font-size: var(--text-base);
    font-weight: var(--font-medium);
    color: var(--mesa-gray-text);
    text-decoration: none;
    border-bottom: 3px solid transparent;
    margin-bottom: -1px;
    transition: color var(--transition-fast), border-color var(--transition-fast);
}

.woocommerce-tabs .wc-tabs li a:hover {
    color: var(--mesa-black);
}

.woocommerce-tabs .wc-tabs li.active a {
    color: var(--mesa-black);
    border-bottom-color: var(--mesa-lime);
}

/* Tab Panels */
.woocommerce-tabs .woocommerce-Tabs-panel {
    padding: var(--space-xl) 0;
}

.woocommerce-tabs .woocommerce-Tabs-panel h2 {
    display: none; /* Hide default WooCommerce tab titles */
}

/* Mesa Tab Content Wrapper */
.mesa-tab-content {
    line-height: var(--leading-relaxed);
}

.mesa-tab-content h3 {
    font-size: var(--text-xl);
    margin-top: var(--space-xl);
    margin-bottom: var(--space-md);
    color: var(--mesa-black);
}

.mesa-tab-content h3:first-child {
    margin-top: 0;
}

.mesa-tab-content p {
    margin-bottom: var(--space-md);
}

.mesa-tab-content ul,
.mesa-tab-content ol {
    margin-bottom: var(--space-md);
    padding-right: var(--space-lg);
}

.mesa-tab-content li {
    margin-bottom: var(--space-sm);
}

/* Technical Specs Tab */
.mesa-tab-specs table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: var(--space-xl);
}

.mesa-tab-specs th,
.mesa-tab-specs td {
    padding: var(--space-md);
    text-align: right;
    border-bottom: 1px solid var(--mesa-light-gray);
}

.mesa-tab-specs th {
    background-color: var(--mesa-light-gray);
    font-weight: var(--font-semibold);
    width: 40%;
}

.mesa-tab-specs td {
    width: 60%;
}

.mesa-tab-specs tr:hover td {
    background-color: rgba(206, 254, 101, 0.1);
}

/* Compatibility Tab */
.mesa-tab-compat ul {
    list-style: none;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--space-sm);
}

.mesa-tab-compat li {
    padding: var(--space-sm) var(--space-md);
    background-color: var(--mesa-light-gray);
    border-radius: var(--radius-sm);
}

.mesa-compat-notice {
    margin-top: var(--space-2xl);
    padding: var(--space-lg);
    background-color: var(--mesa-light-gray);
    border-radius: var(--radius-md);
    border-right: 4px solid var(--mesa-lime);
}

.mesa-compat-notice p {
    margin: 0 0 var(--space-md) 0;
    font-weight: var(--font-medium);
}

.mesa-whatsapp-link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-lg);
    background-color: #25D366;
    color: var(--mesa-white);
    text-decoration: none;
    border-radius: var(--radius-full);
    font-weight: var(--font-medium);
    transition: background-color var(--transition-fast);
}

.mesa-whatsapp-link:hover {
    background-color: #128C7E;
    color: var(--mesa-white);
}

.mesa-whatsapp-icon::before {
    content: "";
    display: inline-block;
    width: 20px;
    height: 20px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M17.472 14.382c-.297-.149-1.758-.867-2.03-.967-.273-.099-.471-.148-.67.15-.197.297-.767.966-.94 1.164-.173.199-.347.223-.644.075-.297-.15-1.255-.463-2.39-1.475-.883-.788-1.48-1.761-1.653-2.059-.173-.297-.018-.458.13-.606.134-.133.298-.347.446-.52.149-.174.198-.298.298-.497.099-.198.05-.371-.025-.52-.075-.149-.669-1.612-.916-2.207-.242-.579-.487-.5-.669-.51-.173-.008-.371-.01-.57-.01-.198 0-.52.074-.792.372-.272.297-1.04 1.016-1.04 2.479 0 1.462 1.065 2.875 1.213 3.074.149.198 2.096 3.2 5.077 4.487.709.306 1.262.489 1.694.625.712.227 1.36.195 1.871.118.571-.085 1.758-.719 2.006-1.413.248-.694.248-1.289.173-1.413-.074-.124-.272-.198-.57-.347m-5.421 7.403h-.004a9.87 9.87 0 01-5.031-1.378l-.361-.214-3.741.982.998-3.648-.235-.374a9.86 9.86 0 01-1.51-5.26c.001-5.45 4.436-9.884 9.888-9.884 2.64 0 5.122 1.03 6.988 2.898a9.825 9.825 0 012.893 6.994c-.003 5.45-4.437 9.884-9.885 9.884m8.413-18.297A11.815 11.815 0 0012.05 0C5.495 0 .16 5.335.157 11.892c0 2.096.547 4.142 1.588 5.945L.057 24l6.305-1.654a11.882 11.882 0 005.683 1.448h.005c6.554 0 11.89-5.335 11.893-11.893a11.821 11.821 0 00-3.48-8.413z'/%3E%3C/svg%3E");
    background-size: contain;
    background-repeat: no-repeat;
}

/* What's in the Box Tab */
.mesa-tab-box ul {
    list-style: none;
    padding: 0;
}

.mesa-tab-box li {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md);
    border-bottom: 1px solid var(--mesa-light-gray);
}

.mesa-tab-box li::before {
    content: "✓";
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    background-color: var(--mesa-lime);
    color: var(--mesa-black);
    border-radius: 50%;
    font-size: var(--text-sm);
    font-weight: var(--font-bold);
    flex-shrink: 0;
}

/* Shipping Tab */
.mesa-tab-shipping h3 {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.mesa-shipping-global ul {
    list-style: none;
    padding: 0;
}

.mesa-shipping-global li {
    padding: var(--space-sm) 0;
    padding-right: var(--space-lg);
    position: relative;
}

.mesa-shipping-global li::before {
    content: "•";
    position: absolute;
    right: 0;
    color: var(--mesa-lime);
    font-weight: var(--font-bold);
}

/* Mobile: Tabs to Accordion */
@media (max-width: 768px) {
    .woocommerce-tabs .wc-tabs {
        flex-direction: column;
        border-bottom: none;
    }

    .woocommerce-tabs .wc-tabs li {
        border-bottom: 1px solid var(--mesa-light-gray);
    }

    .woocommerce-tabs .wc-tabs li a {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: var(--space-lg);
        border-bottom: none;
    }

    .woocommerce-tabs .wc-tabs li a::after {
        content: "+";
        font-size: var(--text-xl);
        font-weight: var(--font-bold);
        color: var(--mesa-lime);
        transition: transform var(--transition-fast);
    }

    .woocommerce-tabs .wc-tabs li.active a::after {
        transform: rotate(45deg);
    }

    .woocommerce-tabs .woocommerce-Tabs-panel {
        padding: var(--space-lg);
    }

    .mesa-tab-compat ul {
        grid-template-columns: 1fr;
    }
}

/* Product page styles → assets/css/product.css */


/* ============================================
   GLOBAL HEADER & FOOTER STYLES
   Mesa Theme - RTL Optimized
   HIGH SPECIFICITY VERSION - Overrides Kadence
   ============================================ */

/* ===========================================
   CRITICAL: VISIBILITY UTILITY CLASSES
   These MUST work to show/hide mobile/desktop elements
   =========================================== */

/* DESKTOP: Show desktop elements, hide mobile elements */
.mesa-desktop-only {
    display: block !important;
    visibility: visible !important;
}

.mesa-mobile-only {
    display: none !important;
    visibility: hidden !important;
}

/* Flex variant for desktop-only */
.mesa-desktop-only.mesa-header__icons,
.mesa-desktop-only.mesa-header__search,
a.mesa-desktop-only {
    display: flex !important;
}

/* MOBILE: Reverse visibility */
@media screen and (max-width: 768px) {
    .mesa-desktop-only {
        display: none !important;
        visibility: hidden !important;
    }

    .mesa-mobile-only {
        display: block !important;
        visibility: visible !important;
    }

    .mesa-shop__filter-toggle {
        display: flex !important;
    }

    /* Flex variant for mobile-only bottom nav */
    nav.mesa-mobile-only.mesa-bottom-nav,
    .mesa-mobile-only.mesa-bottom-nav {
        display: flex !important;
    }

    .mesa-shop__container .mesa-shop__controls {
        flex-direction: column-reverse;
        align-items: flex-start;
    }
}

/* ===========================================
   GLOBAL RESETS FOR HEADER/FOOTER MENUS
   =========================================== */
#mesa-header ul,
#mesa-header ol,
#mesa-header li,
.mesa-navbar ul,
.mesa-navbar ol,
.mesa-navbar li,
.mesa-mobile-menu ul,
.mesa-mobile-menu ol,
.mesa-mobile-menu li,
.mesa-bottom-nav ul,
.mesa-bottom-nav ol,
.mesa-bottom-nav li {
    list-style: none !important;
    list-style-type: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ===========================================
   TOP BAR - Rotating Messages
   =========================================== */
.mesa-topbar {
    height: 28px;
    background: var(--mesa-lime);
    color: var(--mesa-black);
    text-align: center;
    padding: 0.25rem var(--space-md);
    position: relative;
    z-index: 1001;
    overflow: hidden;
}

.mesa-topbar__container {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--container-padding);
}

/* Messages wrapper - fixed height for animation */
.mesa-topbar__messages {
    position: relative;
    height: 1.3em;
    line-height: 1.3em;
}

/* Individual message */
.mesa-topbar__message {
    position: absolute;
    width: 100%;
    top: 0;
    left: 0;
    opacity: 0;
    transform: translateY(100%);
    transition: opacity 0.4s ease, transform 0.4s ease;
    font-size: var(--text-xs);
    font-weight: var(--font-medium);
}

.mesa-topbar__message.is-active {
    opacity: 1;
    transform: translateY(0);
}

.mesa-topbar__message.is-leaving {
    opacity: 0;
    transform: translateY(-100%);
}

/* Link styling */
.mesa-topbar__link {
    color: var(--mesa-black);
    text-decoration: none;
    transition: opacity var(--transition-fast);
}

.mesa-topbar__link:hover {
    opacity: 0.8;
    text-decoration: underline;
}

/* ===========================================
   CUSTOM HEADER - Main Styles
   Overrides Kadence Header Builder completely
   =========================================== */
.mesa-header {
    background-color: var(--mesa-white);
    position: relative;
    z-index: 1000;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

/* Header Container */
.mesa-header__container {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--container-padding);
}

/* ===========================================
   HEADER MAIN ROW - Logo | Search | Icons
   RTL: Logo right, Icons left
   =========================================== */
.mesa-header__main {
    padding: var(--space-md) 0 !important;
    background: var(--mesa-white) !important;
}

.mesa-header__main .mesa-header__container {
    display: grid !important;
    grid-template-columns: minmax(120px, 200px) 1fr minmax(150px, auto) !important;
    gap: var(--space-lg) !important;
    align-items: center !important;
    max-width: var(--container-max) !important;
    margin: 0 auto !important;
    padding: 0 var(--container-padding) !important;
}

/* Logo */
.mesa-header__logo {
    justify-self: start !important;
    grid-column: 1 !important;
}

.mesa-header__logo a {
    display: block !important;
}

.mesa-header__logo img,
.mesa-header__logo .custom-logo {
    max-height: 50px !important;
    width: auto !important;
}

.mesa-header__site-title {
    font-size: var(--text-xl) !important;
    font-weight: var(--font-bold) !important;
    color: var(--mesa-black) !important;
    text-decoration: none !important;
}

/* Search */
.mesa-header__search {
    justify-self: stretch !important;
    grid-column: 2 !important;
    max-width: 600px !important;
    width: 100% !important;
    margin: 0 auto !important;
}

.mesa-header__search .dgwt-wcas-search-wrapp {
    width: 100% !important;
}

/* FiboSearch Styling in Header */
.mesa-header__search .dgwt-wcas-sf-wrapp input[type="search"] {
    background-color: var(--mesa-light-gray) !important;
    border: 2px solid var(--mesa-light-gray) !important;
    border-radius: 8px !important;
    height: 48px !important;
    padding: 0 48px 0 20px !important;
    font-size: 15px !important;
    transition: all 0.2s ease !important;
}

.mesa-header__search .dgwt-wcas-sf-wrapp input[type="search"]:focus {
    border-color: var(--mesa-lime) !important;
    background-color: var(--mesa-white) !important;
    box-shadow: 0 0 0 3px rgba(206, 254, 101, 0.25) !important;
}

/* Icons Cluster */
.mesa-header__icons {
    justify-self: end !important;
    grid-column: 3 !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: var(--space-md) !important;
}

.mesa-header__icon {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    color: var(--mesa-black, #08050C);
    text-decoration: none;
    position: relative;
    transition: color 0.2s ease;
}

.mesa-header__icon:hover {
    color: var(--mesa-lime, #CEFE65);
}

.mesa-header__icon svg {
    width: 24px;
    height: 24px;
}

.mesa-header__icon-label {
    font-size: 11px;
    font-weight: 500;
}

.mesa-header__icon-count,
.mesa-header__cart-count {
    position: absolute;
    top: -8px;
    right: -8px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    background-color: var(--mesa-lime, #CEFE65);
    color: var(--mesa-black, #08050C);
    font-size: 11px;
    font-weight: 700;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Hamburger Button - Hidden on Desktop */
.mesa-header__hamburger {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 30px;
    height: 30px;
    padding: 0;
    background: none;
    border: none;
    cursor: pointer;
}

.mesa-header__hamburger-line {
    display: block;
    width: 100%;
    height: 2px;
    background-color: var(--mesa-black);
    transition: all 0.3s ease;
}

.mesa-header__hamburger.is-active .mesa-header__hamburger-line:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
}

.mesa-header__hamburger.is-active .mesa-header__hamburger-line:nth-child(2) {
    opacity: 0;
}

.mesa-header__hamburger.is-active .mesa-header__hamburger-line:nth-child(3) {
    transform: rotate(-45deg) translate(5px, -5px);
}

/* ===========================================
   HEADER - Mobile Responsive
   =========================================== */
@media screen and (max-width: 768px) {
    /* Hide icon labels on mobile */
    .mesa-header__icon-label {
        display: none !important;
    }
}

/* ===========================================
   NAVIGATION ROW - Desktop Only
   =========================================== */
.mesa-header__nav {
    background-color: var(--mesa-light-gray) !important;
    border-top: 1px solid #eee !important;
}

.mesa-header__nav .mesa-header__container {
    max-width: var(--container-max) !important;
    margin: 0 auto !important;
    padding: 0 var(--container-padding) !important;
}

.mesa-header__menu,
ul.mesa-header__menu,
.mesa-header__nav ul:not(.mega-menu__links) {
    display: flex !important;
    flex-direction: row !important;
    justify-content: center !important;
    align-items: center !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.mesa-header__menu > li {
    position: relative;
}

.mesa-header__menu > li > a {
    display: block;
    padding: 15px 25px;
    color: var(--mesa-black);
    text-decoration: none;
    font-family: 'Open Sans', sans-serif;
    font-size: 1rem;
    font-weight: 600;
    line-height: 150%;
    letter-spacing: 0;
    text-align: right;
    transition: all 0.2s ease;
}

.mesa-header__menu > li > a:hover,
.mesa-header__menu > li.current-menu-item > a,
.mesa-header__menu > li.current-menu-ancestor > a {
    color: var(--mesa-lime);
    background-color: var(--mesa-black);
}

/* Dropdown Menu */
.mesa-header__menu .sub-menu {
    position: absolute;
    top: 100%;
    right: 0;
    min-width: 200px;
    background-color: var(--mesa-white);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
    border-radius: 0 0 8px 8px;
    list-style: none;
    margin: 0;
    padding: 10px 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: all 0.2s ease;
    z-index: 100;
}

.mesa-header__menu > li:hover > .sub-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.mesa-header__menu .sub-menu a {
    display: block;
    padding: 10px 20px;
    color: var(--mesa-black);
    text-decoration: none;
    font-size: 14px;
    transition: all 0.2s ease;
}

.mesa-header__menu .sub-menu a:hover {
    background-color: var(--mesa-light-gray);
    padding-right: 25px;
}

/* Hide nav on mobile */
@media screen and (max-width: 768px) {
    .mesa-header__nav {
        display: none;
    }
}

/* ===========================================
   MINI CART DRAWER - Off-canvas
   =========================================== */
#mesa-mini-cart,
.mesa-mini-cart {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 99999 !important;
    pointer-events: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    transition: opacity 0.3s ease, visibility 0.3s ease !important;
}

#mesa-mini-cart.is-open,
.mesa-mini-cart.is-open {
    pointer-events: all !important;
    visibility: visible !important;
    opacity: 1 !important;
}

#mesa-mini-cart .mesa-mini-cart__overlay,
.mesa-mini-cart__overlay {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background-color: rgba(0, 0, 0, 0.5) !important;
    opacity: 0 !important;
    transition: opacity 0.3s ease !important;
}

#mesa-mini-cart.is-open .mesa-mini-cart__overlay,
.mesa-mini-cart.is-open .mesa-mini-cart__overlay {
    opacity: 1 !important;
}

#mesa-mini-cart .mesa-mini-cart__drawer,
.mesa-mini-cart__drawer {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    bottom: 0 !important;
    width: 90% !important;
    max-width: 420px !important;
    background-color: #fff !important;
    transform: translateX(-100%) !important;
    transition: transform 0.3s ease !important;
    display: flex !important;
    flex-direction: column !important;
    box-shadow: 2px 0 20px rgba(0, 0, 0, 0.15) !important;
    z-index: 100000 !important;
}

#mesa-mini-cart.is-open .mesa-mini-cart__drawer,
.mesa-mini-cart.is-open .mesa-mini-cart__drawer {
    transform: translateX(0) !important;
}

#mesa-mini-cart .mesa-mini-cart__header,
.mesa-mini-cart__header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 23px 20px !important;
    background: #FFFFFF !important;
    flex-shrink: 0 !important;
    position: relative;
}

#mesa-mini-cart .mesa-mini-cart__header::after,
.mesa-mini-cart__header::after {
    content: '';
    display: block;
    width: calc(100% - 40px);
    height: 1px;
    background-color: #F5F5F5;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
}

#mesa-mini-cart .mesa-mini-cart__title,
.mesa-mini-cart__title {
    margin: 0 !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    color: #000000 !important;
    line-height: 140% !important;
}

#mesa-mini-cart .mesa-mini-cart__close,
.mesa-mini-cart__close {
    width: 24px !important;
    height: 24px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #F5F5F5 !important;
    border: none !important;
    cursor: pointer !important;
    color: #08050C !important;
    transition: color 0.2s ease !important;
    padding: 0 !important;
}

#mesa-mini-cart .mesa-mini-cart__close:hover,
.mesa-mini-cart__close:hover {
    color: #888 !important;
}

#mesa-mini-cart .mesa-mini-cart__content,
.mesa-mini-cart__content {
    flex: 1 !important;
    overflow-y: auto !important;
    padding: 24px 20px !important;
}

/* WooCommerce Mini Cart Styles */
.mesa-mini-cart__content .woocommerce-mini-cart {
    list-style: none;
    margin: 0;
    padding: 0;
}

.mesa-mini-cart__content .woocommerce-mini-cart-item {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: var(--space-md);
    padding: var(--space-md) 0;
    border-bottom: 1px solid var(--mesa-light-gray);
    align-items: start;
}

.mesa-mini-cart_col-1 {
    margin-left: 20px;
    flex: 0 0 auto;
}

.mesa-mini-cart_col-1 img {
    width: 70px;
    height: 70px;
    object-fit: cover;
    border-radius: var(--radius-sm);
    display: block;
}

#mesa-mini-cart .woocommerce-mini-cart-item .mesa-mini-cart_col-2 a {
    color: #000;
    text-align: right;
    font-family: "Open Sans";
    font-size: 15px;
    font-style: normal;
    font-weight: 600;
    line-height: 140%; /* 21px */
}

#mesa-mini-cart .woocommerce-mini-cart-item .mesa-mini-cart_col-2 a:hover {
    text-decoration: none;
}

.mesa-mini-cart_col-2 {
    margin-left: 16px;
    flex: 1;
    min-width: 0;
}

.mesa-mini-cart_col-2 a {
    color: var(--mesa-black);
    text-decoration: none;
    font-weight: var(--font-medium);
    font-size: var(--text-sm);
}

.mesa-mini-cart_col-2 a:hover {
    text-decoration: underline;
}

.mesa-mini-cart_col-3 {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: space-between;
    /* gap: 16px; */
    flex: 0 0 auto;
}

.mesa-mini-cart__content .woocommerce-mini-cart-item .quantity {
    color: var(--mesa-black);
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
}

.mesa-mini-cart__content .woocommerce-mini-cart-item .quantity-number {
    display: none;
}

.mesa-mini-cart_col .mesa-qty {
    display: inline-flex;
    align-items: stretch;
    width: 100px;
    height: 30px;
    border: 1px solid #B3B7BD;
    background-color: #FFFFFF;
    border-radius: 4px;
    overflow: hidden;
}

.mesa-mini-cart_col input.mesa-qty__input {
    flex: 1;
    min-width: 0;
    width: auto;
    display: flex;
    align-items: center;
    justify-content: center;
    color:  #08050C;
    font-family: var(--font-hebrew);
    font-size: 15px;
    font-weight: 600;
    line-height: 140%; /* 16.8px */
    border: solid #B3B7BD !important;
    border-width: 0 1px !important;
    background: transparent;
    border-radius: 0;
    box-shadow: none;
    outline: none;
    pointer-events: none;
    text-align: center;
    padding: 0;
}

.mesa-qty__input::-webkit-inner-spin-button,
.mesa-qty__input::-webkit-outer-spin-button {
    -webkit-appearance: none;
    opacity: 0;
    width: 0;
    margin: 0;
}


.mesa-mini-cart_col .mesa-qty__controls {
    display: flex;
    flex-direction: column;
    /* width: 18px; */
    /* border-left: 1px solid #ddd; */
    border-left: none;
}

.mesa-qty__btn {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #08050C;
    font-size: 15px;
    font-weight: 600;
    line-height: 140%; /* 16.8px */
    background: transparent;
    border-radius: 0;
    cursor: pointer;
    padding: 0;
}

.mesa-qty__btn:hover {
    background: #f7f7f7 !important;
    color: #08050C !important;
}

.mesa-qty__btn:active,
.mesa-qty__btn:focus {
    background: #eeeeee !important;
}

.mesa-mini-cart__content .woocommerce-mini-cart-item .remove {
    color: transparent !important;
    font-size: 0 !important;
    text-decoration: none;
    width: 1.5rem;
    height: 1.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: none;
    position: relative;
    flex-shrink: 0;
}

.mesa-mini-cart__content .woocommerce-mini-cart-item .remove::after {
    content: '';
    width: 14px;
    height: 14px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23B4B7BE' stroke-width='2' stroke-linecap='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-size: contain;
}

.mesa-mini-cart__content .woocommerce-mini-cart-item .remove:hover::after {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2308050C' stroke-width='2' stroke-linecap='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3C/svg%3E");
}

.mesa-mini-cart__content .woocommerce-mini-cart__empty-message {
    text-align: center;
    padding: var(--space-2xl);
    color: var(--mesa-gray-text);
}

#mesa-mini-cart .mesa-mini-cart__footer,
.mesa-mini-cart__footer {
    padding: 20px 24px 26px !important;
    border-top: 1px solid #f1f1f1 !important;
    background: #f5f5f5 !important;
    flex-shrink: 0 !important;
}

#mesa-mini-cart .mesa-mini-cart__subtotal,
.mesa-mini-cart__subtotal {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 20px !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    line-height: 140% !important;
    color: #000000 !important;
}

#mesa-mini-cart .mesa-mini-cart__buttons,
.mesa-mini-cart__buttons {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
}

#mesa-mini-cart .mesa-mini-cart__checkout,
.mesa-mini-cart__checkout {
    display: block !important;
    width: 100% !important;
    padding: 14px 16px !important;
    background-color: #CEFE65 !important;
    color: #08050C !important;
    text-align: center !important;
    text-decoration: none !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    border-radius: 0 !important;
    border: none !important;
    transition: all 0.2s ease !important;
}

#mesa-mini-cart .mesa-mini-cart__checkout:hover,
.mesa-mini-cart__checkout:hover {
    background-color: #08050C !important;
    color: #CEFE65 !important;
}

#mesa-mini-cart .mesa-mini-cart__continue,
.mesa-mini-cart__continue {
    display: block !important;
    width: 100% !important;
    padding: 14px 16px !important;
    background: #fff !important;
    /* border: 2px solid #08050C !important; */
    color: #08050C !important;
    text-align: center !important;
    font-weight: 500 !important;
    border-radius: 0 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
}

#mesa-mini-cart .mesa-mini-cart__continue:hover,
.mesa-mini-cart__continue:hover {
    background-color: #08050C !important;
    color: #fff !important;
}

/* Body class when cart is open */
body.mesa-cart-open {
    overflow: hidden !important;
}

/* Hide WooCommerce default mini-cart buttons (we have our own footer) */
#mesa-mini-cart .woocommerce-mini-cart__buttons,
#mesa-mini-cart .widget_shopping_cart_content .woocommerce-mini-cart__buttons,
#mesa-mini-cart .widget_shopping_cart_content > .total,
#mesa-mini-cart .widget_shopping_cart_content p.total,
#mesa-mini-cart .widget_shopping_cart_content p.buttons,
.mesa-mini-cart__content .woocommerce-mini-cart__buttons,
.mesa-mini-cart__content .woocommerce-mini-cart__total {
    display: none !important;
}

/* Style the WooCommerce cart items list */
#mesa-mini-cart .woocommerce-mini-cart,
.mesa-mini-cart__content .woocommerce-mini-cart {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

#mesa-mini-cart .woocommerce-mini-cart-item,
.mesa-mini-cart__content .woocommerce-mini-cart-item {
    display: flex !important;
    align-items: stretch !important;
    gap: 0 !important;
    padding: 0 0 16px !important;
    border-bottom: none !important;
    justify-content: space-between !important;
    width: 100% !important;
}

#mesa-mini-cart .woocommerce-mini-cart-item:last-child {
    border-bottom: none !important;
}

.mesa-mini-cart_wrap-img {
    position: relative;
}

#mesa-mini-cart .woocommerce-mini-cart-item img {
    margin-right: 0 !important;
    width: 66px !important;
    height: 66px !important;
    object-fit: cover !important;
    border-radius: 0 !important;
    flex-shrink: 0 !important;
}

#mesa-mini-cart .woocommerce-mini-cart-item > a {
    flex: 1 !important;
    color: #08050C !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    font-size: 14px !important;
}

/*.mesa-mini-cart_col .mesa-qty {*/
/*    margin-top: 12px !important;*/
/*}*/

#mesa-mini-cart .woocommerce-mini-cart-item .quantity {
    display: block !important;
    padding-left: 0 !important;
    color: #08050C !important;
    /* margin-top: 12px !important; */
    font-family: var(--font-hebrew);
    font-size: 15px !important;
    font-weight: 700 !important;
    line-height: 140% !important;
}

#mesa-mini-cart .woocommerce-mini-cart-item .quantity .price-new {
    color: #08050C !important;
}

#mesa-mini-cart .woocommerce-mini-cart-item .quantity .price-old {
    color: #08050C;
    text-decoration-line: line-through;
}

#mesa-mini-cart .woocommerce-mini-cart-item .remove {
    color: transparent !important;
    font-size: 0 !important;
    text-decoration: none !important;
    line-height: 1 !important;
    width: 16px;
    height: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: none !important;
    position: absolute;
    flex-shrink: 0;
}

#mesa-mini-cart .woocommerce-mini-cart-item .remove::after {
    content: '';
    width: 16px;
    height: 16px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'%3E%3Crect width='12' height='12' fill='%2308050C'/%3E%3Cpath d='M9 3L3 9M3 3L9 9' stroke='white' stroke-width='0.7' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-size: contain;
}

#mesa-mini-cart .woocommerce-mini-cart-item .remove:hover::after {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2308050C' stroke-width='2' stroke-linecap='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3C/svg%3E");
}

@media screen and (max-width: 768px) {
    #mesa-mini-cart .mesa-mini-cart__drawer,
    .mesa-mini-cart__drawer {
        width: 99% !important;
    }

    /*.mesa-mini-cart_col-3 {*/
    /*    flex: 0 0 100%;*/
    /*    align-items: flex-start;*/
    /*    padding-top: 16px;*/
    /*    flex-flow: row-reverse;*/
    /*}*/

    /*.mesa-mini-cart_col .mesa-qty {*/
    /*    margin-top: 0 !important;*/
    /*}*/

}

@media screen and (max-width: 390px) {
    .mesa-upsell-item__btn {
        width: 100%;
    }

    .mesa-upsell-item__content,
    .mesa-mini-cart_col-2 {
        margin-left: 0px !important;
    }

    .mesa-mini-cart_col-3 {
        flex: 0 0 100%;
    }
}

/* Empty cart message */
#mesa-mini-cart .woocommerce-mini-cart__empty-message,
.mesa-mini-cart__content .woocommerce-mini-cart__empty-message {
    text-align: center !important;
    padding: 48px 24px !important;
    color: #888 !important;
    font-size: 15px !important;
}

.mesa-upsell-item__btn.is-added {
    min-width: 114px;
    color: var(--mesa-black);
    pointer-events: none;
}

.mesa-upsell-item__btn.is-loading {
    min-width: 114px;
    background: var(--mesa-lime);
    color: var(--mesa-black);
    border: none;
    padding: 8px 16px;
    text-align: center;
    font-family: var(--font-hebrew);
    font-weight: 400;
    line-height: 140%;
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.2s ease;
    pointer-events: none;
}

.mesa-upsell-item__btn.is-loading:hover,
.mesa-upsell-item__btn.is-loading:active,
.mesa-upsell-item__btn.is-loading:focus,
.mesa-upsell-item__btn.is-added:hover,
.mesa-upsell-item__btn.is-added:active,
.mesa-upsell-item__btn.is-added:focus {
    background: var(--mesa-lime);
    color: var(--mesa-black);
}

.mesa-upsell-item__btn.is-added::after {
    content: "✔";
    font-size: 16px;
}

.mesa-upsell-item__btn {
    min-width: 100px;
    background: var(--mesa-lime);
    color: var(--mesa-black);
    border: none;
    border-radius: 0;
    padding: 8px 16px;
    text-align: center;
    font-family: var(--font-hebrew);
    font-size: 15px;
    font-weight: 400;
    line-height: 140%;
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.2s ease;
}

.mesa-upsell-item__btn:hover {
    background: #000;
    color: #fff;
}

.mesa-upsell-item__price {
    display: flex;
    gap: 12px;
}

.mesa-upsell-item__image {
    margin-left: 20px;
    flex: 0 0 auto;
}

.mesa-mini-cart__upsells .price-new {
    color: #08050C;
    text-align: right;
    font-family: var(--font-hebrew);
    font-size: 15px;
    font-weight: 600;
    line-height: 140%;
}

.mesa-mini-cart__upsells .price-old {
    color: rgba(8, 5, 12, 0.6);
    text-align: right;
    font-family: var(--font-hebrew);
    font-size: 15px;
    font-weight: 600;
    line-height: 140%;
    text-decoration-line: line-through;
}

.mesa-mini-cart__upsells .price {
    color: #08050C;
    text-align: right;
    font-family: var(--font-hebrew);
    font-size: 15px;
    font-weight: 600;
    line-height: 140%;
}

.mesa-upsell-item__content {
    flex: 1;
    min-width: 0;
    margin-left: 16px;
}

.mesa-upsell-item__title {
    margin-bottom: 3px;
    color: #000;
    text-align: right;
    font-family: var(--font-hebrew);
    font-size: 15px;
    font-weight: 400;
    line-height: 140%;
}

.mesa-upsell-item__title a {
    color: #000;
    text-decoration: none;
}

.mesa-upsell-item__image img {
    width: 66px;
    height: 66px;
    object-fit: cover;
}

.mesa-upsell-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    /*gap: 12px;*/
}

.mesa-mini-cart__upsells-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.mesa-mini-cart__upsells {
    padding-top: 16px;
    border-top: 1px solid #D9D9D9;
}

.mesa-mini-cart__upsells-title {
    margin-bottom: 16px;
    color: #000;
    text-align: right;
    font-family: var(--font-hebrew);
    font-size: 15px;
    font-weight: 400;
    line-height: 140%;
    text-align: right;
}

@media screen and (max-width: 768px) {
    .mesa-upsell-item {
        flex-wrap: wrap;
        row-gap: 10px;
    }

    #mesa-mini-cart .woocommerce-mini-cart-item,
    .mesa-mini-cart__content .woocommerce-mini-cart-item {
        flex-wrap: wrap;
        row-gap: 10px;
    }

    /*.mesa-mini-cart_col-2 {*/
    /*    width: calc(100% - 106px);*/
    /*}*/
}

/* ===========================================
   MOBILE MENU - Off-canvas
   CRITICAL: Hidden on desktop, available on mobile
   =========================================== */
.mesa-mobile-menu,
#mesa-mobile-menu,
div.mesa-mobile-menu,
.site .mesa-mobile-menu {
    display: none !important;
    visibility: hidden !important;
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    left: 0 !important;
    z-index: 9999 !important;
    pointer-events: none !important;
}

/* Mobile: Allow mobile menu to work */
@media screen and (max-width: 850px) {
    .mesa-mobile-menu,
    #mesa-mobile-menu,
    div.mesa-mobile-menu {
        display: block !important;
        visibility: visible !important;
    }

    .mesa-mobile-menu.is-open,
    #mesa-mobile-menu.is-open {
        pointer-events: all !important;
    }
}

/* ===========================================
   MOBILE MENU — Overlay
   =========================================== */
.mesa-mobile-menu__overlay {
    position: absolute;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.5);
    opacity: 0;
    transition: opacity 0.3s ease;
}

.mesa-mobile-menu.is-open .mesa-mobile-menu__overlay {
    opacity: 1;
}

/* ===========================================
   MOBILE MENU — Panel (full-width)
   =========================================== */
.mesa-mobile-menu__panel {
    position: fixed;
    top: 0;
    right: 0;
    /*bottom: 0;*/
    width: 100%;
    height: 100dvh;
    background-color: var(--mesa-white, #ffffff);
    transform: translateX(100%);
    transition: transform 0.3s ease;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    z-index: 9999;
}

.mesa-mobile-menu.is-open .mesa-mobile-menu__panel {
    transform: translateX(0);
}

/* ===========================================
   MOBILE MENU — Header (X close, right-aligned)
   =========================================== */
.mesa-mobile-menu__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    /*flex-direction: row;*/
    flex-shrink: 0;
    padding: clamp(15px, 4vh, 30px) 20px;
    position: relative;
}

.mesa-mobile-menu__header .mesa-mobile-menu__back {
    display: none !important;
    background: none;
    border: none;
    box-shadow: none;
    padding: 0px;
    cursor: pointer;
    align-items: center;
    justify-content: center;
    order: 1;
}

.mesa-mobile-menu__header .mesa-mobile-menu__back svg {
    transform: rotate(180deg);
}

.mesa-mobile-menu__header .mesa-mobile-menu__title {
    font-weight: 600;
    font-size: 16px;
    color: var(--mesa-black);
    line-height: 22px;
    flex-grow: 1;
    text-align: center;
    order: 2;
}

.mesa-mobile-menu__close {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none !important;
    border: none;
    cursor: pointer;
    color: var(--mesa-black, #08050C);
    padding: 0;
    margin-right: 3px;
}

.mesa-mobile-menu__close svg {
    width: 2rem !important;
    height: 2rem !important;
}

.mesa-mobile-menu__close:focus-visible {
    outline: 2px solid var(--mesa-lime, #CEFE65);
    outline-offset: 2px;
}

.mesa-mobile-menu.is-sub-menu-active .mesa-mobile-menu__close {
    display: none !important;
}

.mesa-mobile-menu.is-sub-menu-active .mesa-mobile-menu__back {
    display: flex !important;
}

.mesa-mobile-menu.is-sub-menu-active .mesa-mobile-menu__header::before {
    content: '';
    width: 27px;
    order: 3;
    display: block;
}

/* ===========================================
   MOBILE MENU — Content
   =========================================== */
.mesa-mobile-menu__content {
    min-height: 0;
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    padding: 0;
}

.mesa-mobile-menu__content.is-sub-opened {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.mesa-mobile-menu__content .mesa-mobile-menu__list {
    flex: 1;
    display: flex;
    flex-direction: column;
    /*justify-content: space-evenly;*/
    padding: 0 20px !important;
}

.mesa-mobile-menu__content .mesa-mobile-menu__account-row {
    padding: 0 20px;
    margin-bottom: clamp(10px, 3vh, 25px);
}

.mesa-mobile-menu__content .mesa-mobile-menu__account-row a {
    position: relative;
    display: flex;
    column-gap: 16px;
    align-items: center;
    color: var(--mesa-black, #08050C);
    text-decoration: none;
    font-family: 'Open Sans', sans-serif;
    font-size: 16px;
    font-weight: 600;
    text-align: right;
    border-bottom: 1px solid #F5F5F5;
    padding: clamp(10px, 2vh, 20px) 0;
    line-height: 1.2;
}

.mesa-mobile-menu__list > li {
    position: relative !important;
    border-bottom: 1px solid #F5F5F5;
}

.mesa-mobile-menu__list > li > a {
    display: block;
    font-family: 'Open Sans', sans-serif;
    /*font-size: 16px;*/
    font-size: clamp(14px, 2vh, 16px);
    font-weight: 600;
    color: var(--mesa-black, #08050C);
    line-height: 32px;
    text-decoration: none;
    text-align: right;
    padding: clamp(10px, 1.8vh, 20px) 0;
}

/* ===========================================
   MOBILE MENU — Lime parallelogram arrow
   Created by JS on all top-level items
   =========================================== */
.mesa-mobile-menu__arrow {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 32px;
    background-color: var(--mesa-lime, #CEFE65);
    clip-path: polygon(11px 0, 100% 0, calc(100% - 11px) 100%, 0 100%);
    cursor: pointer;
    border: none;
}

.mesa-mobile-menu__arrow svg {
    width: 1rem;
    height: 1rem;
    stroke: var(--mesa-black, #08050C);
    stroke-width: 2.5;
    fill: none;
}

/* ===========================================
   MOBILE MENU — Submenus (keep existing accordion)
   =========================================== */
.mesa-mobile-menu__list .sub-menu {
    list-style: none;
    padding: 0 1.25rem 0.625rem;
    margin: 0;
    display: none;
}

.mesa-mobile-menu__list .sub-menu.is-open {
    display: block;
}

.mesa-mobile-menu__list .sub-menu a {
    font-size: 0.875rem;
    font-weight: 400;
    padding: 0.625rem 0;
    color: #666;
    display: block;
    text-decoration: none;
}

/* Hide old toggle button — replaced by lime arrow */
.mesa-submenu-toggle {
    display: none;
}

/* Hide login/account items */
.mesa-mobile-menu__account {
    display: none !important;
}

/* ===========================================
   MOBILE MENU — Social icons
   =========================================== */
.mesa-mobile-menu__social {
    display: flex;
    justify-content: center;
    gap: 24px;
    padding: clamp(15px, 3vh, 30px) 20px;
    margin-top: auto;
    flex-shrink: 0;
    flex-flow: row-reverse;
}

.mesa-mobile-menu__social a {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--mesa-black, #08050C);
    transition: color 0.15s ease;
}

.mesa-mobile-menu__social a:hover {
    color: var(--mesa-lime, #CEFE65);
}

.mesa-mobile-menu__social svg {
    width: 1.625rem;
    height: 1.625rem;
}

/* ===========================================
   MOBILE MENU — Body lock
   =========================================== */
body.mobile-menu-open {
    overflow: hidden;
    height: 100vh !important;
    position: fixed;
    width: 100%;
}

/* ===========================================
   MOBILE BOTTOM NAV - App-like Navigation
   CRITICAL: Hidden on desktop, visible on mobile only
   =========================================== */
nav.mesa-bottom-nav,
.mesa-bottom-nav,
.site nav.mesa-bottom-nav,
body nav.mesa-bottom-nav {
    display: none !important;
    visibility: hidden !important;
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 9998 !important;
    background-color: var(--mesa-white, #ffffff) !important;
    box-shadow: 0 -2px 20px rgba(0, 0, 0, 0.1) !important;
    padding: 8px 0 !important;
    padding-bottom: calc(8px + env(safe-area-inset-bottom, 0px)) !important;
}

/* Mobile: Show bottom nav */
@media screen and (max-width: 768px) {
    nav.mesa-bottom-nav,
    .mesa-bottom-nav,
    .site nav.mesa-bottom-nav,
    body nav.mesa-bottom-nav {
        display: flex !important;
        visibility: visible !important;
        flex-direction: row !important;
        justify-content: space-around !important;
        align-items: center !important;
    }
}

.mesa-bottom-nav__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    flex: 1;
    padding: 8px 5px;
    color: var(--mesa-gray-text, #6B7280);
    text-decoration: none;
    font-size: 10px;
    font-weight: 500;
    background: none;
    border: none;
    cursor: pointer;
    position: relative;
    transition: color 0.2s ease;
}

.mesa-bottom-nav__item svg {
    width: 22px;
    height: 22px;
}

.mesa-bottom-nav__item--active,
.mesa-bottom-nav__item:hover {
    color: var(--mesa-black, #08050C);
}

.mesa-bottom-nav__item--whatsapp,
.mesa-bottom-nav__support {
    color: #25D366;
}

.mesa-bottom-nav__cart,
.mesa-bottom-nav__item--cart {
    position: relative;
}

.mesa-bottom-nav__cart-count {
    position: absolute;
    top: 2px;
    right: 50%;
    transform: translateX(50%);
    margin-right: -15px;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    background-color: var(--mesa-lime, #CEFE65);
    color: var(--mesa-black, #08050C);
    font-size: 10px;
    font-weight: 700;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Body padding when bottom nav is visible */
@media screen and (max-width: 768px) {
    body.has-bottom-nav {
        padding-bottom: calc(70px + env(safe-area-inset-bottom, 0px)) !important;
    }

    body.has-bottom-nav .site-footer,
    body.has-bottom-nav footer {
        /*margin-bottom: calc(70px + env(safe-area-inset-bottom, 0px)) !important;*/
    }
}

/* ===========================================
   SEARCH OVERLAY - Mobile Only
   CRITICAL: Always hidden on desktop
   =========================================== */
.mesa-search-overlay,
div.mesa-search-overlay,
.site .mesa-search-overlay {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    position: fixed !important;
    inset: 0 !important;
    z-index: 10000 !important;
    background-color: rgba(0, 0, 0, 0.9) !important;
    align-items: flex-start !important;
    justify-content: center !important;
    padding: 20vh 20px !important;
    transition: all 0.3s ease !important;
}

/* Allow search overlay to open on all screen sizes */
.mesa-search-overlay.is-open,
div.mesa-search-overlay.is-open,
.site .mesa-search-overlay.is-open {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
}

.mesa-search-overlay__container,
.mesa-search-overlay__inner {
    width: 100%;
    max-width: 600px;
    position: relative;
}

.mesa-search-overlay__close {
    position: absolute;
    top: -50px;
    left: 0;
    width: 3rem;
    height: 3rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: none !important;
    background-color: transparent !important;
    box-shadow: none !important;
    border: none !important;
    outline: none !important;
    cursor: pointer;
    color: var(--mesa-white, #ffffff);
    padding: 0;
}

.mesa-search-overlay__close:hover,
.mesa-search-overlay__close:focus,
.mesa-search-overlay__close:focus-visible,
.mesa-search-overlay__close:active {
    background: none !important;
    background-color: transparent !important;
    box-shadow: none !important;
    outline: none !important;
    opacity: 0.7;
}

.mesa-search-overlay__close svg {
    width: 2rem !important;
    height: 2rem !important;
}

.mesa-search-overlay__content,
.mesa-search-overlay__form {
    width: 100%;
}

.mesa-search-overlay__content input,
.mesa-search-overlay__form input {
    width: 100%;
    padding: 20px 25px;
    border: none;
    border-radius: 10px;
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    background-color: var(--mesa-white, #ffffff);
}

/* Style FiboSearch inside overlay */
.mesa-search-overlay .dgwt-wcas-search-wrapp {
    width: 100% !important;
}

.mesa-search-overlay .dgwt-wcas-sf-wrapp input.dgwt-wcas-search-input {
    width: 100% !important;
    padding: 20px 25px !important;
    border: none !important;
    border-radius: 10px !important;
    font-family: 'Open Sans', sans-serif !important;
    font-size: 18px !important;
    font-weight: 400 !important;
    background-color: var(--mesa-white, #ffffff) !important;
}

body.search-overlay-open {
    overflow: hidden;
}

/* Legacy trust strip, footer, and copyright CSS removed — now in assets/css/footer.css */

/* ===========================================
   RESPONSIVE: Tablet
   =========================================== */
@media (max-width: 1024px) {
    .mesa-header__inner {
        gap: 20px;
    }

    .mesa-header__search {
        max-width: 350px;
    }

    .mesa-navbar__menu > li > a {
        padding: 15px 18px;
        font-size: 14px;
    }

}

/* ===========================================
   RESPONSIVE: Mobile - HIGH SPECIFICITY
   CRITICAL: These rules override Kadence parent
   =========================================== */
@media screen and (max-width: 768px) {
    /* Top Bar - Mobile adjustments */
    .mesa-topbar {
        padding: 4px var(--space-sm);
    }

    .mesa-topbar__message {
        font-size: var(--text-xs);
    }

    /* HEADER - Mobile layout: Hamburger | Logo | Cart */
    #mesa-header .mesa-header__inner,
    header#mesa-header .mesa-header__inner,
    .site #mesa-header .mesa-header__inner,
    header .mesa-header__inner {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        justify-content: space-between !important;
        align-items: center !important;
        gap: 10px !important;
        padding: 12px 15px !important;
    }

    /* HIDE desktop search on mobile */
    #mesa-header .mesa-header__search,
    header#mesa-header .mesa-header__search,
    .mesa-header__search,
    .mesa-header__search.mesa-desktop-only {
        display: none !important;
        visibility: hidden !important;
    }

    /* SHOW hamburger on mobile */
    #mesa-header .mesa-header__hamburger,
    header#mesa-header .mesa-header__hamburger,
    .mesa-header__hamburger {
        display: flex !important;
        visibility: visible !important;
        order: -1 !important; /* Move to right side in RTL */
    }

    /* Header icons - only cart visible */
    #mesa-header .mesa-header__icons,
    header#mesa-header .mesa-header__icons,
    .mesa-header__icons {
        display: flex !important;
        gap: 10px !important;
    }

    #mesa-header .mesa-header__icon--account,
    #mesa-header .mesa-header__icon--wishlist,
    .mesa-header__icon--account,
    .mesa-header__icon--wishlist,
    .mesa-header__icon.mesa-desktop-only {
        display: none !important;
        visibility: hidden !important;
    }

    .mesa-header__icon-label {
        display: none !important;
    }

    /* HIDE desktop navbar on mobile */
    nav.mesa-navbar,
    .mesa-navbar,
    .mesa-navbar.mesa-desktop-only {
        display: none !important;
        visibility: hidden !important;
    }

    /* SHOW bottom nav on mobile */
    nav.mesa-bottom-nav,
    .mesa-bottom-nav,
    .mesa-bottom-nav.mesa-mobile-only {
        display: flex !important;
        visibility: visible !important;
    }

    /* Add padding for bottom nav */
    body,
    body.page,
    body.single,
    body.archive {
        padding-bottom: 70px !important;
    }

}

/* ===========================================
   RESPONSIVE: Small Mobile (480px)
   =========================================== */
@media screen and (max-width: 480px) {
    #mesa-header .mesa-header__logo img,
    .mesa-header__logo img {
        max-height: 35px !important;
    }

    .mesa-bottom-nav__item {
        font-size: 9px !important;
    }

    .mesa-bottom-nav__item svg {
        width: 20px !important;
        height: 20px !important;
    }
}

/* ===========================================
   KADENCE HEADER SHORTCODE STYLING (FORCE OVERRIDE)
   Direct targeting of FiboSearch classes for max specificity
   =========================================== */

/* -------------------------------------------
   1. TOP BAR TEXT
   ------------------------------------------- */
.mesa-top-bar-text {
    font-size: 13px;
    font-weight: 500;
    color: #555;
    letter-spacing: 0.01em;
}

/* Kadence Top Row Background */
.site-header-row.site-header-row-top,
.site-header-row.site-header-row-top .site-header-row-container-inner {
    background-color: #f5f5f5 !important;
}

/* -------------------------------------------
   2. WHATSAPP BUTTON - Solid Green Pill
   ------------------------------------------- */
a.mesa-wa-header-link {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 6px;
    background-color: #25D366 !important;
    color: #fff !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    padding: 6px 16px !important;
    border-radius: 50px !important;
    text-decoration: none !important;
    transition: all 0.3s ease;
    line-height: 1.4;
    box-shadow: 0 2px 8px rgba(37, 211, 102, 0.25);
    white-space: nowrap;
}

a.mesa-wa-header-link:hover {
    background-color: #128C7E !important;
    color: #fff !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(37, 211, 102, 0.35);
}

a.mesa-wa-header-link svg {
    flex-shrink: 0;
    fill: currentColor;
}

/* -------------------------------------------
   3. FIBOSEARCH - Direct Class Targeting
   ------------------------------------------- */

/* Main Wrapper - Center and limit width */
.dgwt-wcas-search-wrapp {
    max-width: 600px !important;
    margin: 0 auto !important;
    width: 100% !important;
}

/* The form wrapper */
.dgwt-wcas-sf-wrapp {
    border-radius: 50px !important;
    overflow: hidden !important;
    border: none !important;
    box-shadow: none !important;
}

/* Input Field - Full Rounded */
.dgwt-wcas-sf-wrapp input[type="search"].dgwt-wcas-search-input,
input.dgwt-wcas-search-input {
    background-color: #f0f2f5 !important;
    border: 1px solid #e1e1e1 !important;
    border-radius: 50px !important;
    height: 48px !important;
    padding-right: 20px !important;
    padding-left: 55px !important;
    font-family: 'Open Sans', sans-serif !important;
    font-size: 15px !important;
    font-weight: 400 !important;
    box-shadow: none !important;
    transition: all 0.2s ease !important;
}

/* Input Placeholder */
.dgwt-wcas-sf-wrapp input[type="search"].dgwt-wcas-search-input::placeholder,
input.dgwt-wcas-search-input::placeholder {
    font-family: 'Open Sans', sans-serif !important;
    font-weight: 400 !important;
}

/* Input Focus State */
.dgwt-wcas-sf-wrapp input[type="search"].dgwt-wcas-search-input:focus,
input.dgwt-wcas-search-input:focus {
    border-color: #CEFE65 !important;
    background-color: #fff !important;
    box-shadow: 0 0 0 3px rgba(206, 254, 101, 0.25) !important;
    outline: none !important;
}

/* Submit Button (Magnifying Glass) */
.dgwt-wcas-sf-wrapp .dgwt-wcas-search-submit,
button.dgwt-wcas-search-submit {
    background: transparent !important;
    border: none !important;
    color: #333 !important;
    border-radius: 50% !important;
    width: 48px !important;
    height: 48px !important;
    right: auto !important;
    left: 2px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    position: absolute !important;
}

.dgwt-wcas-sf-wrapp .dgwt-wcas-search-submit:hover {
    color: #08050C !important;
}

/* Search Icon inside button */
.dgwt-wcas-sf-wrapp .dgwt-wcas-search-submit svg,
.dgwt-wcas-sf-wrapp .dgwt-wcas-ico-magnifier {
    width: 20px !important;
    height: 20px !important;
}

/* Preloader */
.dgwt-wcas-preloader {
    right: auto !important;
    left: 15px !important;
}

/* Suggestions dropdown */
.dgwt-wcas-suggestions-wrapp {
    border-radius: 12px !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.12) !important;
    border: 1px solid #eee !important;
    margin-top: 8px !important;
    font-family: 'Open Sans', sans-serif !important;
}

/* Suggestions — typography (Open Sans) */
.dgwt-wcas-suggestions-wrapp .dgwt-wcas-suggestion,
.dgwt-wcas-suggestions-wrapp .dgwt-wcas-st,
.dgwt-wcas-suggestions-wrapp .dgwt-wcas-sp,
.dgwt-wcas-suggestions-wrapp .dgwt-wcas-sd,
.dgwt-wcas-suggestions-wrapp .dgwt-wcas-content-wrapp,
.dgwt-wcas-suggestions-wrapp .dgwt-wcas-suggestion-title,
.dgwt-wcas-suggestions-wrapp .dgwt-wcas-suggestion-price,
.dgwt-wcas-suggestions-wrapp .dgwt-wcas-suggestion-desc {
    font-family: 'Open Sans', sans-serif !important;
}

/* Suggestions — product title */
.dgwt-wcas-suggestions-wrapp .dgwt-wcas-st {
    font-weight: 500 !important;
}

/* Suggestions — product price */
.dgwt-wcas-suggestions-wrapp .dgwt-wcas-sp {
    font-weight: 600 !important;
}

/* Suggestions — "more results" / category headings */
.dgwt-wcas-suggestions-wrapp .dgwt-wcas-suggestion-headline {
    font-family: 'Open Sans', sans-serif !important;
    font-weight: 600 !important;
}

/* Suggestions — no results text */
.dgwt-wcas-suggestions-wrapp .dgwt-wcas-suggestion-nores {
    font-family: 'Open Sans', sans-serif !important;
}

/* Details panel (FiboSearch Pro right-side preview) */
.dgwt-wcas-details-wrapp,
.dgwt-wcas-details-wrapp * {
    font-family: 'Open Sans', sans-serif !important;
}

/* Custom wrapper if used */
.mesa-custom-search-wrapper {
    width: 100%;
    max-width: 600px;
    margin: 0 auto;
}

/* -------------------------------------------
   4. MAIN NAVIGATION STYLING
   ------------------------------------------- */
.site-header .primary-menu-container > ul > li,
.header-navigation .header-menu-container > ul > li {
    margin: 0 8px !important;
}

.site-header .primary-menu-container > ul > li > a,
.header-navigation .header-menu-container > ul > li > a {
    font-weight: 500 !important;
    font-size: 15px !important;
    padding: 12px 12px !important;
    color: #08050C !important;
    transition: color 0.2s ease !important;
}

.site-header .primary-menu-container > ul > li > a:hover,
.site-header .primary-menu-container > ul > li.current-menu-item > a {
    color: #CEFE65 !important;
}

/* Dropdown Menu */
.site-header .sub-menu,
.site-header .primary-menu-container .sub-menu {
    background-color: #fff !important;
    border-radius: 8px !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1) !important;
    border: 1px solid #eee !important;
    padding: 8px 0 !important;
}

.site-header .sub-menu li a {
    padding: 10px 20px !important;
    font-size: 14px !important;
    color: #333 !important;
}

.site-header .sub-menu li a:hover {
    background-color: #f5f5f5 !important;
}

/* -------------------------------------------
   5. HEADER ICONS (Cart, Account)
   ------------------------------------------- */
.site-header .header-cart-button,
.site-header .header-account-button {
    color: #08050C !important;
    transition: color 0.2s ease !important;
}

.site-header .header-cart-button:hover,
.site-header .header-account-button:hover {
    color: #CEFE65 !important;
}

/* Cart Count Badge */
.header-cart-wrap .header-cart-button .header-cart-total {
    background-color: #CEFE65 !important;
    color: #08050C !important;
    font-weight: 700 !important;
    font-size: 11px !important;
    min-width: 18px !important;
    height: 18px !important;
    line-height: 18px !important;
    border-radius: 50% !important;
}

/* -------------------------------------------
   6. RESPONSIVE ADJUSTMENTS
   ------------------------------------------- */
@media screen and (max-width: 1024px) {
    .dgwt-wcas-search-wrapp {
        max-width: 450px !important;
    }
}

@media screen and (max-width: 768px) {
    .mesa-top-bar-text {
        font-size: 11px;
    }

    /* WhatsApp - Icon only on mobile */
    a.mesa-wa-header-link {
        padding: 8px !important;
        border-radius: 50% !important;
    }

    a.mesa-wa-header-link span {
        display: none !important;
    }

    a.mesa-wa-header-link svg {
        margin: 0 !important;
    }

    /* Search - Full width on mobile */
    .dgwt-wcas-search-wrapp {
        max-width: 100% !important;
    }

    .dgwt-wcas-sf-wrapp input[type="search"].dgwt-wcas-search-input,
    input.dgwt-wcas-search-input {
        height: 44px !important;
        font-size: 14px !important;
    }
}

/* ===========================================
   SHOP / CATEGORY PAGE (PLP) STYLES
   =========================================== */

/* -------------------------------------------
   1. LAYOUT & CONTAINER
   ------------------------------------------- */
.mesa-shop {
    padding: var(--space-lg) 0 var(--space-3xl);
    background-color: var(--mesa-white);
    position: relative;
    overflow: hidden;
}

.mesa-shop__deco-svg {
    position: absolute;
    top: 0;
    left: 0;
    width: clamp(14rem, 38.4vw, 36.3rem);
    height: auto;
    pointer-events: none;
    z-index: 0;
}

.mesa-shop__container {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--container-padding);
    position: relative;
    z-index: 1;
}

.mesa-shop__layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-xl);
}

/* Desktop: Sidebar + Main */
@media screen and (min-width: 1024px) {
    .mesa-shop--has-filters .mesa-shop__layout {
        grid-template-columns: 260px 1fr;
    }
}

.mesa-shop__main {
    min-width: 0; /* Prevent grid blowout */
}

/* -------------------------------------------
   2. CATEGORY HEADER
   ------------------------------------------- */
.mesa-shop__breadcrumbs {
    margin-top: 0 !important;
    margin-bottom: var(--space-md) !important;
    direction: rtl;
    text-align: right;
}

.mesa-shop__breadcrumbs ol,
.mesa-shop__breadcrumbs ul,
.mesa-shop__breadcrumbs .mesa-breadcrumb-list {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: center;
    justify-content: flex-start;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    font-family: 'Open Sans', sans-serif;
    font-weight: 400;
    font-size: 0.9375rem;
    line-height: 140%;
    letter-spacing: 0;
    color: #08050C;
}

.mesa-shop__breadcrumbs li {
    display: inline-flex !important;
    align-items: center;
    list-style: none !important;
}

.mesa-shop__breadcrumbs a {
    color: #08050C;
    text-decoration: none;
}

.mesa-shop__breadcrumbs a:hover {
    color: var(--mesa-lime, #CEFE65);
}

.mesa-shop__breadcrumbs .mesa-breadcrumb-sep {
    display: inline-flex;
    align-items: center;
    margin: 0 0.25rem;
}

.mesa-shop__header {
    margin-bottom: var(--space-xl);
    text-align: right;
}

.mesa-shop__title {
    font-family: 'Open Sans', sans-serif !important;
    font-size: clamp(1.75rem, 3.44vw, 3.25rem);
    font-weight: var(--font-bold);
    font-style: italic !important;
    color: var(--mesa-black);
    margin: 0 0 var(--space-sm);
}

.mesa-shop__intro {
    font-size: var(--text-base);
    color: var(--mesa-gray-text);
    margin: 0 0 var(--space-md);
    max-width: 600px;
}

.mesa-shop__trust-line {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    background-color: rgba(206, 254, 101, 0.15);
    color: var(--mesa-black);
    padding: var(--space-sm) var(--space-lg);
    border-radius: var(--radius-full);
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
}

.mesa-shop__trust-icon {
    color: var(--mesa-lime);
    flex-shrink: 0;
}

/* -------------------------------------------
   3. CONTROLS BAR
   ------------------------------------------- */
.mesa-shop__controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-md) 0;
    margin-bottom: var(--space-lg);
    border-bottom: none;
    flex-wrap: wrap;
    gap: var(--space-md);
}

.mesa-shop__controls-right,
.mesa-shop__controls-left,
.mesa-shop__controls-filters {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--space-md);
}


.mesa-active-filters .mesa-active-filters__chips {
    display: flex;
    flex-wrap: wrap;
    column-gap: 10px;
}

.mesa-active-filters .mesa-active-filters__chips .mesa-filter-chip {
    display: flex;
    column-gap: 5px;
}

.mesa-active-filters .mesa-active-filters__chips .mesa-filter-chip .mesa-filter-chip__remove {
    width: 25px;
    height: 25px;
    border-radius: 50%;
    background-color: #F5F5F5;
    font-size: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
}

@media screen and (min-width: 769px) {
    .mesa-shop__controls-filters {
        display: none;
    }
}

.mesa-shop__product-count {
    font-family: 'Open Sans', sans-serif;
    font-weight: 400;
    font-size: 0.9375rem;
    line-height: 140%;
    letter-spacing: 0;
    text-align: right;
    color: #08050C;
}

/* Sort Dropdown */
.mesa-shop__sort {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.mesa-shop__sort-select {
    padding: 0.625rem 1rem;
    padding-left: 2.5rem;
    border: none;
    border-radius: 0;
    font-family: 'Open Sans', sans-serif;
    font-weight: 400;
    font-size: 0.9375rem;
    line-height: 140%;
    letter-spacing: 0;
    text-align: right;
    color: #08050C;
    background-color: #F5F5F5;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2308050C' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: left 10px center;
}

.mesa-shop__sort-select:focus {
    outline: 2px solid var(--mesa-lime, #CEFE65);
    outline-offset: -2px;
}

/* Filter Toggle Button (Mobile) */
.mesa-shop__filter-toggle {
    display: none;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
    background-color: var(--mesa-black);
    color: var(--mesa-white);
    border: none;
    border-radius: var(--radius-md);
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.mesa-shop__filter-toggle:hover {
    background-color: #222;
}

.mesa-shop__filter-badge {
    flex-shrink: 1;
    background-color: var(--mesa-lime);
    color: var(--mesa-black);
    font-size: 11px;
    font-weight: var(--font-bold);
    min-width: 18px;
    height: 18px;
    line-height: 18px;
    text-align: center;
    border-radius: var(--radius-full);
}

/* -------------------------------------------
   4. PRODUCT GRID
   ------------------------------------------- */
.mesa-product-grid,
ul.mesa-product-grid,
ul.mesa-product-grid.products {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
    list-style: none !important;
    margin: 0;
    padding: 0;
}

.mesa-product-grid .product,
ul.mesa-product-grid .product {
    list-style: none !important;
}

@media screen and (min-width: 768px) {
    .mesa-product-grid,
    ul.mesa-product-grid,
    ul.mesa-product-grid.products {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--space-lg);
    }
}

@media screen and (min-width: 1024px) {
    .mesa-product-grid,
    ul.mesa-product-grid,
    ul.mesa-product-grid.products {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Reset WooCommerce default product styles */
.mesa-product-grid .product {
    list-style: none;
    margin: 0;
    padding: 0;
}

/* -------------------------------------------
   5. PRODUCT CARD
   ------------------------------------------- */
.mesa-product-card {
    display: flex;
    flex-direction: column;
    background-color: var(--mesa-white);
    border: 1px solid #F5F5F5;
    border-radius: 0;
    box-shadow: none;
    transition: box-shadow 0.25s ease;
    height: 100%;
    text-decoration: none;
    color: inherit;
}

.mesa-product-card:hover {
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
    text-decoration: none;
    color: inherit;
}

/* Image */
.mesa-product-card__image-link {
    display: block;
    text-decoration: none;
}

.mesa-product-card__image-wrapper {
    position: relative;
    aspect-ratio: 1;
    background-color: var(--mesa-light-gray, #F1F1F1);
    overflow: hidden;
}

.mesa-product-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-base);
}

.mesa-product-card:hover .mesa-product-card__image {
    transform: scale(1.05);
}

/* Badges */
.mesa-product-card__badges {
    position: absolute;
    top: var(--space-sm);
    right: var(--space-sm);
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
}

.mesa-product-card__badge {
    padding: 4px 10px;
    font-size: 11px;
    font-weight: var(--font-bold);
    border-radius: var(--radius-sm);
    text-transform: uppercase;
}

.mesa-product-card__badge--sale {
    background-color: #dc3545;
    color: var(--mesa-white);
}

.mesa-product-card__badge--new {
    background-color: var(--mesa-lime);
    color: var(--mesa-black);
}

.mesa-product-card__badge--preorder {
    background-color: var(--mesa-black, #08050C);
    color: var(--mesa-lime, #CEFE65);
}

/* Details */
.mesa-product-card__details {
    display: flex;
    flex-direction: column;
    padding: var(--space-md);
    flex: 1;
}

/* Brand */
.mesa-product-card__brand {
    font-size: var(--text-xs);
    color: var(--mesa-gray-text);
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: var(--space-xs);
}

.mesa-product-card__brand:hover {
    color: var(--mesa-black);
}

/* Title — allow up to 3 lines, clamp with ellipsis */
.mesa-product-card__title {
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    line-height: var(--leading-tight);
    margin: 0 0 var(--space-sm);
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden;
}

.mesa-product-card__title a {
    color: var(--mesa-black);
    text-decoration: none;
}

.mesa-product-card__title a:hover {
    color: var(--mesa-black);
    text-decoration: underline;
}

/* Compatibility */
.mesa-product-card__compatibility {
    font-size: var(--text-xs);
    color: var(--mesa-gray-text);
    margin: 0 0 var(--space-sm);
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mesa-product-card__compatibility-label {
    font-weight: var(--font-medium);
}

/* Price */
.mesa-product-card__price {
    margin-top: auto;
    margin-bottom: var(--space-sm);
}

.mesa-product-card__price .price {
    font-size: var(--text-base);
    font-weight: var(--font-bold);
    color: var(--mesa-black);
}

.mesa-product-card__price del {
    color: var(--mesa-gray-text);
    font-size: var(--text-sm);
    font-weight: var(--font-regular);
}

.mesa-product-card__price ins {
    text-decoration: none;
    color: #dc3545;
}

/* Stock Status */
.mesa-product-card__stock {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    font-size: var(--text-xs);
}

.mesa-product-card__stock--instock {
    color: #28a745;
}

.mesa-product-card__stock--outofstock {
    color: #dc3545;
}

.mesa-product-card__stock--onbackorder {
    color: #ffc107;
}

/* -------------------------------------------
   6. FILTER SIDEBAR (Desktop)
   ------------------------------------------- */
.mesa-filter-sidebar {
    position: sticky;
    top: 100px;
}

.mesa-filter-sidebar__form {
    background-color: var(--mesa-white);
    border: none;
    border-radius: 0;
    overflow: hidden;
}

.mesa-filter-sidebar__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-md);
    border-bottom: 1px solid var(--mesa-light-gray);
}

.mesa-filter-sidebar__title {
    font-family: 'Open Sans', sans-serif;
    font-weight: 700;
    font-style: italic !important;
    font-size: 1.25rem;
    line-height: 100%;
    letter-spacing: 0;
    text-align: right;
    color: #08050C;
    margin: 0;
}

.mesa-filter-sidebar__clear {
    font-family: 'Open Sans', sans-serif;
    font-size: 0.8125rem;
    font-weight: 400;
    color: var(--mesa-gray-text, #6B7280) !important;
    text-decoration: none;
    background: none !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0.25rem 0.75rem;
    cursor: pointer;
}

.mesa-filter-sidebar__clear:hover,
.mesa-filter-sidebar__clear:focus,
.mesa-filter-sidebar__clear:active {
    color: #08050C !important;
    text-decoration: underline;
    background: none !important;
    box-shadow: none !important;
}

.mesa-filter-sidebar__groups {
    padding: var(--space-sm);
}

.mesa-filter-sidebar__submit {
    display: block;
    width: calc(100% - var(--space-md) * 2);
    margin: var(--space-md);
    padding: var(--space-sm) var(--space-lg);
    background-color: var(--mesa-lime, #CEFE65);
    color: var(--mesa-black, #08050C);
    font-family: 'Open Sans', sans-serif;
    font-weight: 600;
    font-style: italic;
    font-size: var(--text-sm);
    line-height: 1;
    height: 2.75rem;
    border: none;
    cursor: pointer;
    clip-path: polygon(15px 0, 100% 0, calc(100% - 15px) 100%, 0 100%);
    transition: opacity 0.2s ease;
}

.mesa-filter-sidebar__submit:hover {
    opacity: 0.9;
}

/* -------------------------------------------
   7. FILTER GROUPS (Accordion)
   ------------------------------------------- */
.mesa-filter-group {
    border-bottom: 1px solid var(--mesa-light-gray);
}

.mesa-filter-group:last-child {
    border-bottom: none;
}

.mesa-filter-group__toggle {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    padding: var(--space-md);
    background: none !important;
    border: none;
    cursor: pointer;
    font-family: 'Open Sans', sans-serif;
    font-weight: 600;
    font-size: 1.125rem;
    line-height: 140%;
    letter-spacing: 0;
    color: #08050C;
    text-align: right;
    box-shadow: none !important;
    outline: none;
}

.mesa-filter-group__toggle:hover {
    background-color: #f9f9f9 !important;
}

.mesa-filter-group__toggle:hover .mesa-filter-group__label {
    color: var(--color-text);
}

.mesa-filter-group__toggle:hover .mesa-filter-group__arrow {
    stroke: var(--mesa-black, #08050C);
}

.mesa-filter-group__toggle:focus,
.mesa-filter-group__toggle:active,
.mesa-filter-group__toggle:focus:not(:focus-visible) {
    background: none !important;
    box-shadow: none !important;
    outline: none !important;
    color: var(--mesa-black) !important;
}

.mesa-filter-group__toggle:focus-visible {
    outline: 2px solid var(--mesa-lime, #CEFE65) !important;
    outline-offset: -2px;
}

.mesa-filter-group.is-expanded .mesa-filter-group__toggle {
    background: none !important;
    color: var(--mesa-black) !important;
}

.mesa-filter-group__label {
    flex: 1;
}

.mesa-filter-group__active-count {
    background-color: var(--mesa-lime);
    color: var(--mesa-black);
    font-size: 11px;
    font-weight: var(--font-bold);
    min-width: 20px;
    height: 20px;
    line-height: 20px;
    text-align: center;
    border-radius: var(--radius-full);
    margin-left: var(--space-sm);
}

.mesa-filter-group__arrow {
    transition: transform var(--transition-fast);
    flex-shrink: 0;
    margin-right: var(--space-sm);
}

.mesa-filter-group.is-expanded .mesa-filter-group__arrow {
    transform: rotate(180deg);
}

.mesa-filter-group__content {
    max-height: 0;
    overflow: hidden;
    transition: max-height var(--transition-base);
}

.mesa-filter-group.is-expanded .mesa-filter-group__content {
    max-height: 500px; /* Fallback - JS will set actual height */
}

/* -------------------------------------------
   8. FILTER OPTIONS (Checkboxes/Radios)
   ------------------------------------------- */
.mesa-filter__options {
    padding: 0 var(--space-md) var(--space-md);
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.mesa-filter__option {
    display: flex;
    direction: rtl;
    align-items: center;
    gap: 0.75rem;
    padding: 0.5rem 0;
    cursor: pointer;
    border-radius: 0;
    transition: background-color 0.15s ease;
}

.mesa-filter__option:hover {
    background-color: transparent;
}

.mesa-filter__checkbox,
.mesa-filter__radio {
    position: absolute;
    opacity: 0;
    cursor: pointer;
}

.mesa-filter__checkmark {
    width: 1.25rem;
    height: 1.25rem;
    border: 1px solid #08050C;
    border-radius: 4px;
    flex-shrink: 0;
    position: relative;
    transition: all 0.15s ease;
    background-color: #FFFFFF;
}

.mesa-filter__radio + .mesa-filter__checkmark {
    border-radius: 50%;
}

.mesa-filter__checkbox:checked + .mesa-filter__checkmark,
.mesa-filter__radio:checked + .mesa-filter__checkmark {
    background-color: var(--mesa-lime, #CEFE65);
    border-color: var(--mesa-lime, #CEFE65);
}

.mesa-filter__checkbox:checked + .mesa-filter__checkmark::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 12px;
    height: 9px;
    background-image: url("data:image/svg+xml,%3Csvg width='12' height='9' viewBox='0 0 12 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10.7122 1.05739L11.0625 0.700661L10.3491 -4.68493e-05L9.99874 0.356677L10.3555 0.707031L10.7122 1.05739ZM3.48047 7.70703L3.12374 8.05738L3.48047 8.4206L3.83719 8.05738L3.48047 7.70703ZM10.3555 0.707031L9.99874 0.356677L3.12374 7.35668L3.48047 7.70703L3.83719 8.05738L10.7122 1.05739L10.3555 0.707031ZM3.48047 7.70703L3.83719 7.35668L0.712193 4.17486L0.355469 4.52521L-0.00125533 4.87557L3.12374 8.05738L3.48047 7.70703Z' fill='%230C0C0D'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-size: contain;
    border: none;
}

.mesa-filter__radio:checked + .mesa-filter__checkmark::after {
    content: '';
    position: absolute;
    left: 4px;
    top: 4px;
    width: 6px;
    height: 6px;
    background-color: var(--mesa-black, #08050C);
    border-radius: 50%;
}

.mesa-filter__label {
    font-family: 'Open Sans', sans-serif;
    font-weight: 400;
    font-size: 0.9375rem;
    line-height: 140%;
    letter-spacing: 0;
    text-align: right;
    color: #08050C;
    flex: 1;
}

.mesa-filter__count {
    font-family: 'Open Sans', sans-serif;
    font-weight: 400;
    font-size: 0.8125rem;
    line-height: 140%;
    color: var(--mesa-gray-text, #6B7280);
}

/* -------------------------------------------
   9. FILTER DRAWER (Mobile)
   ------------------------------------------- */
.mesa-filter-drawer {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 99999;
    pointer-events: none;
    visibility: hidden;
    opacity: 0;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.mesa-filter-drawer.is-open {
    pointer-events: all;
    visibility: visible;
    opacity: 1;
}

.mesa-filter-drawer__overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
    opacity: 0;
    transition: opacity 0.3s ease;
}

.mesa-filter-drawer.is-open .mesa-filter-drawer__overlay {
    opacity: 1;
}

.mesa-filter-drawer__panel {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    width: 90%;
    max-width: 380px;
    background-color: var(--mesa-white);
    transform: translateX(-100%);
    transition: transform 0.3s ease;
    display: flex;
    flex-direction: column;
    box-shadow: 2px 0 20px rgba(0, 0, 0, 0.15);
}

.mesa-filter-drawer.is-open .mesa-filter-drawer__panel {
    transform: translateX(0);
}

.mesa-filter-drawer__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid #F5F5F5;
    padding: 20px;
    flex-shrink: 0;
}

.mesa-filter-drawer__title {
    font-size: 18px !important;
    font-weight: var(--font-semibold);
    color: #000000 !important;
    line-height: 140% !important;
    margin: 0 !important;
}

.mesa-filter-drawer__close {
    display: flex;
    align-items: center;
    justify-content: center;
    background: none !important;
    border: none;
    padding: 0;
    cursor: pointer;
    color: var(--mesa-black) !important;
    transition: color var(--transition-fast);
}

.mesa-filter-drawer__close:hover {
    color: var(--mesa-gray-text);
}

.mesa-filter-drawer__close:focus,
.mesa-filter-drawer__close:active,
.mesa-filter-drawer__reset:focus,
.mesa-filter-drawer__reset:active,
.mesa-filter-drawer__apply:focus,
.mesa-filter-drawer__apply:active,
.mesa-filter-drawer button:focus,
.mesa-filter-drawer button:active {
    outline: none !important;
    background-color: inherit !important;
    box-shadow: none !important;
}

.mesa-filter-drawer button:focus-visible {
    outline: 2px solid var(--mesa-black) !important;
    outline-offset: 2px;
}

.mesa-filter-drawer__content {
    flex: 1;
    overflow-y: auto;
    padding: 24px 20px;
}

.mesa-filter-drawer__clear {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
    background-color: #fff0f0;
    color: #dc3545;
    text-decoration: none;
    font-size: var(--text-sm);
}

.mesa-filter-drawer__clear:hover {
    background-color: #ffe5e5;
}

.mesa-filter-drawer__clear .mesa-clear-count {
    flex-shrink: 1;
    background-color: #FFFFFF;
    font-size: 11px;
    font-weight: var(--font-bold);
    min-width: 20px;
    height: 20px;
    line-height: 20px;
    text-align: center;
    border-radius: var(--radius-full);
}

.mesa-filter-drawer__groups {
    /* Filter groups - same styles as sidebar */
}

.mesa-filter-drawer__groups .mesa-filter-group__arrow {
    margin-right: 0;
}

.mesa-filter-drawer__groups .mesa-filter-group__toggle {
    padding: var(--space-md) 0;
}

.mesa-filter-drawer__groups .mesa-filter__options {
    padding: 0 0 var(--space-md);
}

.mesa-filter-drawer__footer {
    display: flex !important;
    flex-shrink: 0 !important;
    gap: 8px !important;
    background: #f5f5f5 !important;
    border-top: 1px solid var(--mesa-light-gray);
    padding: 20px 24px 26px !important;
}

.mesa-filter-drawer__reset {
    flex: 1;
    background-color: var(--mesa-white, #FFFFFF) !important;
    box-shadow: 0px 0px 0px -7px rgba(0, 0, 0, 0);
    border-radius: 0;
    font-family: inherit;
    font-weight: var(--font-medium);
    color: var(--mesa-black) !important;
    padding: 14px 16px !important;
    cursor: pointer;
    transition: all var(--transition-fast);
}

button.mesa-filter-drawer__reset:hover,
button.mesa-filter-drawer__reset:focus,
button.mesa-filter-drawer__reset:active,
button.mesa-filter-drawer__reset:focus-visible {
    background-color: var(--mesa-white, #FFFFFF) !important;
    color: var(--mesa-black) !important;
    box-shadow: 0px 0px 0px -7px rgba(0, 0, 0, 0) !important;
}

.mesa-filter-drawer__apply {
    flex: 2;
    background-color: var(--mesa-lime);
    border: none;
    border-radius: 0;
    font-family: inherit;
    font-weight: var(--font-medium);
    color: var(--mesa-black);
    padding: 14px 16px !important;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.mesa-filter-drawer__apply:hover {
    background-color: var(--mesa-black);
    color: var(--mesa-lime);
}

/* Body class when filter drawer is open */
body.mesa-filter-open {
    overflow: hidden;
}

/* -------------------------------------------
   10.5 PRICE SLIDER (noUISlider overrides)
   ------------------------------------------- */

/* noUISlider overrides
 *
 * Specificity breakdown:
 *   noUISlider's .noUi-handle                              = (0,1,0)
 *   noUISlider's .noUi-horizontal .noUi-handle             = (0,2,0)
 *   noUISlider's .noUi-txt-dir-rtl.noUi-horizontal .noUi-handle = (0,3,0)
 *
 * Our selectors are scoped one level deeper to always win.
 */

/* Track — beats .noUi-target (0,1,0) and .noUi-horizontal (0,1,0) */
.mesa-price-slider-wrap .noUi-target {
    background:    #E5E7EB;
    border:        none;
    box-shadow:    none;
    height:        2px;
    border-radius: 1px;
    margin:        0.875rem 12px 0.5rem;
}

/* Active range — beats .noUi-connect (0,1,0) */
.mesa-price-slider-wrap .noUi-connect {
    background: #CEFE65;
}

/* Handle visual style — beats .noUi-handle (0,1,0) */
.mesa-price-slider-wrap .noUi-handle {
    border-radius: 50%;
    background:    #08050C;
    border:        2px solid #CEFE65;
    box-shadow:    0 1px 3px rgba(0, 0, 0, 0.25);
    cursor:        grab;
    transition:    box-shadow 150ms ease;
}

/* Handle size & base position — beats .noUi-horizontal .noUi-handle (0,2,0) */
.mesa-price-slider-wrap .noUi-horizontal .noUi-handle {
    width:  20px;
    height: 20px;
    right:  -10px;
    top:    -9px;
}

/* RTL position fix — beats .noUi-txt-dir-rtl.noUi-horizontal .noUi-handle (0,3,0) */
.mesa-price-slider-wrap .noUi-txt-dir-rtl.noUi-horizontal .noUi-handle {
    left:  -10px;
    right: auto;
}

.noUi-txt-dir-rtl .noUi-origin {
    left: auto;
    right: 0;
}

.mesa-price-slider-wrap .noUi-handle:hover {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
}

.mesa-price-slider-wrap .noUi-handle:active {
    cursor:     grabbing;
    box-shadow: 0 0 0 4px rgba(206, 254, 101, 0.25);
}

.mesa-price-slider-wrap .noUi-handle::before,
.mesa-price-slider-wrap .noUi-handle::after {
    display: none;
}

.mesa-price-slider-wrap .noUi-handle:focus-visible {
    outline:        2px solid #CEFE65;
    outline-offset: 2px;
}

/* Price slider wrapper */
.mesa-price-slider-wrap {
    padding: 0.25rem 0 0.75rem;
}

.mesa-price-slider__inputs {
    display:    flex;
    gap:        0.75rem;
    margin-top: 1rem;
    direction:  rtl;
}

.mesa-price-slider__field {
    display:       flex;
    align-items:   center;
    gap:           0.25rem;
    flex:          1;
    border:        1px solid var(--mesa-light-gray, #f3f4f6);
    border-radius: 0.375rem;
    padding:       0.3rem 0.5rem;
}

.mesa-price-slider__label {
    font-size:   0.75rem;
    color:       var(--mesa-gray-text, #6B7280);
    white-space: nowrap;
}

.mesa-price-slider__currency {
    font-size: 0.8125rem;
    color:     var(--mesa-gray-text, #6B7280);
}

.mesa-price-slider__input {
    width:       100%;
    border:      none;
    outline:     none;
    font-size:   0.875rem;
    text-align:  center;
    background:  transparent;
    -moz-appearance:  textfield;
    appearance:       textfield;
}

.mesa-price-slider__input::-webkit-outer-spin-button,
.mesa-price-slider__input::-webkit-inner-spin-button {
    -webkit-appearance: none;
}

/* Product grid loading state */
#mesa-products-wrap.is-loading {
    opacity:        0.5;
    pointer-events: none;
    transition:     opacity 0.2s ease;
}

/* -------------------------------------------
   11. SEO CONTENT
   ------------------------------------------- */
.mesa-shop__seo-content {
    margin-top: var(--space-3xl);
    padding: var(--space-xl);
    background-color: #f9f9f9;
    border-radius: var(--radius-lg);
}

.mesa-shop__seo-inner {
    max-width: 800px;
    margin: 0 auto;
}

.mesa-shop__seo-inner h2,
.mesa-shop__seo-inner h3 {
    font-size: var(--text-xl);
    font-weight: var(--font-bold);
    margin: var(--space-lg) 0 var(--space-md);
}

.mesa-shop__seo-inner h2:first-child,
.mesa-shop__seo-inner h3:first-child {
    margin-top: 0;
}

.mesa-shop__seo-inner p {
    color: var(--mesa-gray-text);
    line-height: var(--leading-relaxed);
    margin-bottom: var(--space-md);
}

.mesa-shop__seo-inner a {
    color: var(--mesa-black);
    text-decoration: underline;
}

/* -------------------------------------------
   12. INFINITE SCROLL SENTINEL
   ------------------------------------------- */
.mesa-scroll-sentinel {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: var(--space-xl) 0;
    min-height: 72px;
}

.mesa-scroll-sentinel[hidden] {
    display: none;
}

.mesa-scroll-sentinel__spinner {
    display: block;
    width: 32px;
    height: 32px;
    border: 3px solid var(--mesa-light-gray);
    border-top-color: var(--mesa-black);
    border-radius: 50%;
    animation: mesa-spin 0.7s linear infinite;
}

.mesa-scroll-sentinel.is-hidden .mesa-scroll-sentinel__spinner {
    display: none;
}

@keyframes mesa-spin {
    to { transform: rotate(360deg); }
}

/* -------------------------------------------
   13. EMPTY STATE
   ------------------------------------------- */
.mesa-shop__empty {
    text-align: center;
    padding: var(--space-4xl) var(--space-xl);
}

.mesa-shop__empty-icon {
    color: var(--mesa-gray-text);
    margin-bottom: var(--space-lg);
}

.mesa-shop__empty-title {
    font-size: var(--text-xl);
    font-weight: var(--font-bold);
    margin: 0 0 var(--space-sm);
}

.mesa-shop__empty-text {
    color: var(--mesa-gray-text);
    margin: 0 0 var(--space-lg);
}

.mesa-shop__empty-clear {
    display: inline-block;
    padding: var(--space-md) var(--space-xl);
    background-color: var(--mesa-lime);
    color: var(--mesa-black);
    text-decoration: none;
    border-radius: var(--radius-md);
    font-weight: var(--font-semibold);
    transition: all var(--transition-fast);
}

.mesa-shop__empty-clear:hover {
    background-color: var(--mesa-black);
    color: var(--mesa-lime);
}

/* No Results (Client-Side Filtering) */
.mesa-shop__no-results {
    display: none;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: var(--space-4xl) var(--space-xl);
    min-height: 300px;
}

.mesa-shop__no-results .mesa-shop__empty-icon {
    color: var(--mesa-gray-text);
    margin-bottom: var(--space-lg);
}

.mesa-shop__no-results .mesa-shop__empty-title {
    font-size: var(--text-xl);
    font-weight: var(--font-bold);
    margin: 0 0 var(--space-sm);
}

.mesa-shop__no-results .mesa-shop__empty-text {
    color: var(--mesa-gray-text);
    margin: 0 0 var(--space-lg);
}

.mesa-shop__no-results .mesa-clear-filters-btn {
    display: inline-block;
    padding: var(--space-md) var(--space-xl);
    background-color: var(--mesa-lime);
    color: var(--mesa-black);
    text-decoration: none;
    border: none;
    border-radius: var(--radius-md);
    font-weight: var(--font-semibold);
    font-size: var(--text-base);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.mesa-shop__no-results .mesa-clear-filters-btn:hover {
    background-color: var(--mesa-black);
    color: var(--mesa-lime);
}

/* Filter Status */
.mesa-shop__filter-status {
    padding: var(--space-md) 0;
    text-align: center;
    color: var(--mesa-gray-text);
    font-size: var(--text-sm);
    border-top: 1px solid var(--mesa-light-gray);
    margin-top: var(--space-lg);
}

/* -------------------------------------------
   14. RESPONSIVE UTILITIES
   ------------------------------------------- */
.mesa-desktop-only {
    display: none;
}

@media screen and (min-width: 1024px) {
    .mesa-desktop-only {
        display: block;
    }

    .mesa-mobile-only {
        display: none !important;
    }
}

@media (max-width: 480px) {
    .mesa-product-card__title {
        -webkit-line-clamp: 5 !important;
    }
}

/* Hide WooCommerce default elements on PLP */
.mesa-shop .woocommerce-result-count,
.mesa-shop .woocommerce-ordering {
    display: none;
}

/* ===========================================
   CHECKOUT: Mesa Custom Checkout
   Mobile-first, RTL, Cardcom-compatible
   =========================================== */

/* -------------------------------------------
   Checkout Custom Properties
   ------------------------------------------- */
:root {
    --checkout-field-height: 3.25rem;
    --checkout-field-radius: 0;
    --checkout-field-border: 1px solid #B3B7BD;
    --checkout-field-focus: 2px solid var(--mesa-lime);
    --checkout-section-gap: var(--space-xl);
    --checkout-sidebar-bg: var(--mesa-light-gray);
    --checkout-error: #dc3545;
    --checkout-success: #28a745;
}

/* -------------------------------------------
   Checkout Container & Layout
   ------------------------------------------- */
.mesa-checkout {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: var(--space-lg) var(--container-padding);
}

.mesa-checkout__header {
    text-align: center;
    margin-bottom: var(--space-xl);
}

.mesa-checkout__title {
    font-size: var(--text-2xl);
    font-weight: var(--font-bold);
    margin: 0;
    color: var(--mesa-black);
}

/* ===========================================
   Preorder Banner (checkout hero)
   =========================================== */
.mesa-preorder-banner {
    text-align: center;
    padding: 2rem 1.5rem;
    margin-bottom: 1.5rem;
    background-color: #f8f9fa;
    border: 1px solid #e9ecef;
    border-radius: 0.75rem;
    max-width: 50rem;
    margin-left: auto;
    margin-right: auto;
}

.mesa-preorder-banner__header {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.625rem;
    margin-bottom: 0.75rem;
}

.mesa-preorder-banner__header svg {
    flex-shrink: 0;
}

.mesa-preorder-banner__title {
    font-size: 1.5rem;
    font-weight: 700;
    margin: 0;
    color: var(--mesa-black, #08050C);
}

.mesa-preorder-banner__subtitle {
    font-size: 1rem;
    font-weight: 600;
    color: var(--mesa-black, #08050C);
    margin: 0 0 0.25rem 0;
}

.mesa-preorder-banner__desc {
    font-size: 0.9375rem;
    color: var(--mesa-gray-text, #6B7280);
    margin: 0 0 0.125rem 0;
}

.mesa-preorder-banner__highlight {
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--mesa-black, #08050C);
    margin: 0.5rem 0 0 0;
}

/* ===========================================
   Preorder Gateway Info Box (payment section)
   =========================================== */
.mesa-preorder-gateway-info {
    padding: 1.25rem;
    background-color: #f8f9fa;
    border: 1px solid #e9ecef;
    border-radius: 0.5rem;
}

.mesa-preorder-gateway-section {
    margin-bottom: 1.25rem;
}

.mesa-preorder-gateway-section:last-child {
    margin-bottom: 0;
}

.mesa-preorder-gateway-section__title {
    font-size: 0.9375rem;
    font-weight: 700;
    color: var(--mesa-black, #08050C);
    margin: 0 0 0.5rem 0;
}

.mesa-preorder-gateway-section__list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.mesa-preorder-gateway-section__list li {
    position: relative;
    padding-right: 1rem;
    margin-bottom: 0.25rem;
    font-size: 0.875rem;
    line-height: 1.6;
    color: var(--mesa-gray-text, #6B7280);
}

.mesa-preorder-gateway-section__list li::before {
    content: '';
    position: absolute;
    right: 0;
    top: 0.5625rem;
    width: 0.375rem;
    height: 0.375rem;
    background-color: var(--mesa-lime, #CEFE65);
    border-radius: 50%;
}

.mesa-preorder-gateway-section__text {
    font-size: 0.875rem;
    line-height: 1.6;
    color: var(--mesa-gray-text, #6B7280);
    margin: 0;
}

/* Hide payment method radio when only preorder gateway is available */
.mesa-checkout__section--preorder .wc_payment_methods {
    list-style: none;
    padding: 0;
    margin: 0;
}

.mesa-checkout__section--preorder .wc_payment_method label {
    display: none;
}

.mesa-checkout__section--preorder .wc_payment_method .payment_box {
    display: block !important;
    padding: 1rem;
    background-color: #f8f9fa;
    border: 1px solid #eee;
    border-radius: 0.5rem;
    margin-bottom: 1rem;
    font-size: 0.9375rem;
    line-height: 1.6;
}

/* Preorder thank-you status */
.mesa-thankyou__status--preorder {
    text-align: center;
}

.mesa-thankyou__status--preorder .mesa-thankyou__status-icon {
    color: var(--mesa-lime, #CEFE65);
}

.mesa-checkout__layout {
    display: flex;
    flex-direction: column;
    gap: var(--checkout-section-gap);
}

.mesa-checkout__main {
    width: 100%;
}

.mesa-checkout__sidebar {
    display: none;
}

/* -------------------------------------------
   Mobile Summary Accordion
   ------------------------------------------- */
.mesa-checkout__summary-mobile {
    display: block;
    background-color: var(--checkout-sidebar-bg);
    border-radius: var(--radius-lg);
    margin-bottom: var(--space-lg);
    overflow: hidden;
}

.mesa-checkout__summary-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: var(--space-md) var(--space-lg);
    background: none;
    border: none;
    cursor: pointer;
    font-family: inherit;
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    color: var(--mesa-black);
    text-align: right;
}

.mesa-checkout__summary-toggle-text {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.mesa-checkout__summary-icon {
    flex-shrink: 0;
}

.mesa-checkout__item-count {
    font-weight: var(--font-regular);
    color: var(--mesa-gray-text);
}

.mesa-checkout__summary-total {
    font-weight: var(--font-bold);
    color: var(--mesa-black);
    margin-inline-start: auto;
    margin-inline-end: var(--space-sm);
}

.mesa-checkout__summary-chevron {
    flex-shrink: 0;
    transition: transform var(--transition-fast);
}

.mesa-checkout__summary-mobile.is-open .mesa-checkout__summary-chevron {
    transform: rotate(180deg);
}

.mesa-checkout__summary-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height var(--transition-base);
    padding: 0 var(--space-lg);
}

.mesa-checkout__summary-mobile.is-open .mesa-checkout__summary-content {
    padding-bottom: var(--space-lg);
}

/* -------------------------------------------
   Checkout Sections
   ------------------------------------------- */
.mesa-checkout__section {
    background-color: var(--mesa-white);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    margin-bottom: var(--space-lg);
    border: 1px solid var(--mesa-light-gray);
}

.mesa-checkout__section-title {
    font-family: 'Open Sans', sans-serif;
    font-size: 2rem;
    font-weight: 600;
    line-height: 1.4;
    text-align: right;
    margin: 0 0 var(--space-lg);
    padding-bottom: var(--space-md);
    border-bottom: 1px solid var(--mesa-light-gray);
    color: var(--mesa-black);
}

/* -------------------------------------------
   Shipping Method Selector
   ------------------------------------------- */
.mesa-checkout__shipping-methods {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.mesa-shipping-method {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md) var(--space-lg);
    border: 2px solid var(--mesa-light-gray);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: border-color var(--transition-fast), background-color var(--transition-fast);
}

.mesa-shipping-method:hover {
    border-color: var(--mesa-lime);
}

.mesa-shipping-method.is-selected {
    border-color: var(--mesa-lime);
    background-color: rgba(206, 254, 101, 0.08);
}

.mesa-shipping-method input[type="radio"] {
    flex-shrink: 0;
    width: 1.25rem;
    height: 1.25rem;
    accent-color: var(--mesa-lime);
    cursor: pointer;
}

.mesa-shipping-method__label {
    flex: 1;
    font-family: 'Open Sans', sans-serif;
    font-size: 1rem;
    font-weight: 600;
    color: var(--mesa-black);
    text-align: right;
}

.mesa-shipping-method__price {
    font-family: 'Open Sans', sans-serif;
    font-size: 1rem;
    font-weight: 700;
    color: var(--mesa-black);
    white-space: nowrap;
}

/* -------------------------------------------
   Form Fields
   ------------------------------------------- */
/*.mesa-checkout__fields {*/
/*    display: grid;*/
/*    grid-template-columns: 1fr 1fr;*/
/*    gap: 1.25rem;*/
/*}*/

.mesa-form-row {
    width: 100%;
    margin-bottom: 0 !important;
}

.mesa-form-row label {
    display: block;
    font-family: 'Open Sans', sans-serif;
    font-size: clamp(1rem, 1.19vw, 1.125rem);
    font-weight: 600;
    line-height: 1.4;
    color: #08050C;
    text-align: right;
    margin-bottom: clamp(0.75rem, 1.06vw, 1rem);
}

.mesa-form-row label .required {
    color: var(--checkout-error);
}

.mesa-form-row input[type="text"],
.mesa-form-row input[type="email"],
.mesa-form-row input[type="tel"],
.mesa-form-row input[type="number"],
.mesa-form-row select,
.mesa-form-row textarea {
    width: 100%;
    height: var(--checkout-field-height);
    padding: 0.875rem 1rem;
    font-family: 'Open Sans', sans-serif;
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.5;
    color: #08050C;
    text-align: right;
    background-color: var(--mesa-white);
    border: var(--checkout-field-border);
    border-radius: var(--checkout-field-radius);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    -webkit-appearance: none;
    appearance: none;
}

.mesa-form-row input::placeholder,
.mesa-form-row select::placeholder,
.mesa-form-row textarea::placeholder {
    font-family: 'Open Sans', sans-serif;
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.5;
    color: #B3B7BD;
}

.mesa-form-row textarea {
    height: auto;
    min-height: 6.25rem;
    padding: 0.875rem 1rem;
    resize: vertical;
}

.mesa-form-row input:focus,
.mesa-form-row select:focus,
.mesa-form-row textarea:focus {
    outline: none;
    border-color: var(--mesa-lime);
    box-shadow: 0 0 0 3px rgba(206, 254, 101, 0.25);
}

/* Validation States */
.mesa-form-row.woocommerce-validated input,
.mesa-form-row.woocommerce-validated select {
    border-color: var(--checkout-success);
}

.mesa-form-row.woocommerce-invalid input,
.mesa-form-row.woocommerce-invalid select {
    border-color: var(--checkout-error);
}

.mesa-form-row .woocommerce-input-wrapper {
    width: 100%;
}

/* -------------------------------------------
   Order Notes (Collapsible)
   ------------------------------------------- */
.mesa-checkout__notes {
    margin-bottom: var(--space-lg);
}

.mesa-checkout__notes-summary {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-md) var(--space-lg);
    background-color: var(--mesa-white);
    border: 1px solid var(--mesa-light-gray);
    border-radius: var(--radius-lg);
    cursor: pointer;
    font-size: var(--text-base);
    font-weight: var(--font-medium);
    color: var(--mesa-black);
    list-style: none;
}

.mesa-checkout__notes-summary::-webkit-details-marker {
    display: none;
}

.mesa-checkout__notes-summary svg {
    flex-shrink: 0;
    opacity: 0.6;
}

.mesa-checkout__notes[open] .mesa-checkout__notes-summary {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.mesa-checkout__notes-content {
    padding: var(--space-lg);
    background-color: var(--mesa-white);
    border: 1px solid var(--mesa-light-gray);
    border-top: none;
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
}

/* -------------------------------------------
   Payment Section
   ------------------------------------------- */
.mesa-checkout__section--payment {
    background-color: var(--mesa-white);
}

/* Hide order review table in main column (summary is in sidebar) */
.mesa-checkout__section--payment .woocommerce-checkout-review-order-table {
    display: none;
}

.mesa-review-order__totals {
    margin-bottom: var(--space-lg);
}

.mesa-review-order__totals th,
.mesa-review-order__totals td {
    padding: var(--space-sm) 0;
    border-bottom: 1px solid var(--mesa-light-gray);
}

.mesa-review-order__totals .order-total th,
.mesa-review-order__totals .order-total td {
    font-size: var(--text-lg);
    font-weight: var(--font-bold);
    border-bottom: none;
    padding-top: var(--space-md);
}

/* Payment Methods */
.woocommerce-checkout-payment {
    background-color: transparent;
}

.wc_payment_methods {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--space-lg);
}

.wc_payment_method {
    margin-bottom: var(--space-md);
}

.wc_payment_method > label {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md);
    background-color: var(--mesa-light-gray);
    border-radius: var(--radius-md);
    cursor: pointer;
    font-weight: var(--font-medium);
    transition: background-color var(--transition-fast);
}

.wc_payment_method > label:hover {
    background-color: #e5e5e5;
}

.wc_payment_method input[type="radio"] {
    width: 20px;
    height: 20px;
    accent-color: var(--mesa-lime);
}

.wc_payment_method .payment_box {
    padding: var(--space-md);
    margin-top: var(--space-sm);
    background-color: var(--mesa-light-gray);
    border-radius: var(--radius-md);
}

/* -------------------------------------------
   Submit Button & Trust
   ------------------------------------------- */
.mesa-checkout__trust-badge {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-sm);
    margin-bottom: var(--space-sm);
    color: var(--checkout-success);
    font-weight: var(--font-medium);
}

.mesa-checkout__trust-icon {
    flex-shrink: 0;
}

.mesa-checkout__trust-line {
    text-align: center;
    font-size: var(--text-sm);
    color: var(--mesa-gray-text);
    margin: 0 0 var(--space-md);
}

.mesa-checkout__submit,
#place_order {
    display: block;
    width: 100%;
    height: 56px;
    background-color: var(--mesa-lime);
    color: var(--mesa-black);
    font-size: var(--text-lg);
    font-weight: var(--font-bold);
    border: none;
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.mesa-checkout__submit:hover,
#place_order:hover {
    background-color: var(--mesa-black);
    color: var(--mesa-lime);
}

.mesa-checkout__submit.is-loading,
#place_order.is-loading {
    opacity: 0.7;
    pointer-events: none;
}

.mesa-checkout__policy-links {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--space-sm);
    margin-top: var(--space-lg);
    font-size: var(--text-sm);
}

.mesa-checkout__policy-link {
    color: var(--mesa-gray-text);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.mesa-checkout__policy-link:hover {
    color: var(--mesa-black);
}

.mesa-checkout__policy-separator {
    color: var(--mesa-light-gray);
}

/* -------------------------------------------
   Order Summary Component
   ------------------------------------------- */
.mesa-order-summary {
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
}

.mesa-order-summary__items {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.mesa-order-summary__item {
    display: flex;
    align-items: flex-start;
    gap: var(--space-md);
    position: relative;
    transition: opacity 0.2s ease;
}

/* Remove item button — small badge on thumbnail, opposite corner from qty */
.mesa-order-summary__item-remove {
    position: absolute;
    top: -6px;
    left: -6px;
    z-index: 2;
    width: 20px;
    height: 20px;
    padding: 0;
    background-color: var(--mesa-gray-text, #6B7280);
    color: var(--mesa-white, #FFFFFF);
    border: none;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    opacity: 0;
    transition: opacity 0.15s ease, background-color 0.15s ease;
}

.mesa-order-summary__item:hover .mesa-order-summary__item-remove {
    opacity: 1;
}

.mesa-order-summary__item-remove:hover {
    background-color: #dc3545;
}

.mesa-order-summary__item-thumbnail {
    position: relative;
    flex-shrink: 0;
    width: 60px;
    height: 60px;
    border-radius: var(--radius-md);
    background-color: var(--mesa-white);
    border: 1px solid var(--mesa-light-gray);
}

.mesa-order-summary__item-thumbnail img {
    border-radius: var(--radius-md);
}

.mesa-order-summary__item-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mesa-order-summary__item-qty {
    position: absolute;
    top: -6px;
    right: -6px;
    z-index: 2;
    min-width: 20px;
    height: 20px;
    padding: 0 4px;
    background-color: var(--mesa-gray-text);
    color: var(--mesa-white);
    font-size: 11px;
    font-weight: var(--font-bold);
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
}

.mesa-order-summary__item-details {
    flex: 1;
    min-width: 0;
}

.mesa-order-summary__item-name {
    display: block;
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--mesa-black);
    line-height: 1.3;
}

.mesa-order-summary__item-price {
    flex-shrink: 0;
    font-weight: var(--font-semibold);
    color: var(--mesa-black);
}

/* Coupon Form */
.mesa-order-summary__coupon {
    padding-top: var(--space-md);
    border-top: 1px solid var(--mesa-light-gray);
}

.mesa-coupon-form__message {
    display: none;
    margin-bottom: var(--space-sm);
    font-size: var(--text-sm);
    line-height: 1.4;
}

.mesa-coupon-form__message .woocommerce-error,
.mesa-coupon-form__message .woocommerce-message {
    margin: 0;
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-md);
    font-size: var(--text-sm);
    list-style: none;
}

.mesa-coupon-form__message .woocommerce-error {
    background-color: #fef2f2;
    color: #dc3545;
    border: 1px solid #fecaca;
}

.mesa-coupon-form__message .woocommerce-message {
    background-color: #f0fdf4;
    color: #28a745;
    border: 1px solid #bbf7d0;
}

.mesa-coupon-form__input-wrap {
    display: flex;
    gap: var(--space-sm);
}

.mesa-coupon-form__input {
    flex: 1;
    height: 40px;
    padding: 0 var(--space-md);
    font-size: var(--text-sm);
    border: 1px solid var(--mesa-gray);
    border-radius: var(--radius-md);
    background-color: var(--mesa-white);
}

.mesa-coupon-form__input:focus {
    outline: none;
    border-color: var(--mesa-lime);
}

.mesa-coupon-form__button {
    padding: 0 var(--space-lg);
    height: 40px;
    background-color: var(--mesa-black);
    color: var(--mesa-white);
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    border: none;
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: background-color var(--transition-fast);
}

.mesa-coupon-form__button:hover {
    background-color: #333;
}

.mesa-coupon-form__button:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.mesa-order-summary__applied-coupons {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    margin-top: var(--space-md);
}

.mesa-order-summary__coupon-tag {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    padding: var(--space-xs) var(--space-sm);
    background-color: rgba(206, 254, 101, 0.3);
    border-radius: var(--radius-sm);
    font-size: var(--text-xs);
}

.mesa-order-summary__coupon-code {
    font-weight: var(--font-medium);
    color: var(--mesa-black);
}

.mesa-order-summary__coupon-remove {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    color: var(--mesa-gray-text);
    cursor: pointer;
    transition: color var(--transition-fast);
}

.mesa-order-summary__coupon-remove:hover {
    color: var(--checkout-error);
}

/* Totals */
.mesa-order-summary__totals {
    padding-top: var(--space-md);
    border-top: 1px solid var(--mesa-light-gray);
}

.mesa-order-summary__row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-sm) 0;
}

.mesa-order-summary__label {
    font-size: var(--text-sm);
    color: var(--mesa-gray-text);
}

.mesa-order-summary__value {
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--mesa-black);
}

.mesa-order-summary__value--discount {
    color: var(--checkout-success);
}

.mesa-order-summary__row--total {
    margin-top: var(--space-sm);
    padding-top: var(--space-md);
    border-top: 2px solid var(--mesa-black);
}

.mesa-order-summary__row--total .mesa-order-summary__label {
    font-size: var(--text-base);
    font-weight: var(--font-bold);
    color: var(--mesa-black);
}

.mesa-order-summary__value--total {
    font-size: var(--text-lg);
    font-weight: var(--font-bold);
}

/* Cross-sells */
.mesa-order-summary__cross-sells {
    padding-top: var(--space-md);
    border-top: 1px solid var(--mesa-light-gray);
}

.mesa-order-summary__cross-sells-title {
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    margin: 0 0 var(--space-md);
    color: var(--mesa-black);
}

.mesa-order-summary__cross-sells-grid {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.mesa-order-summary__cross-sell {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm);
    border: 1px solid var(--mesa-light-gray);
    border-radius: var(--radius-sm);
    text-decoration: none;
    color: inherit;
}

.mesa-order-summary__cross-sell-info {
    flex: 1;
    min-width: 0;
}

.mesa-order-summary__cross-sell-name {
    display: block;
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--mesa-black);
}

.mesa-order-summary__cross-sell-price {
    display: block;
    font-size: var(--text-xs);
    color: var(--mesa-gray-text);
    margin-top: 2px;
}

.mesa-order-summary__cross-sell-add {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.375rem 0.75rem;
    background-color: var(--mesa-lime, #CEFE65);
    color: var(--mesa-black, #08050C);
    border: none;
    font-family: 'Open Sans', sans-serif;
    font-size: 0.8125rem;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    transition: opacity 0.15s ease;
    flex-shrink: 0;
}

.mesa-order-summary__cross-sell-add:hover {
    opacity: 0.85;
}

.mesa-order-summary__cross-sell-add.is-loading {
    opacity: 0.5;
    cursor: wait;
}

.mesa-order-summary__cross-sell-add.is-added {
    background-color: #e8f5e9;
    color: #2e7d32;
}

.mesa-order-summary__cross-sell {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm);
    background-color: var(--mesa-white);
    border-radius: var(--radius-md);
    text-decoration: none;
    transition: background-color var(--transition-fast);
}

.mesa-order-summary__cross-sell:hover {
    background-color: var(--mesa-light-gray);
}

.mesa-order-summary__cross-sell img {
    width: 50px;
    height: 50px;
    object-fit: cover;
    border-radius: var(--radius-sm);
}

.mesa-order-summary__cross-sell-name {
    flex: 1;
    font-size: var(--text-xs);
    color: var(--mesa-black);
    line-height: 1.3;
}

.mesa-order-summary__cross-sell-price {
    font-size: var(--text-xs);
    font-weight: var(--font-semibold);
    color: var(--mesa-black);
}

/* -------------------------------------------
   Trust Footer
   ------------------------------------------- */
.mesa-checkout__footer {
    margin-top: var(--space-2xl);
    padding-top: var(--space-xl);
    border-top: 1px solid var(--mesa-light-gray);
}

.mesa-checkout__trust-strip {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
    margin-bottom: var(--space-lg);
}

.mesa-checkout__trust-item {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    font-size: var(--text-sm);
    color: var(--mesa-gray-text);
}

.mesa-checkout__trust-item-icon {
    flex-shrink: 0;
    color: var(--mesa-lime);
}

.mesa-checkout__footer-links {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--space-sm);
    font-size: var(--text-xs);
}

.mesa-checkout__footer-link {
    color: var(--mesa-gray-text);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.mesa-checkout__footer-link:hover {
    color: var(--mesa-black);
}

.mesa-checkout__footer-separator {
    color: var(--mesa-light-gray);
}

/* -------------------------------------------
   Sidebar (Desktop Only)
   ------------------------------------------- */
.mesa-checkout__sidebar-title {
    font-size: var(--text-lg);
    font-weight: var(--font-bold);
    margin: 0 0 var(--space-lg);
    padding-bottom: var(--space-md);
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
    color: var(--mesa-black);
}

/* -------------------------------------------
   Tablet Responsive (768px+)
   ------------------------------------------- */
@media screen and (min-width: 768px) {
    /*.mesa-checkout__fields {*/
    /*    display: grid;*/
    /*    grid-template-columns: repeat(2, 1fr);*/
    /*    gap: var(--space-md);*/
    /*}*/

    .mesa-form-row--half {
        grid-column: span 1;
    }

    .mesa-form-row--full {
        grid-column: span 2;
    }

    .mesa-form-row--wide {
        grid-column: span 1;
    }

    .mesa-form-row--narrow {
        grid-column: span 1;
    }

    .mesa-checkout__trust-strip {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* -------------------------------------------
   Desktop Responsive (1024px+)
   ------------------------------------------- */
@media screen and (min-width: 1024px) {
    .mesa-checkout {
        padding: var(--space-2xl) var(--container-padding);
    }

    .mesa-checkout__title {
        font-size: var(--text-3xl);
    }

    .mesa-checkout__layout {
        flex-direction: row;
        align-items: flex-start;
    }

    .mesa-checkout__main {
        flex: 0 0 60%;
        padding-inline-end: var(--space-xl);
    }

    .mesa-checkout__sidebar {
        display: block;
        flex: 0 0 38%;
        position: sticky;
        top: 40px;
        align-self: flex-start;
    }

    .mesa-checkout__summary-mobile {
        display: none;
    }

    .mesa-checkout__order-summary {
        background-color: var(--checkout-sidebar-bg);
        border-radius: var(--radius-lg);
        padding: var(--space-lg);
    }

    .mesa-form-row--wide {
        grid-column: span 1;
    }

    .mesa-form-row--narrow {
        grid-column: span 1;
    }

    /* Split address fields properly */
    /*.mesa-checkout__fields {*/
    /*    grid-template-columns: 70% 30%;*/
    /*}*/

    .mesa-checkout__fields .mesa-form-row--half {
        grid-column: span 1;
    }

    .mesa-checkout__fields .mesa-form-row--full {
        grid-column: 1 / -1;
    }

    .mesa-checkout__fields .mesa-form-row--wide {
        grid-column: 1;
    }

    .mesa-checkout__fields .mesa-form-row--narrow {
        grid-column: 2;
    }

    /* Full-width fields by default, half only for explicit --half rows */
    .mesa-checkout__fields {
        grid-template-columns: 1fr;
    }

    .mesa-checkout__fields .mesa-form-row--half {
        /* Restore 2-col only for explicit half-width rows */
    }
}

/* ===========================================
   MOBILE — ≤768px
   =========================================== */
@media (max-width: 768px) {
    .mesa-checkout {
        padding: var(--space-lg) 0;
    }
}

/* -------------------------------------------
   WooCommerce Override Fixes
   ------------------------------------------- */
.woocommerce-checkout .mesa-checkout__section .form-row {
    padding: 0;
    margin: 0;
    width: 100%;
    float: none;
}

/* Force all checkout fields to full width */
.woocommerce-checkout .mesa-checkout__fields .form-row,
.woocommerce-checkout .mesa-checkout__fields .form-row-first,
.woocommerce-checkout .mesa-checkout__fields .form-row-last,
.woocommerce-checkout .mesa-checkout__fields .form-row-wide {
    width: 100% !important;
    float: none !important;
    grid-column: 1 / -1;
}

.woocommerce-checkout .select2-container {
    width: 100% !important;
}

.woocommerce-checkout .select2-container .select2-selection--single {
    height: var(--checkout-field-height);
    border: var(--checkout-field-border);
    border-radius: var(--checkout-field-radius);
}

.woocommerce-checkout .select2-container .select2-selection--single .select2-selection__rendered {
    line-height: var(--checkout-field-height);
    padding-right: var(--space-md);
    padding-left: var(--space-md);
}

/* -------------------------------------------
   Checkout Field Typography & Spacing Overrides
   (defeats WooCommerce forms.css + Kadence specificity)
   ------------------------------------------- */

/* Labels */
.woocommerce form .form-row label,
.woocommerce-checkout .mesa-form-row label {
    font-family: 'Open Sans', sans-serif !important;
    font-size: clamp(1rem, 1.19vw, 1.125rem) !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
    color: #08050C !important;
    text-align: right !important;
    margin-bottom: 1rem !important;
}

/* Inputs */
.woocommerce form .form-row .input-text,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea,
.woocommerce-checkout .mesa-form-row input[type="text"],
.woocommerce-checkout .mesa-form-row input[type="email"],
.woocommerce-checkout .mesa-form-row input[type="tel"],
.woocommerce-checkout .mesa-form-row input[type="number"],
.woocommerce-checkout .mesa-form-row select,
.woocommerce-checkout .mesa-form-row textarea {
    height: 3.25rem !important;
    padding: 0.875rem 1rem !important;
    font-family: 'Open Sans', sans-serif !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    line-height: 1.5 !important;
    color: #08050C !important;
    text-align: right !important;
    border: 1px solid #B3B7BD !important;
    border-radius: 0 !important;
}

/* Placeholders */
.woocommerce form .form-row .input-text::placeholder,
.woocommerce-checkout .mesa-form-row input::placeholder {
    font-family: 'Open Sans', sans-serif !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    color: #B3B7BD !important;
}

/* Textarea height override */
.woocommerce form .form-row textarea,
.woocommerce-checkout .mesa-form-row textarea {
    height: auto !important;
    min-height: 6.25rem !important;
}

/* Row spacing — gap between field bottom and next label top */
.woocommerce form .form-row,
.woocommerce-checkout .mesa-form-row {
    margin-bottom: 1.25rem !important;
    padding: 0 !important;
}

/* Checkout heading hierarchy */
.woocommerce-billing-fields h3,
.woocommerce-shipping-fields h3,
.woocommerce-checkout h3 {
    font-family: 'Open Sans', sans-serif !important;
    font-size: 1.625rem !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
    color: #08050C !important;
    text-align: right !important;
}

/* Global checkout typography — Open Sans for all text */
.mesa-checkout,
.mesa-checkout *:not(svg):not(path):not(line):not(circle):not(polyline):not(rect) {
    font-family: 'Open Sans', sans-serif !important;
}

/* Consistent 1px border-radius across checkout */
.mesa-checkout {
    --radius-sm: 1px;
    --radius-md: 1px;
    --radius-lg: 1px;
    --radius-full: 1px;
    --checkout-field-radius: 1px;
}

.mesa-checkout *:not(.mesa-order-summary__item-qty) {
    border-radius: 1px !important;
}

.woocommerce-checkout .select2-container .select2-selection--single .select2-selection__arrow {
    height: var(--checkout-field-height);
}

.woocommerce-checkout .woocommerce-error,
.woocommerce-checkout .woocommerce-message,
.woocommerce-checkout .woocommerce-info {
    margin-bottom: var(--space-lg);
    padding: var(--space-md);
    border-radius: var(--radius-md);
}

/* Hide default WooCommerce checkout heading */
.woocommerce-checkout h3#order_review_heading {
    display: none;
}

/* Hide Kadence page title hero and checkout heading */
body.woocommerce-checkout .entry-hero,
body.woocommerce-checkout .page-hero-section,
body.woocommerce-checkout .mesa-checkout__header {
    display: none !important;
}

/* White background, no spacing between header and checkout */
body.woocommerce-checkout,
body.woocommerce-checkout .site,
body.woocommerce-checkout .site-container,
body.woocommerce-checkout .content-area,
body.woocommerce-checkout .entry-content-wrap,
body.woocommerce-checkout .content-wrap {
    background-color: var(--mesa-white) !important;
    padding-top: 0 !important;
    margin-top: 0 !important;
}

body.woocommerce-checkout .mesa-checkout {
    padding-top: var(--space-lg);
}

/* Distraction-free checkout header */
body.woocommerce-checkout .mesa-topbar,
body.woocommerce-checkout .mesa-header__nav,
body.woocommerce-checkout .mesa-header__action--search,
body.woocommerce-checkout .mesa-header__action--user,
body.woocommerce-checkout .mesa-header__hamburger,
body.woocommerce-checkout .mesa-mobile-menu,
body.woocommerce-checkout .mesa-bottom-nav,
body.woocommerce-checkout .mesa-search-overlay {
    display: none !important;
}

/* Hide full footer on checkout (trust footer is in checkout template) */
body.woocommerce-checkout .mesa-footer {
    display: none;
}

/* -------------------------------------------
   Thank You Page
   ------------------------------------------- */
.mesa-thankyou {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: var(--space-lg) var(--container-padding);
}

/* Status Header (Success / Failed) */
.mesa-thankyou__status {
    text-align: center;
    padding: var(--space-2xl) 0 var(--space-xl);
}

.mesa-thankyou__status-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    border-radius: var(--radius-full);
    margin-bottom: var(--space-lg);
    animation: mesaThankyouPop 0.5s ease-out;
}

@keyframes mesaThankyouPop {
    0% { transform: scale(0); opacity: 0; }
    60% { transform: scale(1.15); }
    100% { transform: scale(1); opacity: 1; }
}

.mesa-thankyou__status--success .mesa-thankyou__status-icon {
    background-color: rgba(206, 254, 101, 0.2);
    color: var(--checkout-success);
}

.mesa-thankyou__status--failed .mesa-thankyou__status-icon {
    background-color: rgba(220, 53, 69, 0.1);
    color: var(--checkout-error);
}

.mesa-thankyou__title {
    font-size: var(--text-2xl);
    font-weight: var(--font-bold);
    color: var(--mesa-black);
    margin: 0 0 var(--space-sm);
}

.mesa-thankyou__subtitle {
    font-size: var(--text-base);
    color: var(--mesa-gray-text);
    margin: 0;
    max-width: 480px;
    margin-inline: auto;
    line-height: 1.6;
}

/* Retry Button (Failed Orders) */
.mesa-thankyou__retry-btn {
    display: inline-block;
    margin-top: var(--space-lg);
    padding: var(--space-md) var(--space-2xl);
    background-color: var(--mesa-black);
    color: var(--mesa-white);
    font-size: var(--text-base);
    font-weight: var(--font-bold);
    border-radius: var(--radius-md);
    text-decoration: none;
    transition: all var(--transition-fast);
}

.mesa-thankyou__retry-btn:hover {
    background-color: var(--mesa-lime);
    color: var(--mesa-black);
}

/* Info Grid (Order #, Date, Total, Payment) */
.mesa-thankyou__info-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
    margin-bottom: var(--space-xl);
}

.mesa-thankyou__info-card {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
    padding: var(--space-md) var(--space-lg);
    background-color: var(--mesa-light-gray);
    border-radius: var(--radius-lg);
}

.mesa-thankyou__info-label {
    font-size: var(--text-xs);
    color: var(--mesa-gray-text);
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.mesa-thankyou__info-value {
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    color: var(--mesa-black);
}

/* Sections (Order Items, Addresses) */
.mesa-thankyou__section {
    background-color: var(--mesa-white);
    border: 1px solid var(--mesa-light-gray);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    margin-bottom: var(--space-lg);
}

.mesa-thankyou__section-title {
    font-size: var(--text-lg);
    font-weight: var(--font-bold);
    margin: 0 0 var(--space-lg);
    padding-bottom: var(--space-md);
    border-bottom: 1px solid var(--mesa-light-gray);
    color: var(--mesa-black);
}

/* Address Display */
.mesa-thankyou__address {
    font-style: normal;
    font-size: var(--text-base);
    line-height: 1.7;
    color: var(--mesa-black);
}

.mesa-thankyou__address p {
    margin: var(--space-xs) 0 0;
}

.mesa-thankyou__address-phone,
.mesa-thankyou__address-email {
    color: var(--mesa-gray-text);
}

/* Details Grid (Shipping + Billing side by side) */
.mesa-thankyou__details-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

.mesa-thankyou__details-grid .mesa-thankyou__section {
    margin-bottom: 0;
}

/* Continue Shopping CTA */
.mesa-thankyou__cta {
    text-align: center;
    padding: var(--space-xl) 0;
}

.mesa-thankyou__continue-btn {
    display: inline-block;
    padding: var(--space-md) var(--space-2xl);
    background-color: var(--mesa-lime);
    color: var(--mesa-black);
    font-size: var(--text-base);
    font-weight: var(--font-bold);
    border-radius: var(--radius-md);
    text-decoration: none;
    transition: all var(--transition-fast);
}

.mesa-thankyou__continue-btn:hover {
    background-color: var(--mesa-black);
    color: var(--mesa-lime);
}

/* Distraction-free thank you page (same as checkout) */
body.woocommerce-order-received .mesa-topbar,
body.woocommerce-order-received .mesa-header__nav,
body.woocommerce-order-received .mesa-header__action--search,
body.woocommerce-order-received .mesa-header__action--user,
body.woocommerce-order-received .mesa-header__hamburger,
body.woocommerce-order-received .mesa-mobile-menu,
body.woocommerce-order-received .mesa-bottom-nav,
body.woocommerce-order-received .mesa-search-overlay {
    display: none !important;
}

body.woocommerce-order-received .mesa-footer {
    display: none;
}

body.woocommerce-order-received,
body.woocommerce-order-received .site,
body.woocommerce-order-received .site-container,
body.woocommerce-order-received .content-area,
body.woocommerce-order-received .entry-content-wrap,
body.woocommerce-order-received .content-wrap {
    background-color: var(--mesa-white) !important;
    padding-top: 0 !important;
    margin-top: 0 !important;
}

body.woocommerce-order-received .entry-hero,
body.woocommerce-order-received .page-hero-section {
    display: none !important;
}

/* Thank You - Tablet (768px+) */
@media screen and (min-width: 768px) {
    .mesa-thankyou__info-grid {
        grid-template-columns: repeat(4, 1fr);
    }

    .mesa-thankyou__details-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Thank You - Desktop (1024px+) */
@media screen and (min-width: 1024px) {
    .mesa-thankyou {
        max-width: 800px;
        padding: var(--space-2xl) var(--container-padding);
    }

    .mesa-thankyou__title {
        font-size: var(--text-3xl);
    }
}

/* ===========================================
   END OF MESA THEME STYLES
   =========================================== */
