/* ==========================================================================
   VANT — Tema Nuvemshop v2
   Redesign editorial, feminino e aspiracional
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. Design Tokens
   -------------------------------------------------------------------------- */
:root {
  /* Paleta principal */
  --color-bg:           #FAF7F2;
  --color-sand:         #E9DDD1;
  --color-sand-deep:    #D9C9B8;
  --color-champagne:    #D8BC8A;
  --color-rose:         #F3E5E1;
  --color-rose-deep:    #EDD5CF;
  --color-gold:         #B9945E;
  --color-gold-light:   #E2CBA5;
  --color-gold-dark:    #8B6B3D;
  --color-moss:         #4A6741;
  --color-moss-dark:    #2E4229;
  --color-moss-light:   #EBF0E8;
  --color-text:         #2A2522;
  --color-text-muted:   #7A6B61;
  --color-border:       #E5D9CF;
  --color-white:        #FFFFFF;
  --color-error:        #C0392B;
  --color-success:      #27AE60;

  /* Tipografia */
  --font-serif:  'Cormorant Garamond', Georgia, serif;
  --font-sans:   'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

  /* Escala tipográfica */
  --text-xs:   0.6875rem;
  --text-sm:   0.8125rem;
  --text-base: 1rem;
  --text-md:   1.125rem;
  --text-lg:   1.25rem;
  --text-xl:   1.5rem;
  --text-2xl:  2rem;
  --text-3xl:  2.75rem;
  --text-4xl:  3.75rem;
  --text-5xl:  5.5rem;
  --text-6xl:  7rem;

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

  /* Bordas e sombras */
  --radius-sm:   4px;
  --radius-md:   10px;
  --radius-lg:   20px;
  --radius-xl:   32px;
  --radius-full: 9999px;
  --shadow-xs:   0 1px 3px rgba(42,37,34,.05);
  --shadow-sm:   0 2px 8px rgba(42,37,34,.07);
  --shadow-md:   0 6px 24px rgba(42,37,34,.09);
  --shadow-lg:   0 16px 48px rgba(42,37,34,.12);
  --shadow-gold: 0 4px 24px rgba(185,148,94,.18);

  /* Transições */
  --ease:       cubic-bezier(.25,.46,.45,.94);
  --ease-out:   cubic-bezier(.16,1,.3,1);
  --t-fast:     160ms;
  --t-base:     280ms;
  --t-slow:     480ms;

  /* Layout */
  --container-max:    1320px;
  --container-narrow: 780px;
  --header-height:    72px;
  --topbar-height:    38px;
}

/* --------------------------------------------------------------------------
   2. Reset & Base
   -------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--color-text);
  background: var(--color-bg);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

img, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: var(--font-sans); cursor: pointer; border: none; background: none; }
input, select, textarea { font-family: var(--font-sans); }
ul, ol { list-style: none; }
h1,h2,h3,h4,h5,h6 { font-family: var(--font-serif); font-weight: 400; line-height: 1.15; }

.skip-link {
  position: absolute; top: -100%; left: 1rem;
  padding: .5rem 1rem; background: var(--color-text); color: #fff;
  border-radius: var(--radius-sm); font-size: var(--text-sm); z-index: 10000;
  transition: top var(--t-fast);
}
.skip-link:focus { top: 1rem; }

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

:focus-visible {
  outline: 2px solid var(--color-gold);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

/* --------------------------------------------------------------------------
   3. Layout
   -------------------------------------------------------------------------- */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-5);
}
@media (min-width: 768px)  { .container { padding-inline: var(--space-10); } }
@media (min-width: 1200px) { .container { padding-inline: var(--space-16); } }
.container--narrow { max-width: var(--container-narrow); }

/* --------------------------------------------------------------------------
   4. Typography utilities
   -------------------------------------------------------------------------- */
.rte p { margin-bottom: var(--space-4); }
.rte p:last-child { margin-bottom: 0; }
.rte a { color: var(--color-gold); text-decoration: underline; }
.rte ul { list-style: disc; padding-left: var(--space-6); margin-bottom: var(--space-4); }
.rte li { margin-bottom: var(--space-2); }

/* --------------------------------------------------------------------------
   5. Buttons
   -------------------------------------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  padding: .875rem var(--space-7, 1.75rem);
  font-family: var(--font-sans); font-size: var(--text-xs); font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase;
  border-radius: var(--radius-full);
  border: 1.5px solid transparent;
  transition: all var(--t-base) var(--ease);
  cursor: pointer; white-space: nowrap; line-height: 1;
}
.btn:disabled { opacity: .45; cursor: not-allowed; pointer-events: none; }

.btn--primary {
  background: var(--color-moss); color: var(--color-white); border-color: var(--color-moss);
}
.btn--primary:hover { background: var(--color-moss-dark); border-color: var(--color-moss-dark); transform: translateY(-1px); box-shadow: var(--shadow-md); }

.btn--gold {
  background: var(--color-gold); color: var(--color-white); border-color: var(--color-gold);
}
.btn--gold:hover { background: var(--color-gold-dark); border-color: var(--color-gold-dark); transform: translateY(-1px); box-shadow: var(--shadow-gold); }

.btn--outline {
  background: transparent; color: var(--color-text); border-color: var(--color-text);
}
.btn--outline:hover { background: var(--color-moss); color: var(--color-white); border-color: var(--color-moss); transform: translateY(-1px); }

.btn--outline-gold {
  background: transparent; color: var(--color-gold-dark); border-color: var(--color-gold);
}
.btn--outline-gold:hover { background: var(--color-gold); color: var(--color-white); transform: translateY(-1px); }

.btn--ghost { background: transparent; color: var(--color-text); border-color: var(--color-border); }
.btn--ghost:hover { border-color: var(--color-text); }

.btn--sm  { padding: .625rem var(--space-5); }
.btn--lg  { padding: 1.125rem var(--space-10); font-size: var(--text-sm); }
.btn--xl  { padding: 1.25rem 3rem; font-size: var(--text-sm); }
.btn--full { width: 100%; }

/* --------------------------------------------------------------------------
   6. Top Bar
   -------------------------------------------------------------------------- */
.top-bar {
  background: var(--color-moss);
  color: rgba(255,255,255,.85);
  height: var(--topbar-height);
  display: flex; align-items: center;
  position: relative; z-index: 200;
}
.top-bar__inner {
  width: 100%; max-width: var(--container-max);
  margin-inline: auto; padding-inline: var(--space-5);
  text-align: center;
}
.top-bar__text--desktop { display: none; font-size: var(--text-xs); letter-spacing: .08em; }
.top-bar__slider { overflow: hidden; height: 18px; }
.top-bar__slides { display: flex; flex-direction: column; transition: transform .5s var(--ease); }
.top-bar__slide {
  font-size: var(--text-xs); letter-spacing: .07em;
  height: 18px; display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
@media (min-width: 768px) {
  .top-bar__text--desktop { display: block; }
  .top-bar__slider { display: none; }
}

/* --------------------------------------------------------------------------
   7. Header
   -------------------------------------------------------------------------- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: var(--color-white);
  border-bottom: 1px solid var(--color-border);
  height: var(--header-height);
  transition: box-shadow var(--t-base), border-color var(--t-base);
}
.site-header.is-scrolled { box-shadow: var(--shadow-sm); }

.header__inner {
  display: flex; align-items: center; justify-content: space-between;
  height: var(--header-height); gap: var(--space-6);
}

.header__logo { display: flex; align-items: center; flex-shrink: 0; text-decoration: none; }
.header__logo-img { height: 42px; width: auto; object-fit: contain; transition: opacity var(--t-fast); }
.header__logo-img:hover { opacity: .8; }
.header__logo-svg { height: 44px; width: auto; display: block; transition: opacity var(--t-fast); }
.header__logo-svg--sm { height: 36px; }
.header__logo:hover .header__logo-svg { opacity: .78; }
.header__logo-text {
  font-family: var(--font-serif); font-size: var(--text-2xl);
  font-weight: 600; letter-spacing: .15em; color: var(--color-text);
}

/* ── Logo gem animation ─────────────────────────────────── */
.vhf-glow {
  fill: none; stroke: rgba(185,148,94,.18); stroke-width: 16;
  stroke-dasharray: 150; stroke-dashoffset: 150;
  animation: vhfDraw 1s .05s cubic-bezier(.4,0,.2,1) forwards;
}
.vhf-gem {
  fill: none; stroke: var(--color-gold); stroke-width: 1;
  stroke-dasharray: 150; stroke-dashoffset: 150;
  animation: vhfDraw .8s .1s cubic-bezier(.4,0,.2,1) forwards;
}
.vhf-facet {
  fill: none; stroke: var(--color-gold); stroke-width: .55; opacity: 0;
  animation: vhfFade .38s ease forwards;
}
.vhf-f1 { animation-delay: .72s; }
.vhf-f2 { animation-delay: .80s; }
.vhf-f3 { animation-delay: .87s; }
.vhf-f4 { animation-delay: .93s; }
.vhf-inner {
  fill: none; stroke: rgba(185,148,94,.28); stroke-width: .38; opacity: 0;
  animation: vhfFade .5s .96s ease forwards;
}
.vhf-ext {
  stroke-dasharray: 80; stroke-dashoffset: 80;
  animation: vhfDraw .5s ease forwards;
}
.vhf-ll { animation-delay: .82s; }
.vhf-lr { animation-delay: .92s; }
.vhf-jewel {
  opacity: 0;
  animation: vhfPop .38s .88s cubic-bezier(.34,1.56,.64,1) forwards;
}
.vhf-wm {
  opacity: 0;
  animation: vhfRise .55s 1.05s cubic-bezier(.16,1,.3,1) forwards;
}
.vhf-glow-loop {
  animation: vhfDraw 1s .05s cubic-bezier(.4,0,.2,1) forwards,
             vhfGlowPulse 3.2s 2.2s ease-in-out infinite;
}
@keyframes vhfDraw      { to { stroke-dashoffset: 0; } }
@keyframes vhfFade      { to { opacity: 1; } }
@keyframes vhfPop       { from { opacity:0; transform:scale(0); } to { opacity:1; transform:scale(1); } }
@keyframes vhfRise      { from { opacity:0; transform:translateY(5px); } to { opacity:1; transform:translateY(0); } }
@keyframes vhfGlowPulse { 0%,100% { opacity:.08; } 50% { opacity:.22; } }

/* Desktop nav */
.header__nav { display: none; }
@media (min-width: 1024px) { .header__nav { display: flex; align-items: center; flex: 1; justify-content: center; } }

.nav__list { display: flex; align-items: center; gap: var(--space-8); }

.nav__link {
  font-size: var(--text-xs); font-weight: 500; letter-spacing: .08em; text-transform: uppercase;
  color: var(--color-text-muted); padding: var(--space-2) 0;
  position: relative; transition: color var(--t-fast);
  display: flex; align-items: center; gap: 4px;
}
.nav__link::after {
  content: ''; position: absolute; bottom: -2px; left: 0; right: 0;
  height: 1px; background: var(--color-gold);
  transform: scaleX(0); transform-origin: left; transition: transform var(--t-base) var(--ease);
}
.nav__link:hover { color: var(--color-text); }
.nav__link:hover::after { transform: scaleX(1); }
.nav__link--highlight { color: var(--color-gold-dark); font-weight: 600; }
.nav__link--highlight::after { background: var(--color-gold-dark); }

/* Dropdown */
.nav__item--dropdown { position: relative; }
.nav__dropdown {
  position: absolute; top: calc(100% + var(--space-4)); left: 50%;
  transform: translateX(-50%) translateY(-8px);
  background: var(--color-white); border: 1px solid var(--color-border);
  border-radius: var(--radius-md); box-shadow: var(--shadow-lg);
  padding: var(--space-4); min-width: 220px;
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity var(--t-base), visibility var(--t-base), transform var(--t-base) var(--ease);
}
.nav__item--dropdown:hover .nav__dropdown,
.nav__item--dropdown:focus-within .nav__dropdown {
  opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); pointer-events: all;
}
.nav__dropdown-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; }
.nav__dropdown-link {
  display: block; padding: var(--space-2) var(--space-3);
  font-size: var(--text-xs); font-weight: 500; letter-spacing: .04em;
  color: var(--color-text-muted); border-radius: var(--radius-sm);
  transition: background var(--t-fast), color var(--t-fast);
}
.nav__dropdown-link:hover { background: var(--color-rose); color: var(--color-text); }
.nav__dropdown-link--featured {
  color: var(--color-gold-dark); font-weight: 600;
  grid-column: 1/-1; border-top: 1px solid var(--color-border);
  margin-top: var(--space-2); padding-top: var(--space-3);
}

/* Actions */
.header__actions { display: flex; align-items: center; gap: var(--space-2); flex-shrink: 0; }
.header__action-btn {
  position: relative; display: flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: var(--radius-full); color: var(--color-text-muted);
  transition: color var(--t-fast), background var(--t-fast);
}
.header__action-btn:hover { color: var(--color-text); background: var(--color-rose); }
.header__action-btn--account { display: none; }
@media (min-width: 768px) { .header__action-btn--account { display: flex; } }

.cart-count, .wishlist-count {
  position: absolute; top: 3px; right: 3px; min-width: 17px; height: 17px;
  background: var(--color-gold); color: #fff; border-radius: var(--radius-full);
  font-size: 9px; font-weight: 700; display: flex; align-items: center; justify-content: center;
  padding: 0 4px; line-height: 1;
}

/* Hamburger */
.header__menu-toggle { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; color: var(--color-text); }
@media (min-width: 1024px) { .header__menu-toggle { display: none; } }
.hamburger { display: flex; flex-direction: column; gap: 5px; width: 22px; }
.hamburger span { display: block; height: 1.5px; background: currentColor; border-radius: 2px; transition: transform var(--t-base), opacity var(--t-base); }
.header__menu-toggle[aria-expanded="true"] .hamburger span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.header__menu-toggle[aria-expanded="true"] .hamburger span:nth-child(2) { opacity: 0; }
.header__menu-toggle[aria-expanded="true"] .hamburger span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* Mobile Menu */
.mobile-menu {
  position: fixed; inset: 0; z-index: 200;
  pointer-events: none; visibility: hidden;
  transition: visibility var(--t-base);
}
.mobile-menu.is-open { pointer-events: all; visibility: visible; }
.mobile-menu__inner {
  position: absolute; inset-block: 0; left: 0; width: min(320px, 90vw);
  background: var(--color-white); display: flex; flex-direction: column; overflow-y: auto;
  transform: translateX(-100%); transition: transform var(--t-slow) var(--ease-out);
  box-shadow: var(--shadow-lg);
}
.mobile-menu.is-open .mobile-menu__inner { transform: translateX(0); }
.mobile-menu__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-5) var(--space-6); border-bottom: 1px solid var(--color-border); flex-shrink: 0;
}
.mobile-menu__close {
  width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  border-radius: var(--radius-sm); color: var(--color-text);
}
.mobile-menu__close:hover { background: var(--color-rose); }
.mobile-nav { flex: 1; padding: var(--space-4) var(--space-6); }
.mobile-nav__item { border-bottom: 1px solid var(--color-border); }
.mobile-nav__link, .mobile-nav__toggle {
  display: flex; align-items: center; justify-content: space-between; width: 100%;
  padding: var(--space-4) 0; font-size: var(--text-sm); font-weight: 500;
  color: var(--color-text); text-align: left;
}
.mobile-nav__link--highlight { color: var(--color-gold-dark); }
.mobile-nav__sublink {
  display: block; padding: var(--space-2) 0 var(--space-2) var(--space-4);
  font-size: var(--text-sm); color: var(--color-text-muted);
}
.mobile-nav__sublink:hover { color: var(--color-text); }
.mobile-nav__sublink--featured { color: var(--color-gold-dark); font-weight: 600; }
.mobile-nav__submenu { padding-bottom: var(--space-3); }
.mobile-menu__footer {
  padding: var(--space-6); border-top: 1px solid var(--color-border);
  display: flex; flex-direction: column; gap: var(--space-3);
}
.mobile-menu__footer-link { font-size: var(--text-sm); color: var(--color-text-muted); }
.mobile-menu__footer-link:hover { color: var(--color-text); }
@media (min-width: 1024px) { .mobile-menu { display: none; } }

/* --------------------------------------------------------------------------
   8. Overlay
   -------------------------------------------------------------------------- */
.overlay {
  position: fixed; inset: 0; background: rgba(42,37,34,.45); z-index: 90;
  opacity: 0; visibility: hidden; backdrop-filter: blur(3px);
  transition: opacity var(--t-base), visibility var(--t-base);
}
.overlay.is-visible { opacity: 1; visibility: visible; }

/* --------------------------------------------------------------------------
   9. Hero — Split editorial
   -------------------------------------------------------------------------- */
.hero {
  display: grid;
  grid-template-columns: 1fr;
  min-height: calc(100svh - var(--topbar-height) - var(--header-height));
  background: var(--color-bg);
  overflow: hidden;
}

@media (min-width: 1024px) {
  .hero { grid-template-columns: 1fr 1fr; min-height: calc(100svh - var(--topbar-height) - var(--header-height)); }
}

.hero__left {
  display: flex; flex-direction: column; justify-content: center;
  padding: var(--space-16) var(--space-10) var(--space-12);
  order: 2;
}

@media (min-width: 1024px) {
  .hero__left { order: 1; padding: var(--space-20) var(--space-16) var(--space-20) var(--space-16); }
}

.hero__eyebrow {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-size: var(--text-xs); font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
  color: var(--color-gold); margin-bottom: var(--space-5);
}
.hero__eyebrow::before {
  content: ''; display: block; width: 24px; height: 1px; background: var(--color-gold);
}

.hero__heading {
  font-family: var(--font-serif);
  font-size: clamp(2.75rem, 5vw, 5.5rem);
  font-weight: 400; font-style: italic;
  color: var(--color-text); line-height: 1.08;
  letter-spacing: -.01em; margin-bottom: var(--space-6);
}
.hero__heading em { font-style: normal; color: var(--color-gold-dark); }

.hero__subtext {
  font-size: clamp(1rem, 1.5vw, 1.125rem);
  color: var(--color-text-muted); line-height: 1.7;
  max-width: 420px; margin-bottom: var(--space-8);
}

.hero__ctas { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-bottom: var(--space-6); }

.hero__trust {
  display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap;
  font-size: var(--text-xs); color: var(--color-text-muted); letter-spacing: .04em;
}
.hero__trust-dot { color: var(--color-gold); font-size: 8px; }

/* Hero right — editorial image panel */
.hero__right {
  position: relative; overflow: hidden; order: 1;
  min-height: 55vw; background: var(--color-sand);
}

@media (min-width: 1024px) {
  .hero__right { order: 2; min-height: unset; }
}

.hero__media {
  position: absolute; inset: 0;
}

.hero__img {
  width: 100%; height: 100%; object-fit: cover;
  object-position: center top;
  transition: transform 8s var(--ease);
}
.hero:hover .hero__img { transform: scale(1.03); }

/* Editorial overlay when no image */
.hero__editorial-bg {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, var(--color-rose) 0%, var(--color-sand) 40%, var(--color-champagne) 100%);
}
.hero__editorial-orb {
  position: absolute; width: 70%; padding-bottom: 70%; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(216,188,138,.5) 0%, rgba(233,221,209,.2) 60%, transparent 100%);
}
.hero__editorial-frame {
  position: absolute; inset: 40px;
  border: 1px solid rgba(185,148,94,.2); border-radius: 50%;
}
.hero__editorial-frame-2 {
  position: absolute; inset: 80px;
  border: 1px solid rgba(185,148,94,.15); border-radius: 50%;
}
.hero__badge {
  position: absolute; bottom: var(--space-8); left: var(--space-8);
  background: rgba(255,255,255,.85); backdrop-filter: blur(12px);
  border: 1px solid var(--color-border); border-radius: var(--radius-xl);
  padding: var(--space-4) var(--space-5);
  display: flex; align-items: center; gap: var(--space-3);
  box-shadow: var(--shadow-md);
  animation: badgePop .6s var(--ease-out) 1s both;
}
@keyframes badgePop {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.hero__badge-icon { font-size: 1.5rem; }
.hero__badge-text { display: flex; flex-direction: column; }
.hero__badge-text strong { font-size: var(--text-sm); font-weight: 600; color: var(--color-text); }
.hero__badge-text span { font-size: var(--text-xs); color: var(--color-text-muted); }

/* --------------------------------------------------------------------------
   10. Section utilities
   -------------------------------------------------------------------------- */
.section { padding-block: var(--space-20); }
.section--sand { background: var(--color-sand); }
.section--rose { background: var(--color-rose); }
.section--white { background: var(--color-white); }
.section--cream { background: var(--color-bg); }

.section-heading { text-align: center; margin-bottom: var(--space-12); }
.section-heading--left { text-align: left; }

.section-heading__eyebrow {
  display: inline-block; font-size: var(--text-xs); font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase; color: var(--color-gold);
  margin-bottom: var(--space-3);
}
.section-heading__title {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 4vw, 3.25rem);
  font-weight: 400; color: var(--color-text);
  line-height: 1.15; margin-bottom: var(--space-4);
}
.section-heading__title em { font-style: italic; color: var(--color-gold-dark); }
.section-heading__sub {
  font-size: var(--text-md); color: var(--color-text-muted);
  max-width: 500px; margin-inline: auto; line-height: 1.7;
}
.section__cta { text-align: center; margin-top: var(--space-10); }

/* --------------------------------------------------------------------------
   11. Category Cards
   -------------------------------------------------------------------------- */
/* Mobile: horizontal drag carousel */
.categories-grid {
  display: flex;
  gap: var(--space-3);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding-bottom: var(--space-2);
}
.categories-grid::-webkit-scrollbar { display: none; }

/* Tablet: 3-col grid */
@media (min-width: 640px) {
  .categories-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    overflow-x: visible;
    scroll-snap-type: none;
  }
}
/* Desktop: 6-col grid */
@media (min-width: 1024px) {
  .categories-grid { grid-template-columns: repeat(6, 1fr); gap: var(--space-4); }
}

.category-card {
  position: relative; display: block;
  flex: 0 0 72vw; scroll-snap-align: start;
  aspect-ratio: 3/4;
  border-radius: var(--radius-lg); overflow: hidden;
  aspect-ratio: 3/4; background: var(--color-sand);
  cursor: pointer;
}
@media (min-width: 640px)  { .category-card { flex: none; scroll-snap-align: none; aspect-ratio: auto; } }
@media (min-width: 1024px) { .category-card { aspect-ratio: 2/3; } }

.category-card__image-wrapper { position: absolute; inset: 0; overflow: hidden; }
.category-card__image {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform var(--t-slow) var(--ease);
}
.category-card:hover .category-card__image { transform: scale(1.06); }

.category-card__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(42,37,34,.6) 0%, rgba(42,37,34,.05) 55%, transparent 100%);
  transition: opacity var(--t-base);
}
.category-card:hover .category-card__overlay { opacity: .85; }

.category-card__content {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: var(--space-5) var(--space-4) var(--space-4);
  transform: translateY(4px); transition: transform var(--t-base) var(--ease);
}
.category-card:hover .category-card__content { transform: translateY(0); }

.category-card__name {
  font-family: var(--font-serif); font-size: var(--text-lg);
  font-weight: 400; color: #fff; display: block; margin-bottom: var(--space-2);
}
.category-card__cta {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: var(--text-xs); font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
  color: rgba(255,255,255,.7);
  opacity: 0; transform: translateY(6px);
  transition: opacity var(--t-base), transform var(--t-base);
}
.category-card:hover .category-card__cta { opacity: 1; transform: translateY(0); }

/* --------------------------------------------------------------------------
   12. Product Cards — elevated
   -------------------------------------------------------------------------- */
.products-grid {
  display: grid; gap: var(--space-5);
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 768px)  { .products-grid--4col { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .products-grid--4col { grid-template-columns: repeat(4, 1fr); } }

.products-carousel {
  display: grid; gap: var(--space-5);
  grid-template-columns: repeat(2, 1fr);
  overflow-x: auto; scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch; scrollbar-width: none;
}
.products-carousel::-webkit-scrollbar { display: none; }
@media (min-width: 640px)  { .products-carousel { grid-template-columns: repeat(3, minmax(240px, 1fr)); } }
@media (min-width: 1024px) {
  .products-carousel {
    grid-template-columns: repeat(4, minmax(220px, 1fr));
    overflow-x: visible; scroll-snap-type: none;
  }
}
.products-carousel .product-card { scroll-snap-align: start; }

.product-card { display: flex; flex-direction: column; }

.product-card__image-wrapper {
  position: relative; overflow: hidden;
  border-radius: var(--radius-lg); background: var(--color-sand);
  aspect-ratio: 4/5; flex-shrink: 0;
  transition: box-shadow var(--t-base);
}
.product-card:hover .product-card__image-wrapper { box-shadow: var(--shadow-md); }

.product-card__img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform var(--t-slow) var(--ease);
}
.product-card__img--hover {
  position: absolute; inset: 0; opacity: 0;
  transition: opacity var(--t-base);
}
.product-card:hover .product-card__img--main { transform: scale(1.04); }
.product-card:hover .product-card__img--hover { opacity: 1; }

.product-card__image-link { display: block; width: 100%; height: 100%; }
.product-card__placeholder { width: 100%; height: 100%; background: var(--color-sand); }

.product-card__badges {
  position: absolute; top: var(--space-3); left: var(--space-3);
  display: flex; flex-direction: column; gap: 4px; z-index: 1;
}

.product-card__wishlist {
  position: absolute; top: var(--space-3); right: var(--space-3);
  width: 36px; height: 36px; background: rgba(250,247,242,.88); backdrop-filter: blur(8px);
  border-radius: var(--radius-full); display: flex; align-items: center; justify-content: center;
  color: var(--color-text-muted); z-index: 1;
  opacity: 0; transition: opacity var(--t-base), color var(--t-fast), transform var(--t-fast);
}
.product-card:hover .product-card__wishlist { opacity: 1; }
.product-card__wishlist:hover { color: var(--color-text); transform: scale(1.1); }
.product-card__wishlist.is-wishlisted { opacity: 1; color: var(--color-gold-dark); }
.product-card__wishlist.is-wishlisted svg path { fill: var(--color-gold-dark); stroke: var(--color-gold-dark); }

.product-card__quick-add {
  position: absolute; bottom: 0; left: 0; right: 0; padding: var(--space-3);
  transform: translateY(100%); transition: transform var(--t-base) var(--ease);
}
.product-card:hover .product-card__quick-add { transform: translateY(0); }
.product-card__quick-add-btn {
  width: 100%; padding: var(--space-3);
  background: var(--color-moss); color: #fff;
  font-size: var(--text-xs); font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  transition: background var(--t-fast);
}
.product-card__quick-add-btn:hover { background: var(--color-moss-dark); }

.product-card__info { padding-top: var(--space-3); flex: 1; }
.product-card__name-link { display: block; margin-bottom: 4px; }
.product-card__name {
  font-family: var(--font-sans); font-size: var(--text-sm); font-weight: 400;
  color: var(--color-text); line-height: 1.4; transition: color var(--t-fast);
}
.product-card__name-link:hover .product-card__name { color: var(--color-gold-dark); }

/* Badges */
.badge {
  display: inline-flex; align-items: center; padding: 3px 9px;
  font-size: 9px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase;
  border-radius: var(--radius-full); line-height: 1;
}
.badge--bestseller { background: var(--color-champagne); color: var(--color-gold-dark); }
.badge--new { background: var(--color-rose-deep); color: var(--color-text); }
.badge--brasil-core { background: var(--color-gold); color: #fff; }
.badge--last { background: var(--color-moss); color: #fff; }

/* --------------------------------------------------------------------------
   13. Price Display
   -------------------------------------------------------------------------- */
.price-display { display: flex; flex-direction: column; gap: 2px; }
.price-display__compare { font-size: var(--text-xs); color: var(--color-text-muted); }
.price-display__current { font-size: var(--text-sm); font-weight: 600; color: var(--color-text); }
.price-display__current--sale { color: var(--color-gold-dark); }
.price-display__installments { font-size: var(--text-xs); color: var(--color-text-muted); }

/* --------------------------------------------------------------------------
   14. Brasil Core Banner
   -------------------------------------------------------------------------- */
.brasil-core-banner {
  position: relative; overflow: hidden;
  min-height: 520px; display: grid;
  grid-template-columns: 1fr;
  background: var(--color-rose-deep);
}
@media (min-width: 1024px) {
  .brasil-core-banner { grid-template-columns: 1fr 1fr; min-height: 600px; }
}

.brasil-core-banner__media {
  position: relative; overflow: hidden;
  min-height: 300px; background: var(--color-sand-deep);
}
@media (min-width: 1024px) { .brasil-core-banner__media { min-height: unset; } }

.brasil-core-banner__image {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 8s var(--ease);
}
.brasil-core-banner:hover .brasil-core-banner__image { transform: scale(1.03); }

.brasil-core-banner__content {
  display: flex; flex-direction: column; justify-content: center;
  padding: var(--space-16) var(--space-10);
}
@media (min-width: 1024px) { .brasil-core-banner__content { padding: var(--space-20) var(--space-16); } }

.brasil-core-banner__eyebrow {
  font-size: var(--text-xs); font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: var(--color-gold); display: block; margin-bottom: var(--space-4);
}
.brasil-core-banner__title {
  font-family: var(--font-serif); font-weight: 400; font-style: italic;
  font-size: clamp(2.25rem, 4vw, 3.75rem);
  color: var(--color-text); line-height: 1.1; margin-bottom: var(--space-5);
}
.brasil-core-banner__sub {
  font-size: var(--text-md); color: var(--color-text-muted);
  max-width: 380px; line-height: 1.7; margin-bottom: var(--space-8);
}

/* --------------------------------------------------------------------------
   15. Storytelling Section
   -------------------------------------------------------------------------- */
.storytelling {
  display: grid; grid-template-columns: 1fr; gap: 0;
  background: var(--color-bg);
}
@media (min-width: 1024px) {
  .storytelling { grid-template-columns: 1fr 1fr; min-height: 580px; }
}

.storytelling__media {
  position: relative; overflow: hidden; background: var(--color-sand);
  min-height: 400px;
}
@media (min-width: 1024px) { .storytelling__media { min-height: unset; } }

.storytelling__img {
  width: 100%; height: 100%; object-fit: cover; object-position: center;
  transition: transform 8s var(--ease);
}
.storytelling:hover .storytelling__img { transform: scale(1.03); }

.storytelling__content {
  display: flex; flex-direction: column; justify-content: center;
  padding: var(--space-16) var(--space-10);
  background: var(--color-bg);
}
@media (min-width: 1024px) { .storytelling__content { padding: var(--space-20) var(--space-16); } }

.storytelling__eyebrow {
  font-size: var(--text-xs); font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--color-gold); margin-bottom: var(--space-5);
  display: flex; align-items: center; gap: var(--space-3);
}
.storytelling__eyebrow::before {
  content: ''; display: block; width: 28px; height: 1px; background: var(--color-gold);
}

.storytelling__title {
  font-family: var(--font-serif); font-size: clamp(2rem, 3.5vw, 3.25rem);
  font-weight: 400; font-style: italic; line-height: 1.15;
  color: var(--color-text); margin-bottom: var(--space-6); max-width: 480px;
}

.storytelling__text {
  font-size: var(--text-md); color: var(--color-text-muted); line-height: 1.8;
  max-width: 420px; margin-bottom: var(--space-8);
}

/* --------------------------------------------------------------------------
   16. Benefits Bar
   -------------------------------------------------------------------------- */
.benefits-bar { background: var(--color-moss); padding-block: var(--space-10); }

.benefits-bar__list {
  display: grid; gap: var(--space-6);
  grid-template-columns: repeat(2, 1fr);
  align-items: start;
}
@media (min-width: 768px)  { .benefits-bar__list { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .benefits-bar__list { grid-template-columns: repeat(5, 1fr); gap: var(--space-8); } }

.benefit-item {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: var(--space-3);
}
.benefit-item__icon {
  width: 44px; height: 44px; display: flex; align-items: center; justify-content: center;
  color: var(--color-gold);
}
.benefit-item__title {
  font-size: var(--text-xs); font-weight: 700; letter-spacing: .06em;
  text-transform: uppercase; color: #fff;
}
.benefit-item__desc { font-size: var(--text-xs); color: rgba(255,255,255,.5); line-height: 1.5; }

/* --------------------------------------------------------------------------
   17. Social Proof
   -------------------------------------------------------------------------- */
.social-proof { background: var(--color-bg); padding-block: var(--space-20); }

.reviews-grid {
  display: grid; gap: var(--space-5);
  grid-template-columns: 1fr;
}
@media (min-width: 640px)  { .reviews-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .reviews-grid { grid-template-columns: repeat(3, 1fr); } }

.review-card {
  background: var(--color-white); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--space-6);
  transition: box-shadow var(--t-base), transform var(--t-base);
}
.review-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }

.review-card__stars {
  display: flex; gap: 3px; margin-bottom: var(--space-4); color: var(--color-gold);
}
.review-card__text {
  font-size: var(--text-sm); color: var(--color-text); line-height: 1.7;
  font-style: italic; margin-bottom: var(--space-5);
}
.review-card__author {
  display: flex; align-items: center; gap: var(--space-3);
}
.review-card__avatar {
  width: 36px; height: 36px; border-radius: var(--radius-full);
  background: var(--color-sand); display: flex; align-items: center; justify-content: center;
  font-size: var(--text-xs); font-weight: 700; color: var(--color-gold-dark); flex-shrink: 0;
}
.review-card__name { font-size: var(--text-xs); font-weight: 700; color: var(--color-text); display: block; }
.review-card__product { font-size: var(--text-xs); color: var(--color-text-muted); }

/* --------------------------------------------------------------------------
   18. Instagram Grid
   -------------------------------------------------------------------------- */
.instagram-grid {
  display: grid; gap: var(--space-2);
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 480px)  { .instagram-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .instagram-grid { grid-template-columns: repeat(6, 1fr); } }

.instagram-grid__item {
  display: block; aspect-ratio: 1; overflow: hidden;
  border-radius: var(--radius-md); background: var(--color-sand); position: relative;
}
.instagram-grid__item img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform var(--t-slow) var(--ease);
}
.instagram-grid__item:hover img { transform: scale(1.08); }

.instagram-grid__item::after {
  content: '';
  position: absolute; inset: 0;
  background: rgba(42,37,34,0);
  transition: background var(--t-base);
  pointer-events: none;
}
.instagram-grid__item:hover::after { background: rgba(42,37,34,.15); }

.instagram-grid__item--hidden-mobile { display: none; }
@media (min-width: 1024px) { .instagram-grid__item--hidden-mobile { display: block; } }

/* --------------------------------------------------------------------------
   19. Newsletter
   -------------------------------------------------------------------------- */
.newsletter-section { background: var(--color-sand); padding-block: var(--space-20); }

.newsletter-section__inner {
  display: flex; flex-direction: column; align-items: center; gap: var(--space-8);
  text-align: center;
}
@media (min-width: 1024px) {
  .newsletter-section__inner {
    flex-direction: row; text-align: left; align-items: flex-start; justify-content: space-between;
  }
}

.newsletter-section__title {
  font-family: var(--font-serif);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 400; font-style: italic;
  color: var(--color-text); margin-bottom: var(--space-2);
}
.newsletter-section__sub { font-size: var(--text-sm); color: var(--color-text-muted); max-width: 360px; line-height: 1.7; }

.newsletter-form { width: 100%; max-width: 460px; }
.newsletter-form__group {
  display: flex; gap: 0;
  border: 1.5px solid var(--color-sand-deep); border-radius: var(--radius-full);
  overflow: hidden; background: var(--color-white);
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.newsletter-form__group:focus-within {
  border-color: var(--color-gold); box-shadow: 0 0 0 3px rgba(185,148,94,.12);
}
.newsletter-form__input {
  flex: 1; padding: var(--space-4) var(--space-5); background: transparent;
  color: var(--color-text); border: none; outline: none; font-size: var(--text-sm); min-width: 0;
}
.newsletter-form__input::placeholder { color: var(--color-text-muted); }
.newsletter-form__btn {
  padding: var(--space-4) var(--space-5); background: var(--color-gold); color: #fff;
  font-size: var(--text-xs); font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  border: none; cursor: pointer; white-space: nowrap; flex-shrink: 0;
  transition: background var(--t-fast);
}
.newsletter-form__btn:hover { background: var(--color-gold-dark); }
.newsletter-form__success { margin-top: var(--space-3); font-size: var(--text-sm); color: var(--color-gold-dark); }

/* Footer newsletter variant */
.footer__newsletter-form .newsletter-form__group { border-color: var(--color-border); }

/* --------------------------------------------------------------------------
   20. Footer
   -------------------------------------------------------------------------- */
.site-footer {
  background: var(--color-white); border-top: 1px solid var(--color-border);
  padding-top: var(--space-16); padding-bottom: var(--space-8);
}
.footer__top {
  display: grid; grid-template-columns: 1fr; gap: var(--space-10); margin-bottom: var(--space-12);
}
@media (min-width: 768px) { .footer__top { grid-template-columns: 180px 1fr 260px; } }

.footer__logo-img { height: 40px; width: auto; object-fit: contain; display: block; margin-bottom: var(--space-3); }
.footer__logo-text { font-family: var(--font-serif); font-size: var(--text-2xl); font-weight: 600; letter-spacing: .12em; }
.footer__slogan { font-size: var(--text-sm); color: var(--color-text-muted); margin-bottom: var(--space-4); font-style: italic; }
.footer__instagram {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-size: var(--text-sm); color: var(--color-text-muted); transition: color var(--t-fast);
}
.footer__instagram:hover { color: var(--color-gold-dark); }

.footer__nav { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-6); }
@media (min-width: 640px) { .footer__nav { grid-template-columns: repeat(3, 1fr); } }
.footer__nav-title {
  font-family: var(--font-sans); font-size: var(--text-xs); font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase; color: var(--color-text); margin-bottom: var(--space-4);
}
.footer__nav ul { display: flex; flex-direction: column; gap: var(--space-2); }
.footer__nav-link { font-size: var(--text-sm); color: var(--color-text-muted); transition: color var(--t-fast); }
.footer__nav-link:hover { color: var(--color-text); }
.footer__nav-link--featured { color: var(--color-gold-dark); }
.footer__newsletter-title { font-family: var(--font-sans); font-size: var(--text-xs); font-weight: 700; letter-spacing: .1em; text-transform: uppercase; margin-bottom: var(--space-2); }
.footer__newsletter-text { font-size: var(--text-sm); color: var(--color-text-muted); margin-bottom: var(--space-4); }
.footer__bottom {
  border-top: 1px solid var(--color-border); padding-top: var(--space-6);
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: var(--space-4);
}
.footer__legal { font-size: var(--text-xs); color: var(--color-text-muted); }
.footer__payment-icons { display: flex; gap: var(--space-2); }
.payment-icon {
  display: inline-block; padding: 4px 10px; background: var(--color-sand);
  border-radius: var(--radius-sm); font-size: var(--text-xs); color: var(--color-text-muted); font-weight: 600;
}

/* --------------------------------------------------------------------------
   21. Cart Drawer
   -------------------------------------------------------------------------- */
.cart-drawer {
  position: fixed; inset-block: 0; right: 0; width: min(400px, 100vw);
  background: var(--color-white); z-index: 150;
  display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform var(--t-slow) var(--ease-out);
  box-shadow: var(--shadow-lg);
}
.cart-drawer.is-open { transform: translateX(0); }
.cart-drawer__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-5) var(--space-6); border-bottom: 1px solid var(--color-border); flex-shrink: 0;
}
.cart-drawer__title { font-family: var(--font-serif); font-size: var(--text-xl); font-weight: 400; }
.cart-drawer__close {
  width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  border-radius: var(--radius-sm); color: var(--color-text);
}
.cart-drawer__close:hover { background: var(--color-rose); }

.cart-drawer__shipping-bar {
  padding: var(--space-3) var(--space-6); background: var(--color-rose); flex-shrink: 0;
}
.shipping-bar__track {
  height: 3px; background: rgba(185,148,94,.2); border-radius: var(--radius-full);
  overflow: hidden; margin-bottom: var(--space-2);
}
.shipping-bar__fill {
  height: 100%; background: var(--color-gold); border-radius: var(--radius-full);
  transition: width var(--t-slow) var(--ease);
}
.shipping-bar__text { font-size: var(--text-xs); color: var(--color-text-muted); text-align: center; }

.cart-drawer__body { flex: 1; overflow-y: auto; padding: var(--space-4) var(--space-6); }
.cart-drawer__items { display: flex; flex-direction: column; gap: var(--space-4); }

.cart-item { display: flex; gap: var(--space-4); }
.cart-item__image {
  width: 80px; height: 80px; object-fit: cover;
  border-radius: var(--radius-md); background: var(--color-sand); flex-shrink: 0;
}
.cart-item__info { flex: 1; min-width: 0; }
.cart-item__name {
  font-size: var(--text-sm); font-weight: 500; color: var(--color-text);
  display: block; margin-bottom: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cart-item__variant { font-size: var(--text-xs); color: var(--color-text-muted); display: block; margin-bottom: var(--space-3); }
.cart-item__actions { display: flex; align-items: center; gap: var(--space-3); }
.cart-item__price { font-size: var(--text-sm); font-weight: 600; margin-left: auto; }
.cart-item__remove {
  color: var(--color-text-muted); display: flex; align-items: center; justify-content: center;
  transition: color var(--t-fast);
}
.cart-item__remove:hover { color: var(--color-error); }

.cart-drawer__empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: var(--space-4); text-align: center; padding: var(--space-12) 0; color: var(--color-text-muted);
}
.cart-drawer__footer {
  padding: var(--space-5) var(--space-6); border-top: 1px solid var(--color-border); flex-shrink: 0;
}
.cart-drawer__total {
  display: flex; justify-content: space-between; align-items: center;
  font-size: var(--text-md); margin-bottom: var(--space-4);
}
.cart-drawer__view-cart {
  display: block; text-align: center; margin-top: var(--space-3);
  font-size: var(--text-sm); color: var(--color-text-muted);
  text-decoration: underline; text-underline-offset: 3px;
}

/* --------------------------------------------------------------------------
   22. Qty Selector
   -------------------------------------------------------------------------- */
.qty-selector {
  display: flex; align-items: center; border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full); overflow: hidden;
}
.qty-selector__btn {
  width: 32px; height: 32px; display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; color: var(--color-text); transition: background var(--t-fast); flex-shrink: 0;
}
.qty-selector__btn:hover { background: var(--color-rose); }
.qty-selector__input {
  width: 40px; text-align: center; border: none;
  border-inline: 1.5px solid var(--color-border); height: 32px;
  font-size: var(--text-sm); color: var(--color-text);
  -moz-appearance: textfield; appearance: textfield;
}
.qty-selector__input::-webkit-outer-spin-button,
.qty-selector__input::-webkit-inner-spin-button { -webkit-appearance: none; }

/* --------------------------------------------------------------------------
   23. Search Drawer
   -------------------------------------------------------------------------- */
.search-drawer {
  position: fixed; inset-inline: 0; top: 0; z-index: 150;
  transform: translateY(-100%); transition: transform var(--t-slow) var(--ease-out); pointer-events: none;
}
.search-drawer.is-open { transform: translateY(0); pointer-events: all; }
.search-drawer__inner { background: var(--color-white); border-bottom: 1px solid var(--color-border); box-shadow: var(--shadow-lg); }
.search-drawer__header { padding: var(--space-4) var(--space-6); border-bottom: 1px solid var(--color-border); }
.search-drawer__form {
  display: flex; align-items: center; gap: var(--space-3);
  max-width: var(--container-max); margin-inline: auto;
}
.search-drawer__input {
  flex: 1; border: none; outline: none;
  font-size: var(--text-lg); color: var(--color-text); background: transparent; padding: var(--space-2) 0;
}
.search-drawer__input::placeholder { color: var(--color-border); }
.search-drawer__submit, .search-drawer__close {
  display: flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; color: var(--color-text-muted); border-radius: var(--radius-sm); flex-shrink: 0;
}
.search-drawer__submit:hover, .search-drawer__close:hover { color: var(--color-text); background: var(--color-rose); }
.search-drawer__body { padding: var(--space-6); max-width: var(--container-max); margin-inline: auto; }
.search-drawer__label {
  font-size: var(--text-xs); font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--color-text-muted); margin-bottom: var(--space-3);
}
.search-quick-tags { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.search-tag {
  display: inline-block; padding: var(--space-2) var(--space-4);
  background: var(--color-rose); border-radius: var(--radius-full);
  font-size: var(--text-sm); color: var(--color-text); transition: background var(--t-fast);
}
.search-tag:hover { background: var(--color-sand); }

/* --------------------------------------------------------------------------
   24. Modal (size guide)
   -------------------------------------------------------------------------- */
.modal {
  position: fixed; inset: 0; z-index: 200;
  display: flex; align-items: center; justify-content: center; padding: var(--space-4);
  opacity: 0; visibility: hidden; transition: opacity var(--t-base), visibility var(--t-base);
}
.modal.is-open { opacity: 1; visibility: visible; }
.modal__overlay { position: absolute; inset: 0; background: rgba(42,37,34,.5); backdrop-filter: blur(4px); }
.modal__inner {
  position: relative; background: var(--color-white); border-radius: var(--radius-xl);
  max-width: 620px; width: 100%; max-height: 90vh; overflow-y: auto; box-shadow: var(--shadow-lg);
  transform: translateY(12px); transition: transform var(--t-base) var(--ease-out);
}
.modal.is-open .modal__inner { transform: translateY(0); }
.modal__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-6); border-bottom: 1px solid var(--color-border);
  position: sticky; top: 0; background: var(--color-white); z-index: 1;
}
.modal__title { font-family: var(--font-serif); font-size: var(--text-xl); font-weight: 400; }
.modal__close { width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; border-radius: var(--radius-sm); color: var(--color-text-muted); }
.modal__close:hover { background: var(--color-rose); }
.modal__body { padding: var(--space-6); }
.size-guide__intro { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.7; margin-bottom: var(--space-6); }
.size-guide__steps { display: flex; flex-direction: column; gap: var(--space-4); margin-bottom: var(--space-6); }
.size-guide__step { display: flex; align-items: flex-start; gap: var(--space-4); font-size: var(--text-sm); }
.size-guide__step-num {
  width: 28px; height: 28px; border-radius: var(--radius-full); background: var(--color-gold); color: #fff;
  display: flex; align-items: center; justify-content: center; font-size: var(--text-xs); font-weight: 700; flex-shrink: 0;
}
.size-guide__table-wrapper { overflow-x: auto; border-radius: var(--radius-md); border: 1px solid var(--color-border); margin-bottom: var(--space-5); }
.size-guide__table { width: 100%; border-collapse: collapse; font-size: var(--text-sm); }
.size-guide__table th { background: var(--color-rose); padding: var(--space-3) var(--space-4); text-align: left; font-size: var(--text-xs); font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--color-text-muted); }
.size-guide__table td { padding: var(--space-3) var(--space-4); border-top: 1px solid var(--color-border); }
.size-guide__table tr:hover td { background: var(--color-bg); }
.size-guide__tip { font-size: var(--text-sm); color: var(--color-text-muted); padding: var(--space-3) var(--space-4); background: var(--color-rose); border-radius: var(--radius-sm); }

/* --------------------------------------------------------------------------
   25. Breadcrumbs
   -------------------------------------------------------------------------- */
.breadcrumbs { margin-bottom: var(--space-6); }
.breadcrumbs__list { display: flex; align-items: center; flex-wrap: wrap; gap: var(--space-2); }
.breadcrumbs__link { font-size: var(--text-xs); color: var(--color-text-muted); transition: color var(--t-fast); }
.breadcrumbs__link:hover { color: var(--color-text); }
.breadcrumbs__current { font-size: var(--text-xs); color: var(--color-text); }
.breadcrumbs__sep::after { content: '/'; font-size: var(--text-xs); color: var(--color-border); }

/* --------------------------------------------------------------------------
   26. Product Page
   -------------------------------------------------------------------------- */
.page-product { padding-top: var(--space-8); padding-bottom: var(--space-16); }
.product-layout { display: grid; grid-template-columns: 1fr; gap: var(--space-8); }
@media (min-width: 1024px) { .product-layout { grid-template-columns: 1fr 1fr; gap: var(--space-16); align-items: start; } }

.product-gallery { display: flex; flex-direction: column; gap: var(--space-3); position: sticky; top: calc(var(--header-height) + var(--space-6)); }
@media (min-width: 1024px) { .product-gallery { flex-direction: row-reverse; align-items: flex-start; } }
.product-gallery__thumbs { display: none; }
@media (min-width: 1024px) { .product-gallery__thumbs { display: flex; flex-direction: column; gap: var(--space-2); width: 80px; flex-shrink: 0; } }
.gallery-thumb {
  width: 76px; height: 76px; border-radius: var(--radius-md); overflow: hidden;
  border: 1.5px solid transparent; transition: border-color var(--t-fast); flex-shrink: 0;
}
.gallery-thumb.is-active, .gallery-thumb:hover { border-color: var(--color-gold); }
.gallery-thumb img { width: 100%; height: 100%; object-fit: cover; }
.product-gallery__main { flex: 1; position: relative; }
.product-gallery__slides { position: relative; border-radius: var(--radius-xl); overflow: hidden; background: var(--color-sand); aspect-ratio: 1; }
.product-gallery__slide { position: absolute; inset: 0; opacity: 0; transition: opacity var(--t-base); }
.product-gallery__slide.is-active { opacity: 1; position: relative; }
.product-gallery__img { width: 100%; height: 100%; object-fit: cover; cursor: zoom-in; }
.gallery-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 40px; height: 40px; background: rgba(250,247,242,.9); border-radius: var(--radius-full);
  display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow-sm);
  transition: background var(--t-fast); z-index: 2;
}
.gallery-nav:hover { background: var(--color-white); }
.gallery-nav--prev { left: var(--space-3); }
.gallery-nav--next { right: var(--space-3); }
@media (min-width: 1024px) { .gallery-nav { display: none; } }
.gallery-dots { display: flex; justify-content: center; gap: var(--space-2); margin-top: var(--space-3); }
@media (min-width: 1024px) { .gallery-dots { display: none; } }
.gallery-dot {
  width: 6px; height: 6px; border-radius: var(--radius-full); background: var(--color-border);
  transition: background var(--t-fast), width var(--t-fast);
}
.gallery-dot.is-active { background: var(--color-gold); width: 20px; }

.product-info { padding-top: var(--space-4); }
@media (min-width: 1024px) { .product-info { padding-top: 0; } }
.product-info__badges { display: flex; gap: var(--space-2); margin-bottom: var(--space-4); flex-wrap: wrap; }
.product-info__name {
  font-family: var(--font-serif); font-size: clamp(1.75rem, 3vw, 2.75rem); font-weight: 400;
  color: var(--color-text); margin-bottom: var(--space-5); line-height: 1.2;
}
.product-info__pricing { margin-bottom: var(--space-6); }
.product-info__price-main { display: flex; align-items: baseline; gap: var(--space-3); margin-bottom: 4px; }
.price-compare { font-size: var(--text-sm); color: var(--color-text-muted); }
.price-current { font-size: var(--text-2xl); font-weight: 600; color: var(--color-text); }
.price-current--sale { color: var(--color-gold-dark); }
.price-installments { font-size: var(--text-sm); color: var(--color-text-muted); }

.variant-group { margin-bottom: var(--space-5); }
.variant-group__header { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-3); flex-wrap: wrap; }
.variant-group__label { font-size: var(--text-xs); font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--color-text); }
.variant-group__selected { font-size: var(--text-xs); color: var(--color-text-muted); }
.variant-group__guide-link { display: inline-flex; align-items: center; gap: 4px; font-size: var(--text-xs); color: var(--color-gold); text-decoration: underline; text-underline-offset: 3px; margin-left: auto; }
.variant-group__options { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.variant-swatch { cursor: pointer; }
.variant-swatch__input { display: none; }
.variant-swatch__color {
  display: flex; align-items: center; padding: 6px 18px;
  border: 1.5px solid var(--color-border); border-radius: var(--radius-full);
  font-size: var(--text-xs); font-weight: 500; color: var(--color-text-muted);
  transition: border-color var(--t-fast), background var(--t-fast), color var(--t-fast);
}
.variant-swatch__input:checked + .variant-swatch__color { border-color: var(--color-moss); background: var(--color-moss); color: #fff; }
.variant-swatch.is-unavailable .variant-swatch__color { opacity: .4; cursor: not-allowed; }
.variant-group__chips { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.variant-chip { cursor: pointer; }
.variant-chip__input { display: none; }
.variant-chip__label {
  display: flex; align-items: center; justify-content: center;
  min-width: 44px; height: 44px; padding: 0 var(--space-3);
  border: 1.5px solid var(--color-border); border-radius: var(--radius-md);
  font-size: var(--text-sm); color: var(--color-text);
  transition: border-color var(--t-fast), background var(--t-fast), color var(--t-fast);
}
.variant-chip__input:checked + .variant-chip__label { border-color: var(--color-moss); background: var(--color-moss); color: #fff; }
.variant-chip.is-unavailable .variant-chip__label { opacity: .4; text-decoration: line-through; cursor: not-allowed; }

.product-form__quantity { margin-bottom: var(--space-5); }
.product-form__qty-label { font-size: var(--text-xs); font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--color-text); display: block; margin-bottom: var(--space-3); }
.product-form__ctas { display: flex; flex-direction: column; gap: var(--space-3); margin-bottom: var(--space-5); }
.product-form__wishlist { display: flex; align-items: center; justify-content: center; gap: var(--space-2); }
.product-form__wishlist.is-wishlisted svg path { fill: var(--color-gold-dark); stroke: var(--color-gold-dark); }
.product-form__whatsapp { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); color: var(--color-text-muted); margin-bottom: var(--space-6); width: fit-content; transition: color var(--t-fast); }
.product-form__whatsapp:hover { color: var(--color-text); }

.shipping-calculator { padding: var(--space-5) 0; border-top: 1px solid var(--color-border); margin-bottom: var(--space-5); }
.shipping-calculator__title { font-size: var(--text-xs); font-weight: 700; letter-spacing: .08em; text-transform: uppercase; margin-bottom: var(--space-3); }
.shipping-calculator__input-group { display: flex; gap: var(--space-2); margin-bottom: var(--space-2); }
.shipping-calculator__input {
  flex: 1; padding: var(--space-3) var(--space-4); border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm); font-size: var(--text-sm); color: var(--color-text);
  background: var(--color-white); transition: border-color var(--t-fast); min-width: 0;
}
.shipping-calculator__input:focus { border-color: var(--color-gold); outline: none; }
.shipping-calculator__btn {
  padding: var(--space-3) var(--space-4); background: var(--color-moss); color: #fff;
  border-radius: var(--radius-sm); font-size: var(--text-xs); font-weight: 700; letter-spacing: .06em;
  text-transform: uppercase; white-space: nowrap; transition: background var(--t-fast); flex-shrink: 0;
}
.shipping-calculator__btn:hover { background: var(--color-moss-dark); }
.shipping-calculator__cep-link { font-size: var(--text-xs); color: var(--color-gold); text-decoration: underline; text-underline-offset: 3px; }

.product-accordions { border-top: 1px solid var(--color-border); }
.accordion { border-bottom: 1px solid var(--color-border); }
.accordion__trigger {
  display: flex; align-items: center; justify-content: space-between; width: 100%;
  padding: var(--space-4) 0; font-size: var(--text-sm); font-weight: 500;
  color: var(--color-text); text-align: left; gap: var(--space-3);
}
.accordion__icon { flex-shrink: 0; transition: transform var(--t-base); color: var(--color-text-muted); }
.accordion__trigger[aria-expanded="true"] .accordion__icon { transform: rotate(180deg); }
.accordion__body { padding-bottom: var(--space-4); font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.7; }
.accordion__body a { color: var(--color-gold); text-decoration: underline; }

/* --------------------------------------------------------------------------
   27. Category page
   -------------------------------------------------------------------------- */
.page-category { padding-top: var(--space-8); padding-bottom: var(--space-16); }
.category-header { margin-bottom: var(--space-10); }
.category-header__title { font-family: var(--font-serif); font-size: clamp(2rem, 4vw, 3rem); font-weight: 400; margin-bottom: var(--space-3); }
.category-header__description { font-size: var(--text-md); color: var(--color-text-muted); max-width: 580px; margin-bottom: var(--space-2); line-height: 1.7; }
.category-header__count { font-size: var(--text-sm); color: var(--color-text-muted); }
.category-layout { display: grid; grid-template-columns: 1fr; gap: var(--space-8); }
@media (min-width: 1024px) { .category-layout { grid-template-columns: 240px 1fr; align-items: start; } }
.filters-sidebar { display: none; }
@media (min-width: 1024px) { .filters-sidebar { display: block; position: sticky; top: calc(var(--header-height) + var(--space-6)); } }
.filters-sidebar.is-open { display: block; position: fixed; inset-block: 0; left: 0; width: min(320px, 90vw); background: var(--color-white); z-index: 150; overflow-y: auto; box-shadow: var(--shadow-lg); padding: var(--space-6); }
.filter-group { margin-bottom: var(--space-6); }
.filter-group__trigger { width: 100%; text-align: left; font-size: var(--text-xs); font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--color-text); padding-bottom: var(--space-3); border-bottom: 1px solid var(--color-border); margin-bottom: var(--space-3); display: flex; justify-content: space-between; align-items: center; }
.filter-group__options { display: flex; flex-direction: column; gap: var(--space-2); }
.filter-option { display: flex; align-items: center; gap: var(--space-3); cursor: pointer; }
.filter-option__input { width: 16px; height: 16px; accent-color: var(--color-gold); cursor: pointer; flex-shrink: 0; }
.filter-option__label { font-size: var(--text-sm); color: var(--color-text); }
.filter-swatch { width: 20px; height: 20px; border-radius: var(--radius-full); border: 1.5px solid var(--color-border); flex-shrink: 0; }
.filter-swatch--dourado { background: var(--color-champagne); }
.filter-swatch--prata { background: #A8A8A8; }
.category-toolbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-6); gap: var(--space-4); }
.sort-select {
  padding: var(--space-2) var(--space-8) var(--space-2) var(--space-3); border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full); font-size: var(--text-sm); color: var(--color-text);
  background: var(--color-white); appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237A6B61' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center; cursor: pointer;
  transition: border-color var(--t-fast);
}
.sort-select:focus { border-color: var(--color-gold); outline: none; }
.products-empty { grid-column: 1/-1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-4); text-align: center; padding: var(--space-20) 0; color: var(--color-text-muted); }
.products-empty__title { font-family: var(--font-serif); font-size: var(--text-xl); color: var(--color-text); }
.pagination { display: flex; align-items: center; justify-content: center; gap: var(--space-2); margin-top: var(--space-12); }
.pagination__num, .pagination__btn {
  display: flex; align-items: center; justify-content: center; min-width: 40px; height: 40px;
  padding: 0 var(--space-3); border: 1.5px solid var(--color-border); border-radius: var(--radius-full);
  font-size: var(--text-sm); color: var(--color-text); transition: border-color var(--t-fast), background var(--t-fast);
}
.pagination__num:hover, .pagination__btn:hover { border-color: var(--color-text); }
.pagination__num.is-current { background: var(--color-moss); color: #fff; border-color: var(--color-moss); }

/* --------------------------------------------------------------------------
   28. Cart Page
   -------------------------------------------------------------------------- */
.page-cart { padding-top: var(--space-8); padding-bottom: var(--space-16); }
.page-cart__title { font-family: var(--font-serif); font-size: clamp(2rem, 4vw, 3rem); font-weight: 400; margin-bottom: var(--space-6); }
.cart-layout { display: grid; grid-template-columns: 1fr; gap: var(--space-8); }
@media (min-width: 1024px) { .cart-layout { grid-template-columns: 1fr 360px; align-items: start; } }
.cart-item--page { display: grid; grid-template-columns: auto 1fr; gap: var(--space-4); padding-block: var(--space-5); border-bottom: 1px solid var(--color-border); }
@media (min-width: 768px) { .cart-item--page { grid-template-columns: auto 1fr auto auto; align-items: center; gap: var(--space-8); } }
.cart-item--page .cart-item__product { display: flex; gap: var(--space-4); }
.cart-item--page .cart-item__image { width: 80px; height: 80px; }
.cart-item__remove-link { font-size: var(--text-xs); color: var(--color-text-muted); text-decoration: underline; text-underline-offset: 2px; cursor: pointer; margin-top: var(--space-2); display: block; background: none; border: none; padding: 0; transition: color var(--t-fast); }
.cart-item__remove-link:hover { color: var(--color-error); }
.cart-item__total-price { font-size: var(--text-md); font-weight: 600; }
.cart-summary { background: var(--color-rose); border-radius: var(--radius-xl); padding: var(--space-6); position: sticky; top: calc(var(--header-height) + var(--space-6)); }
.cart-summary__title { font-family: var(--font-serif); font-size: var(--text-xl); font-weight: 400; margin-bottom: var(--space-5); }
.cart-summary__row { display: flex; justify-content: space-between; padding-block: var(--space-3); border-bottom: 1px solid var(--color-border); font-size: var(--text-sm); color: var(--color-text-muted); }
.cart-summary__total { display: flex; justify-content: space-between; padding-block: var(--space-4); margin-bottom: var(--space-5); font-size: var(--text-md); }
.cart-summary__continue { display: block; text-align: center; margin-top: var(--space-4); font-size: var(--text-sm); color: var(--color-text-muted); text-decoration: underline; text-underline-offset: 3px; }
.cart-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-4); padding: var(--space-20) 0; text-align: center; }
.cart-empty__title { font-family: var(--font-serif); font-size: var(--text-2xl); font-weight: 400; }
.cart-empty__text { color: var(--color-text-muted); max-width: 360px; }
.shipping-bar--page { margin-bottom: var(--space-6); padding: var(--space-4); background: var(--color-rose); border-radius: var(--radius-md); }

/* --------------------------------------------------------------------------
   29. Static Pages
   -------------------------------------------------------------------------- */
.page-header { margin-bottom: var(--space-10); }
.page-header__title { font-family: var(--font-serif); font-size: clamp(2rem, 4vw, 3rem); font-weight: 400; margin-bottom: var(--space-4); }
.page-header__sub { font-size: var(--text-md); color: var(--color-text-muted); max-width: 520px; line-height: 1.7; }
.page-generic, .page-faq, .page-contact, .page-size-guide { padding-top: var(--space-8); padding-bottom: var(--space-16); }
.page-content { color: var(--color-text-muted); font-size: var(--text-md); line-height: 1.8; }
.faq-list { margin-bottom: var(--space-10); }
.faq-footer { text-align: center; padding: var(--space-10); background: var(--color-rose); border-radius: var(--radius-xl); display: flex; flex-direction: column; align-items: center; gap: var(--space-4); }
.contact-layout { display: grid; grid-template-columns: 1fr; gap: var(--space-12); }
@media (min-width: 768px) { .contact-layout { grid-template-columns: 1fr 1fr; } }
.form-group { margin-bottom: var(--space-5); }
.form-label { display: block; font-size: var(--text-xs); font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--color-text); margin-bottom: var(--space-2); }
.form-label--optional { font-weight: 400; color: var(--color-text-muted); text-transform: none; letter-spacing: 0; }
.form-input, .form-textarea { width: 100%; padding: var(--space-3) var(--space-4); border: 1.5px solid var(--color-border); border-radius: var(--radius-md); font-size: var(--text-base); color: var(--color-text); background: var(--color-white); transition: border-color var(--t-fast); resize: vertical; }
.form-input:focus, .form-textarea:focus { border-color: var(--color-gold); outline: none; }
.form-textarea { min-height: 120px; }
.contact-info__title { font-family: var(--font-serif); font-size: var(--text-xl); font-weight: 400; margin-bottom: var(--space-6); }
.contact-channel { display: flex; align-items: center; gap: var(--space-4); padding: var(--space-4); border: 1.5px solid var(--color-border); border-radius: var(--radius-md); margin-bottom: var(--space-4); transition: border-color var(--t-fast); }
.contact-channel:hover { border-color: var(--color-gold); }
.contact-channel__icon { color: var(--color-text-muted); }
.contact-channel__text { display: flex; flex-direction: column; }
.contact-channel__text strong { font-size: var(--text-sm); }
.contact-channel__text span { font-size: var(--text-xs); color: var(--color-text-muted); }
.contact-info__links { display: flex; flex-direction: column; gap: var(--space-2); margin-top: var(--space-6); }
.contact-info__link { font-size: var(--text-sm); color: var(--color-gold); text-decoration: underline; text-underline-offset: 3px; }
.size-guide-page { margin-bottom: var(--space-10); }
.size-guide__tips { margin-top: var(--space-8); padding: var(--space-6); background: var(--color-rose); border-radius: var(--radius-xl); }
.size-guide__tips-title { font-family: var(--font-sans); font-size: var(--text-base); font-weight: 600; margin-bottom: var(--space-4); }
.size-guide__tips-list { display: flex; flex-direction: column; gap: var(--space-3); list-style: disc; padding-left: var(--space-5); }
.size-guide__tips-list li { font-size: var(--text-sm); color: var(--color-text-muted); }
.size-guide__cta { text-align: center; }

/* --------------------------------------------------------------------------
   30. 404
   -------------------------------------------------------------------------- */
.page-404 { padding-block: var(--space-24); }
.page-404__content { max-width: 480px; margin-inline: auto; text-align: center; display: flex; flex-direction: column; align-items: center; gap: var(--space-4); }
.page-404__code { font-family: var(--font-serif); font-size: 7rem; font-weight: 300; line-height: 1; color: var(--color-border); }
.page-404__title { font-family: var(--font-serif); font-size: var(--text-2xl); font-weight: 400; }
.page-404__text { color: var(--color-text-muted); max-width: 360px; }
.page-404__ctas { display: flex; flex-wrap: wrap; gap: var(--space-3); justify-content: center; margin-top: var(--space-4); }

/* --------------------------------------------------------------------------
   31. Search page
   -------------------------------------------------------------------------- */
.search-header { margin-bottom: var(--space-8); }
.search-header__title { font-family: var(--font-serif); font-size: clamp(1.5rem, 3vw, 2.5rem); font-weight: 400; }
.search-empty { text-align: center; padding: var(--space-16) 0; display: flex; flex-direction: column; align-items: center; gap: var(--space-6); }
.search-empty__text { color: var(--color-text-muted); max-width: 400px; }
.search-empty__tags { display: flex; flex-wrap: wrap; gap: var(--space-2); justify-content: center; }

/* --------------------------------------------------------------------------
   32. Cookies Banner
   -------------------------------------------------------------------------- */
.cookies-banner {
  position: fixed; bottom: var(--space-4); left: var(--space-4); right: var(--space-4);
  max-width: 520px; background: var(--color-moss); color: #fff;
  border-radius: var(--radius-xl); z-index: 300; box-shadow: var(--shadow-lg);
  padding: var(--space-5) var(--space-6); opacity: 0; transition: opacity var(--t-base);
}
.cookies-banner:not([hidden]) { opacity: 1; }
@media (min-width: 640px) { .cookies-banner { right: auto; left: var(--space-6); bottom: var(--space-6); } }
.cookies-banner__inner { display: flex; flex-direction: column; gap: var(--space-4); }
@media (min-width: 480px) { .cookies-banner__inner { flex-direction: row; align-items: center; } }
.cookies-banner__text { font-size: var(--text-xs); color: rgba(255,255,255,.7); line-height: 1.6; }
.cookies-banner__link { color: var(--color-gold-light); text-decoration: underline; }
.cookies-banner__actions { display: flex; gap: var(--space-2); flex-shrink: 0; }
.cookies-banner .btn--ghost { border-color: rgba(255,255,255,.2); color: rgba(255,255,255,.7); font-size: var(--text-xs); }
.cookies-banner .btn--gold { font-size: var(--text-xs); }

/* --------------------------------------------------------------------------
   33. Misc utilities
   -------------------------------------------------------------------------- */
[hidden] { display: none !important; }

@keyframes shimmer {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}
.is-loading { position: relative; overflow: hidden; }
.is-loading::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,.5) 50%, transparent 100%);
  animation: shimmer 1.5s infinite;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}
@media print {
  .site-header, .site-footer, .cart-drawer, .search-drawer, .cookies-banner { display: none !important; }
}
