/* ============================================================
   PRIME DECANTS — Main Stylesheet
   Brand colors from settings_data.json
   ============================================================ */

/* ── CSS Custom Properties ─────────────────────────────────── */
:root {
  /* Colors */
  --color-bg: #ffffff;
  --color-heading: #1a1a1a;
  --color-text: #3a3a3a;
  --color-text-muted: #6a6a6a;
  --color-gold: #c7a86b;
  --color-gold-dark: #a67f4a;
  --color-dark: #282928;
  --color-button: #282928;
  --color-button-text: #ffffff;
  --color-button-hover: #101010;
  --color-sale: #b04a2e;
  --color-success: #6a8f77;
  --color-error: #b04a2e;
  --color-border: #e6e6e6;
  --color-secondary-bg: #f3f6ef;

  /* Header */
  --color-header-bg: #ffffff;
  --color-header-text: #282928;
  --color-header-border: #e1e3e1;

  /* Footer */
  --color-footer-bg: #282928;
  --color-footer-heading: #ffffff;
  --color-footer-text: #d0d0d0;
  --color-footer-link: #c7a86b;
  --color-footer-border: #343634;

  /* Scrolling banner */
  --color-banner-bg: #c7a86b;
  --color-banner-text: #1a1a1a;

  /* Typography */
  --font-body: 'DM Sans', system-ui, -apple-system, sans-serif;
  --font-heading: 'DM Sans', system-ui, -apple-system, sans-serif;
  --font-highlight: 'Playfair Display', Georgia, serif;

  /* Spacing */
  --page-width: 1400px;
  --section-gap: 60px;
  --section-gap-mobile: 36px;

  /* Misc */
  --header-height: 64px;
  --radius: 8px;
  --radius-sm: 4px;
  --shadow: 0 2px 20px rgba(0,0,0,0.08);
  --transition: 0.2s ease;
}

/* ── Reset ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  font-size: 15.4px; /* 110% of 14px base */
  line-height: 1.6;
  color: var(--color-text);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; background: none; border: none; font: inherit; }
ul { list-style: none; }
input, button, textarea { font: inherit; }

/* ── Layout ────────────────────────────────────────────────── */
.page-width {
  max-width: var(--page-width);
  margin: 0 auto;
  padding: 0 24px;
}
@media (min-width: 768px) { .page-width { padding: 0 40px; } }
@media (min-width: 1200px) { .page-width { padding: 0 60px; } }

/* ── Buttons ───────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 24px;
  border-radius: var(--radius);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1;
  transition: background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition);
  white-space: nowrap;
  text-align: center;
}
.btn--primary {
  background: var(--color-button);
  color: var(--color-button-text);
  border: 2px solid var(--color-button);
}
.btn--primary:hover {
  background: var(--color-button-hover);
  border-color: var(--color-button-hover);
  transform: translateY(-1px);
}
.btn--secondary {
  background: transparent;
  color: var(--color-button);
  border: 2px solid var(--color-button);
}
.btn--secondary:hover {
  background: var(--color-button);
  color: var(--color-button-text);
}
.btn--sm { padding: 9px 16px; font-size: 13px; }
.btn--full { width: 100%; }
.btn--hero { padding: 14px 28px; font-size: 15px; }
.btn:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }

/* ── Icon buttons ──────────────────────────────────────────── */
.icon-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  color: var(--color-header-text);
  transition: background var(--transition), color var(--transition);
  position: relative;
}
.icon-btn:hover { background: rgba(0,0,0,0.06); }
.icon-btn svg { width: 20px; height: 20px; }

/* ── Typography ────────────────────────────────────────────── */
.section-heading {
  font-family: var(--font-heading);
  font-size: clamp(24px, 4vw, 42px);
  font-weight: 500;
  color: var(--color-heading);
  line-height: 1.15;
  margin-bottom: 32px;
  letter-spacing: -0.02em;
}
.section-heading--center { text-align: center; }
.heading-highlight, em.heading-highlight {
  font-family: var(--font-highlight);
  font-style: italic;
  color: var(--color-heading);
}

/* ============================================================
   SCROLLING BANNER
   ============================================================ */
.scrolling-banner {
  background: var(--color-banner-bg);
  color: var(--color-banner-text);
  font-size: 13px;
  font-weight: 500;
  overflow: hidden;
  white-space: nowrap;
  height: 40px;
  display: flex;
  align-items: center;
  letter-spacing: 0.01em;
}
.scrolling-track {
  display: inline-flex;
  animation: scrollBanner 30s linear infinite;
}
.scrolling-track:hover { animation-play-state: paused; }
.scrolling-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0 60px;
}
.banner-icon { width: 16px; height: 16px; flex-shrink: 0; }
@keyframes scrollBanner {
  0% { transform: translateX(0); }
  100% { transform: translateX(-33.333%); }
}

/* ============================================================
   HEADER
   ============================================================ */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--color-header-bg);
  border-bottom: 1px solid var(--color-header-border);
  box-shadow: 0 1px 12px rgba(0,0,0,0.06);
  transition: box-shadow var(--transition);
}
.site-header.scrolled { box-shadow: 0 2px 20px rgba(0,0,0,0.12); }

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

/* Logo */
.logo {
  display: flex;
  align-items: center;
  color: var(--color-header-text);
  flex-shrink: 0;
  transition: opacity var(--transition);
}
.logo:hover { opacity: 0.8; }
.logo-img { height: 36px; width: auto; object-fit: contain; display: block; }
@media (max-width: 1023px) { .logo-img { height: 28px; } }

/* Desktop nav */
.main-nav { flex: 1; display: flex; justify-content: center; }
.nav-list { display: flex; align-items: center; gap: 4px; }
.nav-item { position: relative; }
.nav-link {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 8px 14px;
  font-size: 14px;
  font-weight: 500;
  color: var(--color-header-text);
  border-radius: var(--radius-sm);
  transition: background var(--transition), color var(--transition);
  white-space: nowrap;
}
.nav-link:hover, .nav-item:hover > .nav-link {
  background: var(--color-secondary-bg);
  color: var(--color-heading);
}
.nav-caret { width: 10px; height: 6px; transition: transform var(--transition); }
.nav-item:hover > .nav-link .nav-caret { transform: rotate(180deg); }

/* Dropdown */
.nav-dropdown {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  min-width: 200px;
  padding: 16px 8px 8px; /* top padding bridges the visual gap without breaking hover chain */
  opacity: 0;
  visibility: hidden;
  transform: translateX(-50%) translateY(-4px);
  transition: opacity var(--transition), transform var(--transition), visibility var(--transition);
  transition-delay: 150ms; /* delay hiding so cursor has time to reach the dropdown */
  pointer-events: none;
}
.nav-item:hover .nav-dropdown,
.nav-item:focus-within .nav-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
  pointer-events: all;
  transition-delay: 0ms; /* show immediately */
}
.dropdown-list { display: flex; flex-direction: column; }
.dropdown-list a {
  display: block;
  padding: 9px 14px;
  font-size: 14px;
  border-radius: var(--radius-sm);
  transition: background var(--transition), color var(--transition);
  color: var(--color-text);
}
.dropdown-list a:hover { background: var(--color-secondary-bg); color: var(--color-heading); }
.dropdown-list li:last-child a { color: var(--color-gold-dark); font-weight: 500; }

/* Header icons */
.header-icons { display: flex; align-items: center; gap: 4px; }
.cart-count {
  position: absolute;
  top: 2px; right: 2px;
  background: var(--color-gold);
  color: white;
  font-size: 10px;
  font-weight: 700;
  min-width: 16px;
  height: 16px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 3px;
  line-height: 1;
}
.cart-count:empty, [data-count="0"] .cart-count { display: none; }

/* Hamburger */
.hamburger-btn { display: none; }
.hamburger-close { display: none; }
.hamburger-btn.is-open .hamburger-open { display: none; }
.hamburger-btn.is-open .hamburger-close { display: block; }

@media (max-width: 1023px) {
  .main-nav { display: none; }
  .hamburger-btn { display: flex; }
}

/* ── Search Overlay ──────────────────────────────────────────── */
.search-overlay {
  position: absolute;
  top: 100%;
  left: 0; right: 0;
  background: white;
  border-bottom: 1px solid var(--color-border);
  padding: 20px 0;
  transform: translateY(-8px);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition), transform var(--transition), visibility var(--transition);
  z-index: 90;
  box-shadow: 0 8px 24px rgba(0,0,0,0.1);
}
.search-overlay.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.search-inner { display: flex; flex-direction: column; gap: 12px; }
.search-form {
  display: flex;
  align-items: center;
  gap: 12px;
  border: 2px solid var(--color-border);
  border-radius: var(--radius);
  padding: 10px 16px;
  transition: border-color var(--transition);
}
.search-form:focus-within { border-color: var(--color-gold); }
.search-icon { width: 18px; height: 18px; flex-shrink: 0; color: var(--color-text-muted); }
.search-input {
  flex: 1;
  border: none;
  outline: none;
  font-size: 15px;
  color: var(--color-heading);
  background: transparent;
}
.search-input::placeholder { color: var(--color-text-muted); }
.search-close { color: var(--color-text-muted); transition: color var(--transition); }
.search-close:hover { color: var(--color-heading); }
.search-close svg { width: 18px; height: 18px; }
.search-prompts { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.search-prompt-label { font-size: 13px; color: var(--color-text-muted); }
.search-prompt-tag {
  font-size: 13px;
  padding: 4px 10px;
  background: var(--color-secondary-bg);
  border-radius: 20px;
  color: var(--color-text);
  transition: background var(--transition), color var(--transition);
}
.search-prompt-tag:hover { background: var(--color-dark); color: white; }

/* ── Mobile Menu ─────────────────────────────────────────────── */
.mobile-menu {
  position: fixed;
  top: 0; left: 0;
  width: min(360px, 90vw);
  height: 100vh;
  background: white;
  z-index: 200;
  transform: translateX(-100%);
  transition: transform 0.3s ease;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  padding-top: var(--header-height);
}
.mobile-menu.is-open { transform: translateX(0); }
.mobile-menu-inner { display: flex; flex-direction: column; height: 100%; padding: 16px 0; }

.mobile-nav-list { padding: 0 16px; }
.mobile-nav-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 14px 8px;
  font-size: 16px;
  font-weight: 500;
  color: var(--color-heading);
  border-bottom: 1px solid var(--color-border);
  text-align: left;
}
.mobile-nav-link:hover { color: var(--color-gold-dark); }
.mobile-nav-caret { width: 10px; height: 6px; transition: transform var(--transition); }
.mobile-nav-expand.is-open .mobile-nav-caret { transform: rotate(180deg); }
.mobile-sub-nav { display: none; padding: 8px 0 8px 16px; }
.mobile-sub-nav.is-open { display: block; }
.mobile-sub-nav a {
  display: block;
  padding: 10px 8px;
  font-size: 14px;
  color: var(--color-text);
  border-bottom: 1px solid rgba(0,0,0,0.05);
}
.mobile-sub-nav a:hover { color: var(--color-gold-dark); }

.mobile-menu-footer {
  margin-top: auto;
  padding: 24px;
  border-top: 1px solid var(--color-border);
}
.mobile-social-links { display: flex; gap: 12px; margin-bottom: 12px; }
.mobile-social-links a { color: var(--color-text); transition: color var(--transition); }
.mobile-social-links a:hover { color: var(--color-gold-dark); }
.mobile-social-links svg { width: 22px; height: 22px; }
.mobile-email a { font-size: 13px; color: var(--color-text-muted); }
.mobile-email a:hover { color: var(--color-gold-dark); }

/* Overlay backdrop */
.overlay-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.4);
  z-index: 150;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.overlay-backdrop.is-visible { opacity: 1; visibility: visible; }

/* ============================================================
   HERO SECTION
   ============================================================ */
/* ── Hero — bottles panel ────────────────────────────────── */
.hero-section { display: flex; flex-direction: column; }

.hero-bottles-area {
  background: #d8dfe6;
  /* No fixed height — grows with image so nothing ever crops */
  overflow: visible;
}
.hero-elite-img {
  width: 100%;
  height: auto;   /* natural proportions — no crop */
  display: block;
}

.hero-bottles-grid {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  width: 100%;
  height: 100%;
  gap: 0;
  padding: 0 2%;
}

.hero-bottle {
  flex: 1;
  height: 100%;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  text-decoration: none;
  overflow: hidden;
  transition: transform 0.3s ease;
}
.hero-bottle--center {
  flex: 1.4;
  z-index: 2;
}
.hero-bottle:hover { transform: translateY(-6px); }
.hero-bottle--center:hover { transform: translateY(-8px); }

.hero-bottle img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: bottom center;
  display: block;
}

/* Skeleton placeholders */
.skeleton-hero-bottle {
  background: linear-gradient(90deg,rgba(255,255,255,.12) 25%,rgba(255,255,255,.22) 50%,rgba(255,255,255,.12) 75%);
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.6s infinite;
  border-radius: 8px 8px 0 0;
  margin: 0 12px 0;
  height: 70%;
  max-width: 180px;
}
.skeleton-hero-bottle.hero-bottle--center { height: 85%; max-width: 240px; }
@media (max-width: 767px) {
  .skeleton-hero-bottle { max-width: 80px; }
  .skeleton-hero-bottle.hero-bottle--center { max-width: 110px; }
}

/* ── Hero — overlay (heading + buttons on image) ───────── */
.hero-overlay-top {
  position: absolute;
  top: 28px;
  left: 36px;
  right: 36px;
  display: flex;
  align-items: center;
  gap: 32px;
  z-index: 10;
  pointer-events: none;
}
.hero-overlay-top > * { pointer-events: auto; }

.hero-heading {
  font-size: clamp(22px, 3.2vw, 52px);
  font-weight: 500;
  color: #ffffff;
  line-height: 1.05;
  letter-spacing: -0.03em;
  margin: 0;
  white-space: nowrap;
  flex-shrink: 0;
  text-shadow: 0 2px 14px rgba(0,0,0,0.55);
}
.hero-highlight {
  font-family: var(--font-highlight);
  font-style: italic;
  color: var(--color-gold);
}
@media (min-width: 768px) {
  .hero-highlight { color: #1a1a1a; }
}
.hero-buttons { display: flex; gap: 10px; flex-wrap: nowrap; }
.hero-buttons .btn--primary {
  background: #ffffff;
  color: #1a1a1a;
  border-color: #ffffff;
}
.hero-buttons .btn--primary:hover {
  background: rgba(255,255,255,0.9);
  border-color: rgba(255,255,255,0.9);
  color: #1a1a1a;
}
@media (max-width: 767px) {
  .hero-overlay-top {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    top: 16px;
    left: 16px;
    right: 16px;
  }
  .hero-heading { white-space: normal; }
  .hero-buttons { flex-wrap: wrap; }
}

/* ── Mobile hero CTA (below image) ─────────────────────── */
.hero-mobile-cta { display: none; }

@media (max-width: 767px) {
  .hero-overlay-top { display: none; }

  .hero-mobile-cta {
    display: block;
    background: #ffffff;
    padding: 24px 20px 20px;
    text-align: center;
    border-bottom: 1px solid var(--color-border);
  }

  .hero-mobile-heading {
    font-size: clamp(26px, 7vw, 38px);
    white-space: normal;
    color: #1a1a1a;
    text-shadow: none;
    margin-bottom: 16px;
  }

  .hero-mobile-cta .hero-highlight { color: var(--color-gold); }

  .hero-mobile-buttons { justify-content: center; flex-wrap: wrap; gap: 10px; }

  .hero-mobile-buttons .btn--primary {
    background: #1a1a1a;
    color: #ffffff;
    border-color: #1a1a1a;
  }
  .hero-mobile-buttons .btn--primary:hover {
    background: #ffffff;
    border-color: #1a1a1a;
    color: #1a1a1a;
  }
}

/* ============================================================
   SHOP BY BRAND
   ============================================================ */
.brand-section {
  padding: var(--section-gap) 0;
  border-bottom: 1px solid var(--color-border);
}
@media (max-width: 767px) { .brand-section { padding: var(--section-gap-mobile) 0; } }

.brand-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--color-border);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
}
@media (max-width: 767px) { .brand-grid { grid-template-columns: repeat(2, 1fr); } }

.brand-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 32px 24px;
  background: var(--color-bg);
  text-align: center;
  transition: background var(--transition), color var(--transition);
  gap: 12px;
}
.brand-card:hover { background: var(--color-secondary-bg); }
.brand-logo-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 52px;
}
.brand-logo-text { width: 180px; height: 50px; color: var(--color-heading); }
.brand-count {
  font-size: 12px;
  color: var(--color-text-muted);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  transition: color var(--transition);
}
.brand-card:hover .brand-count { color: var(--color-gold-dark); }

/* ============================================================
   FEATURED COLLECTIONS
   ============================================================ */
.collections-section { padding: var(--section-gap) 0; }
@media (max-width: 767px) { .collections-section { padding: var(--section-gap-mobile) 0; } }

.collections-header { margin-bottom: 40px; }
.collections-header .section-heading { margin-bottom: 24px; }

/* Tabs */
.collection-tabs {
  display: flex;
  justify-content: center;
  gap: 4px;
  flex-wrap: wrap;
}
.tab-btn {
  padding: 9px 20px;
  font-size: 14px;
  font-weight: 500;
  color: var(--color-text);
  border: 2px solid var(--color-border);
  border-radius: 24px;
  transition: all var(--transition);
  white-space: nowrap;
}
.tab-btn:hover { border-color: var(--color-dark); color: var(--color-heading); }
.tab-btn.active {
  background: var(--color-dark);
  color: white;
  border-color: var(--color-dark);
}

/* Products grid */
.products-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px;
}
@media (max-width: 1200px) { .products-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 900px) { .products-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px) { .products-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; } }

/* Product card */
.product-card {
  display: flex;
  flex-direction: column;
}
.product-card__image-link {
  display: block;
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  margin-bottom: 12px;
}
.product-card__image-wrap {
  aspect-ratio: 3/4;
  overflow: hidden;
}
.product-card__image-link:hover .product-card__image-wrap > div {
  transform: scale(1.04);
}

/* Placeholder images */
.product-placeholder {
  width: 100%;
  height: 100%;
  transition: transform 0.4s ease;
}
.product-placeholder--1 { background: linear-gradient(145deg, #f5f0ea 0%, #e8dfd4 40%, #d4c5b0 100%); }
.product-placeholder--2 { background: linear-gradient(145deg, #e8eff5 0%, #cdd9e6 40%, #b5c8d8 100%); }
.product-placeholder--3 { background: linear-gradient(145deg, #f0ede8 0%, #e0dbd3 40%, #c8c0b4 100%); }
.product-placeholder--4 { background: linear-gradient(145deg, #ede8f0 0%, #ddd3e6 40%, #c8b8d4 100%); }
.product-placeholder--5 { background: linear-gradient(145deg, #f5eae8 0%, #e6d4d0 40%, #d4b8b4 100%); }
.product-placeholder--6 { background: linear-gradient(145deg, #e8f0ea 0%, #d0e0d4 40%, #b4c8bc 100%); }
.product-placeholder--7 { background: linear-gradient(145deg, #f0f0e8 0%, #e0e0d0 40%, #c8c8b4 100%); }
.product-placeholder--8 { background: linear-gradient(145deg, #eaecf0 0%, #d4d8e6 40%, #b8bcd4 100%); }
.product-placeholder--9 { background: linear-gradient(145deg, #f0eaea 0%, #e6d4d4 40%, #d4b8b8 100%); }

/* After/before decorative bottle shape on placeholder */
.product-placeholder::after {
  content: '';
  display: block;
  width: 40%;
  height: 65%;
  background: rgba(255,255,255,0.25);
  border-radius: 12px 12px 8px 8px;
  position: relative;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

/* Badge */
.product-card__badge {
  position: absolute;
  top: 10px;
  left: 10px;
  padding: 4px 8px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-radius: var(--radius-sm);
  background: var(--color-dark);
  color: white;
  z-index: 1;
}
.product-card__badge--sale { background: var(--color-sale); }
.product-card__badge--new { background: var(--color-success); }

.product-card__info { display: flex; flex-direction: column; gap: 4px; flex: 1; }
.product-card__vendor { font-size: 12px; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.06em; }
.product-card__title { font-size: 14px; font-weight: 500; color: var(--color-heading); line-height: 1.3; margin-bottom: 2px; }
.product-card__title a { color: inherit; }
.product-card__title a:hover { color: var(--color-gold-dark); }
.price { font-size: 14px; font-weight: 500; color: var(--color-heading); }
.price--sale { color: var(--color-sale); }
.price--compare { font-size: 12px; text-decoration: line-through; color: var(--color-text-muted); }

.product-card__price { display: flex; align-items: baseline; gap: 6px; margin-bottom: 8px; }
.quick-add-btn { margin-top: auto; }

/* View all link */
.collection-view-all { text-align: center; margin-top: 40px; }

/* Tab panels */
.tab-panel[hidden] { display: none; }

/* ============================================================
   BUNDLE SECTION
   ============================================================ */
.bundle-section {
  padding: var(--section-gap) 0;
  background: var(--color-secondary-bg);
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}
@media (max-width: 767px) { .bundle-section { padding: var(--section-gap-mobile) 0; } }

.bundle-header { text-align: center; margin-bottom: 40px; }
.bundle-description { font-size: 16px; color: var(--color-text); max-width: 560px; margin: 0 auto; line-height: 1.5; }

.bundle-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 32px;
  align-items: start;
}
@media (max-width: 1023px) {
  .bundle-layout { grid-template-columns: 1fr; }
}

.bundle-products-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
}
@media (max-width: 1200px) { .bundle-products-grid { grid-template-columns: repeat(5, 1fr); } }
@media (max-width: 900px) { .bundle-products-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 600px) { .bundle-products-grid { grid-template-columns: repeat(3, 1fr); gap: 8px; } }

.bundle-product-card {
  display: flex;
  flex-direction: column;
  border: 2px solid transparent;
  border-radius: var(--radius);
  overflow: hidden;
  cursor: pointer;
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
  background: white;
  text-align: left;
}
.bundle-product-card:hover { border-color: var(--color-border); transform: translateY(-2px); }
.bundle-product-card.selected { border-color: var(--color-gold); box-shadow: 0 0 0 1px var(--color-gold); }

.bundle-product-image {
  position: relative;
  aspect-ratio: 3/4;
  overflow: hidden;
}
.bundle-product-image .product-placeholder { width: 100%; height: 100%; }

.bundle-check-icon {
  position: absolute;
  top: 8px; right: 8px;
  width: 24px; height: 24px;
  background: var(--color-gold);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transform: scale(0.6);
  transition: opacity var(--transition), transform var(--transition);
}
.bundle-check-icon svg { width: 14px; height: 14px; color: white; }
.bundle-product-card.selected .bundle-check-icon { opacity: 1; transform: scale(1); }

.bundle-product-info { padding: 8px 10px 10px; }
.bundle-vendor { font-size: 10px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--color-text-muted); margin-bottom: 2px; }
.bundle-title { font-size: 12px; font-weight: 500; color: var(--color-heading); line-height: 1.2; margin-bottom: 2px; }
.bundle-price { font-size: 12px; color: var(--color-text); }
.bundle-size-select {
  width: 100%;
  margin-top: 5px;
  padding: 4px 6px;
  font-size: 11px;
  font-family: inherit;
  border: 1px solid var(--color-border);
  border-radius: 4px;
  background: #fafafa;
  color: var(--color-text);
  cursor: pointer;
  appearance: auto;
}
.bundle-size-single { font-size: 11px; color: var(--color-text-muted); margin-top: 4px; }

/* Bundle summary */
.bundle-summary {
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 24px;
  position: sticky;
  top: calc(var(--header-height) + 16px);
}
.bundle-summary-heading { font-size: 18px; font-weight: 600; color: var(--color-heading); margin-bottom: 4px; }
.bundle-summary-desc { font-size: 13px; color: var(--color-text-muted); margin-bottom: 16px; line-height: 1.4; }

.bundle-items-list { min-height: 80px; margin-bottom: 16px; }
.bundle-empty-msg { font-size: 13px; color: var(--color-text-muted); font-style: italic; padding: 16px 0; }
.bundle-item-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 0;
  border-bottom: 1px solid var(--color-border);
  font-size: 13px;
}
.bundle-item-row:last-child { border-bottom: none; }
.bundle-item-name { flex: 1; color: var(--color-heading); }
.bundle-item-price { color: var(--color-text); }
.bundle-item-remove {
  color: var(--color-text-muted);
  transition: color var(--transition);
  padding: 2px;
  display: flex;
}
.bundle-item-remove:hover { color: var(--color-error); }
.bundle-item-remove svg { width: 14px; height: 14px; }

/* Progress bar */
.bundle-discount-bar { margin-bottom: 16px; }
.bundle-progress-track {
  height: 4px;
  background: var(--color-border);
  border-radius: 2px;
  overflow: hidden;
  margin-bottom: 6px;
}
.bundle-progress-fill {
  height: 100%;
  background: var(--color-gold);
  border-radius: 2px;
  transition: width 0.3s ease;
}
.bundle-progress-label { font-size: 12px; color: var(--color-text-muted); }

/* Totals */
.bundle-totals { margin-bottom: 16px; border-top: 1px solid var(--color-border); padding-top: 12px; }
.bundle-total-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 14px;
  padding: 4px 0;
  color: var(--color-text);
}
.bundle-total-final { font-size: 16px; font-weight: 600; color: var(--color-heading); }
.bundle-discount-label { color: var(--color-success); }
.bundle-discount-value { color: var(--color-success); }

.bundle-add-btn { margin-bottom: 12px; }
.bundle-note { font-size: 12px; color: var(--color-text-muted); line-height: 1.6; }

/* ============================================================
   REVIEWS SECTION
   ============================================================ */
.reviews-section { padding: var(--section-gap) 0; }
@media (max-width: 767px) { .reviews-section { padding: var(--section-gap-mobile) 0; } }

.reviews-carousel { position: relative; overflow: hidden; }
.review-card {
  display: none;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 0 24px;
  max-width: 760px;
  margin: 0 auto;
}
.review-card.active { display: flex; }

.review-stars { display: flex; gap: 4px; margin-bottom: 20px; }
.review-stars svg { width: 20px; height: 20px; }

.review-text {
  font-size: clamp(16px, 2.5vw, 22px);
  color: var(--color-heading);
  line-height: 1.5;
  font-style: normal;
  margin-bottom: 20px;
  font-weight: 400;
}
.review-author { font-size: 14px; color: var(--color-text-muted); font-style: normal; }

.review-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-top: 32px;
}
.review-dots { display: flex; gap: 8px; }
.review-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--color-border);
  border: none;
  transition: background var(--transition), transform var(--transition);
  padding: 0;
}
.review-dot.active { background: var(--color-gold); transform: scale(1.3); }
.review-prev, .review-next {
  color: var(--color-text-muted);
  transition: color var(--transition);
}
.review-prev:hover, .review-next:hover { color: var(--color-heading); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
  background: var(--color-footer-bg);
  color: var(--color-footer-text);
}
.footer-inner { padding-top: 44px; padding-bottom: 0; }
.footer-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 32px;
  padding-bottom: 36px;
  border-bottom: 1px solid var(--color-footer-border);
}
@media (max-width: 1100px) { .footer-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 700px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .footer-grid { grid-template-columns: 1fr; gap: 24px; } }

.footer-col-heading {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-footer-heading);
  margin-bottom: 16px;
}
.footer-text { font-size: 14px; line-height: 1.6; color: var(--color-footer-text); margin-bottom: 16px; }

.footer-socials { display: flex; gap: 12px; }
.social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
  color: var(--color-footer-text);
  transition: background var(--transition), color var(--transition);
}
.social-link:hover { background: var(--color-gold); color: var(--color-dark); }
.social-link svg { width: 16px; height: 16px; }

.footer-links { display: flex; flex-direction: column; gap: 8px; }
.footer-links a {
  font-size: 14px;
  color: var(--color-footer-text);
  transition: color var(--transition);
  line-height: 1.4;
}
.footer-links a:hover { color: var(--color-footer-link); }

.footer-trust-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 20px; }
.footer-trust-list li {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--color-footer-text);
}
.trust-icon { width: 14px; height: 14px; color: var(--color-gold); flex-shrink: 0; }

.footer-payment-icons { display: flex; gap: 6px; flex-wrap: wrap; }
.payment-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 8px;
  font-size: 10px;
  font-weight: 700;
  background: rgba(255,255,255,0.1);
  color: rgba(255,255,255,0.7);
  border-radius: 4px;
  letter-spacing: 0.04em;
  border: 1px solid rgba(255,255,255,0.15);
}

.footer-bottom {
  padding: 20px 0;
}
.footer-bottom-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
}
.footer-copyright, .footer-disclaimer {
  font-size: 12px;
  color: rgba(255,255,255,0.35);
  line-height: 1.5;
}
@media (max-width: 700px) { .footer-bottom-inner { flex-direction: column; text-align: center; } }

/* ============================================================
   CART DRAWER
   ============================================================ */
.cart-drawer {
  position: fixed;
  inset: 0;
  z-index: 300;
  pointer-events: none;
}
.cart-drawer.is-open { pointer-events: all; }
.cart-drawer-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.4);
  opacity: 0;
  transition: opacity 0.3s ease;
}
.cart-drawer.is-open .cart-drawer-overlay { opacity: 1; }
.cart-drawer-panel {
  position: absolute;
  top: 0; right: 0;
  width: min(420px, 100vw);
  height: 100%;
  background: white;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.3s ease;
  box-shadow: -4px 0 40px rgba(0,0,0,0.15);
}
.cart-drawer.is-open .cart-drawer-panel { transform: translateX(0); }

.cart-drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid var(--color-border);
}
.cart-drawer-title { font-size: 18px; font-weight: 600; color: var(--color-heading); }
.cart-drawer-close { color: var(--color-text); }

.cart-drawer-body { flex: 1; overflow-y: auto; padding: 24px; }
.cart-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
  padding: 40px 0;
}
.cart-empty-icon { width: 48px; height: 48px; color: var(--color-text-muted); margin-bottom: 8px; }
.cart-empty p { font-size: 16px; font-weight: 500; color: var(--color-heading); }
.cart-empty-sub { font-size: 14px; color: var(--color-text-muted); line-height: 1.5; }

/* Cart item */
.cart-item {
  display: flex;
  gap: 16px;
  padding: 16px 0;
  border-bottom: 1px solid var(--color-border);
}
.cart-item__image {
  width: 80px;
  height: 100px;
  border-radius: var(--radius-sm);
  overflow: hidden;
  flex-shrink: 0;
}
.cart-item__image .product-placeholder { width: 100%; height: 100%; }
.cart-item__info { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.cart-item__vendor { font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--color-text-muted); }
.cart-item__title { font-size: 14px; font-weight: 500; color: var(--color-heading); }
.cart-item__variant { font-size: 12px; color: var(--color-text-muted); }
.cart-item__price { font-size: 14px; font-weight: 500; color: var(--color-heading); }
.cart-item__remove { font-size: 12px; color: var(--color-text-muted); margin-top: auto; transition: color var(--transition); align-self: flex-start; }
.cart-item__remove:hover { color: var(--color-error); }

.cart-drawer-footer { padding: 20px 24px; border-top: 1px solid var(--color-border); }
.freeshipping-bar { margin-bottom: 16px; }
.freeshipping-track { height: 4px; background: var(--color-border); border-radius: 2px; overflow: hidden; margin-bottom: 6px; }
.freeshipping-fill { height: 100%; background: var(--color-success); border-radius: 2px; transition: width 0.3s ease; }
.freeshipping-label { font-size: 12px; color: var(--color-text-muted); }
.cart-totals { margin-bottom: 16px; }
.cart-total-row { display: flex; justify-content: space-between; font-size: 15px; font-weight: 500; color: var(--color-heading); padding: 4px 0; }
.cart-payment-methods { display: flex; gap: 6px; justify-content: center; margin-top: 12px; flex-wrap: wrap; }

/* ============================================================
   SCROLL TO TOP
   ============================================================ */
.scroll-top-btn {
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: 44px; height: 44px;
  background: var(--color-dark);
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 50;
  box-shadow: 0 4px 16px rgba(0,0,0,0.2);
  transition: background var(--transition), transform var(--transition), opacity 0.3s;
}
.scroll-top-btn:hover { background: var(--color-gold-dark); transform: translateY(-2px); }
.scroll-top-btn svg { width: 20px; height: 20px; }

/* ============================================================
   UTILITY / ANIMATIONS
   ============================================================ */
@keyframes fadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.tab-panel.active { animation: fadeIn 0.2s ease; }

/* Focus visible */
:focus-visible { outline: 2px solid var(--color-gold); outline-offset: 2px; }

/* ============================================================
   SHOPIFY API INTEGRATION — additions
   ============================================================ */

/* Real product/bundle/cart images */
.product-card__image-wrap img,
.bundle-product-image img,
.cart-item__image img,
.search-result-img img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
}

/* Skeleton loader */
@keyframes skeleton-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
.skeleton-block,
.skeleton-line,
.skeleton-btn {
  background: linear-gradient(90deg, #ebebeb 25%, #d6d6d6 50%, #ebebeb 75%);
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.4s infinite;
  border-radius: 4px;
}
.product-card--skeleton .product-card__image-wrap { background: #ebebeb; }
.product-card--skeleton .product-card__image-wrap.skeleton-block { width: 100%; aspect-ratio: 3/4; }
.product-card--skeleton .skeleton-line  { height: 12px; margin: 10px 0; }
.product-card--skeleton .skeleton-btn   { height: 36px; margin-top: 12px; border-radius: 6px; }
.bundle-product-card--skeleton .bundle-product-image.skeleton-block { height: 140px; border-radius: 6px; }
.bundle-product-card--skeleton .skeleton-line { height: 10px; margin: 8px 0; }
.bundle-product-card--skeleton { pointer-events: none; }

/* Cart qty controls */
.cart-item__qty-wrap {
  display: flex; align-items: center; gap: 8px;
  margin: 6px 0;
}
.cart-qty-btn {
  width: 26px; height: 26px;
  border: 1px solid var(--color-border, #ddd);
  background: transparent; cursor: pointer;
  border-radius: 50%; font-size: 16px; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.15s;
}
.cart-qty-btn:hover { background: var(--color-secondary-bg, #f3f6ef); }
.cart-qty-num { min-width: 20px; text-align: center; font-size: 13px; }

/* Cart loading overlay */
.cart-drawer-footer.is-loading { opacity: 0.5; pointer-events: none; }

/* Search live results */
#search-results { margin-top: 12px; }
.search-loading  { color: var(--color-text-light, #777); font-size: 13px; padding: 4px 0; }
.search-no-results { color: var(--color-text-light, #777); font-size: 14px; padding: 4px 0; }
.search-results-list { list-style: none; margin: 0; padding: 0; }
.search-result-item + .search-result-item { border-top: 1px solid var(--color-border, #eee); }
.search-result-link {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 0; text-decoration: none; color: inherit;
}
.search-result-link:hover .search-result-title { color: var(--color-gold, #c7a86b); }
.search-result-img {
  width: 52px; height: 52px; flex-shrink: 0;
  border-radius: 4px; overflow: hidden; background: #f5f5f5;
}
.search-result-vendor { font-size: 11px; color: var(--color-text-light, #777); text-transform: uppercase; letter-spacing: 0.05em; margin: 0; }
.search-result-title  { font-size: 14px; font-weight: 500; margin: 2px 0; }
.search-result-price  { font-size: 13px; color: var(--color-gold, #c7a86b); margin: 0; }

/* No products message */
.no-products {
  grid-column: 1 / -1; text-align: center;
  padding: 40px 20px; color: var(--color-text-light, #777);
}

/* Sale pricing */
.price--sale { color: #c0392b; font-weight: 700; }
.price--compare { color: var(--color-text-light, #999); font-size: 0.88em; margin-left: 4px; }
.product-card__badge {
  position: absolute; top: 10px; left: 10px;
  background: #c0392b; color: #fff;
  font-size: 11px; font-weight: 700; letter-spacing: 0.07em; text-transform: uppercase;
  padding: 3px 8px; border-radius: 3px; pointer-events: none;
}
.product-card__image-wrap { position: relative; }

/* ============================================================
   BREADCRUMB
   ============================================================ */
.breadcrumb {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--color-text-light, #777);
  padding: 20px 0 0;
}
.breadcrumb a { color: inherit; text-decoration: none; }
.breadcrumb a:hover { color: var(--color-gold); }
.breadcrumb span { color: var(--color-text-light, #aaa); }

/* ============================================================
   COLLECTION PAGE
   ============================================================ */
.collection-header { padding: 20px 0 20px; border-bottom: 1px solid var(--color-border, #eee); margin-bottom: 24px; }
.collection-title { font-size: clamp(24px, 4vw, 40px); font-weight: 500; letter-spacing: -0.02em; margin: 0 0 8px; }
.collection-description { color: var(--color-text-light, #666); font-size: 15px; margin: 0; max-width: 600px; }
.collection-count { font-size: 13px; color: var(--color-text-light); margin-top: 4px; }

.load-more-wrap { display: flex; justify-content: center; padding: 48px 0; }
.btn--outline { background: transparent; color: var(--color-text); border: 1.5px solid var(--color-border, #ccc); padding: 12px 36px; border-radius: var(--radius-btn, 4px); font-weight: 500; cursor: pointer; font-size: 14px; transition: border-color .2s, color .2s; }
.btn--outline:hover { border-color: var(--color-text); }

/* ============================================================
   PRODUCT PAGE
   ============================================================ */
.product-page { padding-top: 24px; padding-bottom: 56px; } /* horizontal padding comes from .page-width */

.product-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
  margin-top: 24px;
}
@media (max-width: 767px) {
  .product-page { padding-top: 16px; padding-bottom: 48px; }
  .product-layout { grid-template-columns: 1fr; gap: 24px; }
}

/* Images */
.product-main-img-wrap {
  aspect-ratio: 1;
  background: #f5f5f5;
  border-radius: 8px;
  overflow: hidden;
}
.product-main-img-wrap img { width: 100%; height: 100%; object-fit: contain; display: block; }
.product-thumbnails { display: flex; gap: 8px; margin-top: 12px; flex-wrap: wrap; }
.product-thumb {
  width: 72px; height: 72px;
  border: 2px solid transparent;
  border-radius: 6px; overflow: hidden;
  cursor: pointer; background: #f5f5f5;
  transition: border-color .2s;
}
.product-thumb.active, .product-thumb:hover { border-color: var(--color-gold); }
.product-thumb img { width: 100%; height: 100%; object-fit: contain; display: block; }

/* Details */
.product-vendor-label { font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-text-light, #888); margin: 0 0 8px; }
.product-page-title { font-size: clamp(22px, 3.5vw, 34px); font-weight: 500; letter-spacing: -0.02em; margin: 0 0 16px; line-height: 1.2; }

.product-page-price { display: flex; align-items: baseline; gap: 10px; margin-bottom: 24px; }
.product-page-price .price { font-size: 24px; font-weight: 600; }
.product-page-price .price--sale { color: #c0392b; }
.product-page-price .price--compare { font-size: 16px; color: #aaa; }

/* Variants */
.variants-label { font-size: 13px; font-weight: 600; margin-bottom: 10px; }
.variants-grid { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 24px; }
.variant-btn {
  padding: 8px 16px;
  border: 1.5px solid var(--color-border, #ddd);
  border-radius: 4px;
  background: transparent;
  cursor: pointer;
  font-size: 14px;
  transition: border-color .2s, background .2s;
}
.variant-btn:hover { border-color: var(--color-text); }
.variant-btn.selected { border-color: var(--color-text); background: var(--color-text); color: #fff; }
.variant-btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* Add to cart */
.product-atc-btn { font-size: 16px; padding: 16px; margin-bottom: 20px; }

/* Trust */
.product-trust { display: flex; flex-direction: column; gap: 6px; padding: 16px 0; border-top: 1px solid var(--color-border, #eee); border-bottom: 1px solid var(--color-border, #eee); margin-bottom: 28px; }
.product-trust-item { display: flex; align-items: center; gap: 10px; font-size: 13px; color: var(--color-text-light, #555); }
.product-trust-item svg { flex-shrink: 0; color: var(--color-gold); }

/* Description */
.product-description-heading { font-size: 15px; font-weight: 600; margin: 0 0 10px; }
.product-description { font-size: 14px; line-height: 1.7; color: var(--color-text-light, #555); }

/* ============================================================
   CRO ADDITIONS
   ============================================================ */

/* ── Urgency badges ─────────────────────────────────────── */
.product-urgency {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 4px 0 16px;
}
.urgency-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 0.78rem;
  font-weight: 500;
  padding: 4px 10px;
  border-radius: 20px;
  background: #fff8f0;
  color: #b06b00;
  border: 1px solid #f0d09a;
}
.urgency-badge--green {
  background: #f0fff4;
  color: #3a7d52;
  border-color: #a8d5b5;
}
.urgency-badge--shipping {
  background: #f0f7ff;
  color: #1a6bbf;
  border-color: #a8cbf5;
}

/* ── Free shipping bar (product page) ─────────────────── */
.product-freeship {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--color-secondary-bg);
  border-radius: var(--radius);
  margin: 0 0 16px;
  font-size: 0.83rem;
  color: var(--color-text);
}
.product-freeship svg { flex-shrink: 0; color: var(--color-success); }
.product-freeship strong { color: var(--color-heading); }

/* ── Size guide collapsible ────────────────────────────── */
.size-guide {
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
  margin: 0 0 16px;
}
.size-guide__toggle {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 13px 16px;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-heading);
  font-family: inherit;
  text-align: left;
}
.size-guide__toggle svg { flex-shrink: 0; transition: transform 0.2s; }
.size-guide.is-open .size-guide__toggle svg { transform: rotate(180deg); }
.size-guide__body {
  display: none;
  border-top: 1px solid var(--color-border);
}
.size-guide.is-open .size-guide__body { display: block; }
.size-guide__table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.825rem;
}
.size-guide__table th,
.size-guide__table td {
  padding: 9px 16px;
  text-align: left;
  border-bottom: 1px solid var(--color-border);
}
.size-guide__table tr:last-child td { border-bottom: none; }
.size-guide__table th { background: var(--color-secondary-bg); font-weight: 600; }

/* ── What is a decant? ─────────────────────────────────── */
.decant-explainer {
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
  margin: 0 0 16px;
}
.decant-explainer__toggle {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 13px 16px;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-heading);
  font-family: inherit;
  text-align: left;
}
.decant-explainer__toggle svg { flex-shrink: 0; transition: transform 0.2s; }
.decant-explainer.is-open .decant-explainer__toggle svg { transform: rotate(180deg); }
.decant-explainer__body {
  display: none;
  padding: 4px 16px 16px;
  font-size: 0.85rem;
  line-height: 1.7;
  color: var(--color-text);
  border-top: 1px solid var(--color-border);
}
.decant-explainer.is-open .decant-explainer__body { display: block; }

/* ── Reviews collapsible (product page) ───────────────── */
.reviews-collapsible {
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
  margin: 0 0 16px;
}
.reviews-collapsible__toggle {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 13px 16px;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-heading);
  font-family: inherit;
}
.reviews-collapsible__toggle svg.chevron { flex-shrink: 0; transition: transform 0.2s; }
.reviews-collapsible.is-open .reviews-collapsible__toggle svg.chevron { transform: rotate(180deg); }
.reviews-collapsible__summary { display: flex; align-items: center; gap: 10px; }
.review-stars-mini { display: flex; gap: 2px; }
.review-stars-mini svg { fill: #f5a623; stroke: none; width: 14px; height: 14px; }
.review-stars-mini svg.star-empty { fill: #e0e0e0; }
.review-stars-mini svg.star-half polygon { stroke: #f5a623; stroke-width: 0.5; }
.reviews-collapsible__body {
  display: none;
  border-top: 1px solid var(--color-border);
  padding: 16px;
}
.reviews-collapsible.is-open .reviews-collapsible__body { display: block; }
.loox-widget-wrap { min-height: 100px; }

/* ── Cross-sells (more from brand) ────────────────────── */
.cross-sells {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--color-border);
}
.cross-sells__heading {
  font-size: 1.1rem;
  font-weight: 600;
  margin: 0 0 20px;
}
.cross-sells__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
@media (max-width: 900px) { .cross-sells__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .cross-sells__grid { grid-template-columns: repeat(2, 1fr); } }

/* ── Sticky ATC bar (mobile) ───────────────────────────── */
.sticky-atc {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 200;
  background: white;
  border-top: 1px solid var(--color-border);
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  box-shadow: 0 -4px 20px rgba(0,0,0,0.12);
  transform: translateY(100%);
  transition: transform 0.3s ease;
}
.sticky-atc.is-visible { transform: translateY(0); }
.sticky-atc__info { flex: 1; min-width: 0; }
.sticky-atc__title {
  font-size: 0.8rem;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--color-heading);
}
.sticky-atc__price { font-size: 0.85rem; color: var(--color-text-muted); }
.sticky-atc__btn { flex-shrink: 0; padding: 12px 20px; font-size: 0.875rem; }
@media (min-width: 900px) { .sticky-atc { display: none; } }

/* ── Testimonials 3-across ─────────────────────────────── */
/* Testimonials section — now powered by Loox widget */
.testimonials-section {
  padding: 52px 0;
  background: var(--color-secondary-bg);
}
.testimonials-section .section-heading { text-align: center; margin-bottom: 24px; }

/* ── Social proof bar ──────────────────────────────────── */
.social-proof-bar {
  background: var(--color-dark);
  color: white;
  padding: 16px 20px;
}
.social-proof-inner {
  display: flex;
  justify-content: center;
  gap: 40px;
  flex-wrap: wrap;
  align-items: center;
}
.social-proof-stat { text-align: center; }
.social-proof-num {
  font-size: 1.625rem;
  font-weight: 700;
  color: var(--color-gold);
  display: block;
  line-height: 1.1;
}
.social-proof-label {
  font-size: 0.75rem;
  opacity: 0.75;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-top: 2px;
  display: block;
}

/* ── Collection Filters ────────────────────────────────── */
.collection-controls {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 24px;
  padding: 14px 16px;
  background: var(--color-secondary-bg);
  border-radius: var(--radius);
}
.filter-select {
  -webkit-appearance: none;
  appearance: none;
  padding: 8px 32px 8px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: white url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat right 10px center;
  font-family: inherit;
  font-size: 0.875rem;
  cursor: pointer;
  color: var(--color-text);
}
.filter-select:focus { outline: 2px solid var(--color-gold); outline-offset: 1px; }
.filter-label {
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  white-space: nowrap;
}
.filter-sep { color: var(--color-border); }
.collection-filter-count {
  margin-left: auto;
  font-size: 0.85rem;
  color: var(--color-text-muted);
}
@media (max-width: 600px) {
  .collection-controls {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    padding: 12px;
  }
  .filter-select { width: 100%; }
  .filter-label { display: none; }
  .collection-filter-count { margin-left: 0; text-align: right; }
}

/* ── Brand marquee (auto-rotating) ─────────────────────── */
.brand-marquee {
  overflow: hidden;
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  padding: 16px 0;
  background: #FAFDF7;
}
.brand-marquee-track {
  display: flex;
  align-items: center;
  width: max-content;
  animation: brand-marquee 28s linear infinite;
}
.brand-marquee-track:hover { animation-play-state: paused; }
.brand-marquee-item {
  display: inline-flex;
  align-items: center;
  padding: 0 44px;
  text-decoration: none;
  color: var(--color-heading);
  opacity: 0.7;
  transition: opacity 0.2s;
}
.brand-marquee-item:hover { opacity: 1; }
.brand-logo {
  height: 30px;
  width: auto;
  display: block;
  mix-blend-mode: multiply;
}
.brand-marquee-sep {
  color: var(--color-gold);
  font-size: 13px;
  flex-shrink: 0;
  user-select: none;
}
@keyframes brand-marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .brand-marquee-track { animation: none; }
}

/* ── Product page compact tweaks ───────────────────────── */
.product-details-col .product-vendor-label { margin-bottom: 4px; }
.product-details-col .product-page-title { margin-bottom: 10px; }
.product-details-col .product-page-price { margin-bottom: 12px; }
.product-details-col #product-variants-wrap { margin-bottom: 14px; }

/* ── Product card — popularity badge ──────────────────── */
.product-card__popular {
  position: absolute;
  top: 10px;
  left: 10px;
  background: var(--color-dark);
  color: white;
  font-size: 0.7rem;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: 20px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* ── Page speed: lazy load shimmer on hero ─────────────── */
@media (prefers-reduced-motion: reduce) {
  .skeleton-block, .skeleton-line { animation: none; }
  .scrolling-track { animation: none; }
}
.product-description p { margin: 0 0 12px; }

/* ── Hero hotspot product cards ────────────────────────── */
.hero-bottles-area { position: relative; }

.hero-hotspot {
  position: absolute;
  cursor: crosshair;
  z-index: 5;
}

/* Subtle pulse dot so users know it's interactive */
.hero-hotspot::after {
  content: '';
  position: absolute;
  bottom: 12px;
  left: 50%;
  transform: translateX(-50%) scale(0.8);
  width: 10px; height: 10px;
  background: white;
  border-radius: 50%;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.45);
  opacity: 0;
  transition: opacity 0.2s, transform 0.2s;
}
.hero-hotspot:hover::after {
  opacity: 1;
  transform: translateX(-50%) scale(1);
}

/* Floating card — appears below cursor, never clips the header */
.hero-product-card {
  position: absolute;
  top: 24px;        /* drops just below where cursor enters */
  bottom: auto;
  left: 50%;
  transform: translateX(-50%) translateY(-6px) scale(0.96);
  transform-origin: top center;
  z-index: 30;
  width: 192px;
  background: white;
  border-radius: 12px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.28);
  overflow: hidden;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.18s ease, transform 0.18s ease;
}
.hero-hotspot:hover .hero-product-card {
  opacity: 1;
  transform: translateX(-50%) translateY(0) scale(1);
  pointer-events: auto;
}

/* Left-aligned card (right-side hotspots — keeps card inside image) */
.hero-hotspot--card-left .hero-product-card {
  left: auto;
  right: 0;
  transform: translateX(0) translateY(-6px) scale(0.96);
  transform-origin: top right;
}
.hero-hotspot--card-left:hover .hero-product-card {
  transform: translateX(0) translateY(0) scale(1);
}

/* Right-aligned card (left-side hotspots — keeps card inside image) */
.hero-hotspot--card-right .hero-product-card {
  left: 0;
  transform: translateX(0) translateY(-6px) scale(0.96);
  transform-origin: top left;
}
.hero-hotspot--card-right:hover .hero-product-card {
  transform: translateX(0) translateY(0) scale(1);
}

@media (max-width: 767px) {
  .hero-hotspot:hover::after { opacity: 0; }
  .hero-hotspot:hover .hero-product-card,
  .hero-hotspot--card-left:hover .hero-product-card,
  .hero-hotspot--card-right:hover .hero-product-card {
    opacity: 0;
    pointer-events: none;
  }
}

/* Card internals */
.hero-pc-img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  display: block;
}
.hero-pc-body { padding: 10px 12px 12px; }
.hero-pc-vendor {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
  margin-bottom: 3px;
}
.hero-pc-title {
  font-size: 13px;
  font-weight: 500;
  color: var(--color-heading);
  line-height: 1.3;
  margin-bottom: 6px;
}
.hero-pc-price {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-heading);
  margin-bottom: 9px;
  display: flex;
  align-items: baseline;
  gap: 5px;
}
.hero-pc-price .price--sale { color: var(--color-sale); }
.hero-pc-price .price--compare {
  font-size: 11px;
  font-weight: 400;
  color: var(--color-text-muted);
  text-decoration: line-through;
}
.hero-pc-btn {
  display: block;
  width: 100%;
  text-align: center;
  padding: 8px 10px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.02em;
  background: var(--color-button);
  color: var(--color-button-text);
  border-radius: 7px;
  text-decoration: none;
  transition: background 0.15s;
}
.hero-pc-btn:hover { background: var(--color-button-hover); color: white; }

/* Hide hotspot cards on touch devices (no hover) */
@media (hover: none) {
  .hero-hotspot { display: none; }
}

/* ── Size Picker Modal ── */
.size-modal {
  position: fixed;
  inset: 0;
  z-index: 400;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition);
}
.size-modal.is-open { opacity: 1; pointer-events: all; }
.size-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.5);
  cursor: pointer;
}
.size-modal__panel {
  position: relative;
  background: white;
  border-radius: var(--radius);
  padding: 24px;
  width: min(420px, calc(100vw - 32px));
  max-height: 85vh;
  overflow-y: auto;
  transform: scale(0.95);
  transition: transform var(--transition);
  box-shadow: 0 20px 60px rgba(0,0,0,0.2);
}
.size-modal.is-open .size-modal__panel { transform: scale(1); }
.size-modal__close {
  position: absolute;
  top: 12px; right: 14px;
  background: none;
  border: none;
  font-size: 22px;
  cursor: pointer;
  color: var(--color-text-muted);
  line-height: 1;
  padding: 4px;
}
.size-modal__close:hover { color: var(--color-heading); }
.size-modal__product {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--color-border);
}
.size-modal__img { width: 64px; height: 64px; object-fit: contain; border-radius: var(--radius-sm); flex-shrink: 0; }
.size-modal__vendor { font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--color-text-muted); margin-bottom: 4px; }
.size-modal__title { font-size: 15px; font-weight: 500; color: var(--color-heading); }
.size-modal__label { font-size: 13px; font-weight: 500; color: var(--color-heading); margin-bottom: 12px; }
.size-modal__options { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; }
.size-modal__option {
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 8px 14px;
  font-size: 12px;
  font-family: inherit;
  cursor: pointer;
  background: none;
  text-align: left;
  line-height: 1.3;
  transition: border-color var(--transition), background var(--transition), color var(--transition);
}
.size-modal__option:hover { border-color: var(--color-dark); }
.size-modal__option.selected { border-color: var(--color-dark); background: var(--color-dark); color: white; }
.size-modal__option-price { font-size: 11px; opacity: 0.8; display: block; }
.size-modal__add-btn { margin-top: 0; }
.size-modal__add-btn:disabled { opacity: 0.4; cursor: not-allowed; }
