/* ============================================================
   KAWAII MERCHANDISE – Main Stylesheet
   Brand: Pink · Purple · White
   Font: Montserrat
   ============================================================ */

/* ============================================================
   0. CSS CUSTOM PROPERTIES (Design Tokens)
   ============================================================ */
:root {
    /* Brand Colors – Pink & Purple Kawaii Palette */
    --color-white:        #FFFFFF;
    --color-light-blue:   #F9D0E8;
    --color-light-blue-2: #F0B0D4;
    --color-light-blue-3: #FDE8F3;
    --color-light-green:  #E8D0F5;
    --color-light-green-2:#D4B0EE;
    --color-light-green-3:#F3E8FC;
    --color-light-brown:  #D4A8D8;
    --color-light-brown-2:#C490CC;
    --color-light-brown-3:#F5E8F8;

    /* Kawaii Accents */
    --color-pink:         #FFB3D1;
    --color-pink-dark:    #FF80B3;
    --color-cream:        #FFF5FA;
    --color-lavender:     #DDB8F5;

    /* Text */
    --color-text:         #3D1A5E;
    --color-text-mid:     #6B4088;
    --color-text-light:   #9B70B8;
    --color-text-inv:     #FFFFFF;

    /* UI */
    --color-border:       #E8C8F0;
    --color-border-light: #F5E0FA;
    --color-bg:           #FFF8FD;
    --color-bg-section:   #FEF0FA;
    --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-7:  1.75rem;
    --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(61,26,94,0.06);
    --shadow-sm:  0 2px 8px rgba(61,26,94,0.08);
    --shadow-md:  0 4px 16px rgba(61,26,94,0.10);
    --shadow-lg:  0 8px 32px rgba(61,26,94,0.12);
    --shadow-xl:  0 16px 48px rgba(61,26,94,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:  170px;
    --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: clip; /* clip (not hidden) — preserves position:sticky in child elements */
}

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: clip; /* clip (not hidden) — preserves position:sticky in child elements */
    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 — pink-to-purple gradient, always white text */
.btn--primary {
    background: linear-gradient(135deg, #FF6EB4, #B06FD8);
    color: #ffffff !important;
    border-color: transparent;
    box-shadow: 0 4px 14px rgba(176,111,216,.35);
}
.btn--primary:hover {
    background: linear-gradient(135deg, #FF4DA6, #9650C8);
    border-color: transparent;
    box-shadow: 0 6px 20px rgba(176,111,216,.45);
    color: #ffffff !important;
    transform: translateY(-3px);
}

/* Outline Button — purple border, dark text; white text on hover */
.btn--outline {
    background: transparent;
    color: #3D1A5E !important;
    border-color: #B06FD8;
}
.btn--outline:hover {
    background: linear-gradient(135deg, #FF6EB4, #B06FD8);
    border-color: transparent;
    color: #ffffff !important;
    box-shadow: 0 4px 14px rgba(176,111,216,.35);
}

/* Secondary / Green → purple tint */
.btn--green {
    background: linear-gradient(135deg, #C490CC, #B06FD8);
    color: #ffffff !important;
    border-color: transparent;
}
.btn--green:hover {
    background: linear-gradient(135deg, #B06FD8, #9650C8);
    border-color: transparent;
    box-shadow: 0 4px 14px rgba(176,111,216,.4);
    color: #ffffff !important;
}

/* Dark Button */
.btn--dark {
    background: #3D1A5E;
    color: #ffffff !important;
    border-color: #3D1A5E;
}
.btn--dark:hover {
    background: #6B4088;
    border-color: #6B4088;
    color: #ffffff !important;
}

/* 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: 3px solid #FFB3D1;
    box-shadow: 0 4px 16px rgba(176,111,216,.12);
    transition: box-shadow var(--transition-base);
    overflow: visible;
}
.site-header.is-scrolled {
    box-shadow: 0 4px 20px rgba(176,111,216,.18);
}

.header-inner {
    display: flex;
    align-items: center;
    gap: var(--space-6);
    min-height: var(--header-height);
    padding-top: 10px;
    padding-bottom: 10px;
}

/* Logo – fixed 150×150 on all devices */
.site-header__logo {
    flex-shrink: 0;
}
.site-header__logo .custom-logo {
    display: block;
    width: 150px !important;
    height: 150px !important;
    max-height: 150px !important;
    object-fit: contain;
}
@media (max-width: 768px) {
    .site-header__logo .custom-logo {
        width: 150px !important;
        height: 150px !important;
        max-height: 150px !important;
    }
}
@media (max-width: 480px) {
    .site-header__logo .custom-logo {
        width: 150px !important;
        height: 150px !important;
        max-height: 150px !important;
    }
}
.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 { width: 150px !important; height: 150px !important; max-height: 150px !important; object-fit: contain; }
.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);
}

/* Parent items: link + chevron side-by-side, sub-menu below on full width */
.mobile-nav-menu .menu-item-has-children {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.mobile-nav-menu .menu-item-has-children > a {
    flex: 1;
    min-width: 0;
}

/* Chevron toggle button */
.mobile-submenu-toggle {
    flex-shrink: 0;
    width: 38px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 1.5px solid var(--color-border-light);
    border-radius: var(--radius-md);
    color: var(--color-text-mid);
    cursor: pointer;
    margin-right: var(--space-4);
    transition: background var(--transition-fast), border-color var(--transition-fast);
}
.mobile-submenu-toggle:hover {
    background: var(--color-light-blue-3);
    border-color: var(--color-light-blue-2);
    color: var(--color-light-blue-2);
}
.mobile-submenu-toggle i {
    font-size: 12px;
    transition: transform 0.22s ease;
    pointer-events: none;
}
.mobile-nav-menu .menu-item-has-children.is-open > .mobile-submenu-toggle i {
    transform: rotate(180deg);
}

.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);
}

/* Sub-menus: hidden by default, full width so they sit below the flex row */
.mobile-nav-menu .sub-menu {
    display: none;
    width: 100%;
    margin-left: var(--space-4);
    margin-top: var(--space-1);
    margin-bottom: 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;
}

/* ============================================================
   5b. HOME PROMO BAR  (.home-promo-bar)
   ============================================================ */
.home-promo-bar {
    background: linear-gradient(90deg, #ffd6e8 0%, #eedcff 35%, #d6eaff 70%, #ffd6e8 100%);
    border-bottom: 1.5px solid rgba(255, 143, 163, .25);
}
.home-promo-bar__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    max-width: 1400px;
    margin: 0 auto;
    padding: 13px 24px;
}
.home-promo-bar__left {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    min-width: 0;
}
.home-promo-bar__heading {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: clamp(15px, 1.8vw, 20px);
    font-weight: 800;
    color: #3a2040;
    margin: 0;
    white-space: nowrap;
    line-height: 1.2;
}
.home-promo-bar__icon { font-size: 1.1em; }
.home-promo-bar__kw {
    background: linear-gradient(135deg, #ff6b9d 0%, #c44da8 55%, #9b59b6 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.home-promo-bar__divider {
    color: rgba(180, 120, 160, .45);
    font-size: 1.2em;
    font-weight: 300;
    flex-shrink: 0;
}
.home-promo-bar__sub {
    font-size: clamp(12px, 1.2vw, 13.5px);
    color: #6a4060;
    margin: 0;
    line-height: 1.4;
    min-width: 0;
}
.home-promo-bar__btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 24px;
    background: linear-gradient(135deg, #ff6b9d 0%, #c44da8 100%);
    color: #fff;
    font-family: var(--font-family);
    font-size: 13.5px;
    font-weight: 700;
    border-radius: 6px;
    text-decoration: none;
    white-space: nowrap;
    flex-shrink: 0;
    transition: opacity .2s ease, transform .2s ease, box-shadow .2s ease;
    box-shadow: 0 3px 12px rgba(196, 77, 168, .28);
}
.home-promo-bar__btn:hover {
    opacity: 0.92;
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(196, 77, 168, .38);
    color: #fff;
}

/* Tablet — hide divider to save space */
@media (max-width: 860px) {
    .home-promo-bar__divider,
    .home-promo-bar__sub { display: none; }
}
/* Mobile — stack vertically */
@media (max-width: 540px) {
    .home-promo-bar__inner { flex-direction: column; gap: 10px; padding: 12px 16px; text-align: center; }
    .home-promo-bar__left  { justify-content: center; }
    .home-promo-bar__heading { font-size: 16px; white-space: normal; justify-content: center; text-align: center; }
    .home-promo-bar__btn   { width: 100%; justify-content: center; }
}

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

.hero-swiper { height: auto; min-height: 400px; }

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

.hero-slide--fallback {
    min-height: clamp(420px, 60vh, 720px);
    background: linear-gradient(135deg, #FFF0FA 0%, #F5E8FF 50%, #FFE8F5 100%);
}

.hero-slide__bg {
    position: absolute;
    inset: 0;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    z-index: 0;
}

.hero-slide__picture {
    position: relative;
    z-index: 0;
    width: 100%;
    line-height: 0;
}
.hero-slide__img {
    width: 100%;
    height: auto;
    object-fit: contain;
    object-position: center;
    display: block;
    max-height: 600px;
}

.hero-slide__overlay {
    display: none;
}

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

.hero-slide__content {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2;
    display: flex;
    align-items: center;
    background: linear-gradient(to right, rgba(255,240,250,0.82) 0%, rgba(255,240,250,0.5) 45%, transparent 100%);
    padding: var(--space-8) 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: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #B06FD8;
    margin-bottom: var(--space-3);
    padding: var(--space-2) var(--space-5);
    background: linear-gradient(135deg, #FFE8F5, #F0D8FF);
    border-radius: var(--radius-full);
    border: 1.5px solid #DDB8F5;
}
.section-header__title {
    margin-bottom: var(--space-4);
    color: #3D1A5E;
}
.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%;
    min-height: 44px;
    min-width: 44px;
}
.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-6); } }

.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, #FF6EB4 0%, #B06FD8 50%, #9650C8 100%);
    padding: var(--space-20) 0;
    position: relative;
    overflow: hidden;
}
.newsletter-section .newsletter-title { color: #fff; }
.newsletter-section .newsletter-desc { color: rgba(255,255,255,.85); }

.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: rgba(255,255,255,.8);
    opacity: 0.8;
    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: #DDB8F5;
    box-shadow: 0 0 0 3px rgba(221,184,245,.2);
}
.newsletter-form__privacy {
    font-size: var(--font-size-xs);
    color: rgba(255,255,255,.7);
    margin-bottom: 0;
}
.newsletter-form__privacy a {
    color: rgba(255,255,255,.9);
    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 { width: 150px !important; height: 150px !important; max-height: 150px !important; object-fit: contain; }
.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-mid);
    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 — stacked full-size images on desktop/tablet */
.product-gallery__stack {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.product-gallery__figure {
    margin: 0;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--color-border-light);
    aspect-ratio: 1 / 1;
}

.product-gallery__figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.4s ease;
}

.product-gallery__figure:hover img { transform: scale(1.02); }

/* Product details column is sticky while gallery stacks */
.product-details {
    position: sticky;
    top: var(--header-height);
    align-self: start;
    overflow-y: auto;
    scrollbar-width: none;
}
.product-details::-webkit-scrollbar { display: none; }

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

/* Gallery arrows + dots — hidden on desktop, shown only on mobile */
.gallery-arrow,
.gallery-dots { display: none; }

/* ── Mobile: single column, horizontal swipe gallery ── */
@media (max-width: 768px) {
    .product-layout {
        grid-template-columns: 1fr;
        gap: var(--space-5);
        margin-bottom: var(--space-10);
    }
    /* Gallery: horizontal swipe on mobile */
    .product-gallery__stack {
        flex-direction: row;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        scroll-behavior: smooth;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding-bottom: var(--space-1);
    }
    .product-gallery__stack::-webkit-scrollbar { display: none; }
    .product-gallery__figure {
        flex-shrink: 0;
        width: 100%;
        border-radius: var(--radius-md);
        scroll-snap-align: start;
    }

    /* Position context for arrows */
    .product-gallery { position: relative; }

    /* Prev / next arrows */
    .gallery-arrow {
        display: flex;
        position: absolute;
        top: 50%;
        transform: translateY(-60%); /* shift up slightly to stay within image, above dots */
        width: 38px;
        height: 38px;
        align-items: center;
        justify-content: center;
        background: rgba(255, 255, 255, 0.88);
        border: none;
        border-radius: 50%;
        box-shadow: 0 2px 10px rgba(0, 0, 0, 0.18);
        cursor: pointer;
        z-index: 10;
        color: var(--color-text);
        font-size: 13px;
        transition: opacity 0.2s ease, background 0.2s ease;
        -webkit-tap-highlight-color: transparent;
    }
    .gallery-arrow--prev { left: 10px; }
    .gallery-arrow--next { right: 10px; }
    .gallery-arrow.is-hidden { opacity: 0; pointer-events: none; }
    .gallery-arrow:active { background: #fff; transform: translateY(-60%) scale(0.94); }

    /* Dot indicators */
    .gallery-dots {
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 7px;
        padding: var(--space-2) 0 var(--space-1);
    }
    .gallery-dot {
        width: 7px;
        height: 7px;
        border-radius: 50%;
        background: var(--color-border);
        border: none;
        padding: 0;
        cursor: pointer;
        transition: background 0.25s ease, transform 0.25s ease;
        -webkit-tap-highlight-color: transparent;
    }
    .gallery-dot.is-active {
        background: var(--color-light-blue-2);
        transform: scale(1.5);
    }
    /* Remove sticky on mobile */
    .product-details {
        position: static;
        max-height: none;
        overflow-y: visible;
        gap: var(--space-4);
        padding: 0 var(--space-1);
    }
    /* Stack price row vertically on mobile */
    .pdp-price-row {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--space-2);
    }
    .pdp-price-row > * { padding-right: 0; }
    .pdp-price-row > *::after { display: none; }
    .product-details__title {
        font-size: var(--font-size-xl) !important;
    }
}

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

.product-details__meta {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    flex-wrap: nowrap;
    overflow: hidden;
}
.product-details__brand-link {
    font-size: var(--font-size-xs);
    font-weight: 700;
    color: var(--color-primary);
    text-decoration: none;
    white-space: nowrap;
    flex-shrink: 0;
}
.product-details__brand-link:hover {
    text-decoration: underline;
}
.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;
}

/* Price · Rating · Stock — horizontal row on desktop/tablet */
.pdp-price-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-2) var(--space-5);
    padding: var(--space-1) 0;
}

/* Pipe divider between items */
.pdp-price-row > * {
    position: relative;
    padding-right: var(--space-5);
}
.pdp-price-row > *::after {
    content: '';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: 1.2em;
    background: var(--color-border);
}
.pdp-price-row > *:last-child { padding-right: 0; }
.pdp-price-row > *:last-child::after { display: none; }

/* Rating */
.product-details__rating {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}
.product-rating-stars { color: var(--color-warning); font-size: 0.95rem; }
.product-rating-count {
    font-size: var(--font-size-xs);
    color: var(--color-text-mid);
    font-weight: 500;
    text-decoration: none;
    white-space: nowrap;
}
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);
    line-height: 1;
}
.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: row;
    align-items: stretch;
    gap: var(--space-3);
}

/* WooCommerce form.cart: qty input + button in a row, fills all available space */
.product-actions form.cart {
    flex: 1;
    display: flex;
    align-items: stretch;
    gap: var(--space-3);
    margin: 0;
}
.product-actions form.cart.variations_form { flex-direction: column; }

/* WC quantity wrapper */
.product-actions form.cart .quantity { flex-shrink: 0; }

/* WC qty number input — styled to match the theme */
.product-actions form.cart .quantity .qty {
    height: 52px;
    width: 72px;
    text-align: center;
    border: 2px solid var(--color-border);
    border-radius: var(--radius-full);
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
    font-family: var(--font-family);
    background: var(--color-white);
    padding: 0 var(--space-2);
    -moz-appearance: textfield;
}
.product-actions form.cart .quantity .qty::-webkit-inner-spin-button,
.product-actions form.cart .quantity .qty::-webkit-outer-spin-button { -webkit-appearance: none; }

/* Add to cart button — grows to fill, always the biggest element */
.product-actions form.cart .single_add_to_cart_button {
    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;
    cursor: pointer;
    white-space: nowrap;
    letter-spacing: 0.03em;
    transition:
        background var(--transition-base),
        border-color var(--transition-base),
        transform var(--transition-fast),
        box-shadow var(--transition-base);
}
.product-actions form.cart .single_add_to_cart_button:hover {
    background: var(--color-text-mid);
    border-color: var(--color-text-mid);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}
.product-actions form.cart .single_add_to_cart_button:active { transform: translateY(0); }

/* Wishlist — icon-only aligned to bottom of form (beside ADOPT ME) */
.product-actions .product-qty-cart--wishlist {
    display: flex;
    align-items: center;
    align-self: flex-end;
    flex-shrink: 0;
}
.product-actions .product-qty-cart--wishlist .product-share-text { display: none; }
.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: 170px; }
    .product-qty-cart { flex-wrap: wrap; }
    .btn--add-to-cart { min-width: 0; flex: 1; }
    .product-actions form.cart .single_add_to_cart_button { min-width: 0; }
    .product-actions .product-qty-cart--wishlist { flex-shrink: 0; }
}

@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-mid);
    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-6);
}
.qv-atc-wrap .variations_form { display: flex; flex-direction: column; gap: var(--space-4); }
.qv-atc-wrap form.cart { display: flex; flex-direction: row; align-items: stretch; gap: var(--space-3); }
.qv-atc-wrap .variations { width: 100%; border: none; margin: 0; border-spacing: 0; }
.qv-atc-wrap .variations tr {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: var(--space-3);
    margin-bottom: var(--space-3);
}
.qv-atc-wrap .variations tr:last-child { margin-bottom: 0; }
.qv-atc-wrap .variations .label {
    display: block;
    font-weight: 700;
    font-size: var(--font-size-sm);
    white-space: nowrap;
    flex-shrink: 0;
    min-width: 72px;
}
.qv-atc-wrap .variations .value { display: block; flex: 1; min-width: 0; }
.qv-atc-wrap .variations select {
    width: 100%;
    padding: 0.65rem var(--space-4);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-family: var(--font-family);
    background: var(--color-white);
    color: var(--color-text);
    cursor: pointer;
    transition: border-color var(--transition-fast);
    -webkit-appearance: auto;
    appearance: auto;
    box-sizing: border-box;
}
.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;
    height: 52px;
    background: var(--color-text) !important;
    border-color: var(--color-text) !important;
    color: var(--color-white) !important;
    font-size: var(--font-size-base) !important;
    padding: 0 var(--space-6) !important;
    border-radius: var(--radius-full) !important;
    font-weight: 700 !important;
    white-space: nowrap !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    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: 0;
}

/* PDP variations — both selectors on one row */
.product-details .variations_form table.variations,
.product-details .variations_form table.variations tbody {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-2) var(--space-4);
    width: 100%;
    border: none;
    border-spacing: 0;
}
.product-details .variations_form table.variations tr {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    flex: 0 0 auto;
}
.product-details .variations_form table.variations .label {
    padding: 0;
    font-weight: 700;
    font-size: var(--font-size-sm);
    color: var(--color-text);
    white-space: nowrap;
}
.product-details .variations_form table.variations .value {
    padding: 0;
    display: flex;
    align-items: center;
    gap: var(--space-2);
}
.product-details .variations_form table.variations select {
    padding: 0.45rem var(--space-4) 0.45rem var(--space-3);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-full);
    font-family: var(--font-family);
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text);
    background: #fff;
    cursor: pointer;
    appearance: auto;
}
.product-details .variations_form table.variations select:focus {
    outline: none;
    border-color: var(--color-light-blue-2);
}
.product-details .variations_form .reset_variations {
    font-size: var(--font-size-xs);
    color: var(--color-text-light);
    white-space: nowrap;
}
@media (max-width: 768px) {
    .product-details .variations_form table.variations,
    .product-details .variations_form table.variations tbody {
        flex-direction: column;
        align-items: flex-start;
    }
}

/* ============================================================
   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, 3fr) minmax(0, 2fr);
    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: contain;
    aspect-ratio: auto;
    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 (#9B70B8) 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);   }
}

/* ══════════════════════════════════════════════════════════════
   PDP CONVERSION SECTIONS
   ══════════════════════════════════════════════════════════════ */

/* ── Shared section header ───────────────────────────────────── */
.pdp-section-header { text-align: center; margin-bottom: 32px; }
.pdp-section-eyebrow {
    display: block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #d06fa8;
    margin-bottom: 6px;
}
.pdp-section-title {
    font-size: 26px;
    font-weight: 800;
    color: #3a2040;
    margin: 0;
}
@media (max-width: 600px) { .pdp-section-title { font-size: 20px; } }

/* ── Urgency bar ─────────────────────────────────────────────── */
.pdp-urgency {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.pdp-urgency__item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 13px;
    border-radius: 20px;
    font-size: 12.5px;
    font-weight: 600;
    line-height: 1.3;
}
.pdp-urgency__item--fire  { background: #fff3e0; color: #d84315; border: 1px solid rgba(216,67,21,.18); }
.pdp-urgency__item--warn  { background: #fff8e1; color: #e65100; border: 1px solid rgba(230,81,0,.18); }
.pdp-urgency__item--demand{ background: #e8f5e9; color: #2e7d32; border: 1px solid rgba(46,125,50,.2); }
.pdp-urgency__dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: #43a047;
    animation: pdp-dot-pulse 1.4s ease-in-out infinite;
    flex-shrink: 0;
}
@keyframes pdp-dot-pulse {
    0%,100% { transform: scale(1);   opacity: 1;   }
    50%      { transform: scale(1.5); opacity: 0.6; }
}

/* ── Below-fold strip (Perfect For + trust — sits below the 2-col grid) ── */
.pdp-below-fold {
    margin-bottom: var(--space-8);
}

/* ── Perfect For ─────────────────────────────────────────────── */
.pdp-perfect-for {
    background: linear-gradient(135deg, #fff5f9 0%, #f8e8ff 100%);
    border: 1px solid rgba(255,143,163,.22);
    border-radius: 14px;
    padding: 14px 16px;
    margin-bottom: 16px;
}
.pdp-perfect-for__title {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #b86fa8;
    margin: 0 0 10px;
}
.pdp-perfect-for__grid { display: flex; flex-wrap: wrap; gap: 7px; }
.pdp-perfect-for__tag {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 12px;
    background: #fff;
    border: 1px solid rgba(255,143,163,.28);
    border-radius: 20px;
    font-size: 12.5px;
    color: #7a4060;
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    cursor: default;
}
.pdp-perfect-for__tag:hover {
    transform: translateY(-2px);
    border-color: rgba(255,107,157,.5);
    box-shadow: 0 4px 12px rgba(255,107,157,.14);
}

/* ── Quick Benefits + Trust 2-col ────────────────────────────── */
.pdp-bottom-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-top: 4px;
}
.pdp-benefits {
    background: linear-gradient(160deg, #fff5f9 0%, #f5e8ff 100%);
    border: 1px solid rgba(255,143,163,.2);
    border-radius: 14px;
    padding: 14px 16px;
}
.pdp-benefits__title {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #b86fa8;
    margin: 0 0 11px;
}
.pdp-benefits__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.pdp-benefits__item { display: flex; align-items: flex-start; gap: 8px; font-size: 12.5px; color: #5a3a5a; line-height: 1.4; }
.pdp-benefits__icon {
    width: 22px; height: 22px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 10px; flex-shrink: 0; margin-top: 1px;
}
.pdp-benefits__icon--pink  { background: #ffe0ec; color: #c2185b; }
.pdp-benefits__icon--blue  { background: #e0eeff; color: #1565c0; }
.pdp-benefits__icon--green { background: #e0fae4; color: #2e7d32; }
.pdp-benefits__icon--lilac { background: #f0e0ff; color: #7b1fa2; }
.pdp-bottom-row .product-trust {
    background: #fff;
    border: 1px solid rgba(255,143,163,.15);
    border-radius: 14px;
    padding: 14px 16px;
}
@media (max-width: 520px) { .pdp-bottom-row { grid-template-columns: 1fr; } }

/* ── Size Guide (plushies) ───────────────────────────────────── */
.pdp-size-guide {
    background: linear-gradient(135deg, #fff5f9 0%, #f8e8ff 50%, #fff5f9 100%);
    border: 1px solid rgba(255,143,163,.22);
    border-radius: 20px;
    padding: 36px 24px 28px;
    margin-bottom: 32px;
    text-align: center;
}
.pdp-size-guide__header { margin-bottom: 28px; }
.pdp-size-guide__title  { font-size: 22px; font-weight: 800; color: #4a2c4a; margin: 4px 0 8px; }
.pdp-size-guide__intro  { font-size: 13.5px; color: #7a5a7a; margin: 0; }
.pdp-size-guide__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
}
.pdp-size-guide__item {
    background: #fff;
    border: 1px solid rgba(255,143,163,.2);
    border-radius: 16px;
    padding: 18px 10px 16px;
    transition: transform .2s ease, box-shadow .2s ease;
}
.pdp-size-guide__item:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(255,107,157,.15);
}
.pdp-size-guide__bear { display: flex; align-items: flex-end; justify-content: center; margin-bottom: 10px; line-height: 1; }
.pdp-size-guide__bear--s  { font-size: 26px; }
.pdp-size-guide__bear--m  { font-size: 38px; }
.pdp-size-guide__bear--l  { font-size: 52px; }
.pdp-size-guide__bear--xl { font-size: 66px; }
.pdp-size-guide__info { display: flex; flex-direction: column; gap: 3px; }
.pdp-size-guide__info strong { font-size: 14px; color: #4a2c4a; display: block; }
.pdp-size-guide__dim  { font-size: 11.5px; color: #9a6a9a; font-weight: 600; }
.pdp-size-guide__ref  { font-size: 11.5px; color: #7a5a7a; margin-top: 3px; }
.pdp-size-guide__note {
    margin: 20px 0 0;
    font-size: 12px; color: #9a6a9a;
    display: flex; align-items: center; justify-content: center; gap: 6px;
}
@media (max-width: 680px) { .pdp-size-guide__grid { grid-template-columns: repeat(2, 1fr); } }

/* ── Material & Safety ───────────────────────────────────────── */
.pdp-material {
    background: linear-gradient(160deg, #fff 0%, #fff5f9 100%);
    border: 1px solid rgba(255,143,163,.18);
    border-radius: 20px;
    padding: 36px 28px;
    margin-top: 40px;
}
.pdp-material__layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
    align-items: start;
}
.pdp-material__specs { display: flex; flex-direction: column; gap: 12px; }
.pdp-material__row {
    display: flex; align-items: flex-start; gap: 14px;
    background: #fff;
    border: 1px solid rgba(255,143,163,.14);
    border-radius: 12px;
    padding: 13px 15px;
    box-shadow: 0 2px 8px rgba(255,107,157,.05);
    transition: box-shadow .2s ease;
}
.pdp-material__row:hover { box-shadow: 0 4px 16px rgba(255,107,157,.12); }
.pdp-material__icon {
    width: 38px; height: 38px;
    background: linear-gradient(135deg, #ffe0ec, #f0d0ff);
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    color: #c44da8; font-size: 15px; flex-shrink: 0;
}
.pdp-material__content { display: flex; flex-direction: column; gap: 2px; }
.pdp-material__label {
    font-size: 10.5px; font-weight: 700;
    letter-spacing: 0.08em; text-transform: uppercase; color: #b86fa8;
}
.pdp-material__value { font-size: 13.5px; color: #4a2c4a; line-height: 1.4; }
.pdp-material__badges {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    align-content: start;
}
.pdp-safety-badge {
    background: #fff;
    border: 1px solid rgba(255,143,163,.2);
    border-radius: 14px;
    padding: 14px 10px;
    text-align: center;
    transition: transform .2s ease, box-shadow .2s ease;
}
.pdp-safety-badge:hover { transform: translateY(-3px); box-shadow: 0 6px 18px rgba(255,107,157,.14); }
.pdp-safety-badge__icon { display: block; font-size: 22px; margin-bottom: 5px; }
.pdp-safety-badge__text { font-size: 11.5px; font-weight: 600; color: #5a3a5a; }
@media (max-width: 680px) {
    .pdp-material__layout { grid-template-columns: 1fr; }
    .pdp-material__badges  { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 420px) { .pdp-material__badges { grid-template-columns: repeat(2, 1fr); } }

/* ── Why Choose Us comparison ────────────────────────────────── */
.pdp-comparison {
    background: #fff;
    border: 1px solid rgba(255,143,163,.18);
    border-radius: 20px;
    padding: 36px 28px;
    margin-top: 28px;
}
.pdp-comparison__table-wrap {
    overflow-x: auto;
    border-radius: 14px;
    border: 1px solid rgba(255,143,163,.2);
    box-shadow: 0 4px 20px rgba(255,107,157,.07);
}
.pdp-comparison__table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.pdp-comparison__table th,
.pdp-comparison__table td {
    padding: 13px 18px;
    text-align: center;
    border-bottom: 1px solid rgba(255,143,163,.1);
}
.pdp-comparison__table th:first-child,
.pdp-comparison__table td:first-child { text-align: left; color: #4a2c4a; font-weight: 500; }
.pdp-comparison__table thead tr {
    background: linear-gradient(135deg, #fff0f7 0%, #f5e8ff 100%);
}
.pdp-comparison__table thead th { font-size: 12.5px; font-weight: 700; color: #5a3a5a; }
.pdp-comparison__table tbody tr:last-child td { border-bottom: none; }
.pdp-comparison__table tbody tr:hover { background: #fff8fc; }
.pdp-comparison__us-col { background: rgba(255,215,235,.18); }
.pdp-comparison__us-label { display: flex; align-items: center; justify-content: center; gap: 5px; }
.pdp-comparison__check  { color: #2e7d32; font-size: 17px; font-weight: 700; }
.pdp-comparison__cross  { color: #c62828; font-size: 17px; font-weight: 700; }
.pdp-comparison__varies {
    font-size: 11.5px; font-weight: 600; color: #e65100;
    background: #fff3e0; padding: 2px 8px; border-radius: 10px;
}

/* ── FAQ ─────────────────────────────────────────────────────── */
.pdp-faq {
    background: linear-gradient(160deg, #fff5f9 0%, #fff 100%);
    border: 1px solid rgba(255,143,163,.18);
    border-radius: 20px;
    padding: 36px 28px;
    margin-top: 28px;
    margin-bottom: 40px;
}
.pdp-faq__list { max-width: 780px; margin: 0 auto; display: flex; flex-direction: column; gap: 10px; }
.pdp-faq__item {
    background: #fff;
    border: 1px solid rgba(255,143,163,.22);
    border-radius: 14px;
    overflow: hidden;
    transition: box-shadow .2s ease, border-color .2s ease;
}
.pdp-faq__item[open] {
    box-shadow: 0 4px 20px rgba(255,107,157,.12);
    border-color: rgba(255,107,157,.4);
}
.pdp-faq__question {
    display: flex; align-items: center; justify-content: space-between; gap: 12px;
    padding: 15px 20px;
    cursor: pointer;
    font-size: 14.5px; font-weight: 600; color: #3a2040;
    list-style: none; user-select: none;
    transition: background .15s ease, color .15s ease;
}
.pdp-faq__question::-webkit-details-marker,
.pdp-faq__question::marker { display: none; }
.pdp-faq__question:hover { background: #fff8fc; color: #c44da8; }
.pdp-faq__chevron { flex-shrink: 0; color: #d06fa8; font-size: 12px; transition: transform .3s ease; }
.pdp-faq__item[open] .pdp-faq__chevron { transform: rotate(180deg); }
.pdp-faq__answer { padding: 0 20px 16px; }
.pdp-faq__answer p { font-size: 13.5px; line-height: 1.65; color: #5a3a5a; margin: 0; }

@media (max-width: 600px) {
    .pdp-material,
    .pdp-comparison,
    .pdp-faq,
    .pdp-size-guide { padding: 24px 16px; border-radius: 14px; }
    .pdp-faq__question { font-size: 13.5px; padding: 13px 15px; }
    .pdp-faq__answer   { padding: 0 15px 14px; }
}

/* ============================================================
   KAWAII GUIDE PAGES  (.guide-page)
   ============================================================ */

/* ── Reading progress bar ── */
.guide-progress {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    z-index: 9999;
    background: transparent;
}
.guide-progress__fill {
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, var(--color-pink-dark), var(--color-light-blue-2));
    transition: width 0.1s linear;
}

/* ── Hero ── */
.guide-hero {
    position: relative;
    overflow: hidden;
    background: linear-gradient(145deg, var(--color-light-blue-3) 0%, #fff 45%, var(--color-pink) 100%);
    padding: calc(var(--space-10) + var(--space-6)) 0 var(--space-10);
}
.guide-hero__blobs {
    position: absolute;
    inset: 0;
    pointer-events: none;
}
.guide-hero__blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(60px);
    opacity: 0.35;
}
.guide-hero__blob--1 {
    width: 480px; height: 480px;
    background: var(--color-light-blue);
    top: -120px; left: -80px;
}
.guide-hero__blob--2 {
    width: 360px; height: 360px;
    background: var(--color-pink);
    bottom: -80px; right: -60px;
}
.guide-hero__blob--3 {
    width: 260px; height: 260px;
    background: var(--color-light-green-2);
    top: 40%; left: 50%;
    transform: translate(-50%, -50%);
}

/* ── Floating deco characters ── */
.guide-hero__deco,
.guide-shop-cta__deco {
    position: absolute;
    inset: 0;
    pointer-events: none;
}
.guide-deco {
    position: absolute;
    font-size: 1.4rem;
    color: var(--color-pink-dark);
    opacity: 0.5;
    animation: guide-float 5s ease-in-out infinite;
    user-select: none;
}
.guide-deco--1  { top: 12%; left: 6%;  animation-delay: 0s;    color: var(--color-pink-dark); }
.guide-deco--2  { top: 28%; left: 14%; animation-delay: 0.8s;  color: var(--color-light-blue-2); font-size: 1rem; }
.guide-deco--3  { top: 60%; left: 4%;  animation-delay: 1.6s;  color: #b5d8ee; }
.guide-deco--4  { top: 80%; left: 22%; animation-delay: 0.4s;  color: var(--color-light-green-2); font-size: 1.1rem; }
.guide-deco--5  { top: 10%; right: 8%; animation-delay: 1.2s;  color: #f5c842; }
.guide-deco--6  { top: 42%; right: 5%; animation-delay: 0.6s;  color: var(--color-pink-dark); font-size: 1rem; }
.guide-deco--7  { top: 72%; right: 14%;animation-delay: 2s;    color: var(--color-light-blue-2); font-size: 0.9rem; }
.guide-deco--8  { top: 18%; left: 8%;  animation-delay: 0.3s;  color: var(--color-pink-dark); }
.guide-deco--9  { top: 55%; left: 18%; animation-delay: 1s;    color: var(--color-light-blue-2); font-size: 1rem; }
.guide-deco--10 { top: 30%; right: 10%;animation-delay: 1.4s;  color: #b5d8ee; }
.guide-deco--11 { top: 70%; right: 20%;animation-delay: 0.7s;  color: var(--color-light-green-2); font-size: 1.1rem; }
@keyframes guide-float {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    33%       { transform: translateY(-10px) rotate(6deg); }
    66%       { transform: translateY(6px) rotate(-4deg); }
}

.guide-hero__inner {
    max-width: 760px;
    margin: 0 auto;
    text-align: center;
}
.guide-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: white;
    border: 1.5px solid var(--color-light-blue-2);
    color: var(--color-text-mid);
    font-size: var(--font-size-xs);
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 10px;
    border-radius: var(--radius-full);
    margin-bottom: var(--space-5);
}
.guide-hero__title {
    font-size: clamp(2rem, 5vw, 3.2rem);
    color: var(--color-text);
    line-height: 1.15;
    margin-bottom: var(--space-5);
}
.guide-hero__title-highlight {
    display: block;
    background: linear-gradient(135deg, var(--color-pink-dark), var(--color-light-blue-2));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.guide-hero__intro {
    font-size: var(--font-size-lg);
    color: var(--color-text-mid);
    line-height: 1.7;
    margin-bottom: var(--space-6);
}
.guide-hero__meta {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--space-3) var(--space-5);
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
}
.guide-hero__meta-item {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
}
.guide-hero__shop-link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: var(--color-pink-dark);
    color: white;
    font-weight: 700;
    font-size: var(--font-size-sm);
    padding: 10px;
    border-radius: var(--radius-full);
    text-decoration: none;
    transition: background var(--transition-fast), transform var(--transition-fast);
}
.guide-hero__shop-link:hover {
    background: var(--color-text);
    transform: translateY(-2px);
}

/* ── Stats strip ── */
.guide-stats {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--space-3);
    margin-top: 10px;
}
.guide-stat {
    background: white;
    border: 1.5px solid var(--color-light-blue-2);
    border-radius: var(--radius-xl);
    padding: 10px;
    text-align: center;
    min-width: 120px;
    box-shadow: var(--shadow-sm);
}
.guide-stat__num-wrap {
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 2px;
    font-size: 2rem;
    font-weight: 800;
    color: var(--color-text);
    line-height: 1;
}
.guide-stat__suffix {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--color-pink-dark);
}
.guide-stat__label {
    display: block;
    font-size: var(--font-size-xs);
    color: var(--color-text-mid);
    margin-top: var(--space-1);
    font-weight: 500;
}

/* ── Mobile TOC ── */
.guide-toc-mobile {
    background: white;
    border-bottom: 1.5px solid var(--color-light-blue-2);
    position: sticky;
    top: 0;
    z-index: 100;
}
.guide-toc-mobile .container {
    padding-top: var(--space-2);
    padding-bottom: var(--space-2);
}
.guide-toc-mobile__toggle {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    width: 100%;
    background: none;
    border: none;
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text);
    cursor: pointer;
    padding: var(--space-2) 0;
    text-align: left;
}
.guide-toc-mobile__chevron {
    margin-left: auto;
    transition: transform var(--transition-base);
}
.guide-toc-mobile__toggle[aria-expanded="true"] .guide-toc-mobile__chevron {
    transform: rotate(180deg);
}
.guide-toc-mobile__nav ol {
    list-style: none;
    margin: 0;
    padding: var(--space-2) 0 var(--space-3);
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}
.guide-toc-mobile__nav a {
    display: block;
    padding: var(--space-2) var(--space-3);
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    text-decoration: none;
    border-radius: var(--radius-lg);
    transition: background var(--transition-fast), color var(--transition-fast);
}
.guide-toc-mobile__nav a:hover {
    background: var(--color-light-blue-3);
    color: var(--color-text);
}

/* ── Two-column layout ── */
.guide-layout {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: var(--space-10);
    align-items: start;
    padding: var(--space-10) 0;
}

/* ── Sidebar / desktop TOC ── */
.guide-sidebar {
    position: sticky;
    top: calc(var(--space-6) + 50px);
}
.guide-toc {
    background: white;
    border: 1.5px solid var(--color-light-blue-2);
    border-radius: var(--radius-xl);
    padding: var(--space-5);
    box-shadow: var(--shadow-sm);
}
.guide-toc__heading {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-mid);
    margin-bottom: var(--space-4);
}
.guide-toc__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.guide-toc__link {
    display: block;
    padding: var(--space-2) var(--space-3);
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    text-decoration: none;
    border-radius: var(--radius-lg);
    border-left: 2.5px solid transparent;
    transition: all var(--transition-fast);
    line-height: 1.4;
}
.guide-toc__link:hover {
    background: var(--color-light-blue-3);
    color: var(--color-text);
    border-left-color: var(--color-light-blue-2);
}
.guide-toc__link.is-active {
    background: var(--color-light-blue-3);
    color: var(--color-text);
    border-left-color: var(--color-pink-dark);
    font-weight: 600;
}
.guide-toc__cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    margin-top: var(--space-5);
    background: var(--color-pink);
    color: var(--color-text);
    font-weight: 700;
    font-size: var(--font-size-sm);
    padding: calc(var(--space-3) + 10px) calc(var(--space-4) + 10px);
    border-radius: var(--radius-full);
    text-decoration: none;
    transition: background var(--transition-fast), transform var(--transition-fast);
}
.guide-toc__cta:hover {
    background: var(--color-pink-dark);
    color: white;
    transform: translateY(-2px);
}

/* ── Article content ── */
.guide-content {
    min-width: 0;
}
.guide-content p {
    font-size: var(--font-size-base);
    line-height: 1.8;
    color: var(--color-text-mid);
    margin-bottom: var(--space-5);
}
.guide-content p a {
    color: var(--color-text);
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-color: var(--color-pink-dark);
    transition: color 0.15s ease;
}
.guide-content p a:hover { color: var(--color-pink-dark); }
.guide-content h2 {
    font-size: clamp(1.35rem, 2.5vw, 1.75rem);
    color: var(--color-text);
    line-height: 1.25;
    margin-bottom: 0;
}
.guide-content h3 {
    font-size: 1.1rem;
    color: var(--color-text);
    margin-top: var(--space-6);
    margin-bottom: var(--space-3);
}

/* ── Section ── */
.guide-section {
    padding: var(--space-8) 0;
}
.guide-section__header {
    display: flex;
    align-items: flex-start;
    gap: var(--space-4);
    margin-bottom: var(--space-6);
}
.guide-section__num {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    background: var(--color-light-blue-3);
    border: 2px solid var(--color-light-blue-2);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-weight: 800;
    color: var(--color-text-mid);
    margin-top: 2px;
}

/* ── Divider ── */
.guide-divider {
    border: none;
    border-top: 1.5px dashed var(--color-light-blue-2);
    margin: 0;
}

/* ── Callout boxes ── */
.guide-callout {
    display: flex;
    gap: var(--space-4);
    align-items: flex-start;
    border-radius: var(--radius-xl);
    padding: var(--space-5) var(--space-6);
    margin: var(--space-6) 0;
}
.guide-callout--blue {
    background: var(--color-light-blue-3);
    border: 1.5px solid var(--color-light-blue-2);
}
.guide-callout--pink {
    background: #fff0f5;
    border: 1.5px solid var(--color-pink-dark);
}
.guide-callout__icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    background: white;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    box-shadow: var(--shadow-sm);
}
.guide-callout--blue .guide-callout__icon { color: var(--color-light-blue-2); }
.guide-callout--pink .guide-callout__icon { color: var(--color-pink-dark); }
.guide-callout__body strong {
    display: block;
    color: var(--color-text);
    margin-bottom: var(--space-2);
    font-size: var(--font-size-base);
}
.guide-callout__body p {
    margin-bottom: 0;
    font-size: var(--font-size-sm);
    line-height: 1.7;
}

/* ── Type grid (Section 1) ── */
.guide-type-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-5);
    margin: var(--space-7) 0;
}
.guide-type {
    background: white;
    border: 1.5px solid var(--color-light-blue-2);
    border-radius: var(--radius-xl);
    padding: var(--space-5);
    text-align: center;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}
.guide-type:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}
.guide-type__emoji {
    font-size: 2.2rem;
    display: block;
    margin-bottom: var(--space-3);
}
.guide-type h3 {
    font-size: var(--font-size-base);
    color: var(--color-text);
    margin: 0 0 var(--space-2);
}
.guide-type p {
    font-size: var(--font-size-sm);
    margin-bottom: 0;
}

/* ── Timeline ── */
.guide-timeline {
    position: relative;
    margin: var(--space-7) 0;
    padding-left: var(--space-6);
}
.guide-timeline::before {
    content: '';
    position: absolute;
    left: 20px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: linear-gradient(to bottom, var(--color-light-blue-2), var(--color-pink));
}
.guide-timeline__item {
    display: grid;
    grid-template-columns: 80px 1fr;
    gap: var(--space-5);
    align-items: start;
    margin-bottom: var(--space-6);
    position: relative;
}
.guide-timeline__item:last-child { margin-bottom: 0; }
.guide-timeline__marker {
    flex-shrink: 0;
    position: relative;
}
.guide-timeline__marker::before {
    content: '';
    position: absolute;
    left: -38px;
    top: 12px;
    width: 12px;
    height: 12px;
    background: white;
    border: 3px solid var(--color-pink-dark);
    border-radius: 50%;
}
.guide-timeline__marker span {
    display: inline-block;
    background: var(--color-pink);
    color: var(--color-text);
    font-size: var(--font-size-xs);
    font-weight: 800;
    padding: var(--space-1) var(--space-3);
    border-radius: var(--radius-full);
}
.guide-timeline__body p {
    margin-bottom: 0;
    padding-top: var(--space-1);
}

/* ── Aesthetic cards (Section 3) ── */
.guide-aesthetic-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-5);
    margin: var(--space-7) 0;
}
.guide-acard {
    background: white;
    border: 1.5px solid var(--color-light-blue-2);
    border-radius: var(--radius-xl);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}
.guide-acard:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}
.guide-acard__icon {
    width: 52px;
    height: 52px;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    margin-bottom: var(--space-4);
}
.guide-acard__icon--blue  { background: var(--color-light-blue-3);   color: var(--color-light-blue-2); }
.guide-acard__icon--pink  { background: #fff0f5;                     color: var(--color-pink-dark); }
.guide-acard__icon--green { background: var(--color-light-green-3);  color: var(--color-light-green-2); }
.guide-acard h3 {
    font-size: var(--font-size-base);
    color: var(--color-text);
    margin: 0 0 var(--space-3);
}
.guide-acard p {
    font-size: var(--font-size-sm);
    margin-bottom: var(--space-3);
}
.guide-acard p:last-child { margin-bottom: 0; }

/* ── Accordion steps (Section 4) ── */
.guide-steps {
    margin: var(--space-7) 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}
.guide-step {
    background: white;
    border: 1.5px solid var(--color-light-blue-2);
    border-radius: var(--radius-xl);
    overflow: hidden;
    transition: border-color var(--transition-base), box-shadow var(--transition-base);
}
.guide-step.is-open {
    border-color: var(--color-pink-dark);
    box-shadow: var(--shadow-sm);
}
.guide-step__toggle {
    width: 100%;
    display: flex;
    align-items: center;
    gap: var(--space-4);
    background: none;
    border: none;
    text-align: left;
    padding: var(--space-5) var(--space-6);
    cursor: pointer;
    transition: background var(--transition-fast);
}
.guide-step__toggle:hover {
    background: var(--color-light-blue-3);
}
.guide-step.is-open .guide-step__toggle {
    background: #fff0f5;
}
.guide-step__badge {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    background: var(--color-light-blue-3);
    border: 2px solid var(--color-light-blue-2);
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-sm);
    font-weight: 800;
    color: var(--color-text-mid);
}
.guide-step.is-open .guide-step__badge {
    background: var(--color-pink);
    border-color: var(--color-pink-dark);
    color: var(--color-text);
}
.guide-step__toggle h3 {
    flex: 1;
    margin: 0;
    font-size: var(--font-size-base);
    color: var(--color-text);
}
.guide-step__chevron {
    flex-shrink: 0;
    color: var(--color-text-mid);
    transition: transform var(--transition-base);
}
.guide-step.is-open .guide-step__chevron {
    transform: rotate(180deg);
    color: var(--color-pink-dark);
}
.guide-step__body {
    padding: 0 var(--space-6) var(--space-6) calc(var(--space-6) + 32px + var(--space-4));
}
.guide-step__body p:last-child { margin-bottom: 0; }

/* ── Occasion grid (Section 5) ── */
.guide-occasions {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-4);
    margin: var(--space-7) 0;
}
.guide-occasion {
    background: white;
    border: 1.5px solid var(--color-light-blue-2);
    border-radius: var(--radius-xl);
    padding: var(--space-5);
    text-align: center;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}
.guide-occasion:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
    border-color: var(--color-pink-dark);
}
.guide-occasion__emoji {
    font-size: 2rem;
    display: block;
    margin-bottom: var(--space-2);
}
.guide-occasion strong {
    display: block;
    color: var(--color-text);
    font-size: var(--font-size-base);
    margin-bottom: var(--space-2);
}
.guide-occasion p {
    font-size: var(--font-size-sm);
    margin-bottom: 0;
}

/* ── Shop CTA section ── */
.guide-shop-cta {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, var(--color-light-blue-3) 0%, #fff5f8 50%, var(--color-light-blue-3) 100%);
    padding: var(--space-16) 0;
    text-align: center;
    margin-top: var(--space-8);
}
.guide-shop-cta__blobs {
    position: absolute;
    inset: 0;
    pointer-events: none;
}
.guide-shop-cta__blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(70px);
    opacity: 0.4;
}
.guide-shop-cta__blob--1 {
    width: 500px; height: 500px;
    background: var(--color-pink);
    top: -150px; right: -100px;
}
.guide-shop-cta__blob--2 {
    width: 380px; height: 380px;
    background: var(--color-light-blue);
    bottom: -100px; left: -80px;
}
.guide-shop-cta__inner {
    position: relative;
    z-index: 1;
    max-width: 680px;
    margin: 0 auto;
}
.guide-shop-cta__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: white;
    border: 1.5px solid var(--color-pink-dark);
    color: var(--color-pink-dark);
    font-size: var(--font-size-xs);
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 10px;
    border-radius: var(--radius-full);
    margin-bottom: var(--space-5);
}
.guide-shop-cta__title {
    font-size: clamp(1.6rem, 3.5vw, 2.4rem);
    color: var(--color-text);
    line-height: 1.2;
    margin-bottom: var(--space-4);
}
.guide-shop-cta__desc {
    font-size: var(--font-size-lg);
    color: var(--color-text-mid);
    line-height: 1.7;
    margin-bottom: var(--space-7);
}
.guide-shop-cta__buttons {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--space-3);
    margin-bottom: var(--space-6);
}
.guide-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-weight: 700;
    font-size: var(--font-size-base);
    padding: 10px;
    border-radius: var(--radius-full);
    text-decoration: none;
    transition: all var(--transition-base);
}
.guide-cta-btn--primary {
    background: var(--color-pink-dark);
    color: white;
    border: 2px solid var(--color-pink-dark);
    box-shadow: var(--shadow-sm);
}
.guide-cta-btn--primary:hover {
    background: var(--color-text);
    border-color: var(--color-text);
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
    color: white;
}
.guide-cta-btn--outline {
    background: white;
    color: var(--color-text);
    border: 2px solid var(--color-light-blue-2);
}
.guide-cta-btn--outline:hover {
    background: var(--color-light-blue-3);
    border-color: var(--color-light-blue-2);
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
}
.guide-shop-cta__trust {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--space-3) var(--space-6);
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
}
.guide-shop-cta__trust span {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
}

/* ── Scroll-reveal ── */
.gfade {
    opacity: 0;
    transform: translateY(22px);
    transition: opacity 0.55s ease, transform 0.55s ease;
}
.gfade--in {
    opacity: 1;
    transform: translateY(0);
}
.gfade--d1 { transition-delay: 0.08s; }
.gfade--d2 { transition-delay: 0.16s; }
.gfade--d3 { transition-delay: 0.24s; }
.gfade--d4 { transition-delay: 0.32s; }
.gfade--d5 { transition-delay: 0.40s; }
.gfade--d6 { transition-delay: 0.48s; }

/* ── Guide page responsive ── */
@media (max-width: 1024px) {
    .guide-layout {
        grid-template-columns: 220px 1fr;
        gap: var(--space-8);
    }
    .guide-aesthetic-grid {
        grid-template-columns: 1fr 1fr;
    }
}
@media (max-width: 860px) {
    .guide-layout {
        grid-template-columns: 1fr;
    }
    .guide-sidebar {
        display: none;
    }
    .guide-toc-mobile {
        display: block;
    }
    .guide-type-grid {
        grid-template-columns: 1fr 1fr;
    }
    .guide-aesthetic-grid {
        grid-template-columns: 1fr;
    }
    .guide-occasions {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media (max-width: 600px) {
    .guide-hero {
        padding: calc(var(--space-9) + var(--space-4)) 0 var(--space-8);
    }
    .guide-stats {
        gap: var(--space-2);
    }
    .guide-stat {
        padding: var(--space-3) var(--space-4);
        min-width: 100px;
    }
    .guide-stat__num-wrap {
        font-size: 1.6rem;
    }
    .guide-type-grid,
    .guide-occasions {
        grid-template-columns: 1fr;
    }
    .guide-section__header {
        flex-direction: column;
        gap: var(--space-3);
    }
    .guide-callout {
        flex-direction: column;
        gap: var(--space-3);
    }
    .guide-step__body {
        padding-left: var(--space-6);
    }
    .guide-shop-cta {
        padding: var(--space-10) 0;
    }
}

/* ── Hide mobile TOC on desktop ── */
@media (min-width: 861px) {
    .guide-toc-mobile {
        display: none;
    }
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
    .guide-deco,
    .gfade {
        animation: none;
        opacity: 1;
        transform: none;
        transition: none;
    }
    .guide-progress__fill {
        transition: none;
    }
}

/* ── Product Showcase (guide pages) ── */
.guide-showcase {
    background: var(--color-bg-section);
    padding: var(--space-10) 0;
    border-top: 1.5px solid var(--color-light-blue-2);
    border-bottom: 1.5px solid var(--color-light-blue-2);
}
.guide-showcase__header {
    text-align: center;
    margin-bottom: var(--space-8);
}
.guide-showcase__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: white;
    border: 1.5px solid var(--color-light-blue-2);
    color: var(--color-text-mid);
    font-size: var(--font-size-xs);
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 10px;
    border-radius: var(--radius-full);
    margin-bottom: var(--space-4);
}
.guide-showcase__title {
    font-size: clamp(1.4rem, 3vw, 2rem);
    color: var(--color-text);
    margin: 0;
}

/* Grid: 4 col desktop → 3 tablet → 2 mobile */
.guide-showcase__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-5);
}

/* Product card */
.guide-pcard {
    display: flex;
    flex-direction: column;
    background: white;
    border: 1.5px solid var(--color-light-blue-2);
    border-radius: var(--radius-xl);
    overflow: hidden;
    text-decoration: none;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}
.guide-pcard:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
    border-color: var(--color-pink-dark);
}
.guide-pcard__img {
    position: relative;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: var(--color-light-blue-3);
}
.guide-pcard__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.45s ease;
}
.guide-pcard:hover .guide-pcard__img img {
    transform: scale(1.07);
}
.guide-pcard__hover {
    position: absolute;
    inset: 0;
    background: rgba(240, 160, 188, 0.82);
    color: white;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    font-size: var(--font-size-sm);
    font-weight: 700;
    opacity: 0;
    transition: opacity var(--transition-base);
    backdrop-filter: blur(2px);
}
.guide-pcard__hover i {
    font-size: 1.4rem;
}
.guide-pcard:hover .guide-pcard__hover {
    opacity: 1;
}
.guide-pcard__body {
    padding: var(--space-4);
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    flex: 1;
}
.guide-pcard__name {
    font-size: var(--font-size-sm);
    color: var(--color-text);
    margin: 0;
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.guide-pcard__price {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-pink-dark);
    margin-top: auto;
}
.guide-showcase__cta {
    text-align: center;
    margin-top: var(--space-8);
}

/* Responsive grid */
@media (max-width: 1024px) {
    .guide-showcase__grid {
        grid-template-columns: repeat(3, 1fr);
    }
    /* Hide 4th card on tablet if only 4 shown */
    .guide-showcase__grid .guide-pcard:nth-child(4) {
        display: none;
    }
}
@media (max-width: 680px) {
    .guide-showcase {
        padding: var(--space-8) 0;
    }
    .guide-showcase__grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-3);
    }
    /* Show all cards on mobile — scroll hint via slight overflow */
    .guide-showcase__grid .guide-pcard:nth-child(4) {
        display: flex;
    }
    .guide-pcard__hover {
        display: none; /* touch devices — no hover */
    }
}

/* ============================================================
   GIFT GUIDE HUB  (.guide-page--gift-hub)
   ============================================================ */

/* ── Hub intro section ── */
.gift-hub-section {
    background: var(--color-bg-section);
    padding: var(--space-10) 0;
    border-top: 1.5px solid var(--color-light-blue-2);
    border-bottom: 1.5px solid var(--color-light-blue-2);
}
.gift-hub-intro {
    max-width: 640px;
    margin: var(--space-3) auto 0;
    font-size: var(--font-size-base);
    color: var(--color-text-mid);
    line-height: 1.7;
    text-align: center;
}

/* ── Guide cards grid ── */
.gift-hub-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-5);
    margin-top: var(--space-8);
}

/* ── Individual guide card ── */
.gift-hub-card {
    display: flex;
    flex-direction: column;
    background: white;
    border: 1.5px solid var(--color-light-blue-2);
    border-radius: var(--radius-xl);
    overflow: hidden;
    text-decoration: none;
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}
.gift-hub-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
}

/* Icon wrap area */
.gift-hub-card__icon-wrap {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-8) var(--space-5) var(--space-6);
}
.gift-hub-card__icon {
    width: 72px;
    height: 72px;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
    box-shadow: var(--shadow-sm);
}
.gift-hub-card__badge {
    position: absolute;
    top: var(--space-4);
    right: var(--space-4);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 4px 10px;
    border-radius: var(--radius-full);
    border: 1.5px solid transparent;
}

/* Color variants */
.gift-hub-card--blue  { border-color: var(--color-light-blue-2); }
.gift-hub-card--blue:hover { border-color: var(--color-light-blue-2); }
.gift-hub-card--blue  .gift-hub-card__icon-wrap { background: var(--color-light-blue-3); }
.gift-hub-card--blue  .gift-hub-card__icon  { background: white; color: var(--color-light-blue-2); border: 2px solid var(--color-light-blue-2); }
.gift-hub-card--blue  .gift-hub-card__badge { background: white; color: var(--color-light-blue-2); border-color: var(--color-light-blue-2); }
.gift-hub-card--blue  .gift-hub-card__cta   { color: var(--color-light-blue-2); }

.gift-hub-card--brown { border-color: var(--color-light-brown-2); }
.gift-hub-card--brown:hover { border-color: var(--color-light-brown-2); }
.gift-hub-card--brown .gift-hub-card__icon-wrap { background: var(--color-light-brown-3); }
.gift-hub-card--brown .gift-hub-card__icon  { background: white; color: var(--color-light-brown-2); border: 2px solid var(--color-light-brown-2); }
.gift-hub-card--brown .gift-hub-card__badge { background: white; color: var(--color-light-brown-2); border-color: var(--color-light-brown-2); }
.gift-hub-card--brown .gift-hub-card__cta   { color: var(--color-light-brown-2); }

.gift-hub-card--pink  { border-color: var(--color-pink-dark); }
.gift-hub-card--pink:hover { border-color: var(--color-pink-dark); }
.gift-hub-card--pink  .gift-hub-card__icon-wrap { background: #fff0f5; }
.gift-hub-card--pink  .gift-hub-card__icon  { background: white; color: var(--color-pink-dark); border: 2px solid var(--color-pink-dark); }
.gift-hub-card--pink  .gift-hub-card__badge { background: white; color: var(--color-pink-dark); border-color: var(--color-pink-dark); }
.gift-hub-card--pink  .gift-hub-card__cta   { color: var(--color-pink-dark); }

.gift-hub-card--lavender { border-color: #c9a8e8; }
.gift-hub-card--lavender:hover { border-color: #c9a8e8; }
.gift-hub-card--lavender .gift-hub-card__icon-wrap { background: #f5f0fb; }
.gift-hub-card--lavender .gift-hub-card__icon  { background: white; color: #9b72cc; border: 2px solid #c9a8e8; }
.gift-hub-card--lavender .gift-hub-card__badge { background: white; color: #9b72cc; border-color: #c9a8e8; }
.gift-hub-card--lavender .gift-hub-card__cta   { color: #9b72cc; }

.gift-hub-card--green { border-color: var(--color-light-green-2); }
.gift-hub-card--green:hover { border-color: var(--color-light-green-2); }
.gift-hub-card--green .gift-hub-card__icon-wrap { background: var(--color-light-green-3); }
.gift-hub-card--green .gift-hub-card__icon  { background: white; color: var(--color-light-green-2); border: 2px solid var(--color-light-green-2); }
.gift-hub-card--green .gift-hub-card__badge { background: white; color: var(--color-light-green-2); border-color: var(--color-light-green-2); }
.gift-hub-card--green .gift-hub-card__cta   { color: var(--color-light-green-2); }

/* Card body */
.gift-hub-card__body {
    padding: var(--space-5) var(--space-6) var(--space-6);
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: var(--space-3);
}
.gift-hub-card__title {
    font-size: 1.1rem;
    color: var(--color-text);
    margin: 0;
    line-height: 1.25;
}
.gift-hub-card__desc {
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    line-height: 1.65;
    margin: 0;
    flex: 1;
}
.gift-hub-card__meta {
    display: flex;
    gap: var(--space-4);
    font-size: 11px;
    color: var(--color-text-mid);
    font-weight: 500;
    padding-top: var(--space-2);
    border-top: 1px solid var(--color-light-blue-2);
}
.gift-hub-card__meta span {
    display: inline-flex;
    align-items: center;
    gap: 5px;
}
.gift-hub-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);
}
.gift-hub-card:hover .gift-hub-card__cta {
    gap: var(--space-3);
}

/* ── Sidebar category quick links ── */
.gift-sidebar-links__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.gift-sidebar-links__link {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-3);
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    text-decoration: none;
    border-radius: var(--radius-lg);
    border-left: 2.5px solid transparent;
    transition: all var(--transition-fast);
    font-weight: 500;
}
.gift-sidebar-links__link:hover { background: var(--color-light-blue-3); color: var(--color-text); }
.gift-sidebar-links__link--blue:hover    { border-left-color: var(--color-light-blue-2); }
.gift-sidebar-links__link--brown:hover   { border-left-color: var(--color-light-brown-2); }
.gift-sidebar-links__link--pink:hover    { border-left-color: var(--color-pink-dark); }
.gift-sidebar-links__link--lavender:hover{ border-left-color: #c9a8e8; }
.gift-sidebar-links__link--green:hover   { border-left-color: var(--color-light-green-2); }

/* ── How-to-choose grid ── */
.gift-chooser-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-5);
    margin: var(--space-7) 0;
}
.gift-chooser-card {
    background: white;
    border: 1.5px solid var(--color-light-blue-2);
    border-radius: var(--radius-xl);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}
.gift-chooser-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}
.gift-chooser-card__emoji {
    font-size: 2rem;
    display: block;
    margin-bottom: var(--space-3);
}
.gift-chooser-card__type {
    font-size: 1rem;
    color: var(--color-text);
    margin: 0 0 var(--space-3);
}
.gift-chooser-card__rec {
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    line-height: 1.65;
    margin: 0 0 var(--space-4);
}
.gift-chooser-card__links {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}
.gift-chooser-card__link {
    display: inline-flex;
    align-items: center;
    font-size: var(--font-size-xs);
    font-weight: 700;
    color: var(--color-pink-dark);
    text-decoration: none;
    padding: var(--space-1) var(--space-3);
    border: 1.5px solid var(--color-pink-dark);
    border-radius: var(--radius-full);
    transition: background var(--transition-fast), color var(--transition-fast);
}
.gift-chooser-card__link:hover {
    background: var(--color-pink-dark);
    color: white;
}

/* ── Hub responsive ── */
@media (max-width: 1024px) {
    .gift-hub-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    /* 5th card full-width on tablet */
    .gift-hub-grid .gift-hub-card:nth-child(5) {
        grid-column: 1 / -1;
        flex-direction: row;
    }
    .gift-hub-grid .gift-hub-card:nth-child(5) .gift-hub-card__icon-wrap {
        min-width: 180px;
    }
}
@media (max-width: 680px) {
    .gift-hub-grid {
        grid-template-columns: 1fr;
    }
    .gift-hub-grid .gift-hub-card:nth-child(5) {
        grid-column: auto;
        flex-direction: column;
    }
    .gift-hub-grid .gift-hub-card:nth-child(5) .gift-hub-card__icon-wrap {
        min-width: unset;
    }
    .gift-chooser-grid {
        grid-template-columns: 1fr;
    }
}

/* ============================================================
   MOTHER'S DAY — KAWAII BEDDING SECTION
   ============================================================ */
.mday-bedding {
    position: relative;
    overflow: hidden;
    padding: 80px 0 72px;
    background: linear-gradient(145deg, #fdf0f5 0%, #fce8f3 45%, #f8eef9 100%);
}

.mday-bedding__blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(64px);
    opacity: 0.42;
    pointer-events: none;
}
.mday-bedding__blob--1 {
    width: 500px; height: 500px;
    background: var(--color-pink, #F9C8D8);
    top: -170px; left: -130px;
}
.mday-bedding__blob--2 {
    width: 380px; height: 380px;
    background: var(--color-lavender, #E8D5F5);
    bottom: -110px; right: -90px;
}

.mday-bedding__deco {
    position: absolute;
    font-size: 2.1rem;
    pointer-events: none;
    animation: mday-float 5s ease-in-out infinite;
    opacity: 0.7;
    user-select: none;
}
.mday-bedding__deco--1 { top: 11%; left: 5%;   animation-delay: 0s;    font-size: 2.4rem; }
.mday-bedding__deco--2 { top: 16%; right: 6%;  animation-delay: 1.6s; }
.mday-bedding__deco--3 { bottom: 15%; left: 20%; animation-delay: 3s;   font-size: 1.8rem; }

@keyframes mday-float {
    0%, 100% { transform: translateY(0) rotate(-5deg); }
    50%       { transform: translateY(-12px) rotate(5deg); }
}

/* ── Header ─────────────────────────────────────────── */
.mday-bedding__header {
    text-align: center;
    margin-bottom: 1.75rem;
    position: relative;
    z-index: 1;
}

.mday-bedding__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2, 0.5rem);
    background: var(--color-pink, #F9C8D8);
    color: var(--color-text, #3D1A5E);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    padding: var(--space-3, 0.75rem) var(--space-7, 1.75rem);
    border-radius: var(--radius-full, 9999px);
    margin-bottom: 1.25rem;
}

.mday-bedding__eyebrow i {
    color: #d46fa0;
}

.mday-bedding__title {
    font-size: clamp(1.8rem, 4.2vw, 2.8rem);
    font-weight: 800;
    color: var(--color-text, #3D1A5E);
    line-height: 1.2;
    margin: 0 0 1rem;
}

.mday-bedding__subtitle {
    font-size: 1.05rem;
    color: var(--color-text-mid, #6B4088);
    max-width: 580px;
    margin: 0 auto;
    line-height: 1.7;
}

/* ── Feature badges ──────────────────────────────────── */
.mday-bedding__badges {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-bottom: 2.5rem;
    position: relative;
    z-index: 1;
}

.mday-bedding__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: #fff;
    color: var(--color-text, #3D1A5E);
    font-size: 0.82rem;
    font-weight: 600;
    padding: 0.5rem 1.1rem;
    border-radius: var(--radius-full, 9999px);
    box-shadow: var(--shadow-sm, 0 1px 6px rgba(0,0,0,0.07));
}

.mday-bedding__badge i {
    color: #d46fa0;
}

/* ── Product grid ────────────────────────────────────── */
.mday-bedding__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.25rem;
    margin-bottom: 2.5rem;
    position: relative;
    z-index: 1;
}

/* ── Product card ────────────────────────────────────── */
.mday-pcard {
    display: flex;
    flex-direction: column;
    background: #fff;
    border-radius: var(--radius-lg, 20px);
    overflow: hidden;
    box-shadow: var(--shadow-sm, 0 2px 8px rgba(0,0,0,0.07));
    text-decoration: none;
    color: inherit;
    transition: transform var(--transition-base, 250ms ease),
                box-shadow var(--transition-base, 250ms ease);
}

.mday-pcard:hover {
    transform: translateY(-6px);
    box-shadow: 0 8px 24px rgba(212, 111, 160, 0.18);
}

.mday-pcard__img-wrap {
    position: relative;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: var(--color-bg-section, #FEF0FA);
}

.mday-pcard__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 420ms ease;
}

.mday-pcard:hover .mday-pcard__img {
    transform: scale(1.07);
}

.mday-pcard__badge {
    position: absolute;
    top: 0.75rem;
    left: 0.75rem;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    background: var(--color-pink, #F9C8D8);
    color: var(--color-text, #3D1A5E);
    font-size: 0.68rem;
    font-weight: 700;
    padding: 0.3rem 0.7rem;
    border-radius: var(--radius-full, 9999px);
    letter-spacing: 0.03em;
}

.mday-pcard__info {
    padding: 1rem;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.mday-pcard__name {
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--color-text, #3D1A5E);
    margin: 0;
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mday-pcard__price {
    font-size: 1rem;
    font-weight: 800;
    color: #a3336b; /* was #d46fa0 — darkened for WCAG AA contrast (6.4:1 on white) */
    margin-top: auto;
}

.mday-pcard__price del,
.mday-pcard__price .woocommerce-Price-amount + .woocommerce-Price-amount {
    color: var(--color-text-mid, #6B4088);
    font-weight: 400;
    font-size: 0.82rem;
    margin-right: 0.3rem;
}

/* ── Footer CTA ──────────────────────────────────────── */
.mday-bedding__footer {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.25rem;
    position: relative;
    z-index: 1;
}

.mday-bedding__footer-text {
    font-size: 0.88rem;
    color: var(--color-text-mid, #6B4088);
    margin: 0;
    text-align: center;
    background: rgba(255,255,255,0.75);
    padding: 0.5rem 1.25rem;
    border-radius: var(--radius-full, 9999px);
}

.mday-bedding__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    background: #a83370;
    color: #fff;
    font-size: 0.95rem;
    font-weight: 700;
    padding: calc(0.75rem + 10px) calc(1.6rem + 10px);
    border-radius: var(--radius-full, 9999px);
    text-decoration: none;
    transition: background var(--transition-fast, 150ms ease),
                transform var(--transition-fast, 150ms ease),
                box-shadow var(--transition-fast, 150ms ease);
    box-shadow: 0 4px 16px rgba(168, 51, 112, 0.38);
}

.mday-bedding__cta:hover {
    background: #8f2960;
    transform: translateY(-2px);
    box-shadow: 0 7px 22px rgba(168, 51, 112, 0.48);
}

/* ── No products fallback ────────────────────────────── */
.mday-bedding__no-products {
    text-align: center;
    color: var(--color-text-mid, #6B4088);
    padding: 2rem;
    font-size: 0.95rem;
}

/* ── Responsive ──────────────────────────────────────── */
@media (max-width: 1024px) {
    .mday-bedding__grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1rem;
    }
}

@media (max-width: 680px) {
    .mday-bedding {
        padding: 56px 0 52px;
    }
    .mday-bedding__deco--1,
    .mday-bedding__deco--2,
    .mday-bedding__deco--3 {
        font-size: 1.5rem;
    }
    .mday-bedding__grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 0.75rem;
    }
    .mday-pcard__info {
        padding: 0.75rem;
    }
    .mday-pcard__name {
        font-size: 0.8rem;
    }
    .mday-pcard__price {
        font-size: 0.9rem;
    }
    .mday-bedding__badges {
        gap: 0.5rem;
    }
    .mday-bedding__badge {
        font-size: 0.75rem;
        padding: 0.4rem 0.85rem;
    }
}

@media (max-width: 380px) {
    .mday-bedding__grid {
        grid-template-columns: 1fr;
    }
}

@media (prefers-reduced-motion: reduce) {
    .mday-bedding__deco {
        animation: none;
    }
}

/* ============================================================
   PRE-FOOTER: HOW PLUSHIES ARE MADE
   ============================================================ */
.plushie-process {
    background: var(--color-bg-section, #FEF0FA);
    padding: 72px 0 68px;
}

.plushie-process__header {
    text-align: center;
    margin-bottom: 3rem;
}

.plushie-process__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2, 0.5rem);
    background: var(--color-light-brown-3, #F5E8F8);
    color: var(--color-text, #3D1A5E);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    padding: var(--space-3, 0.75rem) var(--space-7, 1.75rem);
    border-radius: var(--radius-full, 9999px);
    margin-bottom: 1.25rem;
}

.plushie-process__eyebrow i {
    color: var(--color-light-brown-2, #C490CC);
}

.plushie-process__title {
    font-size: clamp(1.6rem, 3.5vw, 2.4rem);
    font-weight: 800;
    color: var(--color-text, #3D1A5E);
    margin: 0 0 0.75rem;
    line-height: 1.2;
}

.plushie-process__subtitle {
    font-size: 1rem;
    color: var(--color-text-mid, #6B4088);
    max-width: 600px;
    margin: 0 auto;
    line-height: 1.7;
}

/* ── Steps grid ──────────────────────────────────────── */
.plushie-process__steps {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    position: relative;
}

/* Dashed connector line between step cards */
.plushie-process__steps::before {
    content: '';
    position: absolute;
    top: 21px;
    left: calc(12.5% + 24px);
    right: calc(12.5% + 24px);
    height: 2px;
    background: repeating-linear-gradient(
        90deg,
        var(--color-pink-dark, #F0A0BC) 0,
        var(--color-pink-dark, #F0A0BC) 8px,
        transparent 8px,
        transparent 18px
    );
    z-index: 0;
    pointer-events: none;
}

.plushie-process__step {
    display: flex;
    flex-direction: column;
    gap: 0;
    position: relative;
    z-index: 1;
}

/* Step number badge */
.plushie-process__step-num {
    width: 42px;
    height: 42px;
    background: var(--color-pink, #F9C8D8);
    color: var(--color-text, #3D1A5E);
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 0.875rem;
    border: 3px solid var(--color-bg-section, #FEF0FA);
    box-shadow: 0 2px 8px rgba(249, 200, 216, 0.55);
    position: relative;
    z-index: 2;
    flex-shrink: 0;
}

/* Step image */
.plushie-process__step-img-wrap {
    position: relative;
    border-radius: var(--radius-lg, 20px);
    overflow: hidden;
    background: var(--color-light-brown-3, #F5E8F8);
}

.plushie-process__step-img {
    width: 100%;
    height: 240px!important;
    display: block;
    transition: transform 420ms ease;
}

.plushie-process__step:hover .plushie-process__step-img {
    transform: scale(1.05);
}

/* Icon badge on image corner */
.plushie-process__step-icon {
    position: absolute;
    bottom: 10px;
    right: 14px;
    width: 38px;
    height: 38px;
    background: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    font-size: 0.85rem;
    color: var(--color-light-brown-2, #C490CC);
}

/* Step text */
.plushie-process__step-body {
    padding: 1.25rem 0.25rem 0.25rem;
}

.plushie-process__step-title {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--color-text, #3D1A5E);
    margin: 0 0 0.5rem;
    line-height: 1.3;
}

.plushie-process__step-desc {
    font-size: 0.82rem;
    color: var(--color-text-mid, #6B4088);
    line-height: 1.65;
    margin: 0;
}

/* ── Responsive ──────────────────────────────────────── */
@media (max-width: 1024px) {
    .plushie-process__steps {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.25rem;
    }
    .plushie-process__steps::before {
        display: none;
    }
}

@media (max-width: 560px) {
    .plushie-process {
        padding: 52px 0 48px;
    }
    .plushie-process__steps {
        grid-template-columns: 1fr;
        gap: 2rem;
    }
    .plushie-process__step-num {
        margin-left: 0;
    }
}

/* ============================================================
   PRE-FOOTER: LATEST BLOG ARTICLES
   ============================================================ */
.blog-latest {
    background: #fff;
    padding: 68px 0 60px;
    border-bottom: 1px solid var(--color-border, #E8C8F0);
}

.blog-latest__header {
    text-align: center;
    margin-bottom: 2.5rem;
}

.blog-latest__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2, 0.5rem);
    background: var(--color-light-blue-3, #FDE8F3);
    color: var(--color-text, #3D1A5E);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    padding: var(--space-3, 0.75rem) var(--space-7, 1.75rem);
    border-radius: var(--radius-full, 9999px);
    margin-bottom: 1.25rem;
}

.blog-latest__eyebrow i {
    color: var(--color-light-blue-2, #F0B0D4);
}

.blog-latest__title {
    font-size: clamp(1.6rem, 3.5vw, 2.4rem);
    font-weight: 800;
    color: var(--color-text, #3D1A5E);
    margin: 0;
    line-height: 1.2;
}

/* ── 3×3 grid ────────────────────────────────────────── */
.blog-latest__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    margin-bottom: 2.5rem;
}

/* ── Blog card ───────────────────────────────────────── */
.blog-lcard {
    display: flex;
    flex-direction: column;
    background: var(--color-bg-section, #FEF0FA);
    border-radius: var(--radius-lg, 20px);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: transform var(--transition-base, 250ms ease),
                box-shadow var(--transition-base, 250ms ease);
}

.blog-lcard:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-md, 0 6px 20px rgba(0, 0, 0, 0.1));
}

.blog-lcard__img-wrap {
    position: relative;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: var(--color-light-brown-3, #F5E8F8);
    flex-shrink: 0;
}

.blog-lcard__img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 420ms ease;
}

.blog-lcard:hover .blog-lcard__img-wrap img {
    transform: scale(1.05);
}

.blog-lcard__img-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-light-brown-2, #C490CC);
    font-size: 2.5rem;
}

.blog-lcard__cat {
    position: absolute;
    top: 0.75rem;
    left: 0.75rem;
    background: var(--color-light-blue, #F9D0E8);
    color: var(--color-text, #3D1A5E);
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    padding: 0.25rem 0.65rem;
    border-radius: var(--radius-full, 9999px);
    pointer-events: none;
}

.blog-lcard__body {
    padding: 1rem;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.blog-lcard__title {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--color-text, #3D1A5E);
    margin: 0 0 0.5rem;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.blog-lcard__excerpt {
    font-size: 0.8rem;
    color: var(--color-text-mid, #6B4088);
    line-height: 1.6;
    margin: 0 0 auto;
    padding-bottom: 0.75rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.blog-lcard__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 0.75rem;
    border-top: 1px solid var(--color-border, #E8C8F0);
    font-size: 0.74rem;
    color: var(--color-text-mid, #6B4088);
    gap: 0.5rem;
}

.blog-lcard__date {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    flex-shrink: 0;
}

.blog-lcard__read-more {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    font-weight: 600;
    color: var(--color-text, #3D1A5E);
    white-space: nowrap;
    transition: gap var(--transition-fast, 150ms ease);
}

.blog-lcard:hover .blog-lcard__read-more {
    gap: 0.55rem;
}

/* ── Footer CTA ──────────────────────────────────────── */
.blog-latest__footer {
    display: flex;
    justify-content: center;
}

.blog-latest__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    background: var(--color-text, #3D1A5E);
    color: #fff;
    font-size: 0.9rem;
    font-weight: 700;
    padding: calc(0.7rem + 10px) calc(1.5rem + 10px);
    border-radius: var(--radius-full, 9999px);
    text-decoration: none;
    transition: background var(--transition-fast, 150ms ease),
                transform var(--transition-fast, 150ms ease);
}

.blog-latest__cta:hover {
    background: #2d1e11;
    transform: translateY(-2px);
}

/* ── Responsive ──────────────────────────────────────── */
@media (max-width: 860px) {
    .blog-latest__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 560px) {
    .blog-latest {
        padding: 48px 0 44px;
    }
    .blog-latest__grid {
        grid-template-columns: 1fr;
    }
    .blog-lcard__meta {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.4rem;
    }
}

/* ============================================================
   PRE-FOOTER: CUSTOMER REVIEWS CAROUSEL
   ============================================================ */
.rccarousel-section {
    position: relative;
    overflow: hidden;
    padding: 80px 0 72px;
    background: linear-gradient(150deg, #fdf0f7 0%, #f3eefb 50%, #eef6fd 100%);
}

/* Background blobs */
.rccarousel-section__blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(70px);
    opacity: 0.38;
    pointer-events: none;
}
.rccarousel-section__blob--1 {
    width: 520px; height: 520px;
    background: var(--color-pink, #F9C8D8);
    top: -180px; left: -140px;
}
.rccarousel-section__blob--2 {
    width: 400px; height: 400px;
    background: var(--color-lavender, #E8D5F5);
    bottom: -120px; right: -100px;
}

/* Floating deco */
.rccarousel-section__deco {
    position: absolute;
    font-size: 2rem;
    pointer-events: none;
    opacity: 0.55;
    animation: rcfloat 6s ease-in-out infinite;
    user-select: none;
}
.rccarousel-section__deco--1 { top: 10%; left: 4%;  animation-delay: 0s; }
.rccarousel-section__deco--2 { top: 14%; right: 5%; animation-delay: 2.5s; font-size: 1.7rem; }

@keyframes rcfloat {
    0%, 100% { transform: translateY(0) rotate(-6deg); }
    50%       { transform: translateY(-10px) rotate(6deg); }
}

/* ── Header ─────────────────────────────────────────── */
.rccarousel-section__header {
    text-align: center;
    margin-bottom: 2.75rem;
    position: relative;
    z-index: 1;
}

.rccarousel-section__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2, 0.5rem);
    background: var(--color-pink, #F9C8D8);
    color: var(--color-text, #3D1A5E);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    padding: var(--space-3, 0.75rem) var(--space-7, 1.75rem);
    border-radius: var(--radius-full, 9999px);
    margin-bottom: 1.25rem;
}

.rccarousel-section__eyebrow i {
    color: #e08030;
}

.rccarousel-section__title {
    font-size: clamp(1.7rem, 3.8vw, 2.6rem);
    font-weight: 800;
    color: var(--color-text, #3D1A5E);
    margin: 0 0 1rem;
    line-height: 1.2;
}

.rccarousel-section__aggregate {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    background: rgba(255, 255, 255, 0.7);
    padding: 0.45rem 1.1rem;
    border-radius: var(--radius-full, 9999px);
    backdrop-filter: blur(6px);
}

.rcstar-filled i {
    color: #f5a623;
    font-size: 0.85rem;
}

.rccarousel-section__agg-text {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--color-text-mid, #6B4088);
}

/* ── Carousel wrapper ────────────────────────────────── */
.rccarousel {
    position: relative;
    overflow: hidden;
    z-index: 1;
    /* Fade edges */
    -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 4%, #000 96%, transparent 100%);
    mask-image: linear-gradient(90deg, transparent 0, #000 4%, #000 96%, transparent 100%);
}

.rccarousel__track {
    display: flex;
    gap: 20px;
    transition: transform 480ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
    will-change: transform;
    align-items: stretch;
}

/* ── Review card ─────────────────────────────────────── */
.rcard {
    flex: 0 0 calc((100% - 40px) / 3);
    min-width: 0;
    background: #fff;
    border-radius: var(--radius-xl, 28px);
    padding: 1.75rem;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.07);
    display: flex;
    flex-direction: column;
    gap: 1rem;
    transition: box-shadow var(--transition-base, 250ms ease),
                transform var(--transition-base, 250ms ease);
}

.rcard:hover {
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.11);
    transform: translateY(-4px);
}

/* Stars + quote row */
.rcard__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.rcard__stars i {
    color: #f5a623;
    font-size: 0.9rem;
}

.rcard__stars .fa-regular {
    color: #ddd;
}

.rcard__quote {
    width: 36px; height: 36px;
    background: var(--color-pink, #F9C8D8);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #d46fa0;
    font-size: 0.85rem;
    flex-shrink: 0;
}

/* Review text */
.rcard__text {
    font-size: 0.9rem;
    color: var(--color-text, #3D1A5E);
    line-height: 1.7;
    margin: 0;
    flex: 1;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Reviewer row */
.rcard__reviewer {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.rcard__avatar {
    width: 40px; height: 40px;
    background: var(--avatar-bg, var(--color-pink, #F9C8D8));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    font-weight: 800;
    color: var(--color-text, #3D1A5E);
    flex-shrink: 0;
}

.rcard__reviewer-info {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    min-width: 0;
}

.rcard__name {
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--color-text, #3D1A5E);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.rcard__verified {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.72rem;
    color: #2d7a4a;
    font-weight: 600;
}

/* Product link strip */
.rcard__product {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem;
    background: var(--color-bg-section, #FEF0FA);
    border-radius: var(--radius-lg, 20px);
    text-decoration: none;
    color: inherit;
    margin-top: auto;
    transition: background var(--transition-fast, 150ms ease);
}

.rcard__product:hover {
    background: var(--color-light-brown-3, #F5E8F8);
}

.rcard__product-img {
    width: 56px; height: 56px;
    object-fit: cover;
    border-radius: 12px;
    flex-shrink: 0;
    background: var(--color-light-brown-3, #F5E8F8);
}

.rcard__product-info {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    min-width: 0;
    flex: 1;
}

.rcard__product-label {
    font-size: 0.68rem;
    color: var(--color-text-mid, #6B4088);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.rcard__product-name {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--color-text, #3D1A5E);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.rcard__product-arrow {
    font-size: 0.75rem;
    color: var(--color-text-mid, #6B4088);
    flex-shrink: 0;
    transition: transform var(--transition-fast, 150ms ease);
}

.rcard__product:hover .rcard__product-arrow {
    transform: translateX(3px);
}

/* ── Controls ────────────────────────────────────────── */
.rccarousel__controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    margin-top: 2rem;
    position: relative;
    z-index: 1;
}

.rccarousel__btn {
    width: 44px; height: 44px;
    background: #fff;
    border: none;
    border-radius: 50%;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text, #3D1A5E);
    font-size: 0.9rem;
    transition: background var(--transition-fast, 150ms ease),
                box-shadow var(--transition-fast, 150ms ease),
                transform var(--transition-fast, 150ms ease);
    flex-shrink: 0;
}

.rccarousel__btn:hover:not(:disabled) {
    background: var(--color-pink, #F9C8D8);
    box-shadow: 0 4px 14px rgba(249, 200, 216, 0.5);
    transform: scale(1.08);
}

.rccarousel__btn:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

.rccarousel__dots {
    display: flex;
    gap: 0;
    align-items: center;
}

/* Touch target is 44×44px (WCAG 2.5.5); visual dot rendered via ::after */
.rccarousel__dot {
    position: relative;
    width: 44px;
    height: 44px;
    background: transparent;
    border: none;
    border-radius: 0;
    cursor: pointer;
    padding: 0;
    flex-shrink: 0;
}

.rccarousel__dot::after {
    content: '';
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 8px;
    height: 8px;
    background: rgba(74, 55, 40, 0.2);
    border-radius: 50%;
    transition: background var(--transition-fast, 150ms ease),
                width var(--transition-base, 250ms ease),
                border-radius var(--transition-base, 250ms ease);
}

.rccarousel__dot.is-active::after {
    background: #d46fa0;
    width: 24px;
    border-radius: 4px;
}

/* ── Responsive ──────────────────────────────────────── */
@media (max-width: 1024px) {
    .rcard {
        flex: 0 0 calc((100% - 20px) / 2);
    }
}

@media (max-width: 640px) {
    .rccarousel-section {
        padding: 56px 0 52px;
    }
    .rcard {
        flex: 0 0 100%;
    }
    .rccarousel-section__deco {
        font-size: 1.4rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .rccarousel-section__deco { animation: none; }
    .rccarousel__track { transition: none; }
}

/* ============================================================
   PRODUCT CARD — CUSTOM CATEGORY BADGES
   badge-pink / badge-blue / badge-green / badge-brown
   ============================================================ */
.product-card__badge--badge-pink,
.product-card__badge--badge-blue,
.product-card__badge--badge-green,
.product-card__badge--badge-brown {
    white-space: nowrap;
    font-size: 0.65rem;
    padding: 0.25rem 0.6rem;
}
.product-card__badge--badge-pink   { background: var(--color-pink, #F9C8D8);         color: var(--color-text, #3D1A5E); }
.product-card__badge--badge-blue   { background: var(--color-light-blue, #F9D0E8);   color: var(--color-text, #3D1A5E); }
.product-card__badge--badge-green  { background: var(--color-light-green, #E8D0F5);  color: var(--color-text, #3D1A5E); }
.product-card__badge--badge-brown  { background: var(--color-light-brown-3, #F5E8F8); color: var(--color-text, #3D1A5E); }

/* ============================================================
   CATEGORY PAGE — WHY OUR PRODUCTS ARE LOVED
   ============================================================ */
.cat-why-loved {
    padding: 72px 0 68px;
    background: var(--color-bg-section, #FEF0FA);
}

/* Color variants */
.cat-why-loved--pink   { background: linear-gradient(135deg, #fdf2f6 0%, #fce8f3 100%); }
.cat-why-loved--blue   { background: linear-gradient(135deg, #eef8fd 0%, #dff0fa 100%); }
.cat-why-loved--green  { background: linear-gradient(135deg, #f0faf0 0%, #e2f5e2 100%); }
.cat-why-loved--brown  { background: linear-gradient(135deg, #fdf5ee 0%, #f5ede4 100%); }

/* ── Two-column inner layout ─────────────────────────── */
.cat-why-loved__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}

/* ── Image column ────────────────────────────────────── */
.cat-why-loved__img-col {
    position: relative;
}

.cat-why-loved__img-wrap {
    position: relative;
    border-radius: var(--radius-xl, 28px);
    overflow: hidden;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.1);
}

.cat-why-loved__img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 500ms ease;
}

.cat-why-loved__img-wrap:hover .cat-why-loved__img {
    transform: scale(1.04);
}

/* Floating deco emoji */
.cat-why-loved__img-deco {
    position: absolute;
    top: -18px;
    right: -14px;
    font-size: 3rem;
    filter: drop-shadow(0 4px 8px rgba(0,0,0,0.12));
    animation: wl-float 5s ease-in-out infinite;
    pointer-events: none;
    user-select: none;
}

@keyframes wl-float {
    0%, 100% { transform: translateY(0) rotate(-6deg); }
    50%       { transform: translateY(-10px) rotate(6deg); }
}

/* "Customer Favourite" badge on image */
.cat-why-loved__img-badge {
    position: absolute;
    bottom: 1.25rem;
    left: 1.25rem;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(6px);
    color: #d46fa0;
    font-size: 0.78rem;
    font-weight: 700;
    padding: 0.45rem 1rem;
    border-radius: var(--radius-full, 9999px);
    box-shadow: 0 2px 12px rgba(0,0,0,0.1);
}

/* ── Content column ──────────────────────────────────── */
.cat-why-loved__content {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.cat-why-loved__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2, 0.5rem);
    background: var(--color-pink, #F9C8D8);
    color: var(--color-text, #3D1A5E);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    padding: var(--space-3, 0.75rem) var(--space-7, 1.75rem);
    border-radius: var(--radius-full, 9999px);
    width: fit-content;
}

.cat-why-loved--blue  .cat-why-loved__eyebrow { background: var(--color-light-blue, #F9D0E8); }
.cat-why-loved--green .cat-why-loved__eyebrow { background: var(--color-light-green, #E8D0F5); }
.cat-why-loved--brown .cat-why-loved__eyebrow { background: var(--color-light-brown-3, #F5E8F8); }

.cat-why-loved__eyebrow i {
    color: #e08030;
}

.cat-why-loved__title {
    font-size: clamp(1.5rem, 3vw, 2.2rem);
    font-weight: 800;
    color: var(--color-text, #3D1A5E);
    line-height: 1.25;
    margin: 0;
}

.cat-why-loved__intro {
    font-size: 1rem;
    color: var(--color-text-mid, #6B4088);
    line-height: 1.7;
    margin: 0;
}

/* ── Points list ─────────────────────────────────────── */
.cat-why-loved__points {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.cat-why-loved__point {
    display: flex;
    align-items: flex-start;
    gap: 0.875rem;
    font-size: 0.9rem;
    color: var(--color-text, #3D1A5E);
    line-height: 1.55;
}

.cat-why-loved__point-icon {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 0.82rem;
    color: #d46fa0;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    margin-top: 1px;
}

.cat-why-loved--blue  .cat-why-loved__point-icon { color: var(--color-light-blue-2, #F0B0D4); }
.cat-why-loved--green .cat-why-loved__point-icon { color: var(--color-light-green-2, #D4B0EE); }
.cat-why-loved--brown .cat-why-loved__point-icon { color: var(--color-light-brown-2, #C490CC); }

/* ── CTA button ──────────────────────────────────────── */
.cat-why-loved__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    background: var(--color-text, #3D1A5E);
    color: #fff;
    font-size: 0.9rem;
    font-weight: 700;
    padding: calc(0.7rem + 10px) calc(1.5rem + 10px);
    border-radius: var(--radius-full, 9999px);
    text-decoration: none;
    width: fit-content;
    transition: background var(--transition-fast, 150ms ease),
                transform var(--transition-fast, 150ms ease);
}

.cat-why-loved__cta:hover {
    background: #2d1e11;
    transform: translateY(-2px);
}

/* ── Responsive ──────────────────────────────────────── */
@media (max-width: 860px) {
    .cat-why-loved__inner {
        grid-template-columns: 1fr;
        gap: 2rem;
    }
    .cat-why-loved__img-col {
        max-width: 480px;
        margin: 0 auto;
        width: 100%;
    }
}

@media (max-width: 560px) {
    .cat-why-loved {
        padding: 52px 0 48px;
    }
    .cat-why-loved__img-deco {
        font-size: 2rem;
        top: -12px;
        right: -8px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .cat-why-loved__img-deco { animation: none; }
}

/* ============================================================
   TAG SPOTLIGHT – Pre-footer product tag section
   ============================================================ */
.tag-spotlight {
    position: relative;
    padding: var(--space-20) 0 var(--space-16);
    background: var(--color-bg-section);
    overflow: hidden;
}
.tag-spotlight__blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(60px);
    pointer-events: none;
    z-index: 0;
}
.tag-spotlight__blob--1 {
    width: 420px; height: 420px;
    background: var(--color-pink);
    opacity: .28;
    top: -100px; left: -120px;
}
.tag-spotlight__blob--2 {
    width: 360px; height: 360px;
    background: var(--color-light-blue);
    opacity: .25;
    bottom: -80px; right: -100px;
}
.tag-spotlight__deco {
    position: absolute;
    font-size: 2.2rem;
    pointer-events: none;
    z-index: 0;
    opacity: .55;
}
.tag-spotlight__deco--1 { top: 48px;  right: 14%;  animation: tagDecoFloat 6s ease-in-out infinite; }
.tag-spotlight__deco--2 { bottom: 64px; left: 10%; animation: tagDecoFloat 7s ease-in-out infinite reverse; }
@keyframes tagDecoFloat {
    0%, 100% { transform: translateY(0); }
    50%       { transform: translateY(-14px); }
}
.tag-spotlight__header {
    position: relative;
    z-index: 1;
    text-align: center;
    margin-bottom: var(--space-10);
}
.tag-spotlight__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-sm);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: #9e2d62;
    background: rgba(249,200,216,.22);
    padding: 6px 14px;
    border-radius: var(--radius-full);
    margin-bottom: var(--space-4);
}
.tag-spotlight__title {
    font-size: clamp(var(--font-size-2xl), 4vw, var(--font-size-4xl));
    font-weight: 800;
    color: var(--color-text);
    line-height: 1.15;
    margin-bottom: var(--space-4);
}
.tag-spotlight__subtitle {
    font-size: var(--font-size-md);
    color: var(--color-text-mid);
    max-width: 560px;
    margin: 0 auto;
    line-height: 1.6;
}

/* Grid: first 2 cards are large (span 2 cols), last 4 are small */
.tag-spotlight__grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}

/* Card base */
.tag-scard {
    position: relative;
    display: block;
    text-decoration: none;
    border-radius: var(--radius-xl);
    overflow: hidden;
    cursor: pointer;
    outline-offset: 3px;
}
.tag-scard--large { grid-column: span 2; aspect-ratio: 3/4; }
.tag-scard--small { aspect-ratio: 4/3; }

/* Image */
.tag-scard__img-wrap {
    position: absolute;
    inset: 0;
    z-index: 0;
}
.tag-scard__img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .55s cubic-bezier(.25,.46,.45,.94);
    will-change: transform;
}
.tag-scard:hover .tag-scard__img,
.tag-scard:focus-visible .tag-scard__img { transform: scale(1.09); }

/* Dark gradient overlay */
.tag-scard__overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(to top, rgba(30,18,10,.78) 0%, rgba(30,18,10,.25) 55%, rgba(30,18,10,.04) 100%);
    transition: background .3s ease;
}
.tag-scard:hover .tag-scard__overlay,
.tag-scard:focus-visible .tag-scard__overlay {
    background: linear-gradient(to top, rgba(30,18,10,.88) 0%, rgba(30,18,10,.40) 60%, rgba(30,18,10,.10) 100%);
}

/* Accent colour tint strip at the top edge */
.tag-scard__tint {
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 6px;
    z-index: 2;
    border-radius: var(--radius-xl) var(--radius-xl) 0 0;
    transition: height .25s ease;
}
.tag-scard:hover .tag-scard__tint { height: 8px; }
.tag-scard--pink     .tag-scard__tint { background: var(--color-pink); }
.tag-scard--blue     .tag-scard__tint { background: var(--color-light-blue-2); }
.tag-scard--green    .tag-scard__tint { background: var(--color-light-green-2); }
.tag-scard--brown    .tag-scard__tint { background: var(--color-light-brown-2); }
.tag-scard--lavender .tag-scard__tint { background: var(--color-lavender); }
.tag-scard--cream    .tag-scard__tint { background: var(--color-pink-dark); }

/* Body text */
.tag-scard__body {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    z-index: 3;
    padding: 28px 24px 24px;
}
.tag-scard--small .tag-scard__body { padding: 20px 18px 18px; }

/* Count pill */
.tag-scard__count {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: var(--font-size-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: rgba(255,255,255,.85);
    background: rgba(255,255,255,.15);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    border: 1px solid rgba(255,255,255,.22);
    padding: 4px 10px;
    border-radius: var(--radius-full);
    margin-bottom: 10px;
}
.tag-scard--small .tag-scard__count { margin-bottom: 6px; }

/* Tag name */
.tag-scard__name {
    color: #fff;
    font-weight: 800;
    line-height: 1.15;
    text-shadow: 0 2px 12px rgba(0,0,0,.4);
    margin: 0 0 14px;
    font-size: clamp(1.2rem, 2.2vw, 1.75rem);
}
.tag-scard--small .tag-scard__name {
    font-size: clamp(1rem, 1.6vw, 1.2rem);
    margin-bottom: 10px;
}

/* "Shop Now" CTA slides up on hover */
.tag-scard__cta {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
    background: #fff;
    padding: 9px 20px;
    border-radius: var(--radius-full);
    opacity: 0;
    transform: translateY(10px);
    transition: opacity .25s ease, transform .25s ease;
    box-shadow: 0 4px 16px rgba(0,0,0,.2);
    white-space: nowrap;
}
.tag-scard--small .tag-scard__cta { font-size: var(--font-size-xs); padding: 7px 14px; }
.tag-scard:hover .tag-scard__cta,
.tag-scard:focus-visible .tag-scard__cta { opacity: 1; transform: translateY(0); }

/* Shopping bag badge — top-right, appears on hover */
.tag-scard__hover-badge {
    position: absolute;
    top: 18px; right: 18px;
    z-index: 3;
    width: 40px; height: 40px;
    border-radius: 50%;
    background: #fff;
    color: var(--color-text);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    box-shadow: var(--shadow-md);
    opacity: 0;
    transform: scale(.7);
    transition: opacity .25s ease, transform .25s ease;
}
.tag-scard:hover .tag-scard__hover-badge,
.tag-scard:focus-visible .tag-scard__hover-badge { opacity: 1; transform: scale(1); }

/* Footer "Browse All" link */
.tag-spotlight__footer {
    position: relative;
    z-index: 1;
    text-align: center;
    margin-top: var(--space-10);
}
.tag-spotlight__view-all {
    display: inline-flex;
    align-items: center;
    gap: var(--space-3);
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
    background: var(--color-white);
    border: 2px solid var(--color-border);
    padding: 12px 28px;
    border-radius: var(--radius-full);
    text-decoration: none;
    transition: border-color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-base);
}
.tag-spotlight__view-all:hover {
    border-color: var(--color-pink-dark);
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

/* Responsive */
@media (max-width: 900px) {
    .tag-spotlight__grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }
    .tag-scard--large { grid-column: span 1; aspect-ratio: 3/4; }
    .tag-scard--small { aspect-ratio: 3/4; }
    .tag-scard__cta { opacity: 1; transform: translateY(0); }
    .tag-scard__hover-badge { opacity: 1; transform: scale(1); }
}
@media (max-width: 540px) {
    .tag-spotlight { padding: var(--space-16) 0 var(--space-12); }
    .tag-spotlight__grid { gap: 10px; }
    .tag-scard--large,
    .tag-scard--small { aspect-ratio: 1/1; }
    .tag-scard__body { padding: 14px 12px 12px; }
    .tag-scard__name { font-size: .95rem; margin-bottom: 8px; }
    .tag-scard__count { font-size: 10px; }
    .tag-scard__cta { font-size: 10px; padding: 6px 12px; }
    .tag-scard__hover-badge { width: 32px; height: 32px; font-size: 12px; top: 10px; right: 10px; }
}
@media (prefers-reduced-motion: reduce) {
    .tag-spotlight__deco--1,
    .tag-spotlight__deco--2 { animation: none; }
}

/* ============================================================
   KAWAII ROOM PAGE
   ============================================================ */

/* ── Suppress default page padding so hero is full-width ── */
.kroom-page { padding: 0; }

/* ── Hero ─────────────────────────────────────────────────── */
.kroom-hero {
    background: linear-gradient(160deg, #fff0f5 0%, #fff9fb 60%, #f0f5ff 100%);
    padding-top: var(--space-12);
    overflow: hidden;
}
.kroom-hero__intro {
    text-align: center;
    margin-bottom: var(--space-8);
}
.kroom-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: var(--font-size-sm);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--color-pink-dark);
    background: rgba(249,200,216,.2);
    border: 1px solid rgba(249,200,216,.5);
    border-radius: var(--radius-full);
    padding: 6px 18px;
    margin-bottom: var(--space-4);
}
.kroom-hero__title {
    font-size: clamp(2rem, 5vw, 3.5rem);
    font-weight: 800;
    line-height: 1.1;
    color: var(--color-text);
    margin: 0 0 var(--space-4);
}
.kroom-hero__title em {
    font-style: normal;
    color: var(--color-pink-dark);
}
.kroom-hero__sub {
    font-size: var(--font-size-lg);
    color: var(--color-text-mid);
    max-width: 520px;
    margin: 0 auto;
}
.kroom-hero__pin-sample {
    display: inline-block;
    width: 20px;
    height: 20px;
    background: var(--color-pink-dark);
    border-radius: 50%;
    vertical-align: middle;
    position: relative;
    top: -1px;
}

/* ── Room Stage ───────────────────────────────────────────── */
.kroom-hero__stage {
    position: relative;
    max-width: 1100px;
    margin: 0 auto;
    border-radius: var(--radius-xl) var(--radius-xl) 0 0;
    overflow: hidden;
    box-shadow: 0 -8px 40px rgba(0,0,0,.08);
}
.kroom-hero__photo {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
}

/* ── Hotspot Pins ─────────────────────────────────────────── */
.kroom-pin {
    position: absolute;
    transform: translate(-50%, -50%);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    width: 44px;
    height: 44px;
    z-index: 10;
}
.kroom-pin__pulse {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: rgba(249,200,216,.45);
    animation: kroom-pulse 2s ease-out infinite;
}
.kroom-pin__dot {
    position: absolute;
    inset: 8px;
    background: var(--color-pink-dark);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 12px;
    box-shadow: 0 3px 12px rgba(200,90,110,.45);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}
.kroom-pin:hover .kroom-pin__dot,
.kroom-pin:focus-visible .kroom-pin__dot {
    transform: scale(1.2);
    box-shadow: 0 6px 20px rgba(200,90,110,.55);
}

/* Tooltip */
.kroom-pin__tip {
    position: absolute;
    bottom: calc(100% + 6px);
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap;
    background: var(--color-text);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    padding: 5px 12px;
    border-radius: var(--radius-full);
    pointer-events: none;
    opacity: 0;
    transition: opacity var(--transition-base), transform var(--transition-base);
    transform: translateX(-50%) translateY(4px);
}
.kroom-pin__tip::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-top-color: var(--color-text);
}
.kroom-pin:hover .kroom-pin__tip,
.kroom-pin:focus-visible .kroom-pin__tip {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

@keyframes kroom-pulse {
    0%   { transform: scale(1);   opacity: .8; }
    70%  { transform: scale(2);   opacity: 0; }
    100% { transform: scale(2);   opacity: 0; }
}

/* ── Zone Nav ─────────────────────────────────────────────── */
.kroom-nav {
    position: sticky;
    top: var(--header-height, 72px);
    z-index: 90;
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--color-border-light);
    box-shadow: 0 2px 12px rgba(0,0,0,.06);
}
.kroom-nav__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    gap: 0;
    overflow-x: auto;
    scrollbar-width: none;
}
.kroom-nav__list::-webkit-scrollbar { display: none; }
.kroom-nav__link {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 14px 18px;
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text-mid);
    text-decoration: none;
    white-space: nowrap;
    border-bottom: 2px solid transparent;
    transition: color var(--transition-base), border-color var(--transition-base);
}
.kroom-nav__link:hover { color: var(--color-pink-dark); }
.kroom-nav__link.is-active {
    color: var(--color-pink-dark);
    border-bottom-color: var(--color-pink-dark);
}

/* ── Category Zones ───────────────────────────────────────── */
.kroom-zone {
    padding: var(--space-16) 0;
    background: var(--zone-bg, #fff);
}
.kroom-zone--alt {
    background: #fff;
}

.kroom-zone__header {
    display: flex;
    align-items: center;
    gap: var(--space-5);
    margin-bottom: var(--space-8);
    flex-wrap: wrap;
}
.kroom-zone__badge {
    flex-shrink: 0;
    width: 56px;
    height: 56px;
    background: var(--zone-bg, var(--color-pink-light));
    border: 2px solid rgba(0,0,0,.06);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    color: var(--color-pink-dark);
}
.kroom-zone__meta { flex: 1; min-width: 200px; }
.kroom-zone__title {
    font-size: var(--font-size-2xl);
    font-weight: 800;
    margin: 0 0 4px;
    color: var(--color-text);
}
.kroom-zone__desc {
    font-size: var(--font-size-base);
    color: var(--color-text-mid);
    margin: 0;
}
.kroom-zone__cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 11px 24px;
    background: var(--color-text);
    color: #fff;
    font-size: var(--font-size-sm);
    font-weight: 700;
    border-radius: var(--radius-full);
    text-decoration: none;
    transition: background var(--transition-base), transform var(--transition-base);
    white-space: nowrap;
    flex-shrink: 0;
}
.kroom-zone__cta:hover {
    background: var(--color-pink-dark);
    transform: translateY(-1px);
}
.kroom-zone__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-5);
}
.kroom-zone__empty {
    text-align: center;
    padding: var(--space-12) 0;
    color: var(--color-text-light);
}
.kroom-zone__empty i { font-size: 2rem; margin-bottom: var(--space-3); display: block; }
.kroom-zone__empty p { margin: 0; font-size: var(--font-size-base); }

/* ── Bottom CTA ───────────────────────────────────────────── */
.kroom-cta {
    background: linear-gradient(135deg, #fff0f5 0%, #f0f5ff 100%);
    padding: var(--space-20) 0;
    text-align: center;
    border-top: 1px solid var(--color-border-light);
}
.kroom-cta__inner { max-width: 560px; margin: 0 auto; }
.kroom-cta__title {
    font-size: clamp(1.6rem, 4vw, 2.8rem);
    font-weight: 800;
    line-height: 1.2;
    margin: 0 0 var(--space-4);
    color: var(--color-text);
}
.kroom-cta__title em {
    font-style: normal;
    color: var(--color-pink-dark);
}
.kroom-cta__sub {
    font-size: var(--font-size-lg);
    color: var(--color-text-mid);
    margin: 0 0 var(--space-8);
}

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width: 1024px) {
    .kroom-zone__grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
    .kroom-hero { padding-top: var(--space-8); }
    .kroom-zone__grid { grid-template-columns: repeat(2, 1fr); }
    .kroom-zone__header { flex-direction: column; align-items: flex-start; }
    .kroom-zone__cta { align-self: flex-start; }
    .kroom-nav__link { padding: 12px 14px; font-size: 12px; }
    .kroom-nav__link span { display: none; }
    .kroom-nav__link i { font-size: 16px; }
    /* Hide some pins on small screens to avoid crowding */
    .kroom-pin__tip { display: none; }
}
@media (max-width: 480px) {
    .kroom-zone__grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-3); }
    .kroom-pin { width: 36px; height: 36px; }
    .kroom-pin__dot { inset: 6px; font-size: 10px; }
}

/* ============================================================
   KAWAII ROOM HOMEPAGE PROMO
   ============================================================ */

.kroom-promo {
    position: relative;
    padding: var(--space-20) 0;
    background: linear-gradient(140deg, #fff0f5 0%, #ffe4ef 35%, #ffd6e8 65%, #fff0f5 100%);
    overflow: hidden;
}

/* ── Decorative background items ─────────────────────────── */
.kroom-promo__bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
}
.kroom-promo__bg-item {
    position: absolute;
    line-height: 1;
    user-select: none;
    animation: kroom-float 6s ease-in-out infinite;
}
.kroom-promo__bg-item--bear1  { font-size: 72px; top: 6%;  left: 3%;  opacity: .12; animation-delay: 0s;   animation-duration: 7s; }
.kroom-promo__bg-item--bear2  { font-size: 48px; top: 70%; left: 1%;  opacity: .10; animation-delay: 1.5s; animation-duration: 8s; }
.kroom-promo__bg-item--bear3  { font-size: 56px; top: 15%; right: 2%; opacity: .10; animation-delay: 3s;   animation-duration: 6s; }
.kroom-promo__bg-item--heart1 { font-size: 40px; top: 50%; left: 8%;  opacity: .15; animation-delay: .8s;  animation-duration: 5s; }
.kroom-promo__bg-item--heart2 { font-size: 28px; top: 80%; left: 25%; opacity: .13; animation-delay: 2s;   animation-duration: 7s; }
.kroom-promo__bg-item--heart3 { font-size: 32px; top: 10%; left: 48%; opacity: .10; animation-delay: 4s;   animation-duration: 6s; }
.kroom-promo__bg-item--star1  { font-size: 36px; top: 30%; right: 5%; opacity: .12; animation-delay: 1s;   animation-duration: 8s; }
.kroom-promo__bg-item--star2  { font-size: 24px; top: 65%; right: 8%; opacity: .14; animation-delay: 2.5s; animation-duration: 5s; }
.kroom-promo__bg-item--star3  { font-size: 28px; top: 88%; right: 20%;opacity: .12; animation-delay: .5s;  animation-duration: 7s; }
.kroom-promo__bg-item--star4  { font-size: 20px; top: 5%;  left: 65%; opacity: .13; animation-delay: 3.5s; animation-duration: 6s; }

@keyframes kroom-float {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    33%       { transform: translateY(-10px) rotate(4deg); }
    66%       { transform: translateY(6px)  rotate(-3deg); }
}

/* ── Layout ───────────────────────────────────────────────── */
.kroom-promo__inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-12);
    align-items: center;
}

/* ── Copy ─────────────────────────────────────────────────── */
.kroom-promo__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: var(--font-size-sm);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #c94f72;
    background: rgba(255,255,255,.7);
    border: 1.5px solid rgba(201,79,114,.25);
    border-radius: var(--radius-full);
    padding: 6px 18px;
    margin-bottom: var(--space-5);
    backdrop-filter: blur(4px);
}
.kroom-promo__title {
    font-size: clamp(2rem, 4vw, 3.2rem);
    font-weight: 900;
    line-height: 1.1;
    color: var(--color-text);
    margin: 0 0 var(--space-5);
    letter-spacing: -.02em;
}
.kroom-promo__title em {
    font-style: normal;
    background: linear-gradient(135deg, #e91e8c 0%, #f06292 50%, #c2185b 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.kroom-promo__sub {
    font-size: var(--font-size-lg);
    color: var(--color-text-mid);
    line-height: 1.65;
    margin: 0 0 var(--space-7);
    max-width: 440px;
}

/* Category pills */
.kroom-promo__pills {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: var(--space-8);
}
.kroom-promo__pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    background: rgba(255,255,255,.8);
    border: 1.5px solid rgba(201,79,114,.2);
    border-radius: var(--radius-full);
    font-size: 13px;
    font-weight: 600;
    color: #c94f72;
    backdrop-filter: blur(4px);
    transition: background var(--transition-base), border-color var(--transition-base);
}
.kroom-promo__pill:hover {
    background: rgba(255,255,255,1);
    border-color: #c94f72;
}

/* CTA button */
.kroom-promo__cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 16px 36px;
    background: linear-gradient(135deg, #e91e8c 0%, #c2185b 100%);
    color: #fff;
    font-size: var(--font-size-base);
    font-weight: 800;
    border-radius: var(--radius-full);
    text-decoration: none;
    box-shadow: 0 8px 24px rgba(201,79,114,.4), 0 2px 6px rgba(201,79,114,.25);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
    letter-spacing: .01em;
}
.kroom-promo__cta:hover {
    transform: translateY(-3px);
    box-shadow: 0 14px 32px rgba(201,79,114,.5), 0 4px 10px rgba(201,79,114,.3);
    color: #fff;
}
.kroom-promo__cta i { transition: transform var(--transition-base); }
.kroom-promo__cta:hover i { transform: translateX(4px); }

/* Social proof nudge */
.kroom-promo__nudge {
    margin-top: var(--space-5);
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}
.kroom-promo__nudge i { color: #c94f72; font-size: 12px; }

/* ── Visual / Image ───────────────────────────────────────── */
.kroom-promo__visual {
    position: relative;
}
.kroom-promo__frame {
    position: relative;
    border-radius: 24px;
    overflow: hidden;
    box-shadow:
        0 32px 80px rgba(201,79,114,.2),
        0 8px 24px rgba(0,0,0,.08),
        0 0 0 6px rgba(255,255,255,.7),
        0 0 0 8px rgba(249,200,216,.5);
    transform: rotate(1.5deg);
    transition: transform .4s ease;
}
.kroom-promo__frame:hover {
    transform: rotate(0deg) scale(1.01);
}
.kroom-promo__img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 4 / 3;
}

/* Floating badges on image */
.kroom-promo__badge {
    position: absolute;
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 9px 16px;
    border-radius: var(--radius-full);
    font-size: 13px;
    font-weight: 700;
    backdrop-filter: blur(8px);
    box-shadow: 0 4px 16px rgba(0,0,0,.12);
    white-space: nowrap;
}
.kroom-promo__badge--tl {
    top: 16px;
    left: 16px;
    background: rgba(255,255,255,.9);
    color: #c94f72;
    border: 1.5px solid rgba(201,79,114,.2);
    animation: kroom-badge-bob 3s ease-in-out infinite;
}
.kroom-promo__badge--br {
    bottom: 16px;
    right: 16px;
    background: linear-gradient(135deg, #e91e8c, #c2185b);
    color: #fff;
    animation: kroom-badge-bob 3s ease-in-out infinite .8s;
}
@keyframes kroom-badge-bob {
    0%, 100% { transform: translateY(0); }
    50%       { transform: translateY(-5px); }
}

/* Floating pulse dots on image (simulate pins) */
.kroom-promo__dot {
    position: absolute;
    width: 14px;
    height: 14px;
    background: #e91e8c;
    border-radius: 50%;
    border: 2px solid #fff;
    box-shadow: 0 0 0 4px rgba(233,30,140,.25);
    animation: kroom-dot-pulse 2s ease-out infinite;
}
.kroom-promo__dot::before {
    content: '';
    position: absolute;
    inset: -4px;
    border-radius: 50%;
    background: rgba(233,30,140,.2);
    animation: kroom-dot-pulse 2s ease-out infinite;
}
.kroom-promo__dot--1 { top: 48%; left: 32%; animation-delay: 0s; }
.kroom-promo__dot--2 { top: 35%; left: 63%; animation-delay: .7s; }
.kroom-promo__dot--3 { top: 58%; left: 78%; animation-delay: 1.4s; }
@keyframes kroom-dot-pulse {
    0%   { box-shadow: 0 0 0 0 rgba(233,30,140,.4); }
    70%  { box-shadow: 0 0 0 10px rgba(233,30,140,0); }
    100% { box-shadow: 0 0 0 0 rgba(233,30,140,0); }
}

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width: 900px) {
    .kroom-promo__inner {
        grid-template-columns: 1fr;
        gap: var(--space-10);
    }
    .kroom-promo__visual { order: -1; }
    .kroom-promo__frame  { transform: rotate(0); max-width: 540px; margin: 0 auto; }
    .kroom-promo__title  { font-size: 2rem; }
    .kroom-promo__sub    { max-width: 100%; }
}
@media (max-width: 480px) {
    .kroom-promo { padding: var(--space-14) 0; }
    .kroom-promo__cta { width: 100%; justify-content: center; }
    .kroom-promo__badge--tl,
    .kroom-promo__badge--br { font-size: 11px; padding: 7px 12px; }
}

/* ── ① Perfect-for occasion chips ───────────────────────────────────── */
.cat-occasions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin-top: 1.1rem;
}
.cat-occasions__label {
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--color-text-mid, #777);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    white-space: nowrap;
}
.cat-occasions__chip {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.28rem 0.75rem;
    border-radius: 9999px;
    background: rgba(240,160,188,0.13);
    border: 1px solid rgba(240,160,188,0.35);
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--color-text, #333);
    white-space: nowrap;
    transition: background 0.18s ease, border-color 0.18s ease;
}
.cat-occasions__chip:hover {
    background: rgba(240,160,188,0.25);
    border-color: var(--color-pink, #f0a0bc);
}

/* ── ② Trust strip ───────────────────────────────────────────────────── */
.cat-trust-strip {
    background: var(--color-bg-soft, #fdf6f9);
    border-top: 1px solid rgba(240,160,188,0.2);
    border-bottom: 1px solid rgba(240,160,188,0.2);
    padding: 0.75rem 0;
}
.cat-trust-strip__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}
.cat-trust-strip__item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.82rem;
    color: var(--color-text, #333);
    flex: 1;
    min-width: 140px;
}
.cat-trust-strip__item i {
    color: var(--color-pink-dark, #c84b8a);
    font-size: 1rem;
    flex-shrink: 0;
}
@media (max-width: 600px) {
    .cat-trust-strip__inner { justify-content: flex-start; gap: 0.6rem 1.5rem; }
    .cat-trust-strip__item  { flex: 0 0 calc(50% - 0.75rem); min-width: 0; }
}

/* ── ③ Best Sellers section ──────────────────────────────────────────── */
.cat-best-sellers {
    padding: var(--space-20, 2.5rem) 0 var(--space-14, 1.75rem);
}
.cat-best-sellers__header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}
.cat-best-sellers__eyebrow {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-pink-dark, #c84b8a);
    margin-bottom: 0.3rem;
}
.cat-best-sellers__title {
    font-size: clamp(1.2rem, 2.5vw, 1.6rem);
    font-weight: 800;
    color: var(--color-text, #222);
    margin: 0;
}
.cat-best-sellers__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.25rem;
}
@media (max-width: 900px) { .cat-best-sellers__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .cat-best-sellers__grid { grid-template-columns: repeat(2, 1fr); gap: 0.75rem; } }

/* ── Sticky Add-to-Cart bar ───────────────────────────────────────── */
.kt-sticky-atc {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    z-index: 9990;
    background: #fff;
    box-shadow: 0 -2px 16px rgba(0,0,0,0.09), 0 -1px 0 var(--color-pink, #f0a0bc);
    transform: translateY(110%);
    transition: transform 0.3s ease;
    pointer-events: none;
}
.kt-sticky-atc.is-visible {
    transform: translateY(0);
    pointer-events: auto;
}
.kt-sticky-atc.is-visible.cart-open {
    transform: translateY(110%);
    pointer-events: none;
}
.kt-sticky-atc__inner {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.5rem 1rem;
    padding-bottom: calc(0.5rem + env(safe-area-inset-bottom, 0px));
    max-width: 1280px;
    margin: 0 auto;
}
/* Product thumbnail */
.kt-sticky-atc__img {
    flex-shrink: 0;
    width: 52px;
    height: 52px;
    border-radius: 10px;
    object-fit: cover;
}
/* Simple product: name + price */
.kt-sticky-atc__left {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex: 1;
    min-width: 0;
}
.kt-sticky-atc__name {
    font-size: 0.72rem;
    font-weight: 600;
    color: #666;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 140px;
}
.kt-sticky-atc__price {
    font-size: 0.92rem;
    font-weight: 900;
    color: #222;
    white-space: nowrap;
}
.kt-sticky-atc__price ins { text-decoration: none; }
.kt-sticky-atc__price del { font-size: 0.75em; opacity: 0.5; margin-right: 0.15em; }
/* Variable product: variant selects */
.kt-sticky-atc__variants {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex: 1;
    min-width: 0;
    flex-wrap: nowrap;
    overflow-x: auto;
}
.kt-sticky-atc__var-wrap {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    white-space: nowrap;
    cursor: pointer;
}
.kt-sticky-atc__var-label {
    font-size: 0.68rem;
    font-weight: 700;
    color: #888;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}
.kt-sticky-atc__select {
    height: 32px;
    padding: 0 0.4rem;
    font-size: 0.78rem;
    border: 1.5px solid #e0e0e0;
    border-radius: 6px;
    background: #fafafa;
    color: #333;
    cursor: pointer;
    max-width: 110px;
}
.kt-sticky-atc__select:focus {
    outline: none;
    border-color: var(--color-pink, #f0a0bc);
}
/* Button */
.kt-sticky-atc__btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    height: 52px;
    padding: 0 2rem;
    min-width: 160px;
    background: var(--color-text, #3D1A5E);
    color: #fff;
    border: 2px solid var(--color-text, #3D1A5E);
    border-radius: 9999px;
    font-family: var(--font-family, inherit);
    font-size: var(--font-size-base, 1rem);
    font-weight: 700;
    letter-spacing: 0.03em;
    cursor: pointer;
    white-space: nowrap;
    transition:
        background var(--transition-base, 0.2s ease),
        border-color var(--transition-base, 0.2s ease),
        transform var(--transition-fast, 0.15s ease),
        box-shadow var(--transition-base, 0.2s ease);
}
.kt-sticky-atc__btn:hover {
    background: var(--color-text-mid, #6B4088);
    border-color: var(--color-text-mid, #6B4088);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md, 0 4px 16px rgba(74,55,40,0.25));
}
.kt-sticky-atc__btn:active { transform: scale(0.96); }
@keyframes kt-shake {
    0%,100% { transform: translateX(0); }
    20%     { transform: translateX(-6px); }
    40%     { transform: translateX(6px); }
    60%     { transform: translateX(-4px); }
    80%     { transform: translateX(4px); }
}
.kt-shake { animation: kt-shake 0.5s ease; }
@media (max-width: 480px) {
	.kt-sticky-atc__img       { width: 44px; height: 44px; border-radius: 8px; }
    .kt-sticky-atc__var-label { display: none; }
    .kt-sticky-atc__select    { max-width: 90px; font-size: 0.75rem; }
    .kt-sticky-atc__btn       { padding: 0.52rem 0.9rem; font-size: 0.78rem; }
    .kt-sticky-atc__name      { max-width: 80px; }
}



/* ── Sidebar — Collapsible filter widgets ───────────────────────────── */
.filter-widget__body {
    overflow: hidden;
    max-height: 600px;
    transition: max-height 0.3s ease, opacity 0.2s;
    opacity: 1;
}
.filter-widget:not(.is-open) .filter-widget__body {
    max-height: 0;
    opacity: 0;
}
.filter-widget__chevron {
    margin-left: auto;
    transition: transform 0.25s;
    font-size: 0.75rem;
    color: var(--color-text-light);
}
.filter-widget:not(.is-open) .filter-widget__chevron { transform: rotate(-90deg); }
.filter-widget__title {
    display: flex;
    align-items: center;
    user-select: none;
}


/* ── Active Filters Bar ─────────────────────────────────────────────── */
.active-filters-bar {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
    padding: 0.6rem 0.9rem;
    background: #fff8e6;
    border: 1px solid #f5d87a;
    border-radius: 10px;
    font-size: 0.82rem;
}
.active-filters-bar > i { color: #b8860b; flex-shrink: 0; }
.active-filters-bar__chips { display: flex; flex-wrap: wrap; gap: 0.4rem; flex: 1; }
.active-filters-bar__chip {
    padding: 0.2rem 0.65rem;
    background: #fdeea0;
    border: 1px solid #e6c840;
    border-radius: 20px;
    font-size: 0.78rem;
    font-weight: 600;
    color: #6b4f00;
}
.active-filters-bar__clear {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.8rem;
    font-weight: 700;
    color: #c0392b;
    text-decoration: none;
    white-space: nowrap;
    padding: 0.2rem 0.5rem;
    border-radius: 6px;
    transition: background 0.15s;
}
.active-filters-bar__clear:hover { background: #fde8e6; color: #a00; }

/* ── Gift Finder ────────────────────────────────────────────────────── */
.cat-gift-finder { margin: 1rem 0 2rem; }
.cat-gift-finder__card {
    background: linear-gradient(135deg, #fff0f8 0%, #f0ebff 100%);
    border: 1px solid #e8d5f5;
    border-radius: 20px;
    padding: 1.5rem 2rem;
    text-align: center;
}
.cat-gift-finder__header { margin-bottom: 1.25rem; }
.cat-gift-finder__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #c8437a;
    margin-bottom: 0.4rem;
}
.cat-gift-finder__title {
    font-size: 1.3rem;
    font-weight: 800;
    color: #1a1a2e;
    margin: 0;
}
.cat-gift-finder__steps {
    display: flex;
    gap: 2rem;
    justify-content: center;
    margin-bottom: 1.25rem;
    flex-wrap: wrap;
    align-items: flex-start;
}
.cat-gift-finder__step { flex: 1; min-width: 200px; max-width: 480px; }
.cat-gift-finder__question {
    font-size: 0.9rem;
    font-weight: 700;
    color: #3a2040;
    margin: 0 0 0.6rem;
}
.cat-gift-finder__choices {
    display: flex;
    flex-wrap: nowrap;
    gap: 0.5rem;
    justify-content: center;
}
.cat-gift-finder__choice { cursor: pointer; }
.cat-gift-finder__choice input[type="radio"] {
    appearance: none;
    -webkit-appearance: none;
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}
.cat-gift-finder__choice-inner {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0.35rem;
    padding: 0.45rem 0.75rem;
    border: 2px solid #e0d0f0;
    border-radius: 50px;
    background: #fff;
    transition: border-color 0.15s, background 0.15s, transform 0.12s, box-shadow 0.15s;
    white-space: nowrap;
    font-size: 0.85rem;
}
.cat-gift-finder__choice:hover .cat-gift-finder__choice-inner,
.cat-gift-finder__choice.is-selected .cat-gift-finder__choice-inner {
    border-color: #c8437a;
    background: #fff0f6;
    box-shadow: 0 2px 10px rgba(200,67,122,0.15);
    transform: translateY(-2px);
}
.cat-gift-finder__choice.is-selected .cat-gift-finder__choice-inner {
    background: #ffe0ef;
    border-color: #c8437a;
}
.cat-gift-finder__choice-emoji { font-size: 1.1rem; }
.cat-gift-finder__choice-label { font-size: 0.82rem; font-weight: 600; color: #3a2040; }
.cat-gift-finder__btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.7rem 2.2rem;
    background: linear-gradient(135deg, #c8437a 0%, #7c3aed 100%);
    color: #fff;
    border: none;
    border-radius: 50px;
    font-size: 0.95rem;
    font-weight: 700;
    cursor: pointer;
    transition: opacity 0.15s, transform 0.15s, box-shadow 0.15s;
}
.cat-gift-finder__btn:not(:disabled):hover { opacity: 0.88; transform: translateY(-2px); box-shadow: 0 6px 18px rgba(124,58,237,0.30); }
.cat-gift-finder__btn:disabled { opacity: 0.45; cursor: not-allowed; }
@media (max-width: 600px) {
    .cat-gift-finder__card { padding: 1.2rem 1rem; }
    .cat-gift-finder__title { font-size: 1.1rem; }
    .cat-gift-finder__steps { gap: 1.25rem; }
    .cat-gift-finder__choices { flex-wrap: wrap; }
    .cat-gift-finder__choice-inner { padding: 0.4rem 0.6rem; }
}

/* ── Buying Guide ───────────────────────────────────────────────────── */
.cat-buying-guide {
    padding: 4rem 0;
    background: linear-gradient(180deg, #faf8ff 0%, #fff 100%);
}
.cat-buying-guide__header {
    text-align: center;
    margin-bottom: 3rem;
}
.cat-buying-guide__title {
    font-size: 1.75rem;
    font-weight: 800;
    color: #1a1a2e;
    margin: 0.4rem 0 0.75rem;
}
.cat-buying-guide__intro {
    font-size: 1rem;
    color: #6b5c7a;
    margin: 0;
}
.cat-buying-guide__steps {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    margin-bottom: 2.5rem;
}
.cat-buying-guide__step {
    text-align: center;
    padding: 2rem 1.5rem;
    background: #fff;
    border-radius: 16px;
    border: 1px solid #ede5f8;
    box-shadow: 0 2px 14px rgba(124,58,237,0.06);
    position: relative;
}
.cat-buying-guide__step-num {
    position: absolute;
    top: -14px;
    left: 50%;
    transform: translateX(-50%);
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: linear-gradient(135deg, #c8437a, #7c3aed);
    color: #fff;
    font-size: 0.7rem;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
    letter-spacing: 0.03em;
}
.cat-buying-guide__step-icon {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: linear-gradient(135deg, #f0e8ff 0%, #ffe0ef 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0.5rem auto 1rem;
    font-size: 1.2rem;
    color: #7c3aed;
}
.cat-buying-guide__step-title {
    font-size: 1rem;
    font-weight: 700;
    color: #1a1a2e;
    margin: 0 0 0.75rem;
}
.cat-buying-guide__step-desc {
    font-size: 0.875rem;
    color: #6b5c7a;
    line-height: 1.6;
    margin: 0;
}
.cat-buying-guide__cta {
    text-align: center;
}
@media (max-width: 860px) {
    .cat-buying-guide__steps { grid-template-columns: 1fr; gap: 1.5rem; }
    .cat-buying-guide__step { padding: 1.5rem 1.25rem; }
    .cat-buying-guide__title { font-size: 1.35rem; }
}

/* ── Customer Reviews Strip ─────────────────────────────────────────── */
.cat-reviews-strip { padding: 3.5rem 0; background: #fdfaff; }
.cat-reviews-strip__header {
    text-align: center;
    margin-bottom: 2rem;
}
.cat-reviews-strip__title {
    font-size: 1.5rem;
    font-weight: 800;
    color: #1a1a2e;
    margin: 0.3rem 0 0;
}
.cat-reviews-strip__scroll {
    display: flex;
    gap: 1.25rem;
    overflow-x: auto;
    padding-bottom: 1rem;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: #d4baff transparent;
}
.cat-reviews-strip__scroll::-webkit-scrollbar { height: 4px; }
.cat-reviews-strip__scroll::-webkit-scrollbar-thumb { background: #d4baff; border-radius: 4px; }
.cat-review-card {
    flex: 0 0 280px;
    background: #fff;
    border: 1px solid #ede5f8;
    border-radius: 16px;
    padding: 1.5rem;
    scroll-snap-align: start;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    box-shadow: 0 2px 12px rgba(124,58,237,0.07);
}
.cat-review-card__stars { display: flex; gap: 0.2rem; color: #f5a623; font-size: 0.85rem; }
.cat-review-card__text {
    font-size: 0.9rem;
    line-height: 1.6;
    color: #3a2040;
    margin: 0;
    font-style: italic;
    flex: 1;
}
.cat-review-card__meta {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    padding-top: 0.5rem;
    border-top: 1px solid #f0e8f8;
}
.cat-review-card__author { font-size: 0.82rem; font-weight: 700; color: #1a1a2e; }
.cat-review-card__product { font-size: 0.75rem; color: #9b6db5; }

/* ── Conversational Q&A (AEO/GEO) ──────────────────────────────────── */
.cat-scenarios { padding: 4rem 0; background: #fff; }
.cat-scenarios__header { text-align: center; margin-bottom: 2.5rem; }
.cat-scenarios__title {
    font-size: 1.6rem;
    font-weight: 800;
    color: #1a1a2e;
    margin: 0.4rem 0 0.5rem;
}
.cat-scenarios__subtitle { color: #6b5c7a; margin: 0; font-size: 0.95rem; }
.cat-scenarios__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
}
.cat-scenarios__card {
    background: #fafafa;
    border: 1px solid #ede5f8;
    border-radius: 16px;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}
.cat-scenarios__q-row,
.cat-scenarios__a-row {
    display: flex;
    gap: 0.75rem;
    align-items: flex-start;
}
.cat-scenarios__badge {
    flex-shrink: 0;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.72rem;
    font-weight: 800;
    line-height: 1;
    margin-top: 1px;
}
.cat-scenarios__badge--q { background: #f0e8ff; color: #7c3aed; }
.cat-scenarios__badge--a { background: #e8f5e9; color: #2a7a3b; }
.cat-scenarios__q {
    font-size: 0.9rem;
    font-weight: 700;
    color: #1a1a2e;
    margin: 0;
    line-height: 1.45;
}
.cat-scenarios__a {
    font-size: 0.875rem;
    color: #4a3728;
    margin: 0;
    line-height: 1.6;
}
@media (max-width: 768px) {
    .cat-scenarios__grid { grid-template-columns: 1fr; }
    .cat-scenarios__title { font-size: 1.3rem; }
}

/* ── Comparison Table (AEO/GEO) ─────────────────────────────────────── */
.cat-compare-table { padding: 4rem 0; background: #fdfaff; }
.cat-compare-table__header { text-align: center; margin-bottom: 2rem; }
.cat-compare-table__title {
    font-size: 1.5rem;
    font-weight: 800;
    color: #1a1a2e;
    margin: 0.4rem 0 0.5rem;
}
.cat-compare-table__intro { color: #6b5c7a; margin: 0; }
.cat-compare-table__wrap { overflow-x: auto; border-radius: 16px; border: 1px solid #ede5f8; }
.cat-compare-table__table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
    background: #fff;
}
.cat-compare-table__table thead tr {
    background: linear-gradient(135deg, #f0e8ff 0%, #ffe0ef 100%);
}
.cat-compare-table__table th {
    padding: 0.85rem 1.1rem;
    text-align: left;
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #3a2040;
    white-space: nowrap;
}
.cat-compare-table__table td {
    padding: 0.8rem 1.1rem;
    color: #4a3728;
    border-top: 1px solid #f0e8f8;
    vertical-align: top;
    line-height: 1.5;
}
.cat-compare-table__table tbody tr:hover td { background: #fdf8ff; }
.cat-compare-table__table tr.is-highlight td {
    background: #fff8f0;
    font-weight: 600;
}
.cat-compare-table__popular {
    display: inline-block;
    margin-left: 0.5rem;
    padding: 0.1rem 0.5rem;
    background: linear-gradient(135deg, #c8437a, #7c3aed);
    color: #fff;
    border-radius: 20px;
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    vertical-align: middle;
}

/* ── Glossary (AEO/GEO) ─────────────────────────────────────────────── */
.cat-glossary { padding: 4rem 0; background: #fff; }
.cat-glossary__header { text-align: center; margin-bottom: 2.5rem; }
.cat-glossary__title {
    font-size: 1.5rem;
    font-weight: 800;
    color: #1a1a2e;
    margin: 0.4rem 0 0.5rem;
}
.cat-glossary__subtitle { color: #6b5c7a; margin: 0; }
.cat-glossary__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
    margin: 0;
}
.cat-glossary__item {
    background: #fafafa;
    border: 1px solid #ede5f8;
    border-left: 4px solid #c8437a;
    border-radius: 0 12px 12px 0;
    padding: 1.25rem 1.5rem;
}
.cat-glossary__term {
    font-size: 0.95rem;
    font-weight: 800;
    color: #1a1a2e;
    margin: 0 0 0.5rem;
}
.cat-glossary__def {
    font-size: 0.875rem;
    color: #4a3728;
    line-height: 1.65;
    margin: 0;
}
@media (max-width: 768px) {
    .cat-glossary__grid { grid-template-columns: 1fr; }
    .cat-glossary__title { font-size: 1.25rem; }
}

/* ── PDP: "Is This Right For...?" ───────────────────────────────────── */
.pdp-right-for { margin: 3.5rem 0; }
.pdp-right-for__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin-top: 1.5rem;
}
.pdp-right-for__card {
    border-radius: 14px;
    padding: 1.1rem 1.25rem;
    border: 1px solid;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}
.pdp-right-for__card--yes   { background: #f0faf4; border-color: #b8e0c4; }
.pdp-right-for__card--no    { background: #fff5f5; border-color: #f5c6c6; }
.pdp-right-for__card--maybe { background: #fffbf0; border-color: #f5e0a0; }
.pdp-right-for__verdict {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.85rem;
    font-weight: 800;
}
.pdp-right-for__card--yes   .pdp-right-for__verdict { color: #1a7a3b; }
.pdp-right-for__card--no    .pdp-right-for__verdict { color: #c0392b; }
.pdp-right-for__card--maybe .pdp-right-for__verdict { color: #a0730b; }
.pdp-right-for__scenario {
    font-size: 0.82rem;
    font-weight: 700;
    color: #1a1a2e;
    margin: 0;
    line-height: 1.4;
}
.pdp-right-for__reason {
    font-size: 0.8rem;
    color: #4a3728;
    margin: 0;
    line-height: 1.55;
}
@media (max-width: 860px) { .pdp-right-for__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px)  { .pdp-right-for__grid { grid-template-columns: 1fr; } }

/* ── PDP: "Real Talk" Snapshot ──────────────────────────────────────── */
.pdp-real-talk { margin: 3.5rem 0; }
.pdp-real-talk__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    margin-top: 1.5rem;
}
.pdp-real-talk__block {
    background: #fafafa;
    border: 1px solid #ede5f8;
    border-radius: 16px;
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}
.pdp-real-talk__icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: linear-gradient(135deg, #f0e8ff 0%, #ffe0ef 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #7c3aed;
    font-size: 1rem;
}
.pdp-real-talk__label {
    font-size: 0.82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: #7c3aed;
    margin: 0;
}
.pdp-real-talk__text {
    font-size: 0.875rem;
    color: #4a3728;
    line-height: 1.65;
    margin: 0;
    flex: 1;
}
@media (max-width: 860px) { .pdp-real-talk__grid { grid-template-columns: 1fr; } }

/* ── Delivery Estimate ──────────────────────────────────────────────── */
.pdp-delivery-est {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    margin: 0.75rem 0 0.25rem;
    padding: 0.55rem 0.85rem;
    background: #f0faf4;
    border: 1px solid #c3e6ce;
    border-radius: 8px;
    font-size: 0.875rem;
    color: #1a6335;
}
.pdp-delivery-est i {
    font-size: 1rem;
    flex-shrink: 0;
    color: #2a8a4a;
}
.pdp-delivery-est strong { font-weight: 700; }

/* ── Frequently Bought Together ─────────────────────────────────────── */
.pdp-fbt {
    margin: 3rem 0;
    padding: 2rem;
    background: #fafafa;
    border-radius: 16px;
    border: 1px solid #f0e8f5;
}
.pdp-fbt__header {
    margin-bottom: 1.5rem;
    text-align: center;
}
.pdp-fbt__title {
    font-size: 1.4rem;
    font-weight: 700;
    margin: 0.25rem 0 0;
    color: #1a1a2e;
}
.pdp-fbt__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
}
.pdp-fbt__card {
    display: flex;
    flex-direction: column;
    background: #fff;
    border-radius: 12px;
    border: 1px solid #ede8f5;
    overflow: hidden;
    transition: box-shadow 0.2s;
}
.pdp-fbt__card:hover { box-shadow: 0 4px 18px rgba(124,58,237,0.10); }
.pdp-fbt__img-link { display: block; }
.pdp-fbt__img-link img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    display: block;
}
.pdp-fbt__info {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    padding: 0.75rem 0.85rem 0.5rem;
    flex: 1;
}
.pdp-fbt__name {
    font-size: 0.85rem;
    font-weight: 600;
    color: #1a1a2e;
    text-decoration: none;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.pdp-fbt__name:hover { color: #c8437a; }
.pdp-fbt__price {
    font-size: 0.9rem;
    font-weight: 700;
    color: #c8437a;
}
.pdp-fbt__price del { opacity: 0.5; font-size: 0.78rem; font-weight: 400; }
.pdp-fbt__price ins { text-decoration: none; }
.pdp-fbt__btn {
    display: block;
    margin: 0.5rem 0.85rem 0.85rem;
    padding: 0.55rem 0.75rem;
    border-radius: 8px;
    font-size: 0.8rem;
    font-weight: 700;
    text-align: center;
    cursor: pointer;
    border: none;
    background: linear-gradient(135deg, #c8437a 0%, #7c3aed 100%);
    color: #fff;
    transition: opacity 0.15s, transform 0.15s;
    text-decoration: none;
}
.pdp-fbt__btn:hover { opacity: 0.88; transform: translateY(-1px); color: #fff; }
.pdp-fbt__btn:active { transform: scale(0.97); }
.pdp-fbt__btn--link {
    background: transparent;
    border: 2px solid #c8437a;
    color: #c8437a;
}
.pdp-fbt__btn--link:hover { background: #c8437a; color: #fff; }

@media (max-width: 600px) {
    .pdp-fbt { padding: 1.25rem 1rem; margin: 2rem 0; }
    .pdp-fbt__grid { grid-template-columns: 1fr; gap: 1rem; }
    .pdp-fbt__card { flex-direction: row; }
    .pdp-fbt__img-link { width: 90px; flex-shrink: 0; }
    .pdp-fbt__img-link img { aspect-ratio: 1 / 1; height: 100%; }
    .pdp-fbt__info { padding: 0.6rem 0.7rem 0.3rem; }
    .pdp-fbt__btn { margin: 0.3rem 0.7rem 0.7rem; }
}


.kawaii-size-wrapper{
    width:100%;
    overflow-x:auto;
    margin:20px 0;
    border-radius:18px;
}

.kawaii-size-table{
    width:100%;
    min-width:520px;
    border-collapse:collapse;
    background:#fff7fb;
    border-radius:18px;
    overflow:hidden;
    font-family:Arial,sans-serif;
    box-shadow:0 6px 18px rgba(255,182,193,0.18);
}

.kawaii-size-table th{
    background:#ffd6e7;
    color:#5c4b51;
    padding:14px;
    font-size:15px;
    text-align:center;
    border-bottom:2px solid #ffc2da;
}

.kawaii-size-table td{
    padding:12px;
    text-align:center;
    border-bottom:1px solid #ffe3ef;
    color:#5f5661;
    font-size:14px;
}

.kawaii-size-table tr:nth-child(even){
    background:#fff0f7;
}

.kawaii-size-table tr:hover{
    background:#ffe6f2;
}

.kawaii-size-note{
    font-size:13px;
    color:#7a6d73;
    margin-top:10px;
    line-height:1.6;
}

@media screen and (max-width:768px){
    .kawaii-size-table th,
    .kawaii-size-table td{
        padding:10px;
        font-size:13px;
    }
}

@media screen and (max-width:480px){
    .kawaii-size-table{
        min-width:480px;
    }
}

/* ============================================================
   HOMEPAGE INTRO
   ============================================================ */
.homepage-intro {
    background: var(--color-bg);
    padding: var(--space-12) 0;
    text-align: center;
}
.homepage-intro__heading {
    font-size: var(--font-size-xl);
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 var(--space-5);
    line-height: 1.3;
}
.homepage-intro__body {
    max-width: 760px;
    margin: 0 auto var(--space-8);
}
.homepage-intro__body p {
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    line-height: 1.8;
    margin: 0 0 var(--space-4);
}
.homepage-intro__body p:last-child { margin-bottom: 0; }
.homepage-intro__body a {
    color: var(--color-text);
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-color: var(--color-pink-dark);
    transition: color 0.15s ease;
}
.homepage-intro__body a:hover { color: var(--color-light-brown-2); }
.homepage-intro__cta {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: linear-gradient(135deg, #FF6EB4, #B06FD8);
    color: #ffffff !important;
    font-size: var(--font-size-sm);
    font-weight: 700;
    padding: var(--space-4) var(--space-8);
    border-radius: var(--radius-full);
    text-decoration: none;
    border: none;
    box-shadow: 0 4px 16px rgba(176,111,216,.35);
    transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}
.homepage-intro__cta:hover {
    background: linear-gradient(135deg, #FF4DA6, #9650C8);
    color: #ffffff !important;
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(176,111,216,.45);
}
@media (max-width: 600px) {
    .homepage-intro { padding: var(--space-8) 0; }
    .homepage-intro__heading { font-size: var(--font-size-lg); }
}
/* ═══════════════════════════════════════════════
   KAWAII FASHION PAGE  (kf-*)
   page-kawaii-fashion.php
═══════════════════════════════════════════════ */

/* ── Lifestyle image pair ── */
.kf-img-pair {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
    margin: var(--space-6) 0;
}
.kf-img-pair__item {
    border-radius: var(--radius-xl);
    overflow: hidden;
    position: relative;
    background: var(--color-light-blue-3);
}
.kf-img-pair__item img {
    width: 100%;
    height: 320px;
    object-fit: cover;
    display: block;
    transition: transform 0.4s ease;
}
.kf-img-pair__item:hover img { transform: scale(1.04); }
.kf-img-pair__caption {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    background: linear-gradient(transparent, rgba(0,0,0,0.55));
    color: white;
    font-size: 12px;
    font-weight: 600;
    padding: var(--space-4) var(--space-3) var(--space-3);
    letter-spacing: 0.03em;
}

/* ── 3-column lifestyle gallery ── */
.kf-gallery {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-3);
    margin: var(--space-6) 0;
}
.kf-gallery__item {
    border-radius: var(--radius-xl);
    overflow: hidden;
    background: var(--color-light-blue-3);
    position: relative;
}
.kf-gallery__item img {
    width: 100%;
    height: 260px;
    object-fit: cover;
    display: block;
    transition: transform 0.4s ease;
}
.kf-gallery__item:hover img { transform: scale(1.05); }
.kf-gallery__label {
    position: absolute;
    top: var(--space-3); left: var(--space-3);
    background: rgba(255,255,255,0.92);
    color: var(--color-text);
    font-size: 11px;
    font-weight: 700;
    padding: 3px var(--space-2);
    border-radius: var(--radius-lg);
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

/* ── Tag cloud ── */
.kf-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin: var(--space-4) 0;
}
.kf-tag {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: var(--color-light-blue-3);
    color: var(--color-text-mid);
    font-size: 12px;
    font-weight: 600;
    padding: 4px var(--space-3);
    border-radius: 50px;
    border: 1.5px solid var(--color-light-blue-2);
    transition: all 0.18s ease;
    text-decoration: none;
}
.kf-tag:hover { background: var(--color-pink); border-color: var(--color-pink-dark); color: var(--color-text); transform: translateY(-1px); }
.kf-tag--pink { background: #fff0f5; border-color: var(--color-pink-dark); color: var(--color-pink-dark); }
.kf-tag--pink:hover { background: var(--color-pink-dark); color: white; }

/* ── Feature card (image + text, 2-col) ── */
.kf-feature {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 0;
    align-items: stretch;
    background: white;
    border-radius: var(--radius-xl);
    overflow: hidden;
    border: 1.5px solid var(--color-light-blue-2);
    margin: var(--space-6) 0;
    transition: box-shadow 0.2s ease;
}
.kf-feature:hover { box-shadow: 0 8px 28px rgba(0,0,0,0.08); }
.kf-feature--reverse { grid-template-columns: 1.2fr 1fr; }
.kf-feature--reverse .kf-feature__img { order: 2; }
.kf-feature--reverse .kf-feature__body { order: 1; }
.kf-feature__img {
    overflow: hidden;
    min-height: 320px;
}
.kf-feature__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.5s ease;
}
.kf-feature:hover .kf-feature__img img { transform: scale(1.04); }
.kf-feature__body {
    padding: var(--space-7);
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: var(--space-3);
}
.kf-feature__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-pink-dark);
    background: #fff0f5;
    padding: 3px var(--space-3);
    border-radius: 50px;
    align-self: flex-start;
}
.kf-feature__title {
    font-size: var(--font-size-md);
    font-weight: 800;
    color: var(--color-text);
    margin: 0;
    line-height: 1.3;
}
.kf-feature__desc {
    font-size: var(--font-size-sm);
    color: var(--color-text-mid);
    line-height: 1.7;
    margin: 0;
}
.kf-feature__link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-pink-dark);
    text-decoration: none;
    margin-top: var(--space-2);
    transition: gap 0.18s ease;
    align-self: flex-start;
}
.kf-feature__link:hover { gap: var(--space-3); }

/* ── Tips grid (2-col) ── */
.kf-tips-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
    margin: var(--space-5) 0;
}
.kf-tip {
    background: white;
    border: 1.5px solid var(--color-light-blue-2);
    border-radius: var(--radius-xl);
    padding: var(--space-5);
    display: flex;
    gap: var(--space-3);
    align-items: flex-start;
    transition: box-shadow 0.2s ease, transform 0.2s ease;
}
.kf-tip:hover { box-shadow: 0 6px 20px rgba(0,0,0,0.06); transform: translateY(-2px); }
.kf-tip__num {
    width: 34px; height: 34px; min-width: 34px;
    border-radius: 50%;
    background: var(--color-pink);
    border: 2px solid var(--color-pink-dark);
    display: flex; align-items: center; justify-content: center;
    font-size: 13px; font-weight: 800;
    color: var(--color-text);
    flex-shrink: 0;
}
.kf-tip__title {
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 var(--space-1);
}
.kf-tip p { font-size: 13px; color: var(--color-text-mid); margin: 0; line-height: 1.6; }

/* ── FAQ accordion ── */
.kf-faq { margin: var(--space-5) 0; }
.kf-faq__item {
    border: 1.5px solid var(--color-light-blue-2);
    border-radius: var(--radius-xl);
    margin-bottom: var(--space-3);
    overflow: hidden;
    background: white;
}
.kf-faq__toggle {
    width: 100%;
    text-align: left;
    background: none;
    border: none;
    padding: var(--space-4) var(--space-5);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--color-text);
    transition: background 0.15s ease;
    font-family: inherit;
}
.kf-faq__toggle:hover { background: var(--color-light-blue-3); }
.kf-faq__chevron {
    width: 22px; height: 22px; min-width: 22px;
    border-radius: 50%;
    background: var(--color-pink);
    border: 1.5px solid var(--color-pink-dark);
    display: flex; align-items: center; justify-content: center;
    font-size: 9px; color: var(--color-text);
    transition: transform 0.25s ease;
    flex-shrink: 0;
}
.kf-faq__item.is-open .kf-faq__chevron { transform: rotate(180deg); }
.kf-faq__body { padding: 0 var(--space-5) var(--space-5); }
.kf-faq__body p { font-size: var(--font-size-sm); color: var(--color-text-mid); line-height: 1.75; margin: 0; }

/* ── Category sub-links row ── */
.kf-subcats {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin: var(--space-5) 0;
}
.kf-subcat {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: white;
    border: 1.5px solid var(--color-light-blue-2);
    border-radius: var(--radius-lg);
    padding: var(--space-2) var(--space-4);
    font-size: 13px;
    font-weight: 700;
    color: var(--color-text);
    text-decoration: none;
    transition: all 0.18s ease;
}
.kf-subcat:hover { background: var(--color-pink); border-color: var(--color-pink-dark); transform: translateY(-2px); }

/* ── Wardrobe essentials 3-col grid ── */
.kf-wardrobe {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-4);
    margin: var(--space-5) 0;
}
.kf-wr-card {
    background: white;
    border: 1.5px solid var(--color-light-blue-2);
    border-radius: var(--radius-xl);
    padding: var(--space-5) var(--space-4);
    text-align: center;
    transition: box-shadow 0.2s ease, transform 0.2s ease;
    text-decoration: none;
    display: block;
    color: inherit;
}
.kf-wr-card:hover { box-shadow: 0 8px 24px rgba(0,0,0,0.08); transform: translateY(-3px); background: #fff0f5; border-color: var(--color-pink-dark); }
.kf-wr-card__emoji { font-size: 2.2rem; margin-bottom: var(--space-3); display: block; }
.kf-wr-card__name { font-size: 14px; font-weight: 800; color: var(--color-text); margin: 0 0 var(--space-2); }
.kf-wr-card p { font-size: 12px; color: var(--color-text-mid); margin: 0; line-height: 1.5; }

/* ── Responsive ── */
@media (max-width: 900px) {
    .kf-feature { grid-template-columns: 1fr; }
    .kf-feature--reverse { grid-template-columns: 1fr; }
    .kf-feature--reverse .kf-feature__img { order: 0; }
    .kf-feature--reverse .kf-feature__body { order: 0; }
    .kf-feature__img { min-height: 260px; max-height: 320px; }
    .kf-gallery { grid-template-columns: 1fr 1fr; }
    .kf-wardrobe { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
    .kf-img-pair { grid-template-columns: 1fr; }
    .kf-img-pair__item img { height: 240px; }
    .kf-gallery { grid-template-columns: 1fr; }
    .kf-gallery__item img { height: 220px; }
    .kf-tips-grid { grid-template-columns: 1fr; }
    .kf-wardrobe { grid-template-columns: 1fr; }
    .kf-feature__body { padding: var(--space-5); }
    .kf-faq__toggle { font-size: 13px; padding: var(--space-3) var(--space-4); }
}

/* ============================================================
   KAWAII MERCHANDISE — GLOBAL BUTTON CONTRAST OVERRIDES
   Ensures all buttons/CTAs have readable text at all states
   ============================================================ */
.btn--primary,
.btn--primary:hover,
.btn--primary:focus,
.btn--primary:active,
a.btn--primary,
button.btn--primary,
.hero-slide__btn,
.hero-slide__btn:hover { color: #ffffff !important; }

.btn--outline { color: #3D1A5E !important; }
.btn--outline:hover,
.btn--outline:focus { color: #ffffff !important; }

/* Shop Now / hero buttons */
.hero-slide__btn {
    background: linear-gradient(135deg, #FF6EB4, #B06FD8) !important;
    color: #ffffff !important;
    border-color: transparent !important;
    box-shadow: 0 4px 16px rgba(176,111,216,.4) !important;
}
.hero-slide__btn:hover {
    background: linear-gradient(135deg, #FF4DA6, #9650C8) !important;
    color: #ffffff !important;
}

/* Home brand buttons */
.home-brand-btn--primary { color: #ffffff !important; }
.home-brand-btn--primary:hover { color: #ffffff !important; }
.home-brand-btn--outline { color: #B06FD8 !important; }
.home-brand-btn--outline:hover { color: #ffffff !important; background: linear-gradient(135deg,#FF6EB4,#B06FD8) !important; border-color: transparent !important; }

/* WooCommerce add to cart buttons */
.single_add_to_cart_button,
.button.add_to_cart_button,
.wc-block-components-button,
.woocommerce .button,
.woocommerce button.button,
.woocommerce a.button { color: #ffffff !important; }

.single_add_to_cart_button:hover,
.button.add_to_cart_button:hover,
.woocommerce .button:hover,
.woocommerce button.button:hover,
.woocommerce a.button:hover { color: #ffffff !important; }

/* Section CTAs */
.section-footer .btn,
.section-footer a.btn { color: #3D1A5E !important; }
.section-footer .btn:hover,
.section-footer a.btn:hover { color: #ffffff !important; }

.section-footer .btn--outline { border-color: #B06FD8 !important; }
.section-footer .btn--outline:hover { background: linear-gradient(135deg,#FF6EB4,#B06FD8) !important; border-color: transparent !important; }

/* =========================================================================
   KM2 SHARED LAYOUT — used on front-page and about-us
   ========================================================================= */
.km2-section{width:100%;position:relative;}
.km2-container{max-width:1280px;margin:0 auto;padding:0 24px;}

/* Mommy & Kids Section */
.km2-momkids{
  background:linear-gradient(135deg,#FFF0FA 0%,#F5E8FF 50%,#FFF0FA 100%);
  padding:90px 0;
  overflow:hidden;
  position:relative;
}
.km2-momkids::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 20% 50%,rgba(255,110,180,.10) 0%,transparent 60%),
             radial-gradient(ellipse at 80% 50%,rgba(150,80,200,.10) 0%,transparent 60%);
  pointer-events:none;
}
.km2-momkids__inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
  position:relative;z-index:2;
}
@media(max-width:900px){
  .km2-momkids__inner{grid-template-columns:1fr;gap:40px;text-align:center;}
  .km2-momkids__img-wrap{order:-1;max-width:520px;margin:0 auto;}
}
.km2-momkids__img-wrap{position:relative;}
.km2-momkids__img-wrap::before{
  content:'';
  position:absolute;
  inset:-12px;
  background:linear-gradient(135deg,rgba(255,110,180,.2),rgba(176,111,216,.2));
  border-radius:32px;
  filter:blur(20px);
  z-index:0;
}
.km2-momkids__img{
  width:100%;
  border-radius:28px;
  object-fit:cover;
  box-shadow:0 20px 60px rgba(61,26,94,.18);
  position:relative;z-index:1;
  display:block;
}
.km2-momkids__badge{
  position:absolute;
  bottom:-18px;right:-18px;
  background:linear-gradient(135deg,#FF6EB4,#B06FD8);
  color:#fff;
  border-radius:20px;
  padding:14px 20px;
  text-align:center;
  box-shadow:0 8px 24px rgba(176,111,216,.4);
  z-index:2;
  font-size:.85rem;
  font-weight:800;
  line-height:1.3;
}
.km2-momkids__badge span{display:block;font-size:1.6rem;line-height:1;}
@media(max-width:900px){.km2-momkids__badge{right:8px;bottom:-14px;padding:10px 14px;}}
.km2-momkids__eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(135deg,rgba(255,110,180,.15),rgba(150,80,200,.15));
  color:#9650C8;
  font-size:11px;font-weight:800;letter-spacing:.15em;text-transform:uppercase;
  padding:7px 20px;border-radius:99px;margin-bottom:22px;
  border:1.5px solid rgba(176,111,216,.3);
}
.km2-momkids__title{
  font-size:clamp(2rem,3.5vw,3rem);
  font-weight:900;
  color:#3D1A5E;
  line-height:1.1;
  margin:0 0 20px;
  letter-spacing:-.02em;
}
.km2-momkids__title em{
  font-style:normal;
  background:linear-gradient(135deg,#FF6EB4,#9650C8);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.km2-momkids__desc{
  font-size:1.05rem;
  color:#6B4088;
  line-height:1.8;
  margin:0 0 32px;
}
.km2-momkids__perks{
  list-style:none;padding:0;margin:0 0 36px;
  display:flex;flex-direction:column;gap:12px;
}
@media(max-width:900px){.km2-momkids__perks{align-items:center;}}
.km2-momkids__perk{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.95rem;font-weight:600;color:#3D1A5E;
}
.km2-momkids__perk-dot{
  width:24px;height:24px;border-radius:50%;
  background:linear-gradient(135deg,#FF6EB4,#B06FD8);
  color:#fff;font-size:.7rem;font-weight:900;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.km2-momkids__ctas{display:flex;gap:14px;flex-wrap:wrap;}
@media(max-width:900px){.km2-momkids__ctas{justify-content:center;}}
.km2-momkids__btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(135deg,#FF6EB4,#9650C8);
  color:#fff !important;text-decoration:none;
  padding:16px 32px;border-radius:50px;
  font-size:.92rem;font-weight:800;
  box-shadow:0 8px 28px rgba(176,111,216,.4);
  transition:transform .2s,box-shadow .2s;
}
.km2-momkids__btn-primary:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(176,111,216,.5);}
.km2-momkids__btn-outline{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;color:#9650C8 !important;text-decoration:none;
  padding:16px 28px;border-radius:50px;
  font-size:.92rem;font-weight:800;
  border:2px solid #DDB8F5;
  transition:all .2s;
}
.km2-momkids__btn-outline:hover{background:#F5E8FF;border-color:#9650C8;}
.km2-momkids__deco{
  position:absolute;font-size:2rem;opacity:.35;pointer-events:none;
  animation:km2Float 5s ease-in-out infinite;
}
.km2-momkids__deco--1{top:8%;left:3%;animation-delay:0s;}
.km2-momkids__deco--2{top:15%;right:4%;animation-delay:1.5s;}
.km2-momkids__deco--3{bottom:10%;left:5%;animation-delay:3s;}
.km2-momkids__deco--4{bottom:15%;right:3%;animation-delay:0.8s;}
