/* ============================================================
   KAWAII TEDDY – Main Stylesheet
   Brand: White · Light Blue · Light Green · Light Brown
   Font: Montserrat
   ============================================================ */

/* ============================================================
   0. CSS CUSTOM PROPERTIES (Design Tokens)
   ============================================================ */
:root {
    /* Brand Colors */
    --color-white:        #FFFFFF;
    --color-light-blue:   #C5E8F5;
    --color-light-blue-2: #A8D9EE;
    --color-light-blue-3: #E8F6FC;
    --color-light-green:  #C5E8C5;
    --color-light-green-2:#A8D9A8;
    --color-light-green-3:#E8F6E8;
    --color-light-brown:  #D4B896;
    --color-light-brown-2:#C4A07C;
    --color-light-brown-3:#F5EDE4;

    /* Kawaii Accents */
    --color-pink:         #F9C8D8;
    --color-pink-dark:    #F0A0BC;
    --color-cream:        #FEF9F4;
    --color-lavender:     #E8D5F5;

    /* Text */
    --color-text:         #4A3728;
    --color-text-mid:     #7A6558;
    --color-text-light:   #A89585;
    --color-text-inv:     #FFFFFF;

    /* UI */
    --color-border:       #EDE0D4;
    --color-border-light: #F5EDE4;
    --color-bg:           #FEFCFA;
    --color-bg-section:   #F9F5F1;
    --color-success:      #5CAD7C;
    --color-error:        #E05050;
    --color-warning:      #F0B830;

    /* Typography */
    --font-family:        'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-size-xs:       0.75rem;   /* 12px */
    --font-size-sm:       0.875rem;  /* 14px */
    --font-size-base:     1rem;      /* 16px */
    --font-size-md:       1.125rem;  /* 18px */
    --font-size-lg:       1.25rem;   /* 20px */
    --font-size-xl:       1.5rem;    /* 24px */
    --font-size-2xl:      1.875rem;  /* 30px */
    --font-size-3xl:      2.25rem;   /* 36px */
    --font-size-4xl:      3rem;      /* 48px */
    --font-size-5xl:      3.75rem;   /* 60px */

    /* Spacing */
    --space-1:  0.25rem;
    --space-2:  0.5rem;
    --space-3:  0.75rem;
    --space-4:  1rem;
    --space-5:  1.25rem;
    --space-6:  1.5rem;
    --space-8:  2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;
    --space-16: 4rem;
    --space-20: 5rem;
    --space-24: 6rem;
    --space-32: 8rem;

    /* Border Radius */
    --radius-sm:   6px;
    --radius-md:   12px;
    --radius-lg:   20px;
    --radius-xl:   28px;
    --radius-full: 9999px;

    /* Shadows */
    --shadow-xs:  0 1px 3px rgba(74,55,40,0.06);
    --shadow-sm:  0 2px 8px rgba(74,55,40,0.08);
    --shadow-md:  0 4px 16px rgba(74,55,40,0.10);
    --shadow-lg:  0 8px 32px rgba(74,55,40,0.12);
    --shadow-xl:  0 16px 48px rgba(74,55,40,0.15);

    /* Transitions */
    --transition-fast:   150ms ease;
    --transition-base:   250ms ease;
    --transition-slow:   400ms ease;

    /* Layout */
    --container-max:  1280px;
    --container-pad:  1.5rem;   /* 24px – desktop/laptop */
    --header-height:  80px;
    --section-pad:    var(--space-20);
}

/* Guaranteed minimum side padding at every breakpoint */
@media (max-width: 1024px) { :root { --container-pad: 1.5rem; } }
@media (max-width: 768px)  { :root { --container-pad: 1.25rem; } }  /* 20px */
@media (max-width: 480px)  { :root { --container-pad: 1rem; } }     /* 16px */

/* ============================================================
   1. RESET & BASE
   ============================================================ */
*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: 16px;
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
    overflow-x: hidden; /* prevent any element from creating horizontal scroll */
}

body {
    font-family: var(--font-family);
    font-size: var(--font-size-base);
    font-weight: 400;
    line-height: 1.65;
    color: var(--color-text);
    background-color: var(--color-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
    max-width: 100vw;
}

img, video {
    display: block;
    max-width: 100%;
    height: auto;
}

a {
    color: var(--color-light-blue-2);
    text-decoration: none;
    transition: color var(--transition-fast);
}
a:hover { color: var(--color-light-brown-2); }
a:focus-visible {
    outline: 2px solid var(--color-light-blue-2);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
}

ul, ol { list-style: none; }

button {
    font-family: var(--font-family);
    cursor: pointer;
    border: none;
    background: none;
}

input, select, textarea {
    font-family: var(--font-family);
    font-size: var(--font-size-base);
}

/* Headings hierarchy */
h1, h2, h3, h4, h5, h6 {
    font-weight: 700;
    line-height: 1.25;
    color: var(--color-text);
}

h1 { font-size: clamp(var(--font-size-2xl), 4vw, var(--font-size-4xl)); }
h2 { font-size: clamp(var(--font-size-xl),  3vw, var(--font-size-3xl)); }
h3 { font-size: clamp(var(--font-size-lg),  2.5vw, var(--font-size-2xl)); }
h4 { font-size: clamp(var(--font-size-md),  2vw, var(--font-size-xl)); font-weight: 600; }
h5 { font-size: var(--font-size-lg); font-weight: 600; }
h6 { font-size: var(--font-size-base); font-weight: 600; }

p { margin-bottom: var(--space-4); }
p:last-child { margin-bottom: 0; }

.screen-reader-text {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border: 0;
}

.skip-link {
    position: absolute;
    top: -40px;
    left: var(--space-4);
    z-index: 9999;
    padding: var(--space-2) var(--space-4);
    background: var(--color-light-blue-2);
    color: var(--color-text);
    border-radius: var(--radius-md);
    font-weight: 600;
    transition: top var(--transition-fast);
}
.skip-link:focus { top: var(--space-4); }

/* ============================================================
   2. LAYOUT UTILITIES
   ============================================================ */
.container {
    width: 100%;
    max-width: var(--container-max);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--container-pad);
    padding-right: var(--container-pad);
}

#masthead > div.header-inner.container
{
	margin-left: 0px;
	margin-right:0px;
}
/* Header container inherits standard container padding — no overrides */

.site-main { min-height: 60vh; }

/* Responsive helpers */
@media (max-width: 768px) {
    .hide-on-mobile  { display: none !important; }
}
@media (min-width: 769px) {
    .show-on-mobile  { display: none !important; }
}

/* ============================================================
   3. BUTTONS
   ============================================================ */
.btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: 0.75rem 1.75rem;
    font-family: var(--font-family);
    font-size: var(--font-size-sm);
    font-weight: 600;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    border-radius: var(--radius-full);
    border: 2px solid transparent;
    cursor: pointer;
    transition:
        background var(--transition-base),
        color var(--transition-base),
        border-color var(--transition-base),
        transform var(--transition-fast),
        box-shadow var(--transition-base);
    text-decoration: none;
    white-space: nowrap;
    line-height: 1;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }

/* Primary Button */
.btn--primary {
    background: var(--color-light-blue-2);
    color: var(--color-text);
    border-color: var(--color-light-blue-2);
}
.btn--primary:hover {
    background: #8FCDE6;
    border-color: #8FCDE6;
    box-shadow: var(--shadow-md);
    color: var(--color-text);
}

/* Outline Button */
.btn--outline {
    background: transparent;
    color: var(--color-text);
    border-color: var(--color-light-brown);
}
.btn--outline:hover {
    background: var(--color-light-brown-3);
    border-color: var(--color-light-brown-2);
    color: var(--color-text);
    box-shadow: var(--shadow-sm);
}

/* Green Button */
.btn--green {
    background: var(--color-light-green-2);
    color: var(--color-text);
    border-color: var(--color-light-green-2);
}
.btn--green:hover {
    background: #90C490;
    border-color: #90C490;
    box-shadow: var(--shadow-md);
    color: var(--color-text);
}

/* Dark Button */
.btn--dark {
    background: var(--color-text);
    color: var(--color-white);
    border-color: var(--color-text);
}
.btn--dark:hover {
    background: var(--color-text-mid);
    border-color: var(--color-text-mid);
    color: var(--color-white);
}

/* Sizes */
.btn--sm  { padding: 0.5rem 1.25rem; font-size: var(--font-size-xs); }
.btn--lg  { padding: 1rem 2.5rem; font-size: var(--font-size-base); }
.btn--xl  { padding: 1.125rem 3rem; font-size: var(--font-size-md); }
.btn--full { width: 100%; justify-content: center; }

/* ============================================================
   4. SITE HEADER
   ============================================================ */
.site-header {
    position: sticky;
    top: 0;
    z-index: 500;
    background: var(--color-white);
    border-bottom: 1px solid var(--color-border-light);
    box-shadow: var(--shadow-xs);
    transition: box-shadow var(--transition-base);
}
.site-header.is-scrolled {
    box-shadow: var(--shadow-sm);
}

.header-inner {
    display: flex;
    align-items: center;
    gap: var(--space-6);
    height: var(--header-height);
}

/* Logo */
.site-header__logo {
    flex-shrink: 0;
}
.site-header__logo .custom-logo {
    display: block;
    max-height: 56px;
    width: 198px;
}
.site-header__text-logo {
    display: flex;
    flex-direction: column;
    text-decoration: none;
}
.site-header__site-name {
    font-size: var(--font-size-xl);
    font-weight: 800;
    color: var(--color-text);
    line-height: 1.1;
}
.site-header__tagline {
    font-size: var(--font-size-xs);
    color: var(--color-text-mid);
    font-weight: 500;
}

/* Primary Nav */
.site-header__nav {
    flex: 1;
    display: flex;
    align-items: center;
    padding: 0 var(--space-4);
}

.nav-menu {
    display: flex;
    align-items: center;
    justify-content: space-evenly;
    width: 100%;
    flex-wrap: nowrap;
    white-space: nowrap;
}

.nav-menu > li {
    position: relative;
}

.nav-menu > li > a {
    display: block;
    padding: var(--space-2) var(--space-3);
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--color-text);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-radius: var(--radius-full);
    white-space: nowrap;
    transition:
        background var(--transition-fast),
        color var(--transition-fast);
}
.nav-menu > li > a:hover,
.nav-menu > li.current-menu-item > a,
.nav-menu > li.current-menu-ancestor > a {
    background: var(--color-light-blue-3);
    color: var(--color-light-blue-2);
}

/* Dropdown */
.nav-menu .sub-menu {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    min-width: 200px;
    background: var(--color-white);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    padding: var(--space-2) 0;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
        opacity var(--transition-base),
        transform var(--transition-base);
    transform: translateX(-50%) translateY(-8px);
    z-index: 600;
}
.nav-menu > li:hover .sub-menu,
.nav-menu > li:focus-within .sub-menu {
    opacity: 1;
    visibility: visible;
    pointer-events: all;
    transform: translateX(-50%) translateY(0);
}
.nav-menu .sub-menu a {
    display: block;
    padding: var(--space-2) var(--space-5);
    font-size: var(--font-size-sm);
    font-weight: 500;
    color: var(--color-text);
    transition: background var(--transition-fast), color var(--transition-fast);
}
.nav-menu .sub-menu a:hover {
    background: var(--color-light-blue-3);
    color: var(--color-light-blue-2);
}

/* Header Actions */
.site-header__actions {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-shrink: 0;
}

.header-action {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    font-size: 1.125rem;
    color: var(--color-text);
    border-radius: var(--radius-full);
    text-decoration: none;
    transition:
        background var(--transition-fast),
        color var(--transition-fast);
}
.header-action:hover {
    background: var(--color-light-blue-3);
    color: var(--color-light-blue-2);
}

.header-action__count {
    position: absolute;
    top: 4px;
    right: 4px;
    min-width: 18px;
    height: 18px;
    padding: 0 4px;
    background: var(--color-pink-dark);
    color: var(--color-white);
    font-size: 10px;
    font-weight: 700;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    pointer-events: none;
}
.header-action__count:empty,
.header-action__count[data-count="0"] { display: none; }

/* Hamburger */
.hamburger {
    display: flex;
    flex-direction: column;
    gap: 4px;
    width: 20px;
}
.hamburger span {
    display: block;
    height: 2px;
    background: var(--color-text);
    border-radius: 2px;
    transition:
        transform var(--transition-base),
        opacity var(--transition-base);
}

.header-action--menu { display: none; }

/* Tablet search bar – hidden by default, shown only at tablet breakpoint */
.header-search--tablet {
    display: none;
    flex: 1;
    margin: 0 var(--space-4);
    max-width: 460px;
}
.header-search--tablet__form {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    width: 100%;
    background: var(--color-bg-section);
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-full);
    padding: 0 var(--space-4);
    height: 40px;
    transition: border-color var(--transition-fast);
}
.header-search--tablet__form:focus-within {
    border-color: var(--color-light-blue-2);
    background: var(--color-white);
}
.header-search--tablet__form > i {
    color: var(--color-text-light);
    font-size: 0.875rem;
    flex-shrink: 0;
}
.header-search--tablet__input {
    flex: 1;
    border: none;
    background: none;
    font-family: var(--font-family);
    font-size: var(--font-size-sm);
    color: var(--color-text);
    padding: 0;
    min-width: 0;
}
.header-search--tablet__input::placeholder { color: var(--color-text-light); }
.header-search--tablet__input:focus { outline: none; }

/* ≤1280px: hide desktop nav, show hamburger, hide the slide-down search toggle.
   This covers 1025px–1280px where long nav items would overflow and clip the action icons. */
@media (max-width: 1280px) {
    .site-header__nav { display: none; }
    .header-action--menu { display: flex; }
    .header-action--search { display: none; }
}

/* 769px–1280px (tablet + small desktop): show inline search bar; keep all icons visible */
@media (min-width: 768px) and (max-width: 1280px) {
    .header-search--tablet { display: flex; }
    .header-action--wishlist { display: flex; }
}

/* Mobile only (≤768px): hide wishlist from header (it's in the mobile menu) */
@media (max-width: 767px) {
    .header-action--wishlist { display: none; }
    .header-search--tablet { display: none; }
}

/* Desktop nav compact mode: 1281px–1473px – tighter padding so all items fit */
@media (min-width: 1281px) and (max-width: 1473px) {
    .header-inner { gap: var(--space-4); }
    .site-header__nav { padding: 0 var(--space-2); }
    .nav-menu > li > a {
        padding: var(--space-2) var(--space-2);
        font-size: 0.65rem;
        letter-spacing: 0.03em;
    }
    .site-header__actions { gap: var(--space-1); }
    .header-action { width: 36px; height: 36px; font-size: 1rem; }
}

/* Search Bar */
.header-search {
    background: var(--color-light-blue-3);
    border-top: 1px solid var(--color-border-light);
    padding: var(--space-4) 0;
    animation: slideDown var(--transition-base) ease;
}
@keyframes slideDown {
    from { opacity: 0; transform: translateY(-10px); }
    to   { opacity: 1; transform: translateY(0); }
}
.header-search__form {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    max-width: 600px;
    margin: 0 auto;
}
.header-search__input {
    flex: 1;
    padding: 0.75rem var(--space-5);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-full);
    font-size: var(--font-size-base);
    background: var(--color-white);
    color: var(--color-text);
    transition: border-color var(--transition-fast);
}
.header-search__input:focus {
    outline: none;
    border-color: var(--color-light-blue-2);
}
.header-search__close {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-mid);
    font-size: 1.25rem;
    border-radius: var(--radius-full);
    transition: background var(--transition-fast);
}
.header-search__close:hover { background: var(--color-border-light); }

/* ============================================================
   5. MOBILE MENU
   ============================================================ */
.mobile-menu {
    position: fixed;
    inset: 0;
    z-index: 900;
    display: flex;
    align-items: stretch;
}
.mobile-menu[hidden] { display: none; }

.mobile-menu__overlay {
    position: absolute;
    inset: 0;
    background: rgba(74, 55, 40, 0.5);
    backdrop-filter: blur(2px);
    cursor: pointer;
}

.mobile-menu__panel {
    position: relative;
    width: min(340px, 90vw);
    background: var(--color-white);
    height: 100%;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    padding: var(--space-6);
    animation: slideInLeft var(--transition-slow) ease;
    z-index: 1;
}
@keyframes slideInLeft {
    from { transform: translateX(-100%); }
    to   { transform: translateX(0); }
}

.mobile-menu__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-8);
    padding-bottom: var(--space-4);
    border-bottom: 1px solid var(--color-border-light);
}
.mobile-menu__header .custom-logo { max-height: 40px; }
.mobile-menu__site-name { font-weight: 800; font-size: var(--font-size-lg); }
.mobile-menu__close {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    color: var(--color-text-mid);
    border-radius: var(--radius-full);
    transition: background var(--transition-fast);
}
.mobile-menu__close:hover { background: var(--color-border-light); }

.mobile-nav-menu {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}
.mobile-nav-menu li a {
    display: block;
    padding: var(--space-3) var(--space-4);
    font-size: var(--font-size-base);
    font-weight: 600;
    color: var(--color-text);
    border-radius: var(--radius-md);
    transition: background var(--transition-fast);
}
.mobile-nav-menu li a:hover {
    background: var(--color-light-blue-3);
    color: var(--color-light-blue-2);
}
.mobile-nav-menu .sub-menu {
    margin-left: var(--space-4);
    margin-top: var(--space-1);
}
.mobile-nav-menu .sub-menu a {
    font-size: var(--font-size-sm);
    font-weight: 500;
    padding: var(--space-2) var(--space-4);
}

.mobile-menu__footer-actions {
    margin-top: var(--space-8);
    padding-top: var(--space-4);
    border-top: 1px solid var(--color-border-light);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}
.mobile-menu__link {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    font-size: var(--font-size-sm);
    font-weight: 500;
    color: var(--color-text-mid);
    border-radius: var(--radius-md);
    transition: background var(--transition-fast);
}
.mobile-menu__link:hover { background: var(--color-border-light); }
.mobile-menu__cart-badge {
    margin-left: auto;
    min-width: 20px;
    height: 20px;
    padding: 0 5px;
    background: var(--color-pink-dark);
    color: var(--color-white);
    font-size: 11px;
    font-weight: 700;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ============================================================
   6. HERO SLIDER
   ============================================================ */
.hero-slider { position: relative; overflow: hidden; }

.hero-swiper { height: clamp(420px, 60vh, 720px); }

.hero-slide {
    position: relative;
    height: 100%;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.hero-slide--fallback {
    min-height: clamp(420px, 60vh, 720px);
    background: linear-gradient(135deg, var(--color-light-blue-3) 0%, var(--color-light-green-3) 50%, var(--color-light-brown-3) 100%);
}

.hero-slide__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    z-index: 0;
    transform: scale(1.05);
    transition: transform 6s ease;
}
.swiper-slide-active .hero-slide__bg { transform: scale(1); }

.hero-slide__picture {
    position: absolute;
    inset: 0;
    z-index: 0;
}
.hero-slide__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.hero-slide__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to right,
        rgba(255, 255, 255, 0.65) 0%,
        rgba(255, 255, 255, 0.25) 60%,
        transparent 100%
    );
    z-index: 1;
}

.hero-slide--fallback .hero-slide__overlay { display: none; }

.hero-slide__content {
    position: relative;
    z-index: 2;
    width: 100%;
    padding: var(--space-12) 0;
}

.hero-slide__subtitle {
    font-size: var(--font-size-sm);
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-light-blue-2);
    margin-bottom: var(--space-3);
}

.hero-slide__title {
    font-size: clamp(var(--font-size-2xl), 5vw, var(--font-size-5xl));
    font-weight: 800;
    color: var(--color-text);
    margin-bottom: var(--space-4);
    max-width: 600px;
    line-height: 1.1;
}

.hero-slide--fallback .hero-slide__title { color: var(--color-text); }

.hero-slide__desc {
    font-size: var(--font-size-md);
    color: var(--color-text-mid);
    max-width: 480px;
    margin-bottom: var(--space-8);
    font-weight: 500;
}

.hero-slide__btn { margin-top: var(--space-2); }

/* Swiper Overrides for Hero */
.hero-swiper .swiper-button-prev,
.hero-swiper .swiper-button-next {
    width: 50px;
    height: 50px;
    background: rgba(255,255,255,0.9);
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-md);
    color: var(--color-text);
    transition:
        background var(--transition-fast),
        transform var(--transition-fast);
}
.hero-swiper .swiper-button-prev:hover,
.hero-swiper .swiper-button-next:hover {
    background: var(--color-white);
    transform: scale(1.05);
}
.hero-swiper .swiper-button-prev::after,
.hero-swiper .swiper-button-next::after { display: none; }
.hero-swiper .swiper-button-prev i,
.hero-swiper .swiper-button-next i { font-size: 1rem; }

.hero-swiper .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    background: rgba(255,255,255,0.5);
    opacity: 1;
    transition: all var(--transition-base);
}
.hero-swiper .swiper-pagination-bullet-active {
    background: var(--color-white);
    width: 28px;
    border-radius: var(--radius-full);
}

@media (max-width: 768px) {
    .hero-swiper { height: clamp(320px, 55vw, 480px); }
    .hero-slide__title { font-size: var(--font-size-2xl); }
    .hero-swiper .swiper-button-prev,
    .hero-swiper .swiper-button-next { display: none; }
}

/* ============================================================
   7. TRUST BADGES
   ============================================================ */
.trust-badges {
    background: var(--color-light-blue-3);
    padding: var(--space-6) 0;
    border-bottom: 1px solid var(--color-border-light);
}
.trust-badges__list {
    display: flex;
    justify-content: center;
    gap: var(--space-8);
    flex-wrap: wrap;
}
.trust-badge {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}
.trust-badge i {
    font-size: 1.5rem;
    color: var(--color-light-blue-2);
    flex-shrink: 0;
}
.trust-badge strong {
    display: block;
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
    line-height: 1.2;
}
.trust-badge span {
    display: block;
    font-size: var(--font-size-xs);
    color: var(--color-text-mid);
}

@media (max-width: 600px) {
    .trust-badges__list { gap: var(--space-5); }
    .trust-badge span { display: none; }
}

/* ============================================================
   8. SECTION HEADER (shared)
   ============================================================ */
.home-section { padding: var(--section-pad) 0; }
.home-section:nth-child(even) { background: var(--color-bg-section); }

.section-header {
    text-align: center;
    margin-bottom: var(--space-12);
}
.section-header__eyebrow {
    display: inline-block;
    font-size: var(--font-size-xs);
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-light-brown-2);
    margin-bottom: var(--space-3);
    padding: var(--space-1) var(--space-4);
    background: var(--color-light-brown-3);
    border-radius: var(--radius-full);
}
.section-header__title {
    margin-bottom: var(--space-4);
    color: var(--color-text);
}
.section-header__desc {
    font-size: var(--font-size-md);
    color: var(--color-text-mid);
    max-width: 520px;
    margin: 0 auto;
    font-weight: 400;
}

.section-footer {
    text-align: center;
    margin-top: var(--space-12);
}

/* ============================================================
   9. PRODUCT CARDS
   ============================================================ */
.product-row {
    display: grid;
    gap: var(--space-6);
}
.product-row--5 { grid-template-columns: repeat(5, 1fr); }
.product-row--4 { grid-template-columns: repeat(4, 1fr); }
.product-row--3 { grid-template-columns: repeat(3, 1fr); }

@media (max-width: 1200px) {
    .product-row--5 { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 1024px) {
    .product-row--5,
    .product-row--4 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
    .product-row--5,
    .product-row--4,
    .product-row--3 { grid-template-columns: repeat(2, 1fr); }
    .product-row { gap: var(--space-4); }
}
@media (max-width: 480px) {
    .product-row--5,
    .product-row--4 { grid-template-columns: repeat(2, 1fr); }
    .product-row--3 { grid-template-columns: repeat(1, 1fr); }
}

/* Product Card */
.product-card {
    position: relative;
    background: var(--color-white);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-xs);
    transition:
        transform var(--transition-base),
        box-shadow var(--transition-base);
    display: flex;
    flex-direction: column;
}
.product-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.product-card__image-wrap {
    position: relative;
    overflow: hidden;
    aspect-ratio: 1 / 1;
    background: var(--color-border-light);
}
.product-card__image-link {
    display: block;
    width: 100%;
    height: 100%;
}
.product-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}
.product-card:hover .product-card__image { transform: scale(1.06); }

/* Badge */
.product-card__badge {
    position: absolute;
    top: var(--space-3);
    left: var(--space-3);
    z-index: 2;
    padding: var(--space-1) var(--space-3);
    font-size: var(--font-size-xs);
    font-weight: 700;
    border-radius: var(--radius-full);
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.product-card__badge--sale {
    background: var(--color-pink);
    color: var(--color-text);
}
.product-card__badge--new {
    background: var(--color-light-green);
    color: var(--color-text);
}

/* Wishlist */
.product-card__wishlist {
    position: absolute;
    top: var(--space-3);
    right: var(--space-3);
    z-index: 2;
    width: 36px;
    height: 36px;
    background: rgba(255,255,255,0.9);
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    color: var(--color-text-light);
    box-shadow: var(--shadow-xs);
    transition:
        background var(--transition-fast),
        color var(--transition-fast),
        transform var(--transition-fast);
    opacity: 0;
    transform: translateY(-4px);
}
.product-card:hover .product-card__wishlist {
    opacity: 1;
    transform: translateY(0);
}
.product-card__wishlist:hover,
.product-card__wishlist.is-wishlisted {
    background: var(--color-pink);
    color: var(--color-text);
}
.product-card__wishlist.is-wishlisted .fa-regular { font-weight: 900; }

/* Quick Add */
.product-card__quick-add {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--space-3);
    display: flex;
    justify-content: center;
    background: linear-gradient(to top, rgba(255,255,255,0.95) 0%, transparent 100%);
    transform: translateY(100%);
    transition: transform var(--transition-base);
}
.product-card:hover .product-card__quick-add { transform: translateY(0); }

/* Card Info */
.product-card__info {
    padding: var(--space-4);
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}
.product-card__title {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text);
    line-height: 1.35;
    margin: 0;
}
.product-card__title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--transition-fast);
}
.product-card__title a:hover { color: var(--color-light-blue-2); }

.product-card__rating {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    line-height: 1;
}
.product-card__rating .star-rating {
    font-size: 0.65rem;
    gap: 1px;
    display: inline-block; /* FIX */
    position: relative;    /* FIX */
    overflow: hidden;      /* FIX */
    width: 5.4em;          /* REQUIRED */
    height: 1em;
    line-height: 1;
}
.product-card__rating-count {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    font-weight: 500;
}

.product-card__price {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
}
.product-card__price .woocommerce-Price-amount { color: var(--color-text); }
.product-card__price del { color: var(--color-text-light); font-weight: 400; margin-right: var(--space-2); }
.product-card__price ins { text-decoration: none; color: var(--color-pink-dark); }

/* No Products */
.no-products-message {
    text-align: center;
    padding: var(--space-16);
    color: var(--color-text-mid);
    font-style: italic;
}

/* ============================================================
   10. CATEGORY SHOWCASE
   ============================================================ */
.category-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-6);
}

@media (max-width: 1024px) { .category-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .category-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-4); } }

.category-card {
    display: block;
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    text-decoration: none;
    background: var(--color-border-light);
    box-shadow: var(--shadow-xs);
    transition:
        transform var(--transition-base),
        box-shadow var(--transition-base);
}
.category-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.category-card__img-wrap {
    aspect-ratio: 1 / 1;
    overflow: hidden;
}
.category-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}
.category-card:hover .category-card__img { transform: scale(1.08); }

.category-card__info {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--space-4) var(--space-5);
    background: linear-gradient(to top, rgba(255,255,255,0.95) 60%, transparent);
}
.category-card__name {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 2px;
}
.category-card__count {
    font-size: var(--font-size-xs);
    color: var(--color-text-mid);
}

/* ============================================================
   11. ARRIVALS SWIPER (mobile)
   ============================================================ */
.arrivals-swiper { padding-bottom: var(--space-10) !important; }
.arrivals-swiper .swiper-slide { height: auto; }
.arrivals-swiper .product-card { height: 100%; }
.arrivals-swiper__pagination { bottom: 0 !important; }
.arrivals-swiper .swiper-pagination-bullet {
    background: var(--color-light-brown);
}
.arrivals-swiper .swiper-pagination-bullet-active {
    background: var(--color-light-blue-2);
    width: 20px;
    border-radius: var(--radius-full);
}

/* ============================================================
   12. NEWSLETTER SECTION
   ============================================================ */
.newsletter-section {
    background: linear-gradient(135deg, var(--color-light-blue-3) 0%, var(--color-light-green-3) 50%, var(--color-light-brown-3) 100%);
    padding: var(--space-20) 0;
    position: relative;
    overflow: hidden;
}

.newsletter-inner {
    position: relative;
    max-width: 680px;
    margin: 0 auto;
    text-align: center;
}

.newsletter-decoration {
    position: absolute;
    inset: 0;
    pointer-events: none;
}
.deco-star {
    position: absolute;
    font-size: 1.5rem;
    color: var(--color-light-blue-2);
    opacity: 0.6;
    animation: floatStar 4s ease-in-out infinite;
}
.deco-star--1 { top: 10%; left: -60px; animation-delay: 0s; }
.deco-star--2 { top: 50%; right: -40px; font-size: 1rem; animation-delay: 1.5s; }
.deco-star--3 { bottom: 10%; left: -20px; font-size: 0.75rem; animation-delay: 3s; }
.deco-bear {
    position: absolute;
    top: -30px;
    right: -60px;
    font-size: 4rem;
    opacity: 0.15;
    transform: rotate(15deg);
}
@keyframes floatStar {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    50%       { transform: translateY(-10px) rotate(15deg); }
}

.newsletter-title {
    font-size: clamp(var(--font-size-xl), 3vw, var(--font-size-3xl));
    margin-bottom: var(--space-4);
    color: var(--color-text);
}
.newsletter-desc {
    color: var(--color-text-mid);
    font-size: var(--font-size-md);
    margin-bottom: var(--space-8);
}

.newsletter-form__group {
    display: flex;
    gap: var(--space-3);
    max-width: 520px;
    margin: 0 auto var(--space-4);
}
.newsletter-form__input {
    flex: 1;
    padding: 0.875rem var(--space-5);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-full);
    font-size: var(--font-size-base);
    background: var(--color-white);
    color: var(--color-text);
    transition: border-color var(--transition-fast);
}
.newsletter-form__input:focus {
    outline: none;
    border-color: var(--color-light-blue-2);
}
.newsletter-form__privacy {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    margin-bottom: 0;
}
.newsletter-form__privacy a {
    color: var(--color-text-mid);
    text-decoration: underline;
}

.newsletter-form__message {
    margin-top: var(--space-4);
    font-size: var(--font-size-sm);
    font-weight: 600;
    min-height: 24px;
}
.newsletter-form__message.is-success { color: var(--color-success); }
.newsletter-form__message.is-error   { color: var(--color-error); }

@media (max-width: 600px) {
    .newsletter-form__group { flex-direction: column; }
    .newsletter-form__input,
    .newsletter-form__submit { width: 100%; justify-content: center; }
}

/* ============================================================
   13. SITE FOOTER
   ============================================================ */
.site-footer {
    background: var(--color-white);
    border-top: 1px solid var(--color-border-light);
}

.footer-main { padding: var(--space-16) 0 var(--space-12); }

.footer-main__grid {
    display: grid;
    grid-template-columns: 300px 1fr;
    gap: var(--space-16);
    align-items: start;
}

.footer-brand__logo { margin-bottom: var(--space-5); }
.footer-brand__logo .custom-logo { max-height: 56px; }
.footer-brand__text-logo {
    font-size: var(--font-size-xl);
    font-weight: 800;
    color: var(--color-text);
    text-decoration: none;
}
.footer-brand__tagline {
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    line-height: 1.6;
    margin-bottom: var(--space-6);
}

/* Social Links */
.footer-brand__social {
    display: flex;
    gap: var(--space-3);
    flex-wrap: wrap;
}
.social-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: var(--color-border-light);
    color: var(--color-text-mid);
    border-radius: var(--radius-full);
    font-size: 1rem;
    text-decoration: none;
    transition:
        background var(--transition-fast),
        color var(--transition-fast),
        transform var(--transition-fast);
}
.social-link:hover {
    background: var(--color-light-blue);
    color: var(--color-text);
    transform: translateY(-2px);
}

/* Footer Company */
.footer-company {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-8);
}

.footer-col__title {
    font-size: var(--font-size-sm);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text);
    margin-bottom: var(--space-5);
}

.footer-col__list {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}
.footer-col__list li a {
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    text-decoration: none;
    transition: color var(--transition-fast);
    font-weight: 500;
}
.footer-col__list li a:hover { color: var(--color-light-blue-2); }

/* Contact list */
.footer-col__list--contact li {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    font-weight: 500;
}
.footer-col__list--contact li i {
    color: var(--color-light-blue-2);
    margin-top: 3px;
    flex-shrink: 0;
    width: 16px;
}
.footer-col__list--contact li a { color: var(--color-text-mid); }
.footer-col__list--contact li a:hover { color: var(--color-light-blue-2); }

/* Footer Bottom */
.footer-bottom {
    background: var(--color-bg-section);
    border-top: 1px solid var(--color-border-light);
    padding: var(--space-5) 0;
}
.footer-bottom__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--space-4);
}
.footer-bottom__copy {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    margin: 0;
}
.footer-bottom__copy a { color: var(--color-text-mid); }
.footer-bottom__links {
    display: flex;
    gap: var(--space-5);
}
.footer-bottom__links a {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    text-decoration: underline;
    transition: color var(--transition-fast);
}
.footer-bottom__links a:hover { color: var(--color-text); }

.footer-payment {
    display: flex;
    gap: var(--space-3);
    align-items: center;
}
.footer-payment i {
    font-size: 1.75rem;
    color: var(--color-text-light);
    transition: color var(--transition-fast);
}
.footer-payment i:hover { color: var(--color-text-mid); }

@media (max-width: 1024px) {
    .footer-main__grid { grid-template-columns: 1fr; gap: var(--space-10); }
    .footer-brand { text-align: center; }
    .footer-brand__social { justify-content: center; }
    .footer-company { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
    .footer-company { grid-template-columns: repeat(2, 1fr); gap: var(--space-6); }
    .footer-bottom__inner { flex-direction: column; text-align: center; }
    .footer-bottom__links { flex-wrap: wrap; justify-content: center; }
}
@media (max-width: 480px) {
    .footer-company { grid-template-columns: 1fr 1fr; }
}

/* ============================================================
   14. SHOP / ARCHIVE PAGE
   ============================================================ */
.shop-page { padding: var(--space-12) 0 var(--space-20); }

.shop-page__hero {
    background: linear-gradient(135deg, var(--color-light-blue-3), var(--color-light-green-3));
    padding: var(--space-12) 0;
    margin-bottom: var(--space-10);
    text-align: center;
}
.shop-page__hero-inner { max-width: 680px; margin: 0 auto; }
.shop-page__title { margin-bottom: var(--space-3); }
.shop-page__description {
    color: var(--color-text-mid);
    font-size: var(--font-size-md);
}

/* Filters + Products layout */
.shop-page__body {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: var(--space-10);
    align-items: start;
}

@media (max-width: 1024px) {
    .shop-page__body { grid-template-columns: 1fr; }
}

/* Filters Panel */
.shop-filters-panel {
    background: var(--color-white);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    position: sticky;
    top: calc(var(--header-height) + var(--space-4));
}
.shop-filters-panel__title {
    font-size: var(--font-size-base);
    font-weight: 700;
    margin-bottom: var(--space-5);
    padding-bottom: var(--space-4);
    border-bottom: 1px solid var(--color-border-light);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.filter-widget { margin-bottom: var(--space-6); }
.filter-widget:last-child { margin-bottom: 0; }
.filter-widget__title {
    font-size: var(--font-size-sm);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text);
    margin-bottom: var(--space-4);
}

/* Mobile filter toggle */
.shop-filters-toggle {
    display: none;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-5);
    background: var(--color-white);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text);
    cursor: pointer;
    transition: background var(--transition-fast);
    margin-bottom: var(--space-5);
}
.shop-filters-toggle:hover { background: var(--color-border-light); }

@media (max-width: 1024px) {
    .shop-filters-toggle { display: flex; }
    .shop-filters-panel {
        position: fixed;
        top: 0;
        left: 0;
        width: min(320px, 90vw);
        height: 100%;
        z-index: 800;
        overflow-y: auto;
        border-radius: 0;
        transform: translateX(-100%);
        transition: transform var(--transition-slow);
        border: none;
        border-right: 1px solid var(--color-border-light);
    }
    .shop-filters-panel.is-open { transform: translateX(0); }
}

/* Product Toolbar */
.shop-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    margin-bottom: var(--space-6);
    flex-wrap: wrap;
}
.shop-toolbar__count {
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    font-weight: 500;
}
.shop-toolbar__sort select {
    padding: var(--space-2) var(--space-4);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-weight: 500;
    color: var(--color-text);
    background: var(--color-white);
    cursor: pointer;
    transition: border-color var(--transition-fast);
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234A3728' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 36px;
}
.shop-toolbar__sort select:focus { outline: none; border-color: var(--color-light-blue-2); }

/* Shop Products Grid */
.shop-products { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-6); }

@media (max-width: 1200px) { .shop-products { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px)  { .shop-products { grid-template-columns: repeat(2, 1fr); gap: var(--space-4); } }
@media (max-width: 380px)  { .shop-products { grid-template-columns: 1fr; } }

/* Shop pagination */
.shop-pagination {
    margin-top: var(--space-12);
    display: flex;
    justify-content: center;
}
.shop-pagination ul.page-numbers,
.shop-pagination .woocommerce-pagination ul {
    display: flex !important;
    align-items: center;
    gap: var(--space-2);
    flex-wrap: wrap;
    justify-content: center;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
}
.shop-pagination ul.page-numbers li,
.shop-pagination .woocommerce-pagination li {
    list-style: none !important;
    border: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Perfect circles — override WooCommerce defaults with !important */
.shop-pagination .page-numbers a,
.shop-pagination .page-numbers span {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 44px !important;
    height: 44px !important;
    line-height: 44px !important;
    border-radius: 50% !important;
    font-size: var(--font-size-sm) !important;
    font-weight: 700 !important;
    color: var(--color-text-mid) !important;
    background: var(--color-light-brown-3) !important;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    text-decoration: none !important;
    padding: 0 !important;
    transition:
        background var(--transition-fast),
        color var(--transition-fast),
        transform var(--transition-fast),
        box-shadow var(--transition-fast);
}
.shop-pagination .page-numbers a:hover {
    background: var(--color-pink) !important;
    color: var(--color-text) !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(240, 160, 188, 0.4) !important;
    outline: none !important;
}
/* Current page: filled pink circle */
.shop-pagination .page-numbers .current {
    background: var(--color-pink-dark) !important;
    color: var(--color-white) !important;
    box-shadow: 0 4px 14px rgba(240, 160, 188, 0.5) !important;
    cursor: default;
}
/* Dots separator: invisible */
.shop-pagination .page-numbers .dots {
    background: transparent !important;
    color: var(--color-text-light) !important;
    cursor: default;
    pointer-events: none;
    box-shadow: none !important;
}
/* Prev / Next: light blue circles */
.shop-pagination .page-numbers .prev,
.shop-pagination .page-numbers .next {
    background: var(--color-light-blue-3) !important;
    color: var(--color-light-blue-2) !important;
}
.shop-pagination .page-numbers .prev:hover,
.shop-pagination .page-numbers .next:hover {
    background: var(--color-light-blue-2) !important;
    color: var(--color-white) !important;
    box-shadow: 0 4px 12px rgba(168, 217, 238, 0.45) !important;
}
/* Remove focus outline square on pagination links */
.shop-pagination .page-numbers a:focus,
.shop-pagination .page-numbers a:focus-visible {
    outline: none !important;
    box-shadow: none !important;
}

/* Category long description */
.shop-bottom-content {
    margin-top: var(--space-20);
    padding-top: var(--space-12);
    border-top: 1px solid var(--color-border-light);
}
.shop-bottom-content__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-12);
}
@media (max-width: 768px) {
    .shop-bottom-content__grid { grid-template-columns: 1fr; }
}

.shop-long-desc h2,
.shop-long-desc h3 { margin-bottom: var(--space-4); }
.shop-long-desc p  { color: var(--color-text-mid); margin-bottom: var(--space-4); }

/* FAQ */
.shop-faq__title { margin-bottom: var(--space-6); }
.faq-item {
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-md);
    overflow: hidden;
    margin-bottom: var(--space-3);
}
.faq-item__question {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-4) var(--space-5);
    font-size: var(--font-size-base);
    font-weight: 600;
    color: var(--color-text);
    text-align: left;
    background: var(--color-white);
    cursor: pointer;
    transition: background var(--transition-fast);
}
.faq-item__question:hover { background: var(--color-border-light); }
.faq-item__question i {
    font-size: 0.875rem;
    color: var(--color-text-light);
    transition: transform var(--transition-base);
    flex-shrink: 0;
    margin-left: var(--space-4);
}
.faq-item.is-open .faq-item__question i { transform: rotate(180deg); }

.faq-item__answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height var(--transition-slow);
}
.faq-item.is-open .faq-item__answer { max-height: 400px; }
.faq-item__answer-inner {
    padding: var(--space-4) var(--space-5) var(--space-5);
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    line-height: 1.7;
    border-top: 1px solid var(--color-border-light);
}

/* ============================================================
   15. SINGLE PRODUCT (PDP)
   ============================================================ */
.product-page { padding: var(--space-12) 0 var(--space-20); }
@media (max-width: 768px) {
    .product-page { padding: var(--space-6) 0 var(--space-12); }
}

/* Breadcrumb */
.product-breadcrumb {
    margin-bottom: var(--space-8);
}
@media (max-width: 768px) {
    .product-breadcrumb { margin-bottom: var(--space-4); }
}
.product-breadcrumb__list {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-wrap: wrap;
}
.product-breadcrumb__item {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
}
.product-breadcrumb__item a {
    color: var(--color-text-mid);
    font-weight: 500;
    transition: color var(--transition-fast);
}
.product-breadcrumb__item a:hover { color: var(--color-light-blue-2); }
.product-breadcrumb__item::after {
    content: '/';
    color: var(--color-border);
    margin-left: var(--space-2);
}
.product-breadcrumb__item:last-child::after { display: none; }
.product-breadcrumb__item:last-child { color: var(--color-text); font-weight: 600; }

/* Product Layout */
.product-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-12);
    align-items: start;
    margin-bottom: var(--space-16);
}

/* Product Gallery */
.product-gallery {
    position: sticky;
    top: calc(var(--header-height) + var(--space-6));
}

.product-gallery__main-swiper {
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--color-border-light);
    margin-bottom: var(--space-4);
    aspect-ratio: 1 / 1;
}
.product-gallery__main-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    cursor: zoom-in;
}

.product-gallery__thumbs {
    display: flex;
    gap: var(--space-2);
    flex-wrap: wrap;
}
.product-gallery__thumb {
    border-radius: var(--radius-md);
    overflow: hidden;
    border: 2px solid transparent;
    cursor: pointer;
    width: calc(20% - var(--space-2));
    aspect-ratio: 1 / 1;
    background: var(--color-border-light);
    transition: border-color var(--transition-fast);
    flex-shrink: 0;
}
.product-gallery__thumb.is-active { border-color: var(--color-light-blue-2); }
.product-gallery__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-base);
}
.product-gallery__thumb:hover img { transform: scale(1.05); }

/* ── Tablet: narrow columns ── */
@media (max-width: 1024px) {
    .product-layout {
        grid-template-columns: 1fr 1fr;
        gap: var(--space-8);
    }
}

/* ── Mobile: single column, no sticky ── */
@media (max-width: 768px) {
    .product-layout {
        grid-template-columns: 1fr;
        gap: var(--space-5);
        margin-bottom: var(--space-10);
    }
    /* Remove sticky so gallery scrolls normally */
    .product-gallery {
        position: static;
        top: auto;
    }
    /* Main image: less tall on mobile */
    .product-gallery__main-swiper {
        border-radius: var(--radius-md);
        aspect-ratio: 1/1;
    }
    /* Thumbnails: horizontal scroll strip — stays within container */
    .product-gallery__thumbs {
        flex-wrap: nowrap;
        overflow-x: auto;
        overflow-y: hidden;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        gap: var(--space-2);
        padding-bottom: var(--space-1);
        padding-right: var(--space-1); /* ensure last thumb isn't clipped */
        scrollbar-width: none;
        /* Keeps scroll container strictly inside container padding */
        max-width: 100%;
    }
    .product-gallery__thumbs::-webkit-scrollbar { display: none; }
    .product-gallery__thumb {
        width: 60px;
        min-width: 60px;
        flex-shrink: 0;
        scroll-snap-align: start;
    }
    /* Details: add horizontal padding */
    .product-details {
        gap: var(--space-4);
        padding: 0 var(--space-1);
    }
    .product-details__title {
        font-size: var(--font-size-xl) !important;
    }
}

/* Product Details (Right Column) */
.product-details { display: flex; flex-direction: column; gap: var(--space-6); }

.product-details__meta {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    flex-wrap: wrap;
}
.product-details__category {
    font-size: var(--font-size-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-light-blue-2);
}
.product-details__sku {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    font-weight: 500;
}
.product-details__new-badge {
    padding: 2px 10px;
    background: var(--color-light-green);
    color: var(--color-text);
    border-radius: var(--radius-full);
    font-size: var(--font-size-xs);
    font-weight: 700;
}

.product-details__title {
    font-size: clamp(var(--font-size-xl), 3vw, var(--font-size-3xl));
    font-weight: 800;
    color: var(--color-text);
    margin: 0;
    line-height: 1.2;
}

/* Rating */
.product-details__rating {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}
.product-rating-stars { color: var(--color-warning); font-size: 1rem; }
.product-rating-count {
    font-size: var(--font-size-xs);
    color: var(--color-text-mid);
    font-weight: 500;
    text-decoration: none;
}
a.product-rating-count:hover {
    color: var(--color-pink-dark);
    text-decoration: underline;
}

/* Price */
.product-details__price {
    font-size: var(--font-size-2xl);
    font-weight: 800;
    color: var(--color-text);
}
.product-details__price del {
    font-size: var(--font-size-lg);
    color: var(--color-text-light);
    font-weight: 400;
    margin-right: var(--space-3);
}
.product-details__price ins { text-decoration: none; color: var(--color-pink-dark); }

/* Short Description */
.product-details__short-desc {
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    line-height: 1.7;
    padding-bottom: var(--space-4);
    border-bottom: 1px solid var(--color-border-light);
}

/* Variants */
.product-variants { display: flex; flex-direction: column; gap: var(--space-5); }

.variant-group { display: flex; flex-direction: column; gap: var(--space-3); }
.variant-group__label {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}
.variant-group__selected {
    font-weight: 400;
    color: var(--color-text-mid);
}
.variant-group__options {
    display: flex;
    gap: var(--space-2);
    flex-wrap: wrap;
}

.variant-btn {
    min-width: 44px;
    height: 44px;
    padding: 0 var(--space-4);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text);
    background: var(--color-white);
    cursor: pointer;
    transition:
        border-color var(--transition-fast),
        background var(--transition-fast),
        color var(--transition-fast);
    display: flex;
    align-items: center;
    justify-content: center;
}
.variant-btn:hover { border-color: var(--color-light-blue-2); }
.variant-btn.is-selected {
    border-color: var(--color-light-blue-2);
    background: var(--color-light-blue-3);
    color: var(--color-text);
}
.variant-btn.is-unavailable {
    opacity: 0.4;
    cursor: not-allowed;
    text-decoration: line-through;
}

/* Color swatches */
.variant-btn--color {
    width: 36px;
    height: 36px;
    min-width: 36px;
    padding: 0;
    border-radius: var(--radius-full);
    border-width: 3px;
    position: relative;
}
.variant-btn--color.is-selected::after {
    content: '';
    position: absolute;
    inset: -5px;
    border: 2px solid var(--color-light-blue-2);
    border-radius: var(--radius-full);
}

/* Quantity + Add to Cart */
.product-actions { display: flex; flex-direction: column; gap: var(--space-4); }
.product-qty-cart {
    display: flex;
    gap: var(--space-3);
    align-items: stretch;
}

.quantity-selector {
    display: flex;
    align-items: center;
    border: 2px solid var(--color-border);
    border-radius: var(--radius-full);
    overflow: hidden;
    background: var(--color-white);
    flex-shrink: 0;
}
.quantity-selector button {
    width: 44px;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.125rem;
    color: var(--color-text);
    cursor: pointer;
    border: none;
    background: none;
    transition: background var(--transition-fast);
}
.quantity-selector button:hover { background: var(--color-border-light); }
.quantity-selector input {
    width: 52px;
    height: 52px;
    text-align: center;
    font-size: var(--font-size-base);
    font-weight: 700;
    border: none;
    background: none;
    color: var(--color-text);
    font-family: var(--font-family);
}
.quantity-selector input::-webkit-inner-spin-button,
.quantity-selector input::-webkit-outer-spin-button { -webkit-appearance: none; }

.btn--add-to-cart {
    flex: 1;
    height: 52px;
    font-size: var(--font-size-base);
    padding: 0 var(--space-6);
    background: var(--color-text);
    color: var(--color-white);
    border: 2px solid var(--color-text);
    border-radius: var(--radius-full);
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-3);
    cursor: pointer;
    transition:
        background var(--transition-base),
        border-color var(--transition-base),
        transform var(--transition-fast),
        box-shadow var(--transition-base);
}
.btn--add-to-cart:hover {
    background: var(--color-text-mid);
    border-color: var(--color-text-mid);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}
.btn--add-to-cart:active { transform: translateY(0); }

.btn--wishlist-pdp {
    width: 52px;
    height: 52px;
    min-width: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid var(--color-border);
    border-radius: var(--radius-full);
    font-size: 1.125rem;
    color: var(--color-text-mid);
    background: var(--color-white);
    cursor: pointer;
    transition:
        border-color var(--transition-fast),
        background var(--transition-fast),
        color var(--transition-fast);
    flex-shrink: 0;
}
.btn--wishlist-pdp:hover,
.btn--wishlist-pdp.is-wishlisted {
    border-color: var(--color-pink-dark);
    background: var(--color-pink);
    color: var(--color-text);
}

/* Trust features on PDP */
.product-trust {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    padding: var(--space-5);
    background: var(--color-border-light);
    border-radius: var(--radius-md);
}
.product-trust-item {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    font-weight: 500;
}
.product-trust-item i {
    color: var(--color-light-green-2);
    font-size: 1rem;
    width: 18px;
    text-align: center;
}

/* Product Stock */
.product-stock {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-sm);
    font-weight: 600;
}
.product-stock--in i  { color: var(--color-success); }
.product-stock--out i { color: var(--color-error); }

/* Product Description Section */
.product-description-section {
    padding: var(--space-12) 0;
    border-top: 1px solid var(--color-border-light);
}

.product-tabs {
    display: flex;
    gap: 0;
    border-bottom: 2px solid var(--color-border-light);
    margin-bottom: var(--space-8);
    overflow-x: auto;
    scrollbar-width: none;
}
.product-tabs::-webkit-scrollbar { display: none; }

.product-tab-btn {
    padding: var(--space-3) var(--space-6);
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text-mid);
    border: none;
    background: none;
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
    cursor: pointer;
    transition: color var(--transition-fast), border-color var(--transition-fast);
    white-space: nowrap;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.product-tab-btn:hover { color: var(--color-text); }
.product-tab-btn.is-active {
    color: var(--color-text);
    border-bottom-color: var(--color-light-blue-2);
}

.product-tab-content { display: none; }
.product-tab-content.is-active { display: block; animation: fadeIn 0.3s ease; }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.product-tab-content p { color: var(--color-text-mid); line-height: 1.8; margin-top: 25px; }
.product-tab-content ul, .product-tab-content ol {
    padding-left: var(--space-5);
    color: var(--color-text-mid);
    line-height: 1.8;
    margin-bottom: var(--space-4);
}

/* Related Products */
.related-products-section {
    padding: var(--space-12) 0 var(--space-20);
    background: var(--color-bg-section);
}
.related-products-section .section-header { margin-bottom: var(--space-8); }

.related-swiper { padding-bottom: var(--space-10) !important; }
.related-swiper .swiper-slide { height: auto; }
.related-swiper .product-card { height: 100%; }

/* ============================================================
   16. GENERIC PAGE
   ============================================================ */
.page-content-section {
    padding: var(--space-16) 0;
    max-width: 800px;
    margin: 0 auto;
}
.page-content-section .entry-content h2 { margin-top: var(--space-8); margin-bottom: var(--space-4); }
.page-content-section .entry-content h3 { margin-top: var(--space-6); margin-bottom: var(--space-3); }
.page-content-section .entry-content p  { color: var(--color-text-mid); }

/* ============================================================
   17. ANIMATIONS & UTILITIES
   ============================================================ */
.fade-in-up {
    opacity: 0;
    transform: translateY(20px);
    transition:
        opacity var(--transition-slow),
        transform var(--transition-slow);
}
.fade-in-up.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* Toast notification */
.toast {
    position: fixed;
    bottom: var(--space-6);
    right: var(--space-6);
    z-index: 9999;
    background: var(--color-text);
    color: var(--color-white);
    padding: var(--space-4) var(--space-6);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    font-weight: 600;
    box-shadow: var(--shadow-xl);
    transform: translateY(100px);
    opacity: 0;
    transition:
        transform var(--transition-base),
        opacity var(--transition-base);
    max-width: 320px;
}
.toast.is-visible {
    transform: translateY(0);
    opacity: 1;
}
.toast--success { background: var(--color-success); }
.toast--error   { background: var(--color-error); }

/* Overlay for filter on mobile */
.shop-filter-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(74,55,40,0.4);
    z-index: 799;
}
.shop-filter-overlay.is-active { display: block; }

/* ============================================================
   18. RESPONSIVE TWEAKS
   ============================================================ */
@media (max-width: 768px) {
    :root { --section-pad: var(--space-12); --header-height: 68px; }
    .product-qty-cart { flex-wrap: wrap; }
    .btn--add-to-cart { min-width: 0; flex: 1; }
}

@media (max-width: 480px) {
    .trust-badges__list { gap: var(--space-4); }
}

/* ============================================================
   19. SIDE CART DRAWER
   ============================================================ */
.side-cart {
    position: fixed;
    inset: 0;
    z-index: 1000;
    pointer-events: none;
}
.side-cart[hidden] { display: block; } /* keep in DOM, use pointer-events/transform */
.side-cart.is-open { pointer-events: all; }

.side-cart__overlay {
    position: absolute;
    inset: 0;
    background: rgba(74,55,40,0.45);
    backdrop-filter: blur(3px);
    opacity: 0;
    transition: opacity var(--transition-slow);
    cursor: pointer;
}
.side-cart.is-open .side-cart__overlay { opacity: 1; }

.side-cart__panel {
    position: absolute;
    top: 0;
    right: 0;
    width: min(420px, 100vw);
    height: 100%;
    background: var(--color-white);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transform: translateX(100%);
    transition: transform var(--transition-slow);
    box-shadow: var(--shadow-xl);
}
.side-cart.is-open .side-cart__panel { transform: translateX(0); }

/* Header */
.side-cart__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-5) var(--space-6);
    border-bottom: 2px solid var(--color-border-light);
    flex-shrink: 0;
}
.side-cart__title {
    font-size: var(--font-size-lg);
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: var(--space-3);
    margin: 0;
}
.side-cart__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 24px;
    height: 24px;
    padding: 0 6px;
    background: var(--color-light-blue);
    color: var(--color-text);
    border-radius: var(--radius-full);
    font-size: var(--font-size-xs);
    font-weight: 700;
}
.side-cart__close {
    width: 38px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.125rem;
    color: var(--color-text-mid);
    border-radius: var(--radius-full);
    transition: background var(--transition-fast), color var(--transition-fast);
    flex-shrink: 0;
}
.side-cart__close:hover { background: var(--color-border-light); color: var(--color-text); }

/* Free Shipping Bar */
.shipping-bar {
    padding: var(--space-4) var(--space-6);
    background: var(--color-light-blue-3);
    border-bottom: 1px solid var(--color-border-light);
    flex-shrink: 0;
}
.shipping-bar__msg {
    font-size: var(--font-size-xs);
    color: var(--color-text);
    margin-bottom: var(--space-3);
    line-height: 1.5;
    text-align: center;
}
.shipping-bar__msg--achieved {
    color: var(--color-success);
    font-weight: 600;
}
.shipping-bar__track {
    height: 8px;
    background: rgba(255,255,255,0.7);
    border-radius: var(--radius-full);
    overflow: hidden;
    position: relative;
}
.shipping-bar__fill {
    height: 100%;
    background: linear-gradient(90deg, var(--color-light-blue-2), var(--color-light-green-2));
    border-radius: var(--radius-full);
    transition: width 0.6s cubic-bezier(0.34,1.56,0.64,1);
    position: relative;
    min-width: 4px;
}
.shipping-bar__icon {
    position: absolute;
    right: -2px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 14px;
    line-height: 1;
}
.shipping-bar__labels {
    display: flex;
    justify-content: space-between;
    font-size: 10px;
    color: var(--color-text-light);
    margin-top: var(--space-2);
    font-weight: 600;
}

/* Cart Items List */
.side-cart__items {
    flex: 1;
    overflow-y: auto;
    padding: var(--space-4) var(--space-6);
    scroll-behavior: smooth;
}
.side-cart__items::-webkit-scrollbar { width: 4px; }
.side-cart__items::-webkit-scrollbar-track { background: transparent; }
.side-cart__items::-webkit-scrollbar-thumb { background: var(--color-border); border-radius: 4px; }

/* Empty state */
.side-cart__empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--space-16) var(--space-8);
    text-align: center;
    gap: var(--space-4);
}
.side-cart__empty-icon { font-size: 4rem; }
.side-cart__empty-msg { color: var(--color-text-mid); font-size: var(--font-size-md); font-weight: 500; }

/* Individual Cart Item */
.cart-item {
    display: flex;
    gap: var(--space-4);
    padding: var(--space-4) 0;
    border-bottom: 1px solid var(--color-border-light);
    align-items: flex-start;
    animation: cartItemIn 0.3s ease;
    position: relative;
}
.cart-item:last-child { border-bottom: none; }
@keyframes cartItemIn {
    from { opacity: 0; transform: translateX(12px); }
    to   { opacity: 1; transform: translateX(0); }
}

.cart-item__img-link { flex-shrink: 0; }
.cart-item__img {
    width: 72px;
    height: 72px;
    object-fit: cover;
    border-radius: var(--radius-md);
    background: var(--color-border-light);
}

.cart-item__body { flex: 1; min-width: 0; }
.cart-item__name {
    display: block;
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text);
    text-decoration: none;
    line-height: 1.4;
    margin-bottom: var(--space-1);
    transition: color var(--transition-fast);
}
.cart-item__name:hover { color: var(--color-light-blue-2); }

.cart-item__variation {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    margin-bottom: var(--space-3);
    font-weight: 500;
}

.cart-item__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    flex-wrap: wrap;
}

/* Quantity control */
.cart-item__qty-ctrl {
    display: flex;
    align-items: center;
    gap: 0;
    background: var(--color-border-light);
    border-radius: var(--radius-full);
    overflow: hidden;
}
.cart-qty-btn {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    color: var(--color-text);
    background: none;
    border: none;
    cursor: pointer;
    transition: background var(--transition-fast);
    flex-shrink: 0;
}
.cart-qty-btn:hover { background: var(--color-border); }
.cart-qty-display {
    min-width: 28px;
    text-align: center;
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
}

.cart-item__price {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
    white-space: nowrap;
}

.cart-item__remove {
    position: absolute;
    top: var(--space-4);
    right: 0;
    width: 26px;
    height: 26px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    color: var(--color-text-light);
    border-radius: var(--radius-full);
    transition: background var(--transition-fast), color var(--transition-fast);
    flex-shrink: 0;
}
.cart-item__remove:hover { background: #fde8e8; color: var(--color-error); }

/* Cart Footer */
.side-cart__footer {
    padding: var(--space-5) var(--space-6);
    border-top: 2px solid var(--color-border-light);
    background: var(--color-bg-section);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    flex-shrink: 0;
}
.side-cart__subtotal {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: var(--font-size-base);
}
.side-cart__subtotal span { color: var(--color-text-mid); }
.side-cart__subtotal strong { font-size: var(--font-size-lg); font-weight: 800; }
.side-cart__tax-note {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    text-align: center;
    margin: 0;
}
.side-cart__checkout-btn {
    font-size: var(--font-size-sm) !important;
    padding: 0.875rem 1.5rem !important;
    gap: var(--space-2) !important;
}

/* Loading overlay inside cart panel */
.side-cart__panel.is-loading::after {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,0.7);
    z-index: 10;
    backdrop-filter: blur(2px);
}

/* ============================================================
   20. QUICK VIEW MODAL
   ============================================================ */
.quick-view-modal {
    position: fixed;
    inset: 0;
    z-index: 900;
    pointer-events: none;
}
.quick-view-modal[hidden] { display: block; }
.quick-view-modal.is-open { pointer-events: all; }

.qv-overlay {
    position: absolute;
    inset: 0;
    background: rgba(74,55,40,0.55);
    backdrop-filter: blur(4px);
    opacity: 0;
    transition: opacity var(--transition-slow);
    cursor: pointer;
}
.quick-view-modal.is-open .qv-overlay { opacity: 1; }

.qv-panel {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -46%) scale(0.96);
    width: min(820px, 94vw);
    max-height: 88vh;
    background: var(--color-white);
    border-radius: var(--radius-xl);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    opacity: 0;
    transition:
        opacity var(--transition-slow),
        transform var(--transition-slow);
    box-shadow: var(--shadow-xl);
}
.quick-view-modal.is-open .qv-panel {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
}

.qv-close {
    position: absolute;
    top: var(--space-4);
    right: var(--space-4);
    z-index: 10;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-white);
    border-radius: var(--radius-full);
    font-size: 1.125rem;
    color: var(--color-text-mid);
    box-shadow: var(--shadow-md);
    transition: background var(--transition-fast), color var(--transition-fast);
    cursor: pointer;
}
.qv-close:hover { background: var(--color-border-light); color: var(--color-text); }

.qv-content {
    display: grid;
    grid-template-columns: 380px 1fr;
    overflow-y: auto;
    max-height: 88vh;
    scrollbar-width: thin;
}
.qv-content::-webkit-scrollbar { width: 4px; }
.qv-content::-webkit-scrollbar-thumb { background: var(--color-border); border-radius: 4px; }

/* Gallery side */
.qv-gallery {
    padding: var(--space-6);
    background: var(--color-light-blue-3);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    align-items: center;
    border-right: 1px solid var(--color-border-light);
}
.qv-gallery__main {
    width: 100%;
    aspect-ratio: 1 / 1;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--color-white);
    box-shadow: var(--shadow-sm);
}
.qv-gallery__main-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: opacity 0.2s ease;
}
.qv-gallery__thumbs {
    display: flex;
    gap: var(--space-2);
    flex-wrap: wrap;
    justify-content: center;
}
.qv-gallery__thumb {
    width: 52px;
    height: 52px;
    border-radius: var(--radius-md);
    overflow: hidden;
    border: 2px solid transparent;
    cursor: pointer;
    transition: border-color var(--transition-fast);
    padding: 0;
    background: var(--color-white);
    box-shadow: var(--shadow-xs);
}
.qv-gallery__thumb:hover,
.qv-gallery__thumb.is-active { border-color: var(--color-light-blue-2); }
.qv-gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }

/* Details side */
.qv-details {
    padding: var(--space-6) var(--space-7);
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    background: var(--color-white);
}

/* Eyebrow meta strip */
.qv-details .product-details__meta {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-wrap: wrap;
}
.qv-details .product-details__category {
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-light-blue-2);
    text-decoration: none;
    padding: 2px 10px;
    background: var(--color-light-blue-3);
    border-radius: var(--radius-full);
}
.qv-details .product-details__new-badge {
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    padding: 2px 10px;
    background: var(--color-light-green);
    color: var(--color-text);
    border-radius: var(--radius-full);
}

.qv-details__title {
    font-size: clamp(var(--font-size-lg), 2vw, var(--font-size-xl));
    font-weight: 800;
    margin: 0;
    line-height: 1.25;
    color: var(--color-text);
}
.qv-details__price {
    font-size: var(--font-size-xl);
    font-weight: 800;
    color: var(--color-text);
}
.qv-details__price ins { text-decoration: none; }
.qv-details__price del { font-size: 0.85em; font-weight: 500; color: var(--color-text-mid); }

/* Rating */
.qv-details .product-details__rating {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}
.qv-details .product-rating-count { font-size: var(--font-size-xs); color: var(--color-text-mid); }

/* Short desc */
.qv-details .product-details__short-desc {
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    line-height: 1.65;
    border-top: 1px solid var(--color-border-light);
    padding-top: var(--space-3);
}
.qv-details .product-details__short-desc p { margin: 0; }

/* Stock */
.qv-details .product-stock {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-xs);
    font-weight: 600;
}
.qv-details .product-stock--in { color: #16a34a; }
.qv-details .product-stock--out { color: #dc2626; }

.qv-actions-row {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    flex-wrap: wrap;
    padding-top: var(--space-3);
    border-top: 1px solid var(--color-border-light);
    margin-top: auto;
}
.qv-actions-row .btn--wishlist-pdp {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-4);
    font-size: var(--font-size-xs);
    font-weight: 600;
    background: transparent;
    border: 2px solid var(--color-border);
    color: var(--color-text-mid);
    width: auto;
    height: auto;
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: border-color var(--transition-fast), color var(--transition-fast);
}
.qv-actions-row .btn--wishlist-pdp:hover {
    border-color: var(--color-pink-dark);
    color: var(--color-pink-dark);
}
.qv-full-details-link {
    font-size: var(--font-size-xs);
    font-weight: 700;
    color: var(--color-text-mid);
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    text-decoration: none;
    border-bottom: 2px solid var(--color-border-light);
    padding-bottom: 1px;
    transition: color var(--transition-fast), border-color var(--transition-fast);
    margin-left: auto;
	padding-right:20px;
}
.qv-full-details-link:hover {
    color: var(--color-light-blue-2);
    border-color: var(--color-light-blue-2);
}

/* WC form overrides inside quick view */
.qv-atc-wrap {
    background: var(--color-border-light);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
	margin: 20px;
}
.qv-atc-wrap .variations_form,
.qv-atc-wrap form.cart { display: flex; flex-direction: column; gap: var(--space-4); }
.qv-atc-wrap .variations { width: 100%; border: none; margin: 0; }
.qv-atc-wrap .variations tr { display: flex; flex-direction: column; gap: var(--space-2); margin-bottom: var(--space-3); }
.qv-atc-wrap .variations .label { display: block; font-weight: 700; font-size: var(--font-size-sm);text-align:left; }
.qv-atc-wrap .variations .value { display: block; }
.qv-atc-wrap .variations select {
    width: 100%;
    padding: 0.6rem var(--space-4);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-family: var(--font-base);
    background: var(--color-white);
    color: var(--color-text);
    cursor: pointer;
    transition: border-color var(--transition-fast);
    -webkit-appearance: auto;
}
.qv-atc-wrap .variations select:focus { outline: none; border-color: var(--color-light-blue-2); }
.qv-atc-wrap .woocommerce-variation-price { font-size: var(--font-size-lg); font-weight: 800; }
.qv-atc-wrap .woocommerce-variation-availability { font-size: var(--font-size-sm); }
.qv-atc-wrap .cart { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; }
.qv-atc-wrap .quantity { margin-right: 0; }
.qv-atc-wrap .quantity .qty {
    width: 64px;
    padding: 0.65rem var(--space-2);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-full);
    text-align: center;
    font-size: var(--font-size-sm);
    font-weight: 700;
}
.qv-atc-wrap .single_add_to_cart_button {
    flex: 1;
    background: var(--color-text) !important;
    border-color: var(--color-text) !important;
    color: var(--color-white) !important;
    font-size: var(--font-size-sm) !important;
    padding: 0.75rem 1.5rem !important;
    border-radius: var(--radius-full) !important;
    font-weight: 700 !important;
    min-width: 140px;
    transition: background var(--transition-base), transform var(--transition-fast) !important;
}
.qv-atc-wrap .single_add_to_cart_button:hover {
    background: var(--color-light-blue-2) !important;
    border-color: var(--color-light-blue-2) !important;
    transform: translateY(-2px) !important;
}
.qv-atc-wrap .reset_variations {
    font-size: 0.75rem;
    color: var(--color-text-mid);
    text-decoration: underline;
}

/* Loader spinner */
.qv-loader {
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,0.9);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 5;
    border-radius: var(--radius-xl);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition-base);
}
.qv-loader.is-loading {
    opacity: 1;
    pointer-events: all;
}
.qv-spinner {
    width: 44px;
    height: 44px;
    border: 3px solid var(--color-border);
    border-top-color: var(--color-light-blue-2);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* QV Responsive */
@media (max-width: 860px) {
    .qv-content { grid-template-columns: 1fr; }
    .qv-gallery { padding: var(--space-5); max-height: 280px; flex-direction: row; align-items: flex-start; border-right: none; border-bottom: 1px solid var(--color-border-light); }
    .qv-gallery__main { max-width: 240px; flex-shrink: 0; }
    .qv-gallery__thumbs { flex-direction: column; }
    .qv-details { padding: var(--space-5); }
    .qv-panel { max-height: 90vh; top: 50%; width: min(520px, 96vw); }
}
@media (max-width: 560px) {
    .qv-gallery { flex-direction: column; max-height: none; }
    .qv-gallery__main { max-width: 100%; }
    .qv-gallery__thumbs { flex-direction: row; }
    .qv-panel { width: 100vw; max-height: 100dvh; border-radius: var(--radius-xl) var(--radius-xl) 0 0; top: auto; bottom: 0; transform: translate(-50%, 100%) scale(1); }
    .quick-view-modal.is-open .qv-panel { transform: translate(-50%, 0) scale(1); }
}

/* ============================================================
   21. BLOG – Hub & Single Post
   ============================================================ */

/* Page header */
.blog-main { padding-top: 3rem; padding-bottom: 5rem; }

.blog-page-header {
    text-align: center;
    margin-bottom: var(--space-10);
    padding-bottom: var(--space-8);
    border-bottom: 2px solid var(--color-border-light);
}
.blog-page-header__title {
    font-size: clamp(var(--font-size-2xl), 5vw, 3rem);
    font-weight: 900;
    margin: 0 0 var(--space-3);
    background: linear-gradient(135deg, var(--color-light-blue-2), var(--color-light-green-2));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.blog-page-header__subtitle {
    font-size: var(--font-size-md);
    color: var(--color-text-mid);
    max-width: 480px;
    margin: 0 auto;
}

/* Two-column layout – 70 / 30 on desktop */
.blog-layout {
    display: grid;
    grid-template-columns: minmax(0, 7fr) minmax(0, 3fr); /* true 70/30 */
    gap: var(--space-8);
    align-items: start;
}

/* Prevent grid children from overflowing — CSS grid min-width gotcha */
.blog-feed,
.blog-sidebar { min-width: 0; }

/* ── Blog Feed (left column) ── */
.blog-feed { display: flex; flex-direction: column; gap: var(--space-8); }

/* Blog Card */
.blog-card {
    display: grid;
    grid-template-columns: minmax(0, 300px) minmax(0, 1fr);
    gap: 0;
    background: var(--color-white);
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border-light);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
}
.blog-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-3px);
}
.blog-card__image-link { display: block; overflow: hidden; }
.blog-card__image-wrap { position: relative; height: 100%; min-height: 220px; overflow: hidden; }
.blog-card__image { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.blog-card:hover .blog-card__image { transform: scale(1.04); }
.blog-card__cat {
    position: absolute;
    top: var(--space-3);
    left: var(--space-3);
    background: var(--color-light-blue-2);
    color: var(--color-white);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 0.2rem 0.6rem;
    border-radius: var(--radius-full);
}
.blog-card__body {
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    border-left: 1px solid var(--color-border-light);
}
.blog-card__meta {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    flex-wrap: wrap;
}
.blog-card__date,
.blog-card__author {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-xs);
    color: var(--color-text-mid);
}
.blog-card__title {
    font-size: var(--font-size-xl);
    font-weight: 800;
    margin: 0;
    line-height: 1.3;
}
.blog-card__title a { color: var(--color-text); text-decoration: none; }
.blog-card__title a:hover { color: var(--color-light-blue-2); }
.blog-card__excerpt {
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    line-height: 1.7;
    margin: 0;
    flex: 1;
}
.blog-card__read-more {
    align-self: flex-start;
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    margin-top: auto;
}

/* Blog Pagination */
.blog-pagination { margin-top: var(--space-8); }
.blog-pagination .nav-links { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.blog-pagination .page-numbers {
    display: flex; align-items: center; justify-content: center;
    min-width: 40px; height: 40px; padding: 0 var(--space-3);
    border-radius: var(--radius-full);
    border: 2px solid var(--color-border-light);
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text);
    text-decoration: none;
    transition: background var(--transition-fast), border-color var(--transition-fast);
}
.blog-pagination .page-numbers:hover,
.blog-pagination .page-numbers.current {
    background: var(--color-light-blue-2);
    border-color: var(--color-light-blue-2);
    color: var(--color-white);
}

/* Blog Empty */
.blog-empty {
    text-align: center;
    padding: 4rem 2rem;
}
.blog-empty__icon { font-size: 3rem; display: block; margin-bottom: var(--space-4); }

/* ── Sidebar (right column) ── */
.blog-sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--space-6);
    position: sticky;
    top: calc(var(--header-height) + var(--space-6));
    /* No max-height / overflow – sidebar shows full content, no internal scroll */
    min-width: 0;
}

.blog-widget {
    background: var(--color-white);
    border-radius: var(--radius-xl);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border-light);
}
.blog-widget--sticky { position: relative; }
.blog-widget__title {
    font-size: var(--font-size-md);
    font-weight: 800;
    margin: 0 0 var(--space-5);
    display: flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--color-text);
}
.blog-widget__title i { color: var(--color-light-blue-2); }
.blog-widget__cta { width: 100%; justify-content: center; margin-top: var(--space-5); }

/* Best Sellers List */
.blog-bestsellers {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    counter-reset: bestseller;
}
.blog-bestseller-item {
    counter-increment: bestseller;
}
.blog-bestseller-item__link {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    text-decoration: none;
    padding: var(--space-2) 0;
    border-bottom: 1px solid var(--color-border-light);
    transition: opacity var(--transition-fast);
}
.blog-bestseller-item__link:hover { opacity: 0.75; }
.blog-bestseller-item__link::before {
    content: counter(bestseller);
    min-width: 24px;
    height: 24px;
    background: var(--color-light-blue);
    color: var(--color-text);
    font-size: 0.7rem;
    font-weight: 800;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.blog-bestseller-item__img {
    width: 56px;
    height: 56px;
    object-fit: cover;
    border-radius: var(--radius-md);
    flex-shrink: 0;
}
.blog-bestseller-item__info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}
.blog-bestseller-item__name {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.4;
}
.blog-bestseller-item__price {
    font-size: var(--font-size-xs);
    color: var(--color-light-blue-2);
    font-weight: 600;
}

/* Search widget */
.blog-search-form {
    display: flex;
    border: 2px solid var(--color-border);
    border-radius: var(--radius-full);
    overflow: hidden;
    transition: border-color var(--transition-fast);
}
.blog-search-form:focus-within { border-color: var(--color-light-blue-2); }
.blog-search-form__input {
    flex: 1;
    border: none;
    padding: var(--space-2) var(--space-4);
    font-size: var(--font-size-sm);
    font-family: var(--font-base);
    background: transparent;
}
.blog-search-form__input:focus { outline: none; }
.blog-search-form__btn {
    padding: var(--space-2) var(--space-4);
    background: var(--color-light-blue-2);
    color: var(--color-white);
    border: none;
    cursor: pointer;
    font-size: var(--font-size-sm);
    transition: background var(--transition-fast);
}
.blog-search-form__btn:hover { background: var(--color-light-blue); }

/* Categories widget */
.blog-cat-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-2); }
.blog-cat-list__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-2) 0;
    border-bottom: 1px solid var(--color-border-light);
    font-size: var(--font-size-sm);
}
.blog-cat-list__item a { color: var(--color-text); text-decoration: none; font-weight: 500; }
.blog-cat-list__item a:hover { color: var(--color-light-blue-2); }
.blog-cat-list__count {
    font-size: var(--font-size-xs);
    background: var(--color-border-light);
    padding: 1px 8px;
    border-radius: var(--radius-full);
    font-weight: 600;
}

/* ── Single Post Styles ── */
.blog-breadcrumb {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-xs);
    color: var(--color-text-mid);
    margin-bottom: var(--space-5);
    flex-wrap: wrap;
}
.blog-breadcrumb a { color: var(--color-text-mid); text-decoration: none; }
.blog-breadcrumb a:hover { color: var(--color-light-blue-2); }
.blog-breadcrumb [aria-current] { color: var(--color-text); font-weight: 600; }

.blog-post__cats {
    display: flex;
    gap: var(--space-2);
    flex-wrap: wrap;
    margin-bottom: var(--space-4);
}
.blog-post__cat-badge {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    background: var(--color-light-blue);
    color: var(--color-light-blue-2);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-radius: var(--radius-full);
    text-decoration: none;
    transition: background var(--transition-fast);
}
.blog-post__cat-badge:hover { background: var(--color-light-blue-2); color: var(--color-white); }

.blog-post__title {
    font-size: clamp(var(--font-size-2xl), 4vw, 2.5rem);
    font-weight: 900;
    line-height: 1.2;
    margin: 0 0 var(--space-5);
}
.blog-post__meta {
    display: flex;
    gap: var(--space-5);
    flex-wrap: wrap;
    margin-bottom: var(--space-6);
    padding-bottom: var(--space-6);
    border-bottom: 2px solid var(--color-border-light);
}
.blog-post__meta-item {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
}
.blog-post__meta-item i { color: var(--color-light-blue-2); }

.blog-post__hero {
    margin: 0 0 var(--space-8);
    border-radius: var(--radius-xl);
    overflow: hidden;
}
.blog-post__hero-img {
    width: 100%;
    height: auto;
    display: block;
    max-height: 480px;
    object-fit: cover;
}
.blog-post__hero-caption {
    font-size: var(--font-size-xs);
    color: var(--color-text-mid);
    text-align: center;
    padding: var(--space-2) var(--space-4);
    background: var(--color-border-light);
}

/* Post content typography */
.blog-post__content {
    font-size: var(--font-size-md);
    line-height: 1.85;
    color: var(--color-text);
}
.blog-post__content h2,
.blog-post__content h3,
.blog-post__content h4 {
    font-weight: 800;
    margin: 2rem 0 1rem;
    line-height: 1.3;
}
.blog-post__content h2 { font-size: var(--font-size-2xl); }
.blog-post__content h3 { font-size: var(--font-size-xl); }
.blog-post__content h4 { font-size: var(--font-size-lg); }
.blog-post__content p { margin: 0 0 1.25rem; }
.blog-post__content a { color: var(--color-light-blue-2); text-decoration: underline; }
.blog-post__content ul, .blog-post__content ol { margin: 0 0 1.25rem 1.5rem; }
.blog-post__content li { margin-bottom: 0.5rem; }
.blog-post__content img { max-width: 100%; border-radius: var(--radius-lg); height: auto; }
.blog-post__content blockquote {
    border-left: 4px solid var(--color-light-blue-2);
    margin: 2rem 0;
    padding: var(--space-5) var(--space-6);
    background: var(--color-light-blue-3);
    border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
    font-style: italic;
    color: var(--color-text-mid);
}
.blog-post__content pre, .blog-post__content code {
    font-family: monospace;
    background: var(--color-border-light);
    border-radius: var(--radius-sm);
}
.blog-post__content pre { padding: var(--space-4); overflow-x: auto; }
.blog-post__content :not(pre) > code { padding: 0.1em 0.35em; font-size: 0.9em; }

/* Tags */
.blog-post__tags {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-wrap: wrap;
    margin-top: var(--space-8);
    padding-top: var(--space-6);
    border-top: 2px solid var(--color-border-light);
}
.blog-post__tags-label {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text-mid);
}
.blog-post__tag {
    padding: 0.25rem 0.75rem;
    background: var(--color-border-light);
    border-radius: var(--radius-full);
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--color-text-mid);
    text-decoration: none;
    transition: background var(--transition-fast), color var(--transition-fast);
}
.blog-post__tag:hover { background: var(--color-light-blue); color: var(--color-light-blue-2); }

/* Author bio */
.blog-author-box {
    display: flex;
    gap: var(--space-5);
    margin-top: var(--space-8);
    padding: var(--space-6);
    background: var(--color-light-blue-3);
    border-radius: var(--radius-xl);
    border: 1px solid var(--color-light-blue);
}
.blog-author-box__avatar img {
    border-radius: var(--radius-full);
    width: 80px;
    height: 80px;
    object-fit: cover;
    flex-shrink: 0;
}
.blog-author-box__name {
    font-size: var(--font-size-md);
    font-weight: 800;
    margin: 0 0 var(--space-2);
}
.blog-author-box__bio {
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    line-height: 1.65;
    margin: 0;
}

/* Prev/Next navigation */
.blog-post-nav {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
    margin-top: var(--space-8);
    padding-top: var(--space-6);
    border-top: 2px solid var(--color-border-light);
}
.blog-post-nav__link {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    padding: var(--space-4) var(--space-5);
    background: var(--color-white);
    border: 2px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    text-decoration: none;
    transition: border-color var(--transition-base), box-shadow var(--transition-base);
}
.blog-post-nav__link:hover { border-color: var(--color-light-blue-2); box-shadow: var(--shadow-sm); }
.blog-post-nav__link--next { text-align: right; }
.blog-post-nav__label {
    font-size: var(--font-size-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-light-blue-2);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}
.blog-post-nav__link--next .blog-post-nav__label { justify-content: flex-end; }
.blog-post-nav__title {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Comments */
.blog-post__comments { margin-top: var(--space-10); }
.blog-post__comments .comment-form input,
.blog-post__comments .comment-form textarea {
    width: 100%;
    border: 2px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    font-family: var(--font-base);
    font-size: var(--font-size-sm);
    transition: border-color var(--transition-fast);
}
.blog-post__comments .comment-form input:focus,
.blog-post__comments .comment-form textarea:focus {
    outline: none;
    border-color: var(--color-light-blue-2);
}
.blog-post__comments .comment-form .submit {
    background: var(--color-text);
    color: var(--color-white);
    border: none;
    padding: var(--space-3) var(--space-8);
    border-radius: var(--radius-full);
    font-family: var(--font-base);
    font-size: var(--font-size-sm);
    font-weight: 700;
    cursor: pointer;
    transition: background var(--transition-fast);
}
.blog-post__comments .comment-form .submit:hover { background: var(--color-light-blue-2); }

/* Related posts in sidebar */
.blog-related-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-3); }
.blog-related-item { display: flex; gap: var(--space-3); align-items: flex-start; }
.blog-related-item__img-link { flex-shrink: 0; }
.blog-related-item__img { width: 64px; height: 64px; object-fit: cover; border-radius: var(--radius-md); display: block; }
.blog-related-item__info { display: flex; flex-direction: column; gap: var(--space-1); min-width: 0; }
.blog-related-item__title {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
    text-decoration: none;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.4;
}
.blog-related-item__title:hover { color: var(--color-light-blue-2); }
.blog-related-item__date { font-size: var(--font-size-xs); color: var(--color-text-mid); }

/* ── Blog Responsive ── */

/* Tablet + Mobile (≤1024px): single column – sidebar stacks below post */
@media (max-width: 1024px) {
    .blog-layout {
        grid-template-columns: minmax(0, 1fr); /* single column, no overflow */
        gap: var(--space-8);
    }
    .blog-sidebar {
        position: static; /* un-sticky on mobile/tablet */
        top: auto;
        display: flex;
        flex-direction: column;
        gap: var(--space-5);
    }
    /* Tablet blog card: narrower fixed image */
    .blog-card { grid-template-columns: minmax(0, 220px) minmax(0, 1fr); }
}

/* Mobile (≤768px): fully stacked, no fixed image column */
@media (max-width: 768px) {
    .blog-layout { gap: var(--space-6); }
    /* Blog card: stack image above content */
    .blog-card { grid-template-columns: minmax(0, 1fr); }
    .blog-card__image-wrap { min-height: 200px; max-height: 240px; }
    .blog-card__body {
        border-left: none;
        border-top: 1px solid var(--color-border-light);
        padding: var(--space-5);
    }
    /* Post nav, author, page header */
    .blog-post-nav { grid-template-columns: 1fr; }
    .blog-post-nav__link--next { text-align: left; }
    .blog-post-nav__link--next .blog-post-nav__label { justify-content: flex-start; }
    .blog-author-box { flex-direction: column; }
    .blog-page-header__title { font-size: var(--font-size-2xl); }
    .blog-main { padding-top: 2rem; padding-bottom: 3rem; }
}

/* ============================================================
   22. CONTACT PAGE
   ============================================================ */
.contact-hero {
    background: linear-gradient(135deg, var(--color-light-blue-3) 0%, var(--color-light-green-3) 60%, var(--color-light-brown-3) 100%);
    padding: var(--space-16) 0 var(--space-12);
    text-align: center;
    position: relative;
    overflow: hidden;
}
.contact-hero::before {
    content: '🧸';
    position: absolute;
    font-size: 8rem;
    opacity: 0.07;
    top: -1rem;
    right: 5%;
    transform: rotate(15deg);
    pointer-events: none;
}
.contact-hero__eyebrow {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--color-light-blue-2);
    background: var(--color-light-blue-3);
    padding: 0.25rem 1rem;
    border-radius: var(--radius-full);
    margin-bottom: var(--space-4);
}
.contact-hero__title {
    font-size: clamp(var(--font-size-2xl), 5vw, var(--font-size-4xl));
    font-weight: 900;
    color: var(--color-text);
    margin: 0 0 var(--space-4);
}
.contact-hero__subtitle {
    font-size: var(--font-size-md);
    color: var(--color-text-mid);
    max-width: 520px;
    margin: 0 auto;
}

/* Contact Body Layout */
.contact-section { padding: var(--space-16) 0 var(--space-20); }

.contact-layout {
    display: grid;
    grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
    gap: var(--space-12);
    align-items: start;
}

/* ── Left: Info Column ── */
.contact-info {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
    position: sticky;
    top: calc(var(--header-height) + var(--space-6));
}

.contact-info__heading {
    font-size: var(--font-size-xl);
    font-weight: 800;
    color: var(--color-text);
    margin: 0 0 var(--space-2);
}
.contact-info__tagline {
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    margin: 0 0 var(--space-4);
    line-height: 1.7;
}

.contact-card {
    display: flex;
    align-items: flex-start;
    gap: var(--space-4);
    background: var(--color-white);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-xl);
    padding: var(--space-5);
    box-shadow: var(--shadow-xs);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
}
.contact-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}
.contact-card__icon {
    width: 44px;
    height: 44px;
    border-radius: var(--radius-lg);
    background: var(--color-light-blue-3);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.125rem;
    color: var(--color-light-blue-2);
    flex-shrink: 0;
}
.contact-card__body { min-width: 0; }
.contact-card__label {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-light);
    display: block;
    margin-bottom: var(--space-1);
}
.contact-card__value {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text);
    word-break: break-word;
}
.contact-card__value a { color: var(--color-text); text-decoration: none; }
.contact-card__value a:hover { color: var(--color-light-blue-2); }

.contact-social {
    display: flex;
    gap: var(--space-3);
    flex-wrap: wrap;
    margin-top: var(--space-2);
}
.contact-social__link {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-full);
    background: var(--color-light-blue-3);
    color: var(--color-light-blue-2);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    text-decoration: none;
    transition: background var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);
}
.contact-social__link:hover {
    background: var(--color-light-blue-2);
    color: var(--color-white);
    transform: translateY(-2px);
}

/* ── Right: Form Column ── */
.contact-form-wrap {
    background: var(--color-white);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-xl);
    padding: var(--space-10) var(--space-8);
    box-shadow: var(--shadow-md);
    min-width: 0;
}
.contact-form-wrap__title {
    font-size: var(--font-size-xl);
    font-weight: 800;
    color: var(--color-text);
    margin: 0 0 var(--space-2);
}
.contact-form-wrap__subtitle {
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    margin: 0 0 var(--space-8);
}

/* Responsive */
@media (max-width: 960px) {
    .contact-layout { grid-template-columns: 1fr; }
    .contact-info { position: static; top: auto; }
    .contact-form-wrap { padding: var(--space-8) var(--space-6); }
}
@media (max-width: 600px) {
    .contact-hero { padding: var(--space-10) 0 var(--space-8); }
    .contact-section { padding: var(--space-10) 0 var(--space-12); }
    .contact-form-wrap { padding: var(--space-6) var(--space-5); }
}

/* ============================================================
   23. CONTACT FORM 7 – Global Styles
   ============================================================ */

/* Outer wrapper */
.wpcf7 { width: 100%; }

/* Remove CF7 default bottom margin */
.wpcf7 form.wpcf7-form { margin: 0; }

/* ── Field paragraphs (CF7 wraps each field in <p>) ── */
.wpcf7-form > p,
.wpcf7 .wpcf7-form > p {
    margin: 0 0 var(--space-5);
}
.wpcf7-form > p:last-of-type { margin-bottom: 0; }

/* ── Labels ── */
.wpcf7 label {
    display: block;
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--space-2);
    cursor: pointer;
}

/* ── All text-type inputs & textarea ── */
.wpcf7-form-control:not(.wpcf7-submit):not(.wpcf7-checkbox):not(.wpcf7-radio):not(.wpcf7-acceptance):not(.wpcf7-file) {
    width: 100%;
    display: block;
    padding: 0.8rem var(--space-5);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-md);
    font-family: var(--font-family);
    font-size: var(--font-size-base);
    color: var(--color-text);
    background: var(--color-bg);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast), background var(--transition-fast);
    -webkit-appearance: none;
    appearance: none;
}
.wpcf7-form-control:not(.wpcf7-submit):not(.wpcf7-checkbox):not(.wpcf7-radio):not(.wpcf7-acceptance):not(.wpcf7-file):focus {
    outline: none;
    border-color: var(--color-light-blue-2);
    background: var(--color-white);
    box-shadow: 0 0 0 4px rgba(168, 217, 238, 0.25);
}

/* Textarea */
.wpcf7-textarea {
    min-height: 160px;
    resize: vertical;
    border-radius: var(--radius-md) !important;
}

/* Select */
.wpcf7-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234A3728' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 14px center !important;
    padding-right: 36px !important;
    cursor: pointer;
}

/* ── Placeholder ── */
.wpcf7-form-control::placeholder { color: var(--color-text-light); opacity: 1; }

/* ── Validation: invalid field ── */
.wpcf7-form-control.wpcf7-not-valid {
    border-color: var(--color-error) !important;
    background: #fff8f8;
    box-shadow: 0 0 0 4px rgba(224, 80, 80, 0.12);
}

/* ── Validation tip (error message below field) ── */
.wpcf7-not-valid-tip {
    display: block;
    margin-top: var(--space-2);
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: var(--color-error);
}

/* ── Submit button ── */
.wpcf7-submit {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding: 0.875rem var(--space-8) !important;
    background: linear-gradient(135deg, var(--color-light-blue-2), var(--color-light-green-2)) !important;
    color: var(--color-white) !important;
    font-family: var(--font-family) !important;
    font-size: var(--font-size-base) !important;
    font-weight: 700 !important;
    border: none !important;
    border-radius: var(--radius-full) !important;
    cursor: pointer;
    transition: opacity var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast) !important;
    width: auto !important;
    box-shadow: var(--shadow-sm);
}
.wpcf7-submit:hover:not(:disabled) {
    opacity: 0.9;
    transform: translateY(-2px);
    box-shadow: var(--shadow-md) !important;
}
.wpcf7-submit:active:not(:disabled) { transform: translateY(0); }
.wpcf7-submit:disabled { opacity: 0.6; cursor: not-allowed; }

/* ── Spinner ── */
.wpcf7-spinner {
    display: inline-block;
    width: 20px;
    height: 20px;
    margin-left: var(--space-3);
    border: 3px solid rgba(168, 217, 238, 0.4);
    border-top-color: var(--color-light-blue-2);
    border-radius: 50%;
    animation: wpcf7Spin 0.7s linear infinite;
    vertical-align: middle;
    visibility: hidden;
}
.wpcf7-spinner.is-active { visibility: visible; }
@keyframes wpcf7Spin { to { transform: rotate(360deg); } }

/* ── Response output ── */
.wpcf7-response-output {
    margin: var(--space-5) 0 0 !important;
    padding: var(--space-4) var(--space-5) !important;
    border-radius: var(--radius-md) !important;
    font-size: var(--font-size-sm) !important;
    font-weight: 600 !important;
    border: none !important;
}
.wpcf7-form.sent .wpcf7-response-output {
    background: var(--color-light-green-3) !important;
    color: #2e7d50 !important;
}
.wpcf7-form.failed .wpcf7-response-output,
.wpcf7-form.invalid .wpcf7-response-output,
.wpcf7-form.spam .wpcf7-response-output {
    background: #fde8e8 !important;
    color: var(--color-error) !important;
}
.wpcf7-form.unaccepted .wpcf7-response-output {
    background: #fff9e6 !important;
    color: #8a6d00 !important;
}

/* ── Two-column field row (for custom CF7 templates) ── */
.cf7-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-5);
}
.cf7-row .cf7-col { display: flex; flex-direction: column; }
.cf7-row .cf7-col > label { margin-bottom: var(--space-2); }

@media (max-width: 600px) {
    .cf7-row { grid-template-columns: 1fr; }
}

/* ── Contact page: full-width submit ── */
.contact-form-wrap .wpcf7-submit {
    width: 100% !important;
    margin-top: var(--space-3);
}
.contact-form-wrap .wpcf7-form > p { margin-bottom: var(--space-6); }
.contact-form-wrap .wpcf7-form > p:last-of-type { margin-bottom: 0; }

/* ── Submit paragraph: no extra spacing ── */
.wpcf7 p:has(.wpcf7-submit) { margin-bottom: 0; }

/* ============================================================
   24. NEWSLETTER CF7 INLINE LAYOUT
   Apply html_class="kawaii-newsletter-cf7" on the CF7 shortcode
   ============================================================ */
.kawaii-newsletter-cf7 { width: 100%; }

/* Make the form a centered flex column */
.kawaii-newsletter-cf7 .wpcf7-form {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-4);
}

/* The row div the user puts in the CF7 form template */
.kawaii-newsletter-cf7 .newsletter-cf7-row {
    display: flex;
    align-items: stretch;
    gap: var(--space-3);
    width: 100%;
    max-width: 520px;
}

/* CF7 wraps the input in a span – make it stretch */
.kawaii-newsletter-cf7 .newsletter-cf7-row .wpcf7-form-control-wrap {
    flex: 1;
    min-width: 0;
}

/* Email input: pill shape */
.kawaii-newsletter-cf7 .newsletter-cf7-row .wpcf7-form-control {
    border-radius: var(--radius-full) !important;
    height: 52px;
    padding: 0 var(--space-5) !important;
    font-size: var(--font-size-base) !important;
}

/* Submit: pill shape, no extra margin */
.kawaii-newsletter-cf7 .newsletter-cf7-row .wpcf7-submit {
    height: 52px;
    padding: 0 var(--space-6) !important;
    white-space: nowrap;
    flex-shrink: 0;
    margin-top: 0;
}

/* Fallback if CF7 wraps in <p> instead of div */
.kawaii-newsletter-cf7 .wpcf7-form > p {
    margin: 0;
    width: 100%;
    max-width: 520px;
    display: flex;
    gap: var(--space-3);
    align-items: center;
}
.kawaii-newsletter-cf7 .wpcf7-form > p .wpcf7-form-control-wrap { flex: 1; min-width: 0; }
.kawaii-newsletter-cf7 .wpcf7-form > p .wpcf7-submit { flex-shrink: 0; }

/* Response output: centred */
.kawaii-newsletter-cf7 .wpcf7-response-output {
    text-align: center;
    max-width: 520px;
    width: 100%;
}

/* Validation tip: below input */
.kawaii-newsletter-cf7 .wpcf7-not-valid-tip {
    text-align: left;
    margin-top: var(--space-2);
}

/* Privacy note (plain <p> after the row) */
.kawaii-newsletter-cf7 .newsletter-cf7-privacy {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    text-align: center;
    max-width: 520px;
}
.kawaii-newsletter-cf7 .newsletter-cf7-privacy a { color: var(--color-text-light); text-decoration: underline; }

/* Mobile: stack email + button */
@media (max-width: 560px) {
    .kawaii-newsletter-cf7 .newsletter-cf7-row,
    .kawaii-newsletter-cf7 .wpcf7-form > p {
        flex-direction: column;
    }
    .kawaii-newsletter-cf7 .newsletter-cf7-row .wpcf7-submit,
    .kawaii-newsletter-cf7 .wpcf7-form > p .wpcf7-submit {
        width: 100% !important;
    }
}

.woocommerce form.variations_form table.variations td.value select {
	margin-left:10px;
}

/* ============================================================
   25. WISHLIST PAGE
   ============================================================ */

/* ── Hero ── */
.wishlist-hero {
    background: linear-gradient(135deg, var(--color-pink) 0%, var(--color-light-blue-3) 60%, var(--color-light-green-3) 100%);
    padding: var(--space-10) 0 var(--space-8);
    border-bottom: 1px solid var(--color-border-light);
}
.wishlist-hero__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-6);
    flex-wrap: wrap;
}
.wishlist-hero__title {
    font-size: clamp(var(--font-size-xl), 4vw, var(--font-size-3xl));
    font-weight: 900;
    color: var(--color-text);
    margin: 0 0 var(--space-2);
    display: flex;
    align-items: center;
    gap: var(--space-3);
}
.wishlist-hero__title i { color: var(--color-pink-dark); }
.wishlist-hero__count {
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    font-weight: 500;
    margin: 0;
}

/* ── Body ── */
.wishlist-page__body { padding: var(--space-12) 0 var(--space-20); }

/* ── Loading ── */
.wishlist-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-5);
    padding: var(--space-20) 0;
    color: var(--color-text-mid);
    font-size: var(--font-size-sm);
}
.wishlist-loading__spinner {
    width: 48px;
    height: 48px;
    border: 4px solid var(--color-border);
    border-top-color: var(--color-pink-dark);
    border-radius: 50%;
    animation: wishlistSpin 0.8s linear infinite;
}
@keyframes wishlistSpin { to { transform: rotate(360deg); } }

/* ── Product grid ── */
.wishlist-grid { min-height: 200px; }

/* ── Empty state ── */
.wishlist-empty {
    text-align: center;
    padding: var(--space-20) var(--space-8);
}
.wishlist-empty__icon {
    font-size: 4rem;
    display: block;
    margin-bottom: var(--space-5);
    animation: wishlistBounce 2s ease-in-out infinite;
}
@keyframes wishlistBounce {
    0%, 100% { transform: translateY(0); }
    50%       { transform: translateY(-12px); }
}
.wishlist-empty__title {
    font-size: var(--font-size-2xl);
    font-weight: 800;
    color: var(--color-text);
    margin: 0 0 var(--space-4);
}
.wishlist-empty__desc {
    font-size: var(--font-size-md);
    color: var(--color-text-mid);
    margin: 0 0 var(--space-8);
}
.wishlist-empty__desc i { color: var(--color-pink-dark); }

@media (max-width: 600px) {
    .wishlist-hero__inner { flex-direction: column; align-items: flex-start; }
    .wishlist-hero { padding: var(--space-8) 0 var(--space-6); }
}

/* ============================================================
   26. SEO BRAND SECTION (Homepage)
   ============================================================ */
.seo-brand-section {
    padding: var(--space-20) 0;
    background: linear-gradient(160deg, var(--color-light-blue-3) 0%, var(--color-cream) 50%, var(--color-light-green-3) 100%);
    overflow: hidden;
}
.seo-brand__inner {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
    gap: var(--space-16);
    align-items: center;
}
.seo-brand__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-sm);
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-light-blue-2);
    background: rgba(168,217,238,0.18);
    border: 1.5px solid var(--color-light-blue-2);
    border-radius: var(--radius-full);
    padding: var(--space-1) var(--space-4);
    margin-bottom: var(--space-5);
}
.seo-brand__title {
    font-size: clamp(var(--font-size-2xl), 3.2vw, var(--font-size-4xl));
    font-weight: 800;
    line-height: 1.2;
    color: var(--color-text);
    margin-bottom: var(--space-5);
}
.seo-brand__lead {
    font-size: var(--font-size-md);
    font-weight: 600;
    color: var(--color-text);
    line-height: 1.7;
    margin-bottom: var(--space-4);
}
.seo-brand__body {
    font-size: var(--font-size-base);
    color: var(--color-text-mid);
    line-height: 1.75;
    margin-bottom: var(--space-8);
}
.seo-brand__tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-bottom: var(--space-8);
}
.seo-brand__tag {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text);
    background: var(--color-white);
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-full);
    padding: var(--space-2) var(--space-4);
    transition: all var(--transition-fast);
    cursor: default;
}
.seo-brand__tag:hover {
    border-color: var(--color-pink-dark);
    color: var(--color-pink-dark);
    transform: translateY(-2px);
    box-shadow: var(--shadow-sm);
}
.seo-brand__tag i { color: var(--color-pink-dark); }
.seo-brand__cta { margin-top: var(--space-2); }

/* Visual side */
.seo-brand__visual {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 380px;
}
.seo-brand__blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(40px);
    opacity: 0.5;
    pointer-events: none;
}
.seo-brand__blob--1 {
    width: 280px; height: 280px;
    background: var(--color-light-blue);
    top: -20px; right: 20px;
    animation: blobFloat 6s ease-in-out infinite;
}
.seo-brand__blob--2 {
    width: 200px; height: 200px;
    background: var(--color-pink);
    bottom: -10px; left: 10px;
    animation: blobFloat 8s ease-in-out infinite reverse;
}
.seo-brand__cards {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 260px;
}
.seo-brand__card {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    background: var(--color-white);
    border-radius: var(--radius-lg);
    padding: var(--space-5) var(--space-6);
    box-shadow: var(--shadow-md);
    border: 1.5px solid var(--color-border-light);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}
.seo-brand__card:hover { transform: translateY(-4px) scale(1.02); box-shadow: var(--shadow-lg); }
.seo-brand__card-emoji { font-size: 1.75rem; line-height: 1; flex-shrink: 0; }
.seo-brand__card strong { display: block; font-size: var(--font-size-xl); font-weight: 800; color: var(--color-text); line-height: 1; }
.seo-brand__card span   { font-size: var(--font-size-sm); color: var(--color-text-mid); font-weight: 600; }
.seo-brand__card--a { transform: translateX(-12px); }
.seo-brand__card--b { transform: translateX(12px); }
.seo-brand__card--c { transform: translateX(-6px); }
.seo-brand__card--a:hover { transform: translateX(-12px) translateY(-4px) scale(1.02); }
.seo-brand__card--b:hover { transform: translateX(12px) translateY(-4px) scale(1.02); }
.seo-brand__card--c:hover { transform: translateX(-6px) translateY(-4px) scale(1.02); }

@keyframes blobFloat {
    0%, 100% { transform: translate(0, 0) scale(1); }
    33%       { transform: translate(10px, -15px) scale(1.05); }
    66%       { transform: translate(-8px, 8px) scale(0.97); }
}

@media (max-width: 1024px) {
    .seo-brand__inner { grid-template-columns: minmax(0, 1fr); gap: var(--space-10); }
    .seo-brand__visual { min-height: 260px; }
    .seo-brand__cards { flex-direction: row; max-width: 100%; }
    .seo-brand__card--a, .seo-brand__card--b, .seo-brand__card--c { transform: none; }
    .seo-brand__card--a:hover, .seo-brand__card--b:hover, .seo-brand__card--c:hover { transform: translateY(-4px) scale(1.02); }
}
@media (max-width: 600px) {
    .seo-brand__cards { flex-direction: column; align-items: center; }
    .seo-brand__card { width: 100%; max-width: 280px; }
    .seo-brand__visual { min-height: 200px; }
}

/* ============================================================
   27. ABOUT US PAGE
   ============================================================ */

/* Hero */
.about-hero {
    position: relative;
    padding: var(--space-20) 0 var(--space-24);
    overflow: hidden;
    background: linear-gradient(135deg, var(--color-light-blue-3) 0%, var(--color-cream) 40%, var(--color-light-green-3) 100%);
}
.about-hero__blobs { position: absolute; inset: 0; pointer-events: none; }
.about-hero__blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(50px);
    opacity: 0.45;
}
.about-hero__blob--1 { width: 360px; height: 360px; background: var(--color-pink);        top: -80px; right: -60px; animation: blobFloat 7s ease-in-out infinite; }
.about-hero__blob--2 { width: 260px; height: 260px; background: var(--color-light-blue);  bottom: -40px; left: 5%;  animation: blobFloat 9s ease-in-out infinite reverse; }
.about-hero__blob--3 { width: 180px; height: 180px; background: var(--color-light-green); top: 30%;  left: 40%;    animation: blobFloat 11s ease-in-out infinite; }

.about-hero__inner {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
    gap: var(--space-16);
    align-items: center;
    position: relative;
    z-index: 1;
}
.about-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-sm);
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-pink-dark);
    background: rgba(249,200,216,0.25);
    border: 1.5px solid var(--color-pink-dark);
    border-radius: var(--radius-full);
    padding: var(--space-1) var(--space-4);
    margin-bottom: var(--space-5);
}
.about-hero__title {
    font-size: clamp(var(--font-size-2xl), 4vw, var(--font-size-4xl));
    font-weight: 900;
    line-height: 1.18;
    color: var(--color-text);
    margin-bottom: var(--space-5);
}
.about-hero__subtitle {
    font-size: var(--font-size-md);
    color: var(--color-text-mid);
    line-height: 1.7;
    max-width: 500px;
    margin-bottom: var(--space-8);
}
.about-hero__actions { display: flex; gap: var(--space-4); flex-wrap: wrap; }

/* Floating visual */
.about-hero__visual {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 360px;
}
.about-hero__circle {
    width: 220px; height: 220px;
    background: linear-gradient(135deg, var(--color-pink), var(--color-light-blue-2));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 20px 60px rgba(249,200,216,0.5);
    animation: heroCirclePulse 4s ease-in-out infinite;
}
.about-hero__emoji { font-size: 5rem; }

@keyframes heroCirclePulse {
    0%, 100% { transform: scale(1) rotate(0deg); box-shadow: 0 20px 60px rgba(249,200,216,0.5); }
    50%       { transform: scale(1.04) rotate(3deg); box-shadow: 0 28px 80px rgba(249,200,216,0.7); }
}

.about-hero__float-card {
    position: absolute;
    display: flex;
    align-items: center;
    gap: var(--space-2);
    background: var(--color-white);
    border-radius: var(--radius-lg);
    padding: var(--space-3) var(--space-5);
    box-shadow: var(--shadow-lg);
    font-size: var(--font-size-sm);
    font-weight: 700;
    white-space: nowrap;
    border: 1.5px solid var(--color-border-light);
}
.about-hero__float-card span:first-child { font-size: 1.25rem; }
.about-hero__float-card--1 { top: 10%;  left: -10px; animation: floatCardA 5s ease-in-out infinite; }
.about-hero__float-card--2 { top: 55%;  right: -15px; animation: floatCardB 6s ease-in-out infinite; }
.about-hero__float-card--3 { bottom: 8%; left: 10%;  animation: floatCardA 7s ease-in-out infinite reverse; }

@keyframes floatCardA {
    0%, 100% { transform: translateY(0); }
    50%       { transform: translateY(-10px); }
}
@keyframes floatCardB {
    0%, 100% { transform: translateY(0) rotate(1deg); }
    50%       { transform: translateY(-8px) rotate(-1deg); }
}

/* Stats */
.about-stats {
    padding: var(--space-12) 0;
    background: var(--color-white);
    border-top: 1px solid var(--color-border-light);
    border-bottom: 1px solid var(--color-border-light);
}
.about-stats__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-6);
}
.about-stat {
    text-align: center;
    padding: var(--space-6) var(--space-4);
    border-radius: var(--radius-lg);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
    cursor: default;
}
.about-stat:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.about-stat__icon {
    width: 60px; height: 60px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.5rem;
    margin: 0 auto var(--space-4);
}
.about-stat__icon--pink  { background: var(--color-pink);           color: var(--color-pink-dark); }
.about-stat__icon--blue  { background: var(--color-light-blue-3);   color: var(--color-light-blue-2); }
.about-stat__icon--green { background: var(--color-light-green-3);  color: var(--color-light-green-2); }
.about-stat__icon--brown { background: var(--color-light-brown-3);  color: var(--color-light-brown-2); }
.about-stat__num {
    font-size: var(--font-size-3xl);
    font-weight: 900;
    color: var(--color-text);
    line-height: 1;
    margin-bottom: var(--space-2);
}
.about-stat__label {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text-mid);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

/* Story */
.about-story__inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
    gap: var(--space-16);
    align-items: center;
}
.about-story__img-wrap {
    position: relative;
    border-radius: var(--radius-xl);
    overflow: visible;
}
.about-story__img {
    width: 100%;
    border-radius: var(--radius-xl);
    object-fit: cover;
    aspect-ratio: 4/5;
    box-shadow: var(--shadow-xl);
}
.about-story__img-placeholder {
    width: 100%;
    aspect-ratio: 4/5;
    background: linear-gradient(135deg, var(--color-light-blue-3), var(--color-pink));
    border-radius: var(--radius-xl);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 6rem;
    box-shadow: var(--shadow-xl);
}
.about-story__img-badge {
    position: absolute;
    bottom: -16px;
    right: -16px;
    display: flex;
    align-items: center;
    gap: var(--space-2);
    background: var(--color-white);
    border-radius: var(--radius-full);
    padding: var(--space-3) var(--space-5);
    box-shadow: var(--shadow-lg);
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-pink-dark);
    border: 1.5px solid var(--color-pink);
}
.about-story__img-badge i { color: var(--color-pink-dark); }
.about-story__title {
    font-size: clamp(var(--font-size-xl), 2.8vw, var(--font-size-3xl));
    font-weight: 800;
    color: var(--color-text);
    margin: var(--space-3) 0 var(--space-5);
}
.about-story__content p {
    color: var(--color-text-mid);
    line-height: 1.75;
    margin-bottom: var(--space-4);
}

/* Milestones */
.about-story__milestones {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-top: var(--space-8);
    border-left: 3px solid var(--color-border);
    padding-left: var(--space-6);
}
.about-milestone { position: relative; padding-bottom: var(--space-6); }
.about-milestone:last-child { padding-bottom: 0; }
.about-milestone::before {
    content: '';
    position: absolute;
    left: calc(-1 * var(--space-6) - 1px);
    top: 6px;
    width: 12px; height: 12px;
    border-radius: 50%;
    background: var(--color-pink-dark);
    border: 2px solid var(--color-white);
    box-shadow: 0 0 0 3px var(--color-pink);
}
.about-milestone__year {
    font-size: var(--font-size-sm);
    font-weight: 800;
    color: var(--color-pink-dark);
    letter-spacing: 0.08em;
    margin-bottom: var(--space-1);
}
.about-milestone__text {
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    line-height: 1.6;
}

/* Values */
.about-values__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--space-6);
    margin-top: var(--space-10);
}
.about-value {
    background: var(--color-white);
    border-radius: var(--radius-lg);
    padding: var(--space-8) var(--space-6);
    border: 1.5px solid var(--color-border-light);
    transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}
.about-value:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-lg);
    border-color: var(--color-pink);
}
.about-value__icon {
    width: 56px; height: 56px;
    border-radius: var(--radius-md);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.4rem;
    margin-bottom: var(--space-5);
}
.about-value__icon--pink  { background: var(--color-pink);          color: var(--color-pink-dark); }
.about-value__icon--blue  { background: var(--color-light-blue-3);  color: var(--color-light-blue-2); }
.about-value__icon--green { background: var(--color-light-green-3); color: var(--color-light-green-2); }
.about-value__icon--brown { background: var(--color-light-brown-3); color: var(--color-light-brown-2); }
.about-value__title {
    font-size: var(--font-size-lg);
    font-weight: 800;
    color: var(--color-text);
    margin-bottom: var(--space-3);
}
.about-value__desc { font-size: var(--font-size-sm); color: var(--color-text-mid); line-height: 1.7; }

/* Why section */
.about-why__inner {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
    gap: var(--space-16);
    align-items: center;
}
.about-why__list {
    list-style: none;
    margin: var(--space-6) 0 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}
.about-why__item {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    font-size: var(--font-size-base);
    color: var(--color-text);
    font-weight: 600;
}
.about-why__item i { color: var(--color-light-green-2); font-size: 1.1rem; flex-shrink: 0; margin-top: 2px; }

/* Bubble visual */
.about-why__visual {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 320px;
}
.about-why__bubbles {
    position: relative;
    width: 300px;
    height: 300px;
}
.about-why__bubble {
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    font-size: 1.8rem;
    background: var(--color-white);
    box-shadow: var(--shadow-md);
    border: 2px solid var(--color-border-light);
}
.about-why__bubble--1 { width: 80px; height: 80px; top: 0;    left: 50%;  transform: translateX(-50%); animation: bubbleBob 4s ease-in-out infinite; }
.about-why__bubble--2 { width: 68px; height: 68px; top: 20%;  right: 0;   animation: bubbleBob 5s ease-in-out infinite 0.5s; }
.about-why__bubble--3 { width: 72px; height: 72px; top: 20%;  left: 0;    animation: bubbleBob 6s ease-in-out infinite 1s; }
.about-why__bubble--4 { width: 90px; height: 90px; top: 50%;  left: 50%;  transform: translate(-50%, -50%); animation: bubbleBob 4.5s ease-in-out infinite 0.3s; }
.about-why__bubble--5 { width: 64px; height: 64px; bottom: 15%; left: 5%;  animation: bubbleBob 5.5s ease-in-out infinite 0.7s; }
.about-why__bubble--6 { width: 60px; height: 60px; bottom: 15%; right: 5%; animation: bubbleBob 6.5s ease-in-out infinite 1.2s; }

@keyframes bubbleBob {
    0%, 100% { transform: translateY(0); }
    50%       { transform: translateY(-12px); }
}
.about-why__bubble--1 { animation-name: bubbleBobCenter; }
@keyframes bubbleBobCenter {
    0%, 100% { transform: translateX(-50%) translateY(0); }
    50%       { transform: translateX(-50%) translateY(-12px); }
}
.about-why__bubble--4 { animation-name: bubbleBobMid; }
@keyframes bubbleBobMid {
    0%, 100% { transform: translate(-50%, -50%) scale(1); }
    50%       { transform: translate(-50%, -50%) scale(1.08); }
}

/* CTA */
.about-cta {
    position: relative;
    padding: var(--space-20) 0;
    overflow: hidden;
    background: linear-gradient(135deg, var(--color-pink) 0%, var(--color-light-blue-2) 50%, var(--color-light-green-2) 100%);
    text-align: center;
}
.about-cta__blobs { position: absolute; inset: 0; pointer-events: none; }
.about-cta__blob  { position: absolute; border-radius: 50%; filter: blur(60px); opacity: 0.4; }
.about-cta__blob--1 { width: 300px; height: 300px; background: var(--color-white); top: -80px; left: -60px; }
.about-cta__blob--2 { width: 240px; height: 240px; background: var(--color-white); bottom: -60px; right: -40px; }
.about-cta__inner { position: relative; z-index: 1; max-width: 640px; margin: 0 auto; }
.about-cta__emoji { font-size: 2.5rem; margin-bottom: var(--space-4); display: block; }
.about-cta__title {
    font-size: clamp(var(--font-size-xl), 3vw, var(--font-size-3xl));
    font-weight: 900;
    color: var(--color-white);
    margin-bottom: var(--space-4);
    text-shadow: 0 2px 12px rgba(74,55,40,0.15);
}
.about-cta__desc {
    font-size: var(--font-size-md);
    color: rgba(255,255,255,0.9);
    margin-bottom: var(--space-8);
    line-height: 1.65;
}
.about-cta__actions { display: flex; gap: var(--space-4); justify-content: center; flex-wrap: wrap; }
.about-cta .btn--outline {
    border-color: rgba(255,255,255,0.8);
    color: var(--color-white);
    background: rgba(255,255,255,0.15);
    backdrop-filter: blur(8px);
}
.about-cta .btn--outline:hover { background: rgba(255,255,255,0.3); }

/* Responsive: About */
@media (max-width: 1024px) {
    .about-hero__inner     { grid-template-columns: minmax(0, 1fr); gap: var(--space-10); }
    .about-hero__visual    { min-height: 280px; }
    .about-hero__float-card--1 { left: 0; }
    .about-hero__float-card--2 { right: 0; }
    .about-stats__grid     { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .about-story__inner    { grid-template-columns: minmax(0, 1fr); gap: var(--space-10); }
    .about-story__img-wrap { max-width: 480px; margin: 0 auto; }
    .about-values__grid    { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .about-why__inner      { grid-template-columns: minmax(0, 1fr); gap: var(--space-10); }
    .about-why__visual     { order: -1; }
}
@media (max-width: 768px) {
    .about-values__grid { grid-template-columns: minmax(0, 1fr); }
    .about-stats__grid  { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-4); }
    .about-hero__float-card { display: none; }
    .about-story__img-badge { bottom: -12px; right: -8px; font-size: var(--font-size-xs); }
}
@media (max-width: 480px) {
    .about-stats__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .about-cta__actions { flex-direction: column; align-items: center; }
    .about-hero__actions { flex-direction: column; }
}

/* ============================================================
   28. GENERIC POLICY PAGES (page.php)
   ============================================================ */

/* ── Hero ── */
.policy-hero {
    position: relative;
    padding: var(--space-20) 0 var(--space-16);
    overflow: hidden;
    min-height: 280px;
    display: flex;
    align-items: center;
}
.policy-page--pink  .policy-hero { background: linear-gradient(135deg, var(--color-pink) 0%, var(--color-cream) 55%, var(--color-white) 100%); }
.policy-page--blue  .policy-hero { background: linear-gradient(135deg, var(--color-light-blue-3) 0%, var(--color-cream) 55%, var(--color-white) 100%); }
.policy-page--green .policy-hero { background: linear-gradient(135deg, var(--color-light-green-3) 0%, var(--color-cream) 55%, var(--color-white) 100%); }
.policy-page--brown .policy-hero { background: linear-gradient(135deg, var(--color-light-brown-3) 0%, var(--color-cream) 55%, var(--color-white) 100%); }
/* Hero inner container fills full width */
.policy-hero .container { width: 100%; }

.policy-hero__blobs { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.policy-hero__blob  { position: absolute; border-radius: 50%; filter: blur(50px); opacity: 0.3; }
.policy-hero__blob--1 { width: 320px; height: 320px; top: -80px; right: -60px; }
.policy-hero__blob--2 { width: 200px; height: 200px; bottom: -50px; left: -40px; }
.policy-page--pink  .policy-hero__blob { background: var(--color-pink-dark); }
.policy-page--blue  .policy-hero__blob { background: var(--color-light-blue-2); }
.policy-page--green .policy-hero__blob { background: var(--color-light-green-2); }
.policy-page--brown .policy-hero__blob { background: var(--color-light-brown-2); }

.policy-hero__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--space-6);
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 680px;
    margin: 0 auto;
}
.policy-hero__icon-wrap {
    flex-shrink: 0;
    width: 80px; height: 80px;
    border-radius: var(--radius-xl);
    display: flex; align-items: center; justify-content: center;
    font-size: 2rem;
    box-shadow: var(--shadow-lg);
    color: var(--color-white);
}
.policy-page--pink  .policy-hero__icon-wrap { background: linear-gradient(135deg, var(--color-pink-dark), var(--color-pink)); }
.policy-page--blue  .policy-hero__icon-wrap { background: linear-gradient(135deg, var(--color-light-blue-2), var(--color-light-blue)); }
.policy-page--green .policy-hero__icon-wrap { background: linear-gradient(135deg, var(--color-light-green-2), var(--color-light-green)); }
.policy-page--brown .policy-hero__icon-wrap { background: linear-gradient(135deg, var(--color-light-brown-2), var(--color-light-brown)); }

.policy-hero__text { min-width: 0; text-align: center; }
.policy-hero__title {
    font-size: clamp(var(--font-size-2xl), 4vw, var(--font-size-4xl));
    font-weight: 900;
    color: var(--color-text);
    margin: 0 0 var(--space-3);
    line-height: 1.15;
}
.policy-hero__subtitle {
    font-size: var(--font-size-md);
    color: var(--color-text-mid);
    margin: 0;
    line-height: 1.6;
    max-width: 520px;
}

/* ── Body / layout ── */
.policy-body { padding: var(--space-12) 0 var(--space-20); background: var(--color-bg-section); }
.policy-container { max-width: 1040px; }

/* ── Article card ── */
.policy-article {
    background: var(--color-white);
    border: 1.5px solid var(--color-border-light);
    border-radius: var(--radius-xl);
    padding: 30px;
    box-shadow: var(--shadow-md);
}
.policy-article h2 {
    font-size: var(--font-size-xl);
    font-weight: 800;
    color: var(--color-text);
    margin: var(--space-10) 0 var(--space-4);
    padding-bottom: var(--space-3);
    border-bottom: 2px solid var(--color-border-light);
}
.policy-article h2:first-child { margin-top: 0; }
.policy-article h3 {
    font-size: var(--font-size-lg);
    font-weight: 700;
    color: var(--color-text);
    margin: var(--space-8) 0 var(--space-3);
}
.policy-article h4 {
    font-size: var(--font-size-md);
    font-weight: 700;
    color: var(--color-text);
    margin: var(--space-5) 0 var(--space-2);
}
.policy-article p {
    font-size: var(--font-size-base);
    color: var(--color-text-mid);
    line-height: 1.85;
    margin-bottom: var(--space-4);
}
.policy-article ul, .policy-article ol {
    margin: 0 0 var(--space-5) var(--space-6);
    color: var(--color-text-mid);
    line-height: 1.8;
}
.policy-article li { margin-bottom: var(--space-2); font-size: var(--font-size-base); }
.policy-article a  { color: var(--color-light-blue-2); font-weight: 600; text-decoration: underline; text-underline-offset: 2px; }
.policy-article a:hover { color: var(--color-text); }
.policy-article strong { color: var(--color-text); font-weight: 700; }
.policy-article em { font-style: italic; }
.policy-article blockquote {
    border-left: 4px solid var(--color-pink);
    background: var(--color-bg-section);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    padding: var(--space-5) var(--space-6);
    margin: var(--space-6) 0;
    color: var(--color-text);
    font-style: italic;
}
.policy-article hr {
    border: none;
    border-top: 2px solid var(--color-border-light);
    margin: var(--space-8) 0;
}
.policy-article table { width: 100%; border-collapse: collapse; margin: var(--space-6) 0; font-size: var(--font-size-sm); overflow-x: auto; display: block; }
.policy-article th { background: var(--color-bg-section); font-weight: 700; color: var(--color-text); padding: var(--space-3) var(--space-4); border: 1px solid var(--color-border); text-align: left; }
.policy-article td { padding: var(--space-3) var(--space-4); border: 1px solid var(--color-border-light); color: var(--color-text-mid); vertical-align: top; }
.policy-article tr:nth-child(even) td { background: var(--color-bg-section); }

/* ── Bottom CTA ── */
.policy-bottom-cta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-5);
    margin-top: var(--space-8);
}
.policy-bottom-cta__card {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    background: var(--color-white);
    border: 1.5px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    padding: 20px;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
    overflow: hidden;
    min-width: 0;
}
.policy-bottom-cta__card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.policy-bottom-cta__card-icon {
    flex-shrink: 0;
    width: 48px; height: 48px;
    border-radius: var(--radius-md);
    background: var(--color-bg-section);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem;
    color: var(--color-text-mid);
}
.policy-bottom-cta__card--shop .policy-bottom-cta__card-icon { background: var(--color-pink); color: var(--color-pink-dark); }
.policy-bottom-cta__card-body { flex: 1; min-width: 0; }
.policy-bottom-cta__card-body strong { display: block; font-size: var(--font-size-base); font-weight: 800; color: var(--color-text); margin-bottom: var(--space-1); }
.policy-bottom-cta__card-body p { font-size: var(--font-size-sm); color: var(--color-text-mid); margin: 0; }
.policy-bottom-cta__card .btn { flex-shrink: 0; white-space: nowrap; }

/* ── Responsive: policy pages ── */
@media (max-width: 768px) {
    .policy-hero          { min-height: 200px; padding: var(--space-14) 0 var(--space-10); }
    .policy-hero__icon-wrap { width: 64px; height: 64px; font-size: 1.6rem; }
    .policy-article       { padding: 30px; border-radius: var(--radius-lg); }
    .policy-bottom-cta    { grid-template-columns: minmax(0, 1fr); }
}
@media (max-width: 480px) {
    .policy-hero          { padding: var(--space-10) 0 var(--space-8); }
    .policy-bottom-cta__card { flex-direction: column; align-items: flex-start; }
    .policy-bottom-cta__card .btn { width: 100%; justify-content: center; }
}

/* ============================================================
   29. FEATURE BANNER (Homepage + About Us)
   ============================================================ */

/* ── Homepage feature banner ── */
.kawaii-feature-banner {
    position: relative;
    overflow: hidden;
    max-height: 520px;
}
.kawaii-feature-banner__img-wrap {
    position: relative;
    width: 100%;
    height: 520px;
}
.kawaii-feature-banner__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}
.kawaii-feature-banner__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        100deg,
        rgba(74, 55, 40, 0.72) 0%,
        rgba(74, 55, 40, 0.45) 50%,
        rgba(74, 55, 40, 0.05) 100%
    );
}
.kawaii-feature-banner__content {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
}
.kawaii-feature-banner__box {
    max-width: 520px;
    padding: var(--space-6) 0;
}
.kawaii-feature-banner__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-sm);
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.9);
    background: rgba(255,255,255,0.15);
    border: 1.5px solid rgba(255,255,255,0.35);
    border-radius: var(--radius-full);
    padding: var(--space-1) var(--space-4);
    margin-bottom: var(--space-5);
    backdrop-filter: blur(4px);
}
.kawaii-feature-banner__title {
    font-size: clamp(var(--font-size-2xl), 3.5vw, var(--font-size-4xl));
    font-weight: 900;
    color: var(--color-white);
    line-height: 1.18;
    margin: 0 0 var(--space-4);
    text-shadow: 0 2px 16px rgba(0,0,0,0.25);
}
.kawaii-feature-banner__desc {
    font-size: var(--font-size-md);
    color: rgba(255,255,255,0.88);
    line-height: 1.65;
    margin: 0 0 var(--space-8);
    max-width: 440px;
}
.kawaii-feature-banner__actions {
    display: flex;
    gap: var(--space-4);
    flex-wrap: wrap;
}
.kawaii-feature-banner__btn-ghost {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-weight: 700;
    color: var(--color-white);
    background: rgba(255,255,255,0.12);
    border: 1.5px solid rgba(255,255,255,0.5);
    border-radius: var(--radius-full);
    padding: 1rem 2.5rem;
    font-size: var(--font-size-base);
    text-decoration: none;
    transition: all var(--transition-fast);
    backdrop-filter: blur(4px);
}
.kawaii-feature-banner__btn-ghost:hover {
    background: rgba(255,255,255,0.25);
    border-color: rgba(255,255,255,0.8);
    color: var(--color-white);
}
@media (max-width: 768px) {
    .kawaii-feature-banner__img-wrap { height: 400px; }
    .kawaii-feature-banner { max-height: 400px; }
    .kawaii-feature-banner__overlay {
        background: linear-gradient(
            180deg,
            rgba(74,55,40,0.1) 0%,
            rgba(74,55,40,0.72) 55%,
            rgba(74,55,40,0.85) 100%
        );
    }
    .kawaii-feature-banner__content { align-items: flex-end; padding-bottom: var(--space-8); }
    .kawaii-feature-banner__box { max-width: 100%; }
    .kawaii-feature-banner__title { font-size: var(--font-size-xl); }
    .kawaii-feature-banner__desc { display: none; }
}
@media (max-width: 480px) {
    .kawaii-feature-banner__img-wrap { height: 320px; }
    .kawaii-feature-banner { max-height: 320px; }
    .kawaii-feature-banner__actions { flex-direction: column; }
    .kawaii-feature-banner__actions .btn,
    .kawaii-feature-banner__btn-ghost { width: 100%; justify-content: center; }
}

/* ── About Us showcase banner ── */
.about-showcase {
    position: relative;
    overflow: hidden;
    height: 480px;
}
.about-showcase__img-wrap {
    position: absolute;
    inset: 0;
}
.about-showcase__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}
.about-showcase__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        135deg,
        rgba(249,200,216,0.85) 0%,
        rgba(168,217,238,0.70) 50%,
        rgba(168,217,168,0.60) 100%
    );
}
.about-showcase__content {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}
.about-showcase__box { max-width: 600px; padding: var(--space-6); }
.about-showcase__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-sm);
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-text);
    background: rgba(255,255,255,0.6);
    border: 1.5px solid rgba(255,255,255,0.8);
    border-radius: var(--radius-full);
    padding: var(--space-1) var(--space-4);
    margin-bottom: var(--space-5);
    backdrop-filter: blur(6px);
}
.about-showcase__title {
    font-size: clamp(var(--font-size-2xl), 4vw, var(--font-size-3xl));
    font-weight: 900;
    color: var(--color-text);
    line-height: 1.2;
    margin: 0 0 var(--space-4);
    text-shadow: 0 1px 8px rgba(255,255,255,0.5);
}
.about-showcase__desc {
    font-size: var(--font-size-md);
    color: var(--color-text);
    line-height: 1.65;
    margin: 0 0 var(--space-8);
    opacity: 0.85;
}
.about-showcase__btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: var(--color-text);
    color: var(--color-white);
    border: none;
    border-radius: var(--radius-full);
    padding: 0.875rem var(--space-8);
    font-size: var(--font-size-base);
    font-weight: 700;
    text-decoration: none;
    box-shadow: var(--shadow-lg);
    transition: all var(--transition-fast);
}
.about-showcase__btn:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-xl);
    background: var(--color-text-mid);
    color: var(--color-white);
}
@media (max-width: 768px) {
    .about-showcase { height: 380px; }
    .about-showcase__title { font-size: var(--font-size-xl); }
    .about-showcase__desc  { font-size: var(--font-size-base); }
}
@media (max-width: 480px) {
    .about-showcase { height: 300px; }
    .about-showcase__desc { display: none; }
}
/* ============================================================
   30. RELATED CATEGORIES (below product grid pagination)
   ============================================================ */
.related-cats {
    padding: var(--space-16) 0 var(--space-12);
    background: var(--color-bg-section);
    border-top: 1px solid var(--color-border-light);
}
.related-cats__header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: var(--space-4);
    margin-bottom: var(--space-8);
    flex-wrap: wrap;
}
.related-cats__title {
    font-size: clamp(var(--font-size-xl), 2.5vw, var(--font-size-2xl));
    font-weight: 800;
    color: var(--color-text);
    margin: var(--space-2) 0 0;
    line-height: 1.2;
}
.related-cats__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: var(--space-5);
}
.related-cat-card {
    display: flex;
    flex-direction: column;
    border-radius: var(--radius-lg);
    overflow: hidden;
    text-decoration: none;
    background: var(--color-white);
    border: 1.5px solid var(--color-border-light);
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}
.related-cat-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.related-cat-card--pink:hover  { border-color: var(--color-pink-dark); }
.related-cat-card--blue:hover  { border-color: var(--color-light-blue-2); }
.related-cat-card--green:hover { border-color: var(--color-light-green-2); }
.related-cat-card--brown:hover { border-color: var(--color-light-brown-2); }

.related-cat-card__img-wrap {
    position: relative;
    width: 100%;
    aspect-ratio: 4/3;
    overflow: hidden;
    background: var(--color-bg-section);
}
.related-cat-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.45s ease;
}
.related-cat-card:hover .related-cat-card__img { transform: scale(1.07); }
.related-cat-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 40%, rgba(74,55,40,0.35) 100%);
    opacity: 0;
    transition: opacity var(--transition-base);
}
.related-cat-card:hover .related-cat-card__overlay { opacity: 1; }
.related-cat-card__placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 3rem;
}
.related-cat-card--pink  .related-cat-card__placeholder { background: var(--color-pink); }
.related-cat-card--blue  .related-cat-card__placeholder { background: var(--color-light-blue-3); }
.related-cat-card--green .related-cat-card__placeholder { background: var(--color-light-green-3); }
.related-cat-card--brown .related-cat-card__placeholder { background: var(--color-light-brown-3); }

.related-cat-card__body { padding: var(--space-4) var(--space-5); display: flex; flex-direction: column; gap: var(--space-1); flex: 1; }
.related-cat-card__count { font-size: var(--font-size-xs); font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-text-light); }
.related-cat-card__name { font-size: var(--font-size-base); font-weight: 800; color: var(--color-text); margin: 0; line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.related-cat-card__cta { display: inline-flex; align-items: center; gap: var(--space-2); font-size: var(--font-size-sm); font-weight: 700; margin-top: var(--space-2); transition: gap var(--transition-fast); }
.related-cat-card--pink  .related-cat-card__cta { color: var(--color-pink-dark); }
.related-cat-card--blue  .related-cat-card__cta { color: var(--color-light-blue-2); }
.related-cat-card--green .related-cat-card__cta { color: var(--color-light-green-2); }
.related-cat-card--brown .related-cat-card__cta { color: var(--color-light-brown-2); }
.related-cat-card:hover .related-cat-card__cta { gap: var(--space-3); }

.shop-no-products { padding: var(--space-16) 0; text-align: center; }
.shop-no-products__icon { font-size: 3.5rem; margin-bottom: var(--space-4); display: block; }
.shop-no-products p { color: var(--color-text-mid); font-size: var(--font-size-md); margin-bottom: var(--space-6); }

@media (max-width: 768px) {
    .related-cats__grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: var(--space-4); }
    .related-cats__header { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 480px) {
    .related-cats__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* ============================================================
   31. CATEGORY LONG DESCRIPTION + FAQ (redesigned)
   ============================================================ */
.cat-bottom-wrap {
    padding: var(--space-16) 0 var(--space-20);
    background: var(--color-white);
}
.cat-bottom-wrap .container { display: flex; flex-direction: column; gap: var(--space-10); }

.cat-long-desc {
    background: linear-gradient(135deg, var(--color-light-blue-3) 0%, var(--color-cream) 60%, var(--color-light-green-3) 100%);
    border-radius: var(--radius-xl);
    padding: var(--space-10) var(--space-12);
    border: 1.5px solid var(--color-border-light);
    box-shadow: var(--shadow-sm);
    position: relative;
    overflow: hidden;
}
.cat-long-desc::before { content: '🧸'; position: absolute; right: var(--space-8); top: var(--space-6); font-size: 5rem; opacity: 0.07; pointer-events: none; user-select: none; }
.cat-long-desc__header { display: flex; align-items: flex-start; gap: var(--space-5); margin-bottom: var(--space-7); }
.cat-long-desc__icon { flex-shrink: 0; width: 52px; height: 52px; border-radius: var(--radius-md); background: linear-gradient(135deg, var(--color-light-blue-2), var(--color-light-green-2)); color: var(--color-white); display: flex; align-items: center; justify-content: center; font-size: 1.4rem; box-shadow: var(--shadow-md); }
.cat-long-desc__eyebrow { display: block; font-size: var(--font-size-xs); font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-light-blue-2); margin-bottom: var(--space-2); }
.cat-long-desc__title { font-size: clamp(var(--font-size-xl), 2.5vw, var(--font-size-2xl)); font-weight: 800; color: var(--color-text); margin: 0; line-height: 1.2; }
.cat-long-desc__body { max-width: 820px; }
.cat-long-desc__body p { font-size: var(--font-size-base); color: var(--color-text-mid); line-height: 1.85; margin-bottom: var(--space-4); }
.cat-long-desc__body h3 { font-size: var(--font-size-lg); font-weight: 800; color: var(--color-text); margin: var(--space-6) 0 var(--space-3); }
.cat-long-desc__body ul { margin: 0 0 var(--space-5) var(--space-6); color: var(--color-text-mid); line-height: 1.75; }
.cat-long-desc__body li { margin-bottom: var(--space-2); }
.cat-long-desc__body strong { color: var(--color-text); font-weight: 700; }
.cat-long-desc__highlights { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-4); margin-top: var(--space-6); }
.cat-long-desc__highlight { display: flex; align-items: flex-start; gap: var(--space-3); background: var(--color-white); border-radius: var(--radius-md); padding: var(--space-4) var(--space-5); border: 1px solid var(--color-border-light); box-shadow: var(--shadow-xs); }
.cat-long-desc__highlight i { color: var(--color-light-blue-2); font-size: 1.1rem; flex-shrink: 0; margin-top: 2px; }
.cat-long-desc__highlight span { font-size: var(--font-size-sm); font-weight: 600; color: var(--color-text); line-height: 1.5; }

.cat-faq { background: var(--color-white); border-radius: var(--radius-xl); border: 1.5px solid var(--color-border-light); padding: var(--space-10) var(--space-12); box-shadow: var(--shadow-sm); }
.cat-faq__header { display: flex; align-items: flex-start; gap: var(--space-5); margin-bottom: var(--space-8); }
.cat-faq__icon { flex-shrink: 0; width: 52px; height: 52px; border-radius: var(--radius-md); background: linear-gradient(135deg, var(--color-pink-dark), var(--color-pink)); color: var(--color-white); display: flex; align-items: center; justify-content: center; font-size: 1.4rem; box-shadow: var(--shadow-md); }
.cat-faq__eyebrow { display: block; font-size: var(--font-size-xs); font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-pink-dark); margin-bottom: var(--space-2); }
.cat-faq__title { font-size: clamp(var(--font-size-xl), 2.5vw, var(--font-size-2xl)); font-weight: 800; color: var(--color-text); margin: 0; line-height: 1.2; }
.cat-faq__list { display: flex; flex-direction: column; gap: var(--space-3); }

.cat-faq-item { border-radius: var(--radius-lg); border: 1.5px solid var(--color-border-light); overflow: hidden; transition: border-color var(--transition-fast), box-shadow var(--transition-fast); background: var(--color-white); }
.cat-faq-item.is-open { box-shadow: var(--shadow-md); }
.cat-faq-item--pink.is-open  { border-color: var(--color-pink-dark); }
.cat-faq-item--blue.is-open  { border-color: var(--color-light-blue-2); }
.cat-faq-item--green.is-open { border-color: var(--color-light-green-2); }
.cat-faq-item--brown.is-open { border-color: var(--color-light-brown-2); }

.cat-faq-item__q { width: 100%; display: flex; align-items: center; gap: var(--space-4); padding: var(--space-5) var(--space-6); background: var(--color-white); border: none; cursor: pointer; text-align: left; font-family: var(--font-family); transition: background var(--transition-fast); }
.cat-faq-item__q:hover, .cat-faq-item.is-open .cat-faq-item__q { background: var(--color-bg-section); }

.cat-faq-item__num { flex-shrink: 0; width: 36px; height: 36px; border-radius: var(--radius-full); display: flex; align-items: center; justify-content: center; font-size: var(--font-size-sm); font-weight: 900; color: var(--color-white); transition: transform var(--transition-fast); }
.cat-faq-item--pink  .cat-faq-item__num { background: var(--color-pink-dark); }
.cat-faq-item--blue  .cat-faq-item__num { background: var(--color-light-blue-2); }
.cat-faq-item--green .cat-faq-item__num { background: var(--color-light-green-2); }
.cat-faq-item--brown .cat-faq-item__num { background: var(--color-light-brown-2); }
.cat-faq-item.is-open .cat-faq-item__num { transform: scale(1.1); }

.cat-faq-item__q-text { flex: 1; font-size: var(--font-size-base); font-weight: 700; color: var(--color-text); line-height: 1.45; }
.cat-faq-item__chevron { flex-shrink: 0; width: 32px; height: 32px; border-radius: 50%; background: var(--color-bg-section); display: flex; align-items: center; justify-content: center; color: var(--color-text-mid); font-size: 0.75rem; transition: transform var(--transition-base), background var(--transition-fast); }
.cat-faq-item.is-open .cat-faq-item__chevron { transform: rotate(180deg); background: var(--color-border); }

.cat-faq-item__a { overflow: hidden; display: none; }
.cat-faq-item.is-open .cat-faq-item__a { display: block; }
.cat-faq-item__a-inner { padding: var(--space-2) var(--space-6) var(--space-6) calc(var(--space-6) + 36px + var(--space-4)); font-size: var(--font-size-base); color: var(--color-text-mid); line-height: 1.8; }
.cat-faq-item__a-inner p { margin-bottom: var(--space-3); }
.cat-faq-item__a-inner p:last-child { margin-bottom: 0; }

@media (max-width: 768px) {
    .cat-long-desc, .cat-faq { padding: var(--space-7) var(--space-6); border-radius: var(--radius-lg); }
    .cat-long-desc__highlights { grid-template-columns: minmax(0, 1fr); }
    .cat-long-desc__header, .cat-faq__header { flex-direction: column; }
    .cat-faq-item__a-inner { padding-left: var(--space-6); }
}
@media (max-width: 480px) {
    .cat-long-desc, .cat-faq { padding: var(--space-6) var(--space-5); }
    .cat-faq-item__q { padding: var(--space-4); }
    .cat-faq-item__num { width: 30px; height: 30px; font-size: var(--font-size-xs); }
}

/* ============================================================
   32. PRODUCT REVIEWS (PDP)
   ============================================================ */
.pdp-reviews {
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
}

/* Summary bar */
.pdp-reviews__summary {
    display: flex;
    align-items: flex-start;
    gap: var(--space-10);
    background: linear-gradient(135deg, var(--color-light-blue-3) 0%, var(--color-cream) 60%, var(--color-pink) 100%);
    border-radius: var(--radius-xl);
    padding: var(--space-8) var(--space-10);
    border: 1.5px solid var(--color-border-light);
}
.pdp-reviews__summary-score {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-2);
    min-width: 120px;
    text-align: center;
}
.pdp-reviews__big-rating {
    font-size: 3.5rem;
    font-weight: 900;
    color: var(--color-text);
    line-height: 1;
}
.pdp-reviews__summary-stars .star-rating { font-size: 1.1rem; }
.pdp-reviews__summary-count {
    font-size: var(--font-size-xs);
    color: var(--color-text-mid);
    font-weight: 600;
}
.pdp-reviews__bars {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}
.pdp-reviews__bar-row {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}
.pdp-reviews__bar-label {
    font-size: var(--font-size-xs);
    font-weight: 700;
    color: var(--color-text);
    min-width: 28px;
    display: flex;
    align-items: center;
    gap: 2px;
}
.pdp-reviews__bar-label .fa-star { color: var(--color-warning); font-size: 0.65rem; }
.pdp-reviews__bar-track {
    flex: 1;
    height: 8px;
    background: var(--color-border-light);
    border-radius: var(--radius-full);
    overflow: hidden;
}
.pdp-reviews__bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--color-warning), var(--color-pink-dark));
    border-radius: var(--radius-full);
    transition: width 0.6s ease;
}
.pdp-reviews__bar-pct {
    font-size: var(--font-size-xs);
    color: var(--color-text-mid);
    min-width: 28px;
    text-align: right;
}

/* Individual review items */
.pdp-reviews__list {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
}
.pdp-review-item {
    display: flex;
    gap: var(--space-4);
    background: var(--color-white);
    border: 1.5px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    padding: var(--space-5) var(--space-6);
    transition: box-shadow var(--transition-fast), border-color var(--transition-fast);
}
.pdp-review-item:hover {
    box-shadow: var(--shadow-md);
    border-color: var(--color-pink-dark);
}
.pdp-review-item__avatar {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    border-radius: var(--radius-full);
    background: linear-gradient(135deg, var(--color-pink-dark), var(--color-light-blue-2));
    color: var(--color-white);
    font-size: var(--font-size-base);
    font-weight: 900;
    display: flex;
    align-items: center;
    justify-content: center;
}
.pdp-review-item__body { flex: 1; min-width: 0; }
.pdp-review-item__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-3);
    margin-bottom: var(--space-3);
    flex-wrap: wrap;
}
.pdp-review-item__meta {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-wrap: wrap;
}
.pdp-review-item__name {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
}
.pdp-review-item__verified {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: var(--font-size-xs);
    font-weight: 600;
    color: #22c55e;
    background: #f0fdf4;
    border-radius: var(--radius-full);
    padding: 2px 8px;
}
.pdp-review-item__date {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    font-weight: 500;
}
.pdp-review-item__stars {
    display: flex;
    gap: 2px;
    color: var(--color-warning);
    font-size: 0.85rem;
    flex-shrink: 0;
}
.pdp-review-item__stars .fa-regular { color: var(--color-border); }
.pdp-review-item__text {
    font-size: var(--font-size-base);
    color: var(--color-text-mid);
    line-height: 1.75;
}
.pdp-review-item__text p { margin-bottom: var(--space-2); }
.pdp-review-item__text p:last-child { margin-bottom: 0; }

.pdp-reviews__empty {
    text-align: center;
    padding: var(--space-10) var(--space-6);
    color: var(--color-text-mid);
}
.pdp-reviews__empty-icon { font-size: 2.5rem; display: block; margin-bottom: var(--space-3); }

/* Review form */
.pdp-review-form-wrap {
    background: var(--color-white);
    border: 1.5px solid var(--color-border-light);
    border-radius: var(--radius-xl);
    padding: var(--space-8) var(--space-10);
}
.pdp-review-form__title {
    font-size: var(--font-size-lg);
    font-weight: 800;
    color: var(--color-text);
    margin: 0 0 var(--space-6);
    display: flex;
    align-items: center;
    gap: var(--space-3);
}
.pdp-review-form__title .fa-pen-to-square { color: var(--color-pink-dark); }

.pdp-review-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}
.pdp-review-form .comment-form-author,
.pdp-review-form .comment-form-email,
.pdp-review-form .comment-form-comment,
.pdp-review-form__field {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    margin: 0;
}
.pdp-review-form .comment-form-author label,
.pdp-review-form .comment-form-email label,
.pdp-review-form .comment-form-comment label,
.pdp-review-form__field label {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
}
.pdp-review-form .comment-form-author input,
.pdp-review-form .comment-form-email input,
.pdp-review-form__field input,
.pdp-review-form__field textarea {
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    font-size: var(--font-size-base);
    font-family: var(--font-family);
    color: var(--color-text);
    background: var(--color-bg-section);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    width: 100%;
}
.pdp-review-form .comment-form-author input:focus,
.pdp-review-form .comment-form-email input:focus,
.pdp-review-form__field input:focus,
.pdp-review-form__field textarea:focus {
    outline: none;
    border-color: var(--color-pink-dark);
    background: var(--color-white);
}
.pdp-review-form__field textarea { resize: vertical; min-height: 120px; }

/* Star picker */
.pdp-review-form__field--stars { flex-direction: row; align-items: center; gap: var(--space-4); }
.pdp-review-form__field--stars label { margin-bottom: 0; white-space: nowrap; }
.pdp-star-picker {
    display: inline-flex;
    gap: var(--space-1);
}
.pdp-star-picker__star {
    background: none;
    border: none;
    cursor: pointer;
    padding: 2px;
    font-size: 1.5rem;
    color: var(--color-border);
    transition: color var(--transition-fast), transform var(--transition-fast);
    line-height: 1;
}
.pdp-star-picker__star:hover,
.pdp-star-picker__star.is-active { color: var(--color-warning); transform: scale(1.1); }

.pdp-review-form__submit {
    align-self: flex-start;
    margin-top: var(--space-2);
}
.pdp-reviews__must-buy {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    background: var(--color-bg-section);
    border-radius: var(--radius-lg);
    padding: var(--space-4) var(--space-5);
    border: 1px solid var(--color-border-light);
}

@media (max-width: 768px) {
    .pdp-reviews__summary { flex-direction: column; gap: var(--space-5); padding: var(--space-6); }
    .pdp-review-form-wrap { padding: var(--space-6); }
    .pdp-review-item { padding: var(--space-4); }
    .pdp-review-item__header { flex-direction: column; }
    .pdp-review-form__field--stars { flex-direction: column; align-items: flex-start; }
}

/* ============================================================
   ACCESSIBILITY — WCAG 2.1 AA
   ============================================================ */

/* ── Skip link ─────────────────────────────────────────────── */
.skip-link {
    position: absolute;
    top: -100px;
    left: var(--space-4);
    z-index: 99999;
    background: var(--color-text);
    color: var(--color-white);
    padding: var(--space-3) var(--space-5);
    border-radius: 0 0 var(--radius-md) var(--radius-md);
    font-weight: 700;
    font-size: var(--font-size-sm);
    text-decoration: none;
    transition: top 0.2s;
}
.skip-link:focus {
    top: 0;
    outline: 3px solid var(--color-pink-dark);
    outline-offset: 2px;
}

/* ── Screen-reader only utility ────────────────────────────── */
.screen-reader-text {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}
.screen-reader-text:focus {
    position: static !important;
    width: auto !important;
    height: auto !important;
    padding: inherit !important;
    margin: inherit !important;
    overflow: visible !important;
    clip: auto !important;
    white-space: inherit !important;
}

/* ── Global focus-visible indicator ────────────────────────── */
/* Remove browser default, add consistent custom indicator */
*:focus { outline: none; }
*:focus-visible {
    outline: 3px solid var(--color-pink-dark);
    outline-offset: 3px;
    border-radius: 2px;
}

/* Inputs and textareas: box shadow focus instead of outline */
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-pink-dark) 25%, transparent);
    border-color: var(--color-pink-dark) !important;
}

/* Buttons: clear ring */
button:focus-visible,
.btn:focus-visible,
.header-action:focus-visible {
    outline: 3px solid var(--color-pink-dark);
    outline-offset: 3px;
}

/* Nav links */
.nav-menu a:focus-visible,
.related-cat-card:focus-visible,
.product-card__image-link:focus-visible {
    outline: 3px solid var(--color-pink-dark);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
}

/* ── Color contrast fix ─────────────────────────────────────── */
/* --color-text-light (#A89585) fails AA on white — darken to #8A7060 */
:root { --color-text-light: #8A7060; }

/* Placeholder text contrast improvement */
::placeholder { color: #8A7060; opacity: 1; }
:-ms-input-placeholder { color: #8A7060; }

/* ── Prefers-reduced-motion ─────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }

    /* Disable specific animations */
    .fade-in-up,
    .blob,
    .about-hero__blob,
    .seo-brand__blob { animation: none !important; }

    .hero-swiper .swiper-wrapper { transition: none !important; }

    .pdp-reviews__bar-fill { transition: none !important; }
}

/* ── High-contrast / forced-colors support ──────────────────── */
@media (forced-colors: active) {
    .btn, .header-action, .product-card__badge {
        border: 2px solid ButtonText;
    }
    .star-rating span::before,
    .pdp-review-item__stars .fa-solid { forced-color-adjust: none; color: Highlight; }
}

/* ── ARIA live region for toast notifications ───────────────── */
#kawaii-toast-region {
    position: fixed;
    bottom: var(--space-6);
    left: 50%;
    transform: translateX(-50%);
    z-index: 9999;
    pointer-events: none;
}

/* ── Visible focus for tab navigation on product cards ──────── */
.product-card:focus-within {
    box-shadow: 0 0 0 3px var(--color-pink-dark);
    border-radius: var(--radius-lg);
}

/* ── FAQ aria-controls focus ────────────────────────────────── */
.cat-faq-item__q:focus-visible,
.faq-item__question:focus-visible {
    outline: 3px solid var(--color-pink-dark);
    outline-offset: -3px;
}

/* ── Form error states ──────────────────────────────────────── */
input[aria-invalid="true"],
textarea[aria-invalid="true"],
select[aria-invalid="true"] {
    border-color: var(--color-error) !important;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-error) 20%, transparent);
}

/* ── Table accessibility ────────────────────────────────────── */
.woocommerce-table th[scope] { font-weight: 700; }

/* ── Ensure modal backdrop blocks pointer for background ─────── */
.side-cart.is-open ~ * [tabindex],
.quick-view-modal.is-open ~ * [tabindex] {
    /* background content not truly inert without JS — handled in JS */
}

/* ── Link underlines for inline text links (WCAG 1.4.1) ─────── */
.entry-content a:not([class]),
.pdp-review-item__text a,
.cat-long-desc__body a,
.policy-article a {
    text-decoration: underline;
    text-underline-offset: 2px;
}

/* ── Minimum touch target size 44x44 (WCAG 2.5.5) ───────────── */
.header-action,
.product-card__wishlist,
.side-cart__close,
.qv-close,
.cat-faq-item__q {
    min-width: 44px;
    min-height: 44px;
}

/* ── Remove animation for print ─────────────────────────────── */
@media print {
    * { animation: none !important; transition: none !important; }
    .site-header, .site-footer { display: block; }
    .side-cart, #quick-view-modal, .shop-filter-overlay { display: none !important; }
}

/* ============================================================
   NEWSLETTER FORM  [kawaii_newsletter_form]
   ============================================================ */

.kawaii-nl-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    max-width: 520px;
}

.kawaii-nl-form__row {
    display: flex;
    gap: var(--space-2);
}

.kawaii-nl-form__row--email {
    flex-direction: row;
}

.kawaii-nl-form__input {
    flex: 1;
    padding: var(--space-3) var(--space-4);
    border: 1.5px solid var(--color-pink-light);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    color: var(--color-text);
    background: var(--color-white);
    transition: border-color 0.2s, box-shadow 0.2s;
    min-width: 0;
}

.kawaii-nl-form__input:focus {
    outline: none;
    border-color: var(--color-pink-dark);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-pink-dark) 18%, transparent);
}

.kawaii-nl-form__btn {
    white-space: nowrap;
    flex-shrink: 0;
}

.kawaii-nl-form__message {
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    font-weight: 600;
}

.kawaii-nl-form__message--success {
    background: #F0FFF4;
    color: #276749;
    border: 1px solid #9AE6B4;
}

.kawaii-nl-form__message--error {
    background: #FFF5F5;
    color: #C53030;
    border: 1px solid #FEB2B2;
}

/* Compact inline variant (e.g. inside a widget) */
.kawaii-nl-form--compact .kawaii-nl-form__row {
    flex-direction: column;
}

@media (max-width: 480px) {
    .kawaii-nl-form__row--email {
        flex-direction: column;
    }
    .kawaii-nl-form__btn {
        width: 100%;
    }
}

/* 1. Reset the star container */
.product-card__rating .star-rating {
    font-family: "star" !important; /* Standard WC font name */
    position: relative;
    display: inline-block;
    width: 73px; /* Exact width for 5 stars */
    height: 14px;
    line-height: 14px;
    font-size: 14px;
    overflow: hidden;
    vertical-align: middle;
}

/* 2. Create the Background (Empty) Stars */
.product-card__rating .star-rating::before {
    content: "\2605\2605\2605\2605\2605"; /* Unicode Black Star */
    color: #e0e0e0; /* Light grey for empty stars */
    position: absolute;
    top: 0;
    left: 0;
    letter-spacing: 2px;
}

/* 3. Create the Foreground (Filled) Stars */
.product-card__rating .star-rating span {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    height: 14px;
    overflow: hidden;
    text-indent: -9999px; /* Hides the "Rated X" text */
}

.product-card__rating .star-rating span::before {
    content: "\2605\2605\2605\2605\2605";
    color: #ffb100; /* Gold/Warning color */
    position: absolute;
    top: 0;
    left: 0;
    text-indent: 0;
    letter-spacing: 2px;
}

/* ============================================================
   CARE GUIDE — Product Care Tab (Washing & Storage)
   ============================================================ */

.care-guide {
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
}

/* ── Section heading ── */
.care-guide__heading {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    margin-bottom: var(--space-5);
}
.care-guide__heading-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: var(--color-light-blue-3);
    color: var(--color-light-blue-2);
    font-size: 1rem;
    flex-shrink: 0;
}
.care-guide__heading h3 {
    font-size: var(--font-size-lg);
    font-weight: 800;
    color: var(--color-text);
    margin: 0;
}

/* ── Cards grid ── */
.care-guide__grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--space-4);
}

.care-guide__card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--space-3);
    padding: var(--space-5) var(--space-4);
    background: var(--color-bg-section);
    border-radius: var(--radius-lg);
    border: 1.5px solid var(--color-border-light);
    transition:
        transform var(--transition-base),
        box-shadow var(--transition-base),
        border-color var(--transition-base);
    cursor: default;
}
.care-guide__card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
    border-color: var(--color-light-blue);
}
.care-guide__card p {
    font-size: var(--font-size-xs);
    color: var(--color-text-mid);
    line-height: 1.55;
    margin: 0;
}

/* ── Card icons ── */
.care-guide__card-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border-radius: 50%;
    font-size: 1.25rem;
    flex-shrink: 0;
    transition: transform var(--transition-base);
}
.care-guide__card:hover .care-guide__card-icon {
    transform: scale(1.12) rotate(-4deg);
}
.care-guide__card-icon--blue  { background: var(--color-light-blue-3);  color: var(--color-light-blue-2); }
.care-guide__card-icon--green { background: var(--color-light-green-3); color: var(--color-light-green-2); }
.care-guide__card-icon--pink  { background: var(--color-pink);          color: var(--color-pink-dark); }
.care-guide__card-icon--brown { background: var(--color-light-brown-3); color: var(--color-light-brown-2); }

/* ── Storage tip banner ── */
.care-guide__storage {
    display: flex;
    align-items: center;
    gap: var(--space-5);
    padding: var(--space-6);
    background: linear-gradient(135deg, var(--color-light-blue-3) 0%, var(--color-light-green-3) 100%);
    border-radius: var(--radius-lg);
    border: 1.5px solid var(--color-light-blue);
}
.care-guide__storage-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: var(--color-white);
    color: var(--color-light-blue-2);
    font-size: 1.5rem;
    flex-shrink: 0;
    box-shadow: var(--shadow-sm);
}
.care-guide__storage-body h3 {
    font-size: var(--font-size-base);
    font-weight: 800;
    color: var(--color-text);
    margin: 0 0 var(--space-2);
}
.care-guide__storage-body p {
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    line-height: 1.65;
    margin: 0;
}

/* ── Responsive ── */
@media (max-width: 900px) {
    .care-guide__grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 600px) {
    .care-guide__grid { grid-template-columns: repeat(2, 1fr); }
    .care-guide__storage { flex-direction: column; text-align: center; }
}
@media (max-width: 380px) {
    .care-guide__grid { grid-template-columns: 1fr; }
}

/* ============================================================
   BLOG PRODUCT POPUP  (inc/blog-product-popup.php)
   Appears after 10 s on single blog posts — 3 random products
   ============================================================ */

/* Overlay */
.kbp-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(74, 55, 40, 0.55);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-4);
    opacity: 0;
    transition: opacity 0.35s ease;
    backdrop-filter: blur(3px);
}
/*
 * Fix: author-stylesheet display:flex overrides the browser's built-in
 * [hidden]{display:none} rule, so the overlay would remain position:fixed;
 * inset:0 after dismissal — invisible but blocking every click on the page.
 * This rule forces it fully off-screen after the JS sets popup.hidden = true.
 */
.kbp-overlay[hidden] { display: none !important; }
.kbp-overlay--active {
    opacity: 1;
}


/* Modal box */
.kbp-modal {
    position: relative;
    background: var(--color-white);
    border-radius: var(--radius-xl);
    padding: var(--space-8);
    width: 100%;
    max-width: 780px;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: var(--shadow-xl);
    transform: translateY(32px) scale(0.97);
    transition: transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.kbp-overlay--active .kbp-modal {
    transform: translateY(0) scale(1);
}

/* Close button */
.kbp-close {
    position: absolute;
    top: var(--space-4);
    right: var(--space-4);
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none;
    background: var(--color-bg-section);
    color: var(--color-text-mid);
    font-size: 1rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--transition-fast), color var(--transition-fast);
    z-index: 1;
}
.kbp-close:hover {
    background: var(--color-pink);
    color: var(--color-text);
}

/* Header */
.kbp-header {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    margin-bottom: var(--space-6);
}
.kbp-header__emoji {
    font-size: 2.5rem;
    line-height: 1;
    flex-shrink: 0;
    animation: kbp-wobble 2.5s ease-in-out infinite;
}
@keyframes kbp-wobble {
    0%, 100% { transform: rotate(-4deg); }
    50%       { transform: rotate(4deg); }
}
.kbp-header__eyebrow {
    font-size: var(--font-size-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-light-blue-2);
    margin: 0 0 var(--space-1);
}
.kbp-header__title {
    font-size: var(--font-size-xl);
    font-weight: 900;
    color: var(--color-text);
    margin: 0;
    line-height: 1.2;
}

/* Product grid */
.kbp-products {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-4);
    margin-bottom: var(--space-6);
}

/* Individual product card */
.kbp-card {
    display: flex;
    flex-direction: column;
    border-radius: var(--radius-lg);
    border: 1.5px solid var(--color-border-light);
    overflow: hidden;
    text-decoration: none;
    color: var(--color-text);
    background: var(--color-white);
    transition:
        transform var(--transition-base),
        box-shadow var(--transition-base),
        border-color var(--transition-base);
}
.kbp-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-md);
    border-color: var(--color-light-blue);
}

.kbp-card__img-wrap {
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: var(--color-bg-section);
}
.kbp-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
}
.kbp-card:hover .kbp-card__img {
    transform: scale(1.06);
}

.kbp-card__info {
    padding: var(--space-4);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    flex: 1;
}
.kbp-card__name {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
    margin: 0;
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.kbp-card__stars .star-rating {
    font-size: 0.6rem;
}
.kbp-card__price {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
}
.kbp-card__price ins  { text-decoration: none; color: var(--color-pink-dark); }
.kbp-card__price del  { font-weight: 400; color: var(--color-text-light); font-size: 0.8em; }

.kbp-card__cta {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    margin-top: auto;
    font-size: var(--font-size-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-light-blue-2);
    transition: gap var(--transition-fast);
}
.kbp-card:hover .kbp-card__cta {
    gap: var(--space-3);
}

/* Footer dismiss link */
.kbp-footer {
    text-align: center;
}
.kbp-footer__dismiss {
    background: none;
    border: none;
    font-family: var(--font-family);
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    cursor: pointer;
    text-decoration: underline;
    transition: color var(--transition-fast);
    padding: 0;
}
.kbp-footer__dismiss:hover {
    color: var(--color-text-mid);
}

/* Responsive */
@media (max-width: 640px) {
    .kbp-modal   { padding: var(--space-6) var(--space-5); }
    .kbp-products { grid-template-columns: 1fr 1fr; }
    .kbp-header__title { font-size: var(--font-size-lg); }
}
@media (max-width: 420px) {
    .kbp-products { grid-template-columns: 1fr; }
}

/* ============================================================
   AJAX LIVE SEARCH  (inc/ajax-search.php)
   Dropdown results panel beneath the search input
   ============================================================ */

/* Wrapper — relative anchor for the absolute dropdown */
.ks-wrap {
    position: relative;
    flex: 1;
}

/* ---- Results panel ---------------------------------------- */
.ks-results {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    z-index: 10000;
    background: var(--color-white);
    border: 1.5px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    box-shadow: 0 16px 48px rgba(74, 55, 40, 0.14);
    overflow: hidden;
    animation: ks-fade-in 0.18s ease;
    max-height: 78vh;
    overflow-y: auto;
    /* Scrollbar styling */
    scrollbar-width: thin;
    scrollbar-color: var(--color-border) transparent;
}
.ks-results[hidden] { display: none; }
.ks-results::-webkit-scrollbar { width: 4px; }
.ks-results::-webkit-scrollbar-track { background: transparent; }
.ks-results::-webkit-scrollbar-thumb { background: var(--color-border); border-radius: 4px; }

@keyframes ks-fade-in {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ---- Section headers -------------------------------------- */
.ks-section { padding: var(--space-3) 0 var(--space-2); }
.ks-section + .ks-section { border-top: 1px solid var(--color-border-light); }
.ks-section--blog { background: var(--color-bg-section); }

.ks-section__label {
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-light);
    padding: 0 var(--space-4) var(--space-2);
    margin: 0;
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

/* ---- Base item (shared by products, posts, footer) -------- */
.ks-item {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-2) var(--space-4);
    text-decoration: none;
    color: var(--color-text);
    transition: background var(--transition-fast);
    cursor: pointer;
    outline: none;
}
.ks-item:hover,
.ks-item--focused,
.ks-item:focus {
    background: var(--color-light-blue-3);
    color: var(--color-text);
    text-decoration: none;
}

/* ---- Product row ------------------------------------------ */
.ks-product {
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
}
.ks-product__img-wrap {
    width: 52px;
    height: 52px;
    flex-shrink: 0;
    border-radius: var(--radius-md);
    overflow: hidden;
    background: var(--color-bg-section);
    border: 1px solid var(--color-border-light);
}
.ks-product__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.ks-product__body {
    flex: 1;
    min-width: 0;
}
.ks-product__meta {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    margin-bottom: 2px;
}
.ks-product__cat {
    font-size: 0.6rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-light);
    background: var(--color-border-light);
    padding: 1px 6px;
    border-radius: 99px;
}
.ks-badge {
    font-size: 0.6rem;
    font-weight: 700;
    text-transform: uppercase;
    padding: 1px 6px;
    border-radius: 99px;
}
.ks-badge--sale { background: var(--color-pink); color: var(--color-text); }
.ks-badge--oos  { background: var(--color-border); color: var(--color-text-light); }

.ks-product__name {
    margin: 0;
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text);
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.ks-product__price {
    font-size: var(--font-size-xs);
    font-weight: 700;
    color: var(--color-text-mid);
    margin-top: 2px;
}
.ks-product__price ins  { text-decoration: none; color: var(--color-pink-dark); }
.ks-product__price del  { font-weight: 400; color: var(--color-text-light); }
.ks-product__arrow {
    font-size: 0.75rem;
    color: var(--color-light-blue-2);
    flex-shrink: 0;
    opacity: 0;
    transform: translateX(-4px);
    transition: opacity var(--transition-fast), transform var(--transition-fast);
}
.ks-product:hover .ks-product__arrow,
.ks-product:focus .ks-product__arrow,
.ks-product--focused .ks-product__arrow {
    opacity: 1;
    transform: translateX(0);
}

/* ---- Blog post row ---------------------------------------- */
.ks-post {
    gap: var(--space-3);
    padding: var(--space-2) var(--space-4);
}
.ks-post__icon {
    font-size: 0.9rem;
    color: var(--color-light-blue-2);
    flex-shrink: 0;
    width: 20px;
    text-align: center;
}
.ks-post__title {
    flex: 1;
    font-size: var(--font-size-sm);
    font-weight: 500;
    color: var(--color-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.ks-post__date {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    flex-shrink: 0;
}

/* ---- Footer "See all results" ----------------------------- */
.ks-footer {
    border-top: 1px solid var(--color-border-light);
}
.ks-footer__link {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-4);
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-light-blue-2);
    background: var(--color-light-blue-3);
    transition: background var(--transition-fast), color var(--transition-fast);
}
.ks-footer__link:hover,
.ks-footer__link:focus {
    background: var(--color-light-blue);
    color: var(--color-text);
    text-decoration: none;
}
.ks-footer__link .fa-arrow-right {
    margin-left: auto;
    font-size: 0.8rem;
}

/* ---- Loading dots ----------------------------------------- */
.ks-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: var(--space-6) var(--space-4);
}
.ks-loading__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--color-light-blue-2);
    animation: ks-bounce 0.9s ease-in-out infinite;
}
.ks-loading__dot:nth-child(2) { animation-delay: 0.15s; }
.ks-loading__dot:nth-child(3) { animation-delay: 0.30s; }
@keyframes ks-bounce {
    0%, 80%, 100% { transform: scale(0.6); opacity: 0.4; }
    40%            { transform: scale(1);   opacity: 1; }
}

/* ---- Empty state ------------------------------------------ */
.ks-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--space-8) var(--space-4);
    gap: var(--space-3);
    text-align: center;
}
.ks-empty__icon { font-size: 2rem; line-height: 1; }
.ks-empty__msg {
    font-size: var(--font-size-sm);
    color: var(--color-text-light);
    margin: 0;
}

/* ---- Tablet search: expand ks-wrap inside the form -------- */
.header-search--tablet__form .ks-wrap { flex: 1; }
.header-search--tablet__form .ks-results { top: calc(100% + 12px); }

/* ---- Desktop slide-down: results sit below the input ------ */
.header-search__form .ks-wrap { flex: 1; }
.header-search__form .ks-results { top: calc(100% + 6px); }

/* ---- Responsive ------------------------------------------- */
@media (max-width: 600px) {
    .ks-results {
        /* On mobile (mobile menu doesn't use this, but just in case) */
        max-height: 60vh;
    }
    .ks-post__date { display: none; }
    .ks-product__img-wrap { width: 44px; height: 44px; }
}


@media (max-width: 380px) {
    .header-action {
        width: 30px;
        height: 30px;
		min-width: 30px;
        min-height: 30px;
    }
	.trust-badge {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

}

@media (max-width: 600px) {
    .product-layout {
        margin-bottom: var(--space-10);
        display: block;
    }
}

@media (max-width: 768px) {
    .woocommerce-cart-form table.shop_table {
        min-width: calc(100%) !important;
    }
}
@media (max-width: 768px) {
.header-inner {
    justify-content: space-evenly;
}
}

/* ── Kawaii Meet Banner ──────────────────────────────────────── */
.kawaii-meet-banner {
    position: relative;
    background: linear-gradient(160deg, #fff5f9 0%, #fdeeff 55%, #fff5f9 100%);
    padding: 20px 24px 16px;
    margin-bottom: 14px;
    overflow: hidden;
    animation: kawaii-banner-in 0.65s cubic-bezier(0.34, 1.56, 0.64, 1) both;
    box-shadow:
        0 4px 20px rgba(255, 107, 157, 0.13),
        inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

/* Floating interactive hearts */
.kawaii-meet-banner__deco {
    position: absolute;
    line-height: 1;
    cursor: pointer;
    user-select: none;
    animation: kawaii-float linear infinite;
    transition: color 0.2s ease, opacity 0.2s ease;
}

/* idle float */
@keyframes kawaii-float {
    0%,100% { transform: translateY(0)    rotate(0deg);  }
    30%      { transform: translateY(-7px) rotate(12deg); }
    70%      { transform: translateY(4px)  rotate(-8deg); }
}

/* pop burst on hover */
.kawaii-meet-banner__deco:hover {
    animation: kawaii-heart-pop 0.45s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
    color: #ff3d78 !important;
    opacity: 1 !important;
}
/* bounce back to float after pop */
.kawaii-meet-banner__deco:not(:hover) {
    animation: kawaii-float linear infinite;
}

@keyframes kawaii-heart-pop {
    0%   { transform: scale(1)    rotate(0deg);   }
    40%  { transform: scale(1.9)  rotate(-15deg); }
    65%  { transform: scale(0.85) rotate(8deg);   }
    100% { transform: scale(1.3)  rotate(-5deg);  }
}

/* Individual heart positions, sizes, and colours */
.kawaii-meet-banner__deco--1 {
    font-size: 18px; color: #ffb7c5; opacity: 0.55;
    top: 10px; left: 44%;
    animation-duration: 3.1s; animation-delay: 0s;
}
.kawaii-meet-banner__deco--2 {
    font-size: 13px; color: #d890ff; opacity: 0.5;
    top: 8px; right: 18%;
    animation-duration: 2.7s; animation-delay: 0.5s;
}
.kawaii-meet-banner__deco--3 {
    font-size: 22px; color: #ff9ec0; opacity: 0.45;
    top: 50%; right: 8%;
    transform: translateY(-50%);
    animation-duration: 3.8s; animation-delay: 1.0s;
}
.kawaii-meet-banner__deco--4 {
    font-size: 11px; color: #ffb7c5; opacity: 0.5;
    bottom: 10px; left: 42%;
    animation-duration: 2.5s; animation-delay: 0.3s;
}
.kawaii-meet-banner__deco--5 {
    font-size: 15px; color: #ff85ad; opacity: 0.5;
    bottom: 8px; right: 22%;
    animation-duration: 3.4s; animation-delay: 0.8s;
}
.kawaii-meet-banner__deco--6 {
    font-size: 10px; color: #d890ff; opacity: 0.45;
    top: 14px; right: 36%;
    animation-duration: 2.9s; animation-delay: 1.4s;
}

@keyframes kawaii-banner-in {
    0%   { opacity: 0; transform: translateY(-10px) scale(0.96); }
    100% { opacity: 1; transform: translateY(0)     scale(1);    }
}

/* Paragraph container */
.kawaii-meet-prefix {
    position: relative;
    z-index: 1;
    margin: 0;
    line-height: 1.35;
}

/* "Meet" label — small uppercase eyebrow */
.kawaii-meet-word {
    display: block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #b86fa8;
    margin-bottom: 3px;
    opacity: 0.85;
}

/* The star — product kawaii name */
.kawaii-name {
    display: inline-block;
    font-size: 30px;
    font-weight: 800;
    line-height: 1.05;
    background: linear-gradient(135deg, #ff5fa0 0%, #c34df0 45%, #ff5fa0 100%);
    background-size: 220% 220%;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    animation: kawaii-shimmer 5s ease-in-out infinite;
    cursor: default;
    transition: filter 0.2s ease;
}

.kawaii-name:hover {
    animation: kawaii-shimmer 5s ease-in-out infinite, kawaii-wiggle 0.55s ease-in-out;
    filter: drop-shadow(0 2px 6px rgba(195, 77, 240, 0.4));
}

@keyframes kawaii-shimmer {
    0%,100% { background-position: 0%   50%; }
    50%      { background-position: 100% 50%; }
}

@keyframes kawaii-wiggle {
    0%   { transform: rotate(0deg)   scale(1);    }
    18%  { transform: rotate(-3deg)  scale(1.06); }
    36%  { transform: rotate(3deg)   scale(1.06); }
    54%  { transform: rotate(-2deg)  scale(1.04); }
    72%  { transform: rotate(1.5deg) scale(1.02); }
    100% { transform: rotate(0deg)   scale(1);    }
}

/* Comma — keeps visual rhythm */
.kawaii-comma {
    font-size: 22px;
    font-weight: 700;
    color: #c07ab8;
    line-height: 1;
}

/* Phrase line */
.kawaii-phrase {
    display: block;
    font-size: 13px;
    font-style: italic;
    color: #9a5c8a;
    margin-top: 5px;
    opacity: 0.9;
}

/* Pulsing heart accent */
.kawaii-heart {
    display: inline-block;
    color: #ff6b9d;
    font-size: 13px;
    margin-left: 3px;
    animation: kawaii-heartbeat 1.5s ease-in-out infinite;
}

@keyframes kawaii-heartbeat {
    0%,100% { transform: scale(1);   }
    14%      { transform: scale(1.35); }
    28%      { transform: scale(1);   }
    42%      { transform: scale(1.2); }
    70%      { transform: scale(1);   }
}