/** Shopify CDN: Minification failed

Line 187:21 Expected identifier but found whitespace
Line 187:23 Unexpected "{"
Line 187:33 Expected ":"
Line 188:23 Expected identifier but found whitespace
Line 188:25 Unexpected "{"
Line 188:35 Expected ":"
Line 189:18 Expected identifier but found whitespace
Line 189:20 Unexpected "{"
Line 189:30 Expected ":"
Line 192:27 Expected identifier but found whitespace
... and 58 more hidden warnings

**/
/**
 * Roomverse Theme Stylesheet
 * ============================================
 * A conversion-focused gaming room decor theme for Gen Z.
 * Features: Glassmorphism, neon accents, 3D tilt cards,
 * social proof toasts, countdown timers, and cart drawer.
 *
 * @version 2.0.0
 * @author Roomverse
 */

/* ============================================
   PART 1: RESET & BASE
   ============================================ */

/* Modern CSS Reset */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: var(--type-base-size, 16px);
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -ms-overflow-style: scrollbar;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  scroll-behavior: smooth;
  accent-color: var(--color-accent-neon-pink, #ff007f);
}

body {
  font-family: var(--font-body, 'Inter', system-ui, -apple-system, sans-serif);
  font-weight: 400;
  line-height: 1.6;
  color: var(--color-text-primary, #ffffff);
  background-color: var(--color-bg-primary, #0a0a0f);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  min-height: 100vh;
}

/* Selection color */
::selection {
  background-color: rgba(255, 0, 127, 0.3);
  color: #ffffff;
}

::-moz-selection {
  background-color: rgba(255, 0, 127, 0.3);
  color: #ffffff;
}

/* Scrollbar styling */
::-webkit-scrollbar {
  width: 8px;
}

::-webkit-scrollbar-track {
  background: var(--color-bg-primary, #0a0a0f);
}

::-webkit-scrollbar-thumb {
  background: var(--color-glass-border, rgba(255, 255, 255, 0.08));
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--color-text-muted, rgba(255, 255, 255, 0.5));
}

/* Base element styles */
a {
  color: var(--color-accent-neon-cyan, #00f0ff);
  text-decoration: none;
  transition: color 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

a:hover {
  color: var(--color-accent-neon-pink, #ff007f);
  text-decoration: none;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
  border-style: none;
}

button {
  font-family: inherit;
  cursor: pointer;
  border: none;
  background: none;
  color: inherit;
}

input,
textarea,
select {
  font-family: inherit;
  font-size: inherit;
  color: inherit;
}

input:focus,
textarea:focus,
select:focus {
  outline: none;
}

/* Focus visible for accessibility */
:focus-visible {
  outline: 2px solid var(--color-accent-neon-pink, #ff007f);
  outline-offset: 2px;
}

:focus:not(:focus-visible) {
  outline: none;
}

/* Skip to content link for accessibility */
.skip-to-content-link {
  position: absolute;
  top: -100%;
  left: 50%;
  transform: translateX(-50%);
  z-index: 9999;
  padding: 12px 24px;
  background: var(--color-bg-secondary, #12121a);
  color: var(--color-text-primary, #ffffff);
  border: 1px solid var(--color-glass-border, rgba(255, 255, 255, 0.08));
  border-radius: 8px;
  font-weight: 600;
  transition: top 0.3s;
}

.skip-to-content-link:focus {
  top: 16px;
}

/* Screen reader only */
.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 none utility */
.focus-none:focus {
  outline: none !important;
}

/* ============================================
   PART 2: CSS CUSTOM PROPERTIES
   ============================================ */

:root {
  /* --- Background Colors --- */
  --color-bg-primary: {{ settings.color_bg_primary | default: '#0a0a0f' }};
  --color-bg-secondary: {{ settings.color_bg_secondary | default: '#12121a' }};
  --color-bg-card: {{ settings.color_bg_card | default: '#0d0d14' }};

  /* --- Accent Colors — Neon Gaming Palette --- */
  --color-accent-neon-pink: {{ settings.color_accent_neon_pink | default: '#ff007f' }};
  --color-accent-neon-cyan: {{ settings.color_accent_neon_cyan | default: '#00f0ff' }};
  --color-accent-neon-purple: {{ settings.color_accent_neon_purple | default: '#b829f7' }};
  --color-accent-gradient: linear-gradient(135deg, #ff007f 0%, #b829f7 50%, #00f0ff 100%);

  /* --- Text Colors --- */
  --color-text-primary: {{ settings.color_text_primary | default: '#ffffff' }};
  --color-text-secondary: {{ settings.color_text_secondary | default: '#b3b3cc' }};
  --color-text-muted: {{ settings.color_text_muted | default: '#808099' }};

  /* --- Status Colors --- */
  --color-success: {{ settings.color_success | default: '#00e676' }};
  --color-warning: {{ settings.color_warning | default: '#ff9100' }};
  --color-danger: {{ settings.color_danger | default: '#ff1744' }};
  --color-sale-red: {{ settings.color_sale_red | default: '#ff3d3d' }};

  /* --- Glassmorphism --- */
  --color-glass-border: {{ settings.color_glass_border | default: '#1a1a2e' }};
  --color-glass-bg: {{ settings.color_glass_bg | default: '#14141f' }};
  --glass-blur: {{ settings.header_blur | default: 20 }}px;

  /* --- Typography --- */
  --font-heading: {{ settings.font_heading.family | default: 'Inter' }}, system-ui, -apple-system, sans-serif;
  --font-body: {{ settings.font_body.family | default: 'Inter' }}, system-ui, -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
  --type-base-size: {{ settings.type_base_size | default: 16 }}px;
  --type-heading-scale: {{ settings.type_heading_scale | default: 1.2 }};

  /* --- Spacing --- */
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;
  --space-2xl: 48px;
  --space-3xl: 64px;
  --space-4xl: 96px;
  --space-section: 120px;

  /* --- Border Radius --- */
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --radius-pill: 50px;
  --radius-full: 50%;

  /* --- Shadows --- */
  --shadow-card: 0 8px 32px rgba(0, 0, 0, 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.05);
  --shadow-card-hover: 0 16px 48px rgba(0, 0, 0, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.08);
  --shadow-glow-pink: 0 0 20px rgba(255, 0, 127, 0.3), 0 0 60px rgba(255, 0, 127, 0.1);
  --shadow-glow-cyan: 0 0 20px rgba(0, 240, 255, 0.3), 0 0 60px rgba(0, 240, 255, 0.1);
  --shadow-glow-purple: 0 0 20px rgba(184, 41, 247, 0.3), 0 0 60px rgba(184, 41, 247, 0.1);
  --shadow-inner: inset 0 2px 4px rgba(0, 0, 0, 0.2);
  --shadow-dropdown: 0 20px 60px rgba(0, 0, 0, 0.5);

  /* --- Transitions --- */
  --transition-default: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-fast: all 0.15s ease;
  --transition-slow: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  --transition-bounce: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);

  /* --- Z-Index Scale --- */
  --z-base: 1;
  --z-above: 10;
  --z-header: 100;
  --z-overlay: 200;
  --z-drawer: 300;
  --z-modal: 400;
  --z-toast: 500;
  --z-skip-link: 9999;
}

/* ============================================
   PART 3: UTILITY CLASSES
   ============================================ */

/* Container */
.container {
  width: 100%;
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--space-lg);
  padding-right: var(--space-lg);
}

.container--narrow {
  max-width: 900px;
}

.container--wide {
  max-width: 1600px;
}

/* Flex utilities */
.flex {
  display: flex;
}

.flex-col {
  flex-direction: column;
}

.items-center {
  align-items: center;
}

.justify-center {
  justify-content: center;
}

.justify-between {
  justify-content: space-between;
}

.flex-wrap {
  flex-wrap: wrap;
}

.flex-1 {
  flex: 1;
}

/* Grid utilities */
.grid {
  display: grid;
}

.grid-2 {
  grid-template-columns: repeat(2, 1fr);
}

.grid-3 {
  grid-template-columns: repeat(3, 1fr);
}

.grid-4 {
  grid-template-columns: repeat(4, 1fr);
}

.gap-sm {
  gap: var(--space-sm);
}

.gap-md {
  gap: var(--space-md);
}

.gap-lg {
  gap: var(--space-lg);
}

.gap-xl {
  gap: var(--space-xl);
}

/* Text utilities */
.text-center {
  text-align: center;
}

.text-left {
  text-align: left;
}

.text-right {
  text-align: right;
}

.text-gradient {
  background: var(--color-accent-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.text-primary {
  color: var(--color-text-primary);
}

.text-secondary {
  color: var(--color-text-secondary);
}

.text-muted {
  color: var(--color-text-muted);
}

/* Font weights */
.font-500 { font-weight: 500; }
.font-600 { font-weight: 600; }
.font-700 { font-weight: 700; }
.font-800 { font-weight: 800; }
.font-mono {
  font-family: var(--font-mono);
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 32px;
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1rem;
  border-radius: var(--radius-pill);
  cursor: pointer;
  transition: var(--transition-default);
  white-space: nowrap;
  min-height: 48px;
  position: relative;
  overflow: hidden;
}

.btn--primary {
  background: var(--color-accent-gradient);
  color: #ffffff;
  border: none;
  box-shadow: var(--shadow-glow-pink);
}

.btn--primary:hover {
  transform: translateY(-2px) scale(1.03);
  box-shadow: 0 0 30px rgba(255, 0, 127, 0.5), 0 0 80px rgba(255, 0, 127, 0.2);
  color: #ffffff;
}

.btn--primary:active {
  transform: translateY(0) scale(0.98);
}

.btn--secondary {
  background: transparent;
  color: var(--color-text-primary);
  border: 1px solid var(--color-glass-border);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.btn--secondary:hover {
  border-color: var(--color-accent-neon-cyan);
  box-shadow: var(--shadow-glow-cyan);
  color: var(--color-accent-neon-cyan);
  transform: translateY(-2px);
}

.btn--outline {
  background: transparent;
  color: var(--color-text-primary);
  border: 2px solid rgba(255, 255, 255, 0.2);
}

.btn--outline:hover {
  border-color: var(--color-accent-neon-pink);
  box-shadow: var(--shadow-glow-pink);
  color: var(--color-accent-neon-pink);
}

.btn--large {
  padding: 18px 48px;
  font-size: 1.125rem;
  min-height: 56px;
}

.btn--small {
  padding: 8px 20px;
  font-size: 0.875rem;
  min-height: 36px;
}

.btn--full {
  width: 100%;
}

/* Glassmorphism utilities */
.glass {
  background: var(--color-glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur));
  backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--color-glass-border);
}

.glass-card {
  background: var(--color-glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur));
  backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  transition: var(--transition-default);
}

.glass-card:hover {
  border-color: rgba(255, 255, 255, 0.15);
  box-shadow: var(--shadow-card-hover);
}

/* Neon glow utilities */
.neon-glow--pink {
  box-shadow: var(--shadow-glow-pink);
}

.neon-glow--cyan {
  box-shadow: var(--shadow-glow-cyan);
}

.neon-glow--purple {
  box-shadow: var(--shadow-glow-purple);
}

/* Section spacing */
.section {
  padding-top: var(--space-section);
  padding-bottom: var(--space-section);
}

.section--sm {
  padding-top: var(--space-3xl);
  padding-bottom: var(--space-3xl);
}

/* Background utilities */
.bg-primary {
  background-color: var(--color-bg-primary);
}

.bg-secondary {
  background-color: var(--color-bg-secondary);
}

/* ============================================
   PART 4: HEADER
   ============================================ */

/* ═══ HEADER — Dark Neon ═══ */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--z-header);
  height: 72px;
  background: #0a0a0f;
  border-bottom: 1px solid rgba(255, 0, 127, 0.12);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Subtle neon glow line at top of header */
.site-header::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(255, 0, 127, 0.4) 30%, rgba(184, 41, 247, 0.4) 60%, rgba(0, 240, 255, 0.3) 80%, transparent 100%);
}

.site-header--scrolled {
  background: #0a0a0f;
  border-bottom-color: rgba(255, 0, 127, 0.35);
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.6), 0 0 40px rgba(255, 0, 127, 0.08);
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 var(--space-lg);
}

/* Logo */
.site-header__logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.site-header__logo img {
  max-height: 40px;
  width: auto;
  object-fit: contain;
}

.site-header__logo-text {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.5rem;
  color: var(--color-text-primary);
  letter-spacing: -0.02em;
}

/* Navigation */
.site-nav {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

.site-nav__item {
  position: relative;
}

.site-nav__link {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 8px 16px;
  font-family: var(--font-heading);
  font-weight: 500;
  font-size: 0.9375rem;
  color: var(--color-text-primary);
  border-radius: var(--radius-sm);
  transition: var(--transition-default);
  position: relative;
}

.site-nav__link::after {
  content: '';
  position: absolute;
  bottom: 4px;
  left: 50%;
  transform: translateX(-50%) scaleX(0);
  width: calc(100% - 32px);
  height: 2px;
  background: var(--color-accent-gradient);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  border-radius: 1px;
}

.site-nav__link:hover {
  color: var(--color-text-primary);
  background: rgba(255, 255, 255, 0.05);
}

.site-nav__link:hover::after {
  transform: translateX(-50%) scaleX(1);
}

.site-nav__icon {
  width: 16px;
  height: 16px;
  transition: transform 0.3s;
}

.site-nav__item:hover .site-nav__icon {
  transform: rotate(180deg);
}

/* Mega menu dropdown */
.mega-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  width: 600px;
  background: var(--color-glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur));
  backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-dropdown);
  padding: var(--space-lg);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: var(--z-above);
}

.site-nav__item:hover .mega-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.mega-menu__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
}

.mega-menu__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.8125rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
  margin-bottom: var(--space-sm);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--color-glass-border);
}

.mega-menu__link {
  display: block;
  padding: 6px 0;
  color: var(--color-text-secondary);
  font-size: 0.875rem;
  transition: var(--transition-default);
}

.mega-menu__link:hover {
  color: var(--color-accent-neon-cyan);
  padding-left: 4px;
}

.mega-menu__image {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: var(--radius-md);
  margin-top: var(--space-sm);
}

/* Header right icons */
.header-icons {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

.header-icons__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: var(--radius-full);
  color: rgba(255, 255, 255, 0.7);
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.06);
  transition: all 0.3s ease;
  position: relative;
}

.header-icons__btn:hover {
  background: rgba(255, 0, 127, 0.1);
  border-color: rgba(255, 0, 127, 0.25);
  color: #ff007f;
  box-shadow: 0 0 15px rgba(255, 0, 127, 0.15);
  transform: scale(1.05);
}

.header-icons__btn svg {
  width: 22px;
  height: 22px;
}

/* Cart badge */
.cart-badge {
  position: absolute;
  top: -2px;
  right: -2px;
  min-width: 20px;
  height: 20px;
  padding: 0 5px;
  background: var(--color-accent-neon-pink);
  color: #ffffff;
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  font-weight: 700;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(255, 0, 127, 0.4);
  animation: pulse-badge 2s infinite;
}

@keyframes pulse-badge {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.1);
  }
}

/* Mobile hamburger */
.hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 42px;
  height: 42px;
  padding: 8px;
  cursor: pointer;
  background: none;
  border: none;
}

.hamburger__line {
  display: block;
  width: 24px;
  height: 2px;
  background: linear-gradient(90deg, #ff007f, #b829f7, #00f0ff);
  border-radius: 2px;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  transform-origin: center;
}

.hamburger:hover .hamburger__line {
  box-shadow: 0 0 8px rgba(255, 0, 127, 0.5);
}

.hamburger.is-active .hamburger__line:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.hamburger.is-active .hamburger__line:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}

.hamburger.is-active .hamburger__line:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* Mobile menu drawer */
.mobile-menu {
  position: fixed;
  top: 0;
  right: 0;
  width: 380px;
  max-width: 90vw;
  height: 100vh;
  background: var(--color-bg-secondary);
  border-left: 1px solid var(--color-glass-border);
  z-index: var(--z-drawer);
  padding: var(--space-xl);
  padding-top: 80px;
  transform: translateX(100%);
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  overflow-y: auto;
}

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

.mobile-menu__overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  z-index: calc(var(--z-drawer) - 1);
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s;
}

.mobile-menu__overlay.is-visible {
  opacity: 1;
  visibility: visible;
}

.mobile-menu__nav {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.mobile-menu__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 0;
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1.125rem;
  color: var(--color-text-primary);
  border-bottom: 1px solid var(--color-glass-border);
  transition: var(--transition-default);
}

.mobile-menu__link:hover {
  color: var(--color-accent-neon-cyan);
  padding-left: var(--space-sm);
}

/* Search overlay */
.search-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10, 10, 15, 0.95);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  z-index: var(--z-modal);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 120px;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s;
}

.search-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.search-overlay__input {
  width: 100%;
  max-width: 700px;
  padding: 20px 24px;
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-lg);
  color: var(--color-text-primary);
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 500;
}

.search-overlay__input:focus {
  border-color: var(--color-accent-neon-cyan);
  box-shadow: var(--shadow-glow-cyan);
}

.search-overlay__input::placeholder {
  color: var(--color-text-muted);
}

.search-overlay__close {
  position: absolute;
  top: var(--space-xl);
  right: var(--space-xl);
  color: var(--color-text-secondary);
  transition: var(--transition-default);
}

.search-overlay__close:hover {
  color: var(--color-text-primary);
  transform: rotate(90deg);
}

/* ============================================
   PART 5: URGENCY BAR
   ============================================ */

.urgency-bar {
  position: relative;
  z-index: calc(var(--z-header) + 1);
  background: linear-gradient(90deg, var(--color-accent-neon-pink) 0%, var(--color-accent-neon-purple) 50%, var(--color-accent-neon-cyan) 100%);
  background-size: 200% 100%;
  animation: gradient-shift 4s ease infinite;
  padding: 10px 0;
  overflow: hidden;
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.8125rem;
  letter-spacing: 0.03em;
}

@keyframes gradient-shift {
  0%, 100% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
}

.urgency-bar__track {
  display: flex;
  width: max-content;
  animation: marquee 30s linear infinite;
}

.urgency-bar__track:hover {
  animation-play-state: paused;
}

.urgency-bar__item {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 0 var(--space-xl);
  white-space: nowrap;
  color: #ffffff;
}

.urgency-bar__dot {
  width: 8px;
  height: 8px;
  background: #ffffff;
  border-radius: var(--radius-full);
  animation: pulse-dot 1.5s ease-in-out infinite;
  flex-shrink: 0;
}

@keyframes pulse-dot {
  0%, 100% {
    opacity: 1;
    transform: scale(1);
  }
  50% {
    opacity: 0.5;
    transform: scale(0.7);
  }
}

@keyframes marquee {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

/* ============================================
   PART 6: HERO SECTION
   ============================================ */

.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  padding-top: 120px;
  padding-bottom: var(--space-3xl);
}

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

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

/* Mobile video background */
.hero__video-mobile {
  display: none;
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}
.hero__video-mobile-el {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(2.0) contrast(1.15) saturate(1.1);
}
.hero__video-mobile .hero__bg-overlay--dark {
  background: linear-gradient(180deg, rgba(10,10,15,0.15) 0%, rgba(10,10,15,0.3) 100%);
}

@media (max-width: 768px) {
  .hero__video-mobile { display: block; }
  .hero__bg--desktop { display: none; }
}

.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, var(--color-bg-primary) 0%, rgba(10, 10, 15, 0.8) 40%, rgba(10, 10, 15, 0.4) 100%);
  z-index: 1;
}

.hero__grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3xl);
  align-items: center;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 var(--space-lg);
  width: 100%;
}

/* Hero content left */
.hero__content {
  max-width: 620px;
}

.hero__badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 8px 20px;
  background: var(--color-glass-bg);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  border: 1px solid transparent;
  border-image: var(--color-accent-gradient) 1;
  border-radius: var(--radius-pill);
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-text-primary);
  margin-bottom: var(--space-lg);
  animation: fadeInUp 0.6s ease-out 0.2s both;
}

.hero__badge-icon {
  width: 16px;
  height: 16px;
  color: var(--color-accent-neon-pink);
}

.hero__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(2.25rem, 5vw, 4rem);
  line-height: 1.1;
  color: var(--color-text-primary);
  margin-bottom: var(--space-md);
  letter-spacing: -0.03em;
  animation: fadeInUp 0.6s ease-out 0.3s both;
}

.hero__title--accent {
  background: var(--color-accent-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero__subtitle {
  font-size: 1.125rem;
  line-height: 1.7;
  color: var(--color-text-secondary);
  max-width: 500px;
  margin-bottom: var(--space-xl);
  animation: fadeInUp 0.6s ease-out 0.4s both;
}

.hero__ctas {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
  flex-wrap: wrap;
  animation: fadeInUp 0.6s ease-out 0.5s both;
}

.hero__trust {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  animation: fadeInUp 0.6s ease-out 0.6s both;
  flex-wrap: wrap;
}

.hero__stars {
  display: flex;
  gap: 2px;
  color: #ffc107;
}

.hero__stars svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
}

.hero__rating-text {
  font-size: 0.8125rem;
  color: var(--color-text-secondary);
}

.hero__avatars {
  display: flex;
  align-items: center;
}

.hero__avatar {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  border: 2px solid var(--color-bg-primary);
  margin-left: -8px;
  object-fit: cover;
  background: var(--color-bg-secondary);
}

.hero__avatar:first-child {
  margin-left: 0;
}

.hero__avatar-more {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  border: 2px solid var(--color-bg-primary);
  margin-left: -8px;
  background: var(--color-accent-gradient);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 0.625rem;
  font-weight: 700;
  color: #ffffff;
}

/* Hero right side - product showcase */
.hero__media {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  animation: fadeInUp 0.8s ease-out 0.5s both;
}

.hero__product-img {
  width: 100%;
  max-width: 500px;
  border-radius: var(--radius-xl);
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.5);
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.hero__product-img:hover {
  transform: scale(1.03) rotate(-1deg);
}

.hero__floating-badge {
  position: absolute;
  padding: 8px 16px;
  background: var(--color-glass-bg);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-pill);
  font-family: var(--font-mono);
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-text-primary);
  box-shadow: var(--shadow-card);
  animation: float 4s ease-in-out infinite;
}

.hero__floating-badge--1 {
  top: 10%;
  right: 5%;
  animation-delay: 0s;
}

.hero__floating-badge--2 {
  bottom: 20%;
  left: 0;
  animation-delay: 1.5s;
}

.hero__floating-badge--3 {
  top: 50%;
  right: -5%;
  animation-delay: 3s;
}

/* Scroll indicator */
.hero__scroll {
  position: absolute;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  color: var(--color-text-muted);
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  animation: fadeInUp 0.6s ease-out 1s both;
}

.hero__scroll svg {
  width: 24px;
  height: 24px;
  animation: bounce-down 2s infinite;
}

@keyframes bounce-down {
  0%, 20%, 50%, 80%, 100% {
    transform: translateY(0);
  }
  40% {
    transform: translateY(8px);
  }
  60% {
    transform: translateY(4px);
  }
}


/* ============================================
   PART 7: PRODUCT CARDS
   ============================================ */

.product-card {
  position: relative;
  background: var(--color-glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur));
  backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: var(--transition-default);
  will-change: transform;
  perspective: 1000px;
}

.product-card:hover {
  border-color: rgba(255, 0, 127, 0.3);
  box-shadow: var(--shadow-glow-pink);
  transform: translateY(-4px);
}

.product-card__image-wrapper {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: var(--color-bg-secondary);
}

.product-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

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

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

.badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-radius: var(--radius-sm);
  white-space: nowrap;
}

.badge--sale {
  background: var(--color-sale-red);
  color: #ffffff;
}

.badge--trending {
  background: var(--color-accent-gradient);
  color: #ffffff;
}

.badge--bestseller {
  background: linear-gradient(135deg, #ffd700 0%, #ffaa00 100%);
  color: #1a1a1a;
}

.badge--low-stock {
  background: var(--color-warning);
  color: #1a1a1a;
  animation: pulse-glow 2s infinite;
}

.badge--out-of-stock {
  background: var(--color-text-muted);
  color: var(--color-text-primary);
}

@keyframes pulse-glow {
  0%, 100% {
    box-shadow: 0 0 5px rgba(255, 145, 0, 0.3);
  }
  50% {
    box-shadow: 0 0 15px rgba(255, 145, 0, 0.6);
  }
}

/* Wishlist button */
.product-card__wishlist {
  position: absolute;
  top: var(--space-sm);
  right: var(--space-sm);
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  background: var(--color-glass-bg);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  border: 1px solid var(--color-glass-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-secondary);
  transition: var(--transition-default);
  z-index: 2;
}

.product-card__wishlist:hover {
  background: rgba(255, 0, 127, 0.15);
  border-color: var(--color-accent-neon-pink);
  color: var(--color-accent-neon-pink);
}

.product-card__wishlist svg {
  width: 18px;
  height: 18px;
}

/* Quick Add button */
.product-card__quick-add {
  position: absolute;
  bottom: var(--space-sm);
  left: var(--space-sm);
  right: var(--space-sm);
  padding: 12px;
  background: var(--color-glass-bg);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-md);
  color: var(--color-text-primary);
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.875rem;
  text-align: center;
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 2;
}

.product-card:hover .product-card__quick-add {
  opacity: 1;
  transform: translateY(0);
}

.product-card__quick-add:hover {
  background: var(--color-accent-neon-pink);
  border-color: var(--color-accent-neon-pink);
  color: #ffffff;
  box-shadow: var(--shadow-glow-pink);
}

/* Product info */
.product-card__info {
  padding: var(--space-md);
}

.product-card__title {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1rem;
  color: var(--color-text-primary);
  margin-bottom: 4px;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.product-card__vendor {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-bottom: var(--space-sm);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Star rating */
.product-card__rating {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: var(--space-sm);
}

.rating-stars {
  display: flex;
  gap: 2px;
}

.rating-stars__star {
  width: 14px;
  height: 14px;
  color: #ffc107;
}

.rating-stars__star--empty {
  color: rgba(255, 255, 255, 0.15);
}

.rating-count {
  font-size: 0.75rem;
  color: var(--color-text-muted);
}

/* Price */
.product-card__price {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex-wrap: wrap;
}

.price {
  font-family: var(--font-mono);
  font-weight: 500;
}

.price--sale {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-accent-neon-pink);
}

.price--compare {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  text-decoration: line-through;
}

.price--unit {
  font-size: 0.75rem;
  color: var(--color-text-muted);
}

/* Stock urgency on card */
.product-card__stock {
  margin-top: var(--space-sm);
  font-size: 0.75rem;
  font-weight: 600;
}

.product-card__stock--ok {
  color: var(--color-success);
}

.product-card__stock--low {
  color: var(--color-warning);
}

.product-card__stock--critical {
  color: var(--color-danger);
  animation: pulse 1.5s infinite;
}

/* Color swatches on card */
.product-card__swatches {
  display: flex;
  gap: 6px;
  margin-top: var(--space-sm);
}

.swatch {
  width: 18px;
  height: 18px;
  border-radius: var(--radius-full);
  border: 2px solid var(--color-glass-border);
  cursor: pointer;
  transition: var(--transition-default);
  position: relative;
}

.swatch:hover {
  border-color: var(--color-text-primary);
  transform: scale(1.2);
}

.swatch.is-active {
  border-color: var(--color-text-primary);
  box-shadow: 0 0 0 2px var(--color-bg-primary), 0 0 0 3px var(--color-text-primary);
}

/* ============================================
   PART 7b: FEATURED PRODUCTS SECTION CONTAINER
   ============================================ */

.featured-products__container {
  max-width: var(--container-max-width);
  margin: 0 auto;
  padding: var(--space-section) var(--container-padding);
}

.featured-products__header {
  text-align: center;
  margin-bottom: var(--space-2xl);
}

.featured-products__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.5rem, 3.5vw, 2.5rem);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  background: var(--color-accent-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: var(--space-sm);
}

.featured-products__title-decoration {
  width: 60px;
  height: 3px;
  background: var(--color-accent-gradient);
  margin: 0 auto var(--space-md);
  border-radius: var(--radius-full);
}

.featured-products__subtitle {
  font-size: 1.0625rem;
  color: var(--color-text-secondary);
  max-width: 500px;
  margin: 0 auto;
}



/* ============================================
   PART 8: SOCIAL PROOF TOASTS
   ============================================ */

.toast-container {
  position: fixed;
  bottom: var(--space-lg);
  left: var(--space-lg);
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  max-width: 380px;
  pointer-events: none;
}

.toast {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md);
  background: var(--color-glass-bg);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  pointer-events: auto;
  transform: translateX(-120%);
  opacity: 0;
  transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}

.toast.is-visible {
  transform: translateX(0);
  opacity: 1;
}

.toast__image {
  width: 48px;
  height: 48px;
  min-width: 48px;
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, rgba(255,0,127,0.15), rgba(184,41,247,0.15));
  border: 1px solid rgba(255,0,127,0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #ff007f;
  flex-shrink: 0;
}

.toast__content {
  flex: 1;
  min-width: 0;
}

.toast__text {
  font-size: 0.8125rem;
  line-height: 1.5;
  color: var(--color-text-primary);
}

.toast__text strong {
  font-weight: 600;
}

.toast__time {
  font-size: 0.6875rem;
  color: var(--color-text-muted);
  margin-top: 2px;
}

.toast__close {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
  border-radius: var(--radius-full);
  flex-shrink: 0;
  transition: var(--transition-default);
}

.toast__close:hover {
  color: var(--color-text-primary);
  background: rgba(255, 255, 255, 0.08);
}

/* Toast progress bar */
.toast__progress {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 2px;
  background: var(--color-accent-gradient);
  border-radius: 0 0 0 var(--radius-lg);
  animation: toast-progress 5s linear forwards;
}

@keyframes toast-progress {
  from {
    width: 100%;
  }
  to {
    width: 0%;
  }
}

/* ============================================
   PART 9: COUNTDOWN TIMER
   ============================================ */

.countdown-section {
  position: relative;
  padding: 40px 0 32px;
  background: linear-gradient(180deg, #ff007f 0%, #b829f7 50%, #b829f7 100%);
  overflow: hidden;
}

/* Transition strip from black (featured-products) to pink (countdown) */
.countdown-section::before {
  content: '';
  display: block;
  height: 20px;
  background: linear-gradient(180deg, #0a0a0f 0%, #ff007f 100%);
  margin-top: -40px;
}

/* Container above particles */
.countdown__container {
  position: relative;
  z-index: 1;
}

/* Rising bubbles/particles — cover full section including gradient overlap */
.countdown__particles {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}

.countdown__particles span {
  position: absolute;
  bottom: -20px;
  width: 10px;
  height: 10px;
  background: rgba(255, 255, 255, 0.25);
  border-radius: 50%;
  animation: rise linear infinite;
}

.countdown__particles span:nth-child(1) { left: 10%; width: 8px; height: 8px; animation-duration: 8s; animation-delay: 0s; }
.countdown__particles span:nth-child(2) { left: 20%; width: 12px; height: 12px; animation-duration: 10s; animation-delay: 1s; }
.countdown__particles span:nth-child(3) { left: 35%; width: 6px; height: 6px; animation-duration: 7s; animation-delay: 2s; }
.countdown__particles span:nth-child(4) { left: 50%; width: 14px; height: 14px; animation-duration: 11s; animation-delay: 0.5s; background: rgba(255,255,255,0.15); }
.countdown__particles span:nth-child(5) { left: 65%; width: 9px; height: 9px; animation-duration: 9s; animation-delay: 3s; }
.countdown__particles span:nth-child(6) { left: 75%; width: 7px; height: 7px; animation-duration: 8.5s; animation-delay: 1.5s; }
.countdown__particles span:nth-child(7) { left: 85%; width: 11px; height: 11px; animation-duration: 12s; animation-delay: 2.5s; background: rgba(255,255,255,0.2); }
.countdown__particles span:nth-child(8) { left: 5%; width: 5px; height: 5px; animation-duration: 6s; animation-delay: 4s; }
.countdown__particles span:nth-child(9) { left: 45%; width: 10px; height: 10px; animation-duration: 9.5s; animation-delay: 0s; }
.countdown__particles span:nth-child(10) { left: 95%; width: 8px; height: 8px; animation-duration: 7.5s; animation-delay: 3.5s; }

@keyframes rise {
  0% {
    transform: translateY(0) scale(1);
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  90% {
    opacity: 0.6;
  }
  100% {
    transform: translateY(calc(-100vh - 100px)) scale(0.5);
    opacity: 0;
  }
}

.countdown {
  position: relative;
  z-index: 1;
  text-align: center;
}

.countdown__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.25rem, 3vw, 2rem);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #ffffff;
  margin-bottom: var(--space-xl);
  text-shadow: 0 0 30px rgba(0,0,0,0.3);
}

.countdown__timer {
  display: flex;
  justify-content: center;
  gap: var(--space-md);
  margin-bottom: 24px;
}

.countdown__box {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 80px;
  padding: var(--space-md) var(--space-lg);
  background: var(--color-glass-bg);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
}

.countdown__number {
  font-family: var(--font-mono);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 700;
  line-height: 1;
  background: linear-gradient(135deg, #00f0ff 0%, #00c8ff 50%, #00e5ff 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: drop-shadow(0 0 8px rgba(0, 240, 255, 0.4));
}

.countdown__label {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255, 255, 255, 0.8);
  margin-top: var(--space-sm);
}

.countdown__separator,
.countdown__colon {
  font-family: var(--font-mono);
  font-size: 2rem;
  font-weight: 700;
  color: #ffffff;
  align-self: center;
  text-shadow: 0 0 15px rgba(0,0,0,0.3);
}

.countdown__cta {
  margin-top: var(--space-lg);
  display: inline-block;
  padding: var(--space-md) var(--space-2xl);
  background: #ffffff;
  color: #ff007f;
  font-weight: 700;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-radius: var(--radius-full);
  text-decoration: none;
  box-shadow: 0 4px 20px rgba(0,0,0,0.2);
  transition: var(--transition-default);
}

.countdown__cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 30px rgba(0,0,0,0.3);
}

/* Alias for liquid template compatibility */
.countdown__headline {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.25rem, 3vw, 2rem);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #ffffff;
  margin-bottom: 24px;
  margin-top: 0;
  text-shadow: 0 0 30px rgba(0,0,0,0.3);
  text-align: center;
}

.countdown__subtext {
  font-size: 1.125rem;
  font-weight: 700;
  color: #ffffff;
  text-align: center;
  margin-top: var(--space-lg);
  text-shadow: 0 0 12px rgba(0, 240, 255, 0.5), 0 0 30px rgba(0, 240, 255, 0.2);
  letter-spacing: 0.02em;
}

/* Urgent state */
.countdown__box--urgent {
  border-color: rgba(255, 255, 255, 0.3);
}

/* ============================================
   PART 10: BENEFITS SECTION
   ============================================ */

.benefits {
  position: relative;
  padding: var(--space-section) 0;
  background: var(--color-bg-primary);
}

/* Compact gradient transition from countdown violet to black — absolute at top */
.benefits::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 20px;
  background: linear-gradient(180deg, #b829f7 0%, #0a0a0f 100%);
  pointer-events: none;
}

.benefits__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
}

.benefit-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--space-xl) var(--space-lg);
  background: var(--color-glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur));
  backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-lg);
  transition: var(--transition-default);
}

.benefit-card:hover {
  border-color: rgba(255, 255, 255, 0.15);
  transform: translateY(-4px);
  box-shadow: var(--shadow-card-hover);
}

.benefit-card__icon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  margin-bottom: var(--space-md);
}

.benefit-card__icon--1 {
  background: rgba(255, 0, 127, 0.1);
  color: var(--color-accent-neon-pink);
}

.benefit-card__icon--2 {
  background: rgba(0, 240, 255, 0.1);
  color: var(--color-accent-neon-cyan);
}

.benefit-card__icon--3 {
  background: rgba(184, 41, 247, 0.1);
  color: var(--color-accent-neon-purple);
}

.benefit-card__icon--4 {
  background: rgba(0, 230, 118, 0.1);
  color: var(--color-success);
}

.benefit-card__icon svg {
  width: 28px;
  height: 28px;
}

.benefit-card__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.0625rem;
  color: var(--color-text-primary);
  margin-bottom: var(--space-sm);
}

.benefit-card__desc {
  font-size: 0.875rem;
  color: var(--color-text-secondary);
  line-height: 1.6;
}

/* ============================================
   PART 11: BUNDLE OFFER
   ============================================ */

.bundle-section {
  padding: var(--space-section) 0;
}

.bundle-section__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  text-align: center;
  margin-bottom: var(--space-xs);
}

.bundle-section__subtitle {
  text-align: center;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-2xl);
  font-size: 1.0625rem;
}

.bundle-section__underline {
  display: block;
  width: 80px;
  height: 3px;
  background: var(--color-accent-gradient);
  margin: var(--space-md) auto 0;
  border-radius: 2px;
}

.bundle-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: var(--space-md);
  align-items: stretch;
}

.bundle-card {
  position: relative;
  grid-row: span 2;
  background: var(--color-glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur));
  backdrop-filter: blur(var(--glass-blur));
  border: 2px solid var(--color-glass-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  display: flex;
  flex-direction: column;
  transition: var(--transition-default);
}

.bundle-card:hover {
  border-color: rgba(255, 0, 127, 0.3);
  box-shadow: var(--shadow-glow-pink);
}

.bundle-card__badge {
  position: absolute;
  top: -1px;
  right: var(--space-lg);
  padding: 8px 16px;
  background: var(--color-accent-gradient);
  color: #ffffff;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  box-shadow: var(--shadow-glow-pink);
}

.bundle-card__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.25rem;
  margin-bottom: var(--space-sm);
  margin-top: var(--space-md);
}

.bundle-card__desc {
  font-size: 0.875rem;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-lg);
}

.bundle-card__products {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
  flex: 1;
}

.bundle-product {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm);
  background: rgba(255, 255, 255, 0.03);
  border-radius: var(--radius-md);
}

.bundle-product__img {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-sm);
  object-fit: cover;
}

.bundle-product__name {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-text-primary);
}

.bundle-product__price {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--color-text-muted);
  text-decoration: line-through;
}

.bundle-card__pricing {
  display: flex;
  align-items: baseline;
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-glass-border);
}

.bundle-card__price-now {
  font-family: var(--font-mono);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-accent-neon-pink);
}

.bundle-card__price-was {
  font-family: var(--font-mono);
  font-size: 1rem;
  color: var(--color-text-muted);
  text-decoration: line-through;
}

.bundle-card__savings {
  font-size: 0.875rem;
  color: var(--color-success);
  font-weight: 600;
  margin-bottom: var(--space-md);
}

.bundle-card__btn {
  width: 100%;
  padding: 16px;
  background: var(--color-accent-gradient);
  color: #ffffff;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1rem;
  border-radius: var(--radius-pill);
  border: none;
  cursor: pointer;
  transition: var(--transition-default);
  box-shadow: var(--shadow-glow-pink);
}

.bundle-card__btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 30px rgba(255, 0, 127, 0.5), 0 0 80px rgba(255, 0, 127, 0.2);
}

.bundle-card__btn:active {
  transform: translateY(0);
}

/* Add-on cards */
.bundle-addon {
  background: var(--color-glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur));
  backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-lg);
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  transition: var(--transition-default);
}

.bundle-addon:hover {
  border-color: rgba(255, 255, 255, 0.15);
  transform: translateY(-2px);
}

.bundle-addon__img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: var(--radius-md);
  margin-bottom: var(--space-sm);
}

.bundle-addon__title {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.9375rem;
  margin-bottom: 4px;
}

.bundle-addon__price {
  font-family: var(--font-mono);
  font-size: 0.875rem;
  color: var(--color-accent-neon-pink);
  font-weight: 600;
  margin-bottom: var(--space-sm);
}

.bundle-addon__checkbox {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-top: auto;
  font-size: 0.8125rem;
  color: var(--color-text-secondary);
  cursor: pointer;
}

.bundle-addon__checkbox input[type="checkbox"] {
  width: 20px;
  height: 20px;
  accent-color: var(--color-accent-neon-pink);
}


/* ============================================
   PART 12: UGC GALLERY
   ============================================ */

.ugc-section {
  padding: var(--space-section) 0;
}

.ugc-section__header {
  text-align: center;
  margin-bottom: var(--space-2xl);
}

.ugc-section__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  margin-bottom: var(--space-sm);
}

.ugc-section__subtitle {
  color: var(--color-text-secondary);
  font-size: 1.0625rem;
}

.ugc-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 280px;
  gap: var(--space-sm);
}

.ugc-item {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: pointer;
}

.ugc-item--large {
  grid-row: span 2;
  grid-column: span 2;
}

.ugc-item__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.ugc-item:hover .ugc-item__img {
  transform: scale(1.05);
}

.ugc-item__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(10, 10, 15, 0.8) 0%, rgba(10, 10, 15, 0) 60%);
  opacity: 0;
  transition: opacity 0.3s;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: var(--space-lg);
}

.ugc-item:hover .ugc-item__overlay {
  opacity: 1;
}

.ugc-item__btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  background: var(--color-glass-bg);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-pill);
  color: var(--color-text-primary);
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.875rem;
  transform: translateY(10px);
  transition: all 0.3s;
}

.ugc-item:hover .ugc-item__btn {
  transform: translateY(0);
}

.ugc-item__btn:hover {
  background: var(--color-accent-neon-pink);
  border-color: var(--color-accent-neon-pink);
  color: #ffffff;
  box-shadow: var(--shadow-glow-pink);
}

.ugc-item__handle {
  position: absolute;
  top: var(--space-md);
  left: var(--space-md);
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  background: rgba(0, 0, 0, 0.5);
  border-radius: var(--radius-pill);
  font-size: 0.6875rem;
  font-weight: 600;
  color: #ffffff;
}

/* ============================================
   PART 13: TESTIMONIALS CAROUSEL
   ============================================ */

.testimonials {
  padding: var(--space-section) 0;
  overflow: hidden;
}

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

.testimonials__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  margin-bottom: var(--space-sm);
}

.testimonials__counter {
  color: var(--color-text-secondary);
  font-size: 1.0625rem;
}

.testimonials__counter span {
  background: var(--color-accent-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 700;
}

/* Carousel */
.testimonials__carousel {
  position: relative;
  max-width: 900px;
  margin: 0 auto;
}

.testimonials__track {
  display: flex;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.testimonial-card {
  flex: 0 0 100%;
  padding: var(--space-xl);
  background: var(--color-glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur));
  backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-lg);
  text-align: center;
  transition: var(--transition-default);
}

.testimonial-card:hover {
  border-color: rgba(255, 255, 255, 0.15);
}

.testimonial-card__stars {
  display: flex;
  justify-content: center;
  gap: 4px;
  margin-bottom: var(--space-md);
}

.testimonial-card__stars svg {
  width: 20px;
  height: 20px;
  fill: #ffc107;
}

.testimonial-card__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.125rem;
  margin-bottom: var(--space-sm);
  color: var(--color-text-primary);
}

.testimonial-card__text {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-lg);
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.testimonial-card__author {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-md);
}

.testimonial-card__avatar {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-full);
  object-fit: cover;
}

.testimonial-card__name {
  font-weight: 600;
  color: var(--color-text-primary);
}

.testimonial-card__verified {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.75rem;
  color: var(--color-success);
  margin-top: 2px;
}

.testimonial-card__verified svg {
  width: 14px;
  height: 14px;
}

/* Carousel navigation */
.testimonials__nav {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--space-lg);
  margin-top: var(--space-xl);
}

.testimonials__arrow {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-full);
  color: var(--color-text-primary);
  transition: var(--transition-default);
}

.testimonials__arrow:hover {
  background: var(--color-accent-neon-pink);
  border-color: var(--color-accent-neon-pink);
  box-shadow: var(--shadow-glow-pink);
}

.testimonials__arrow svg {
  width: 20px;
  height: 20px;
}

.testimonials__dots {
  display: flex;
  gap: 8px;
}

.testimonials__dot {
  width: 10px;
  height: 10px;
  border-radius: var(--radius-full);
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  cursor: pointer;
  transition: var(--transition-default);
}

.testimonials__dot:hover {
  border-color: var(--color-accent-neon-pink);
}

.testimonials__dot.is-active {
  background: var(--color-accent-neon-pink);
  border-color: var(--color-accent-neon-pink);
  box-shadow: 0 0 8px rgba(255, 0, 127, 0.4);
  width: 28px;
  border-radius: 5px;
}

/* ============================================
   PART 14: TRUST BADGES
   ============================================ */

.trust-badges {
  padding: var(--space-2xl) 0;
  border-top: 1px solid var(--color-glass-border);
  border-bottom: 1px solid var(--color-glass-border);
}

.trust-badges__row {
  display: flex;
  justify-content: space-around;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-xl);
}

.trust-badge {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  color: var(--color-text-muted);
  transition: var(--transition-default);
}

.trust-badge:hover {
  color: var(--color-text-primary);
}

.trust-badge__icon {
  width: 28px;
  height: 28px;
  opacity: 0.6;
  transition: var(--transition-default);
}

.trust-badge:hover .trust-badge__icon {
  opacity: 1;
}

.trust-badge__text {
  font-size: 0.8125rem;
  font-weight: 500;
}

/* ============================================
   PART 15: FAQ ACCORDION
   ============================================ */

.faq-section {
  padding: var(--space-section) 0;
}

.faq-section__header {
  text-align: center;
  margin-bottom: var(--space-2xl);
}

.faq-section__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  margin-bottom: var(--space-sm);
}

.faq-section__subtitle {
  color: var(--color-text-secondary);
  font-size: 1.0625rem;
}

.faq-list {
  max-width: 800px;
  margin: 0 auto;
}

.faq-item {
  border-bottom: 1px solid var(--color-glass-border);
}

.faq-item__question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--space-lg) 0;
  background: none;
  border: none;
  color: var(--color-text-primary);
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1.0625rem;
  text-align: left;
  cursor: pointer;
  transition: var(--transition-default);
}

.faq-item__question:hover {
  color: var(--color-accent-neon-cyan);
}

.faq-item__icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  color: var(--color-text-muted);
  transition: transform 0.3s;
}

.faq-item.is-open .faq-item__icon {
  transform: rotate(45deg);
  color: var(--color-accent-neon-pink);
}

.faq-item__answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s, padding 0.3s;
  opacity: 0;
}

.faq-item.is-open .faq-item__answer {
  max-height: 500px;
  opacity: 1;
  padding-bottom: var(--space-lg);
}

.faq-item__answer p {
  color: var(--color-text-secondary);
  line-height: 1.7;
  font-size: 0.9375rem;
}

.faq-item__answer a {
  color: var(--color-accent-neon-cyan);
  text-decoration: underline;
}

/* ============================================
   PART 16: NEWSLETTER POPUP
   ============================================ */

.popup-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10, 10, 15, 0.85);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s;
  padding: var(--space-lg);
}

.popup-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.popup {
  position: relative;
  width: 100%;
  max-width: 520px;
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-xl);
  padding: var(--space-2xl);
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.5);
  transform: scale(0.9) translateY(20px);
  transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
  overflow: hidden;
}

.popup-overlay.is-open .popup {
  transform: scale(1) translateY(0);
}

.popup__close {
  position: absolute;
  top: var(--space-md);
  right: var(--space-md);
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-full);
  color: var(--color-text-secondary);
  transition: var(--transition-default);
  z-index: 2;
}

.popup__close:hover {
  background: rgba(255, 0, 127, 0.15);
  color: var(--color-accent-neon-pink);
  border-color: rgba(255, 0, 127, 0.3);
  transform: rotate(90deg);
}

.popup__close svg {
  width: 18px;
  height: 18px;
}

/* Spin wheel decorative */
.popup__wheel {
  position: absolute;
  top: -80px;
  right: -80px;
  width: 200px;
  height: 200px;
  opacity: 0.1;
  pointer-events: none;
  animation: spin 30s linear infinite;
}

@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

.popup__content {
  position: relative;
  z-index: 1;
}

.popup__heading {
  font-family: var(--font-heading);
  font-weight: 900;
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  text-align: center;
  margin-bottom: var(--space-sm);
  background: var(--color-accent-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.popup__subheading {
  text-align: center;
  color: var(--color-text-secondary);
  font-size: 1rem;
  margin-bottom: var(--space-xl);
}

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

.popup__input {
  width: 100%;
  padding: 16px 20px;
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-pill);
  color: var(--color-text-primary);
  font-family: var(--font-heading);
  font-size: 1rem;
  transition: var(--transition-default);
}

.popup__input:focus {
  border-color: var(--color-accent-neon-pink);
  box-shadow: 0 0 0 3px rgba(255, 0, 127, 0.15), var(--shadow-glow-pink);
}

.popup__input::placeholder {
  color: var(--color-text-muted);
}

.popup__btn {
  width: 100%;
  padding: 16px;
  background: var(--color-accent-gradient);
  color: #ffffff;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1rem;
  border: none;
  border-radius: var(--radius-pill);
  cursor: pointer;
  transition: var(--transition-default);
  box-shadow: var(--shadow-glow-pink);
}

.popup__btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 30px rgba(255, 0, 127, 0.5), 0 0 80px rgba(255, 0, 127, 0.2);
}

.popup__success {
  text-align: center;
  padding: var(--space-xl) 0;
}

.popup__success-icon {
  width: 64px;
  height: 64px;
  margin: 0 auto var(--space-md);
  background: rgba(0, 230, 118, 0.1);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-success);
}

.popup__success-icon svg {
  width: 32px;
  height: 32px;
}

.popup__discount-code {
  display: inline-block;
  padding: var(--space-sm) var(--space-lg);
  background: var(--color-glass-bg);
  border: 2px dashed var(--color-accent-neon-pink);
  border-radius: var(--radius-md);
  font-family: var(--font-mono);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-accent-neon-pink);
  margin-top: var(--space-md);
  cursor: pointer;
  transition: var(--transition-default);
  position: relative;
}

.popup__discount-code:hover {
  background: rgba(255, 0, 127, 0.1);
}

.popup__discount-code.is-copied::after {
  content: 'Copied!';
  position: absolute;
  top: -30px;
  left: 50%;
  transform: translateX(-50%);
  padding: 4px 10px;
  background: var(--color-success);
  color: #1a1a1a;
  font-size: 0.6875rem;
  font-weight: 700;
  border-radius: var(--radius-sm);
  white-space: nowrap;
}

.popup__disclaimer {
  text-align: center;
  font-size: 0.75rem;
  color: var(--color-text-muted);
  margin-top: var(--space-md);
}

/* Exit intent popup variant */
.popup--exit {
  border: 2px solid var(--color-accent-neon-pink);
  box-shadow: 0 0 40px rgba(255, 0, 127, 0.3), 0 30px 80px rgba(0, 0, 0, 0.5);
}

.popup__urgency {
  display: inline-block;
  padding: 6px 14px;
  background: rgba(255, 0, 127, 0.1);
  border: 1px solid rgba(255, 0, 127, 0.3);
  border-radius: var(--radius-pill);
  font-family: var(--font-mono);
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--color-accent-neon-pink);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--space-md);
}


/* ============================================
   PART 17: CART DRAWER
   ============================================ */

.cart-drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10, 10, 15, 0.7);
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  z-index: calc(var(--z-drawer) - 1);
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s;
}

.cart-drawer-overlay.is-visible {
  opacity: 1;
  visibility: visible;
}

.cart-drawer {
  position: fixed;
  top: 0;
  right: 0;
  width: 460px;
  max-width: 100vw;
  height: 100vh;
  background: var(--color-bg-secondary);
  border-left: 1px solid var(--color-glass-border);
  z-index: var(--z-drawer);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
}

.cart-drawer.is-open {
  transform: translateX(0);
}

/* Header */
.cart-drawer__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-lg) var(--space-xl);
  border-bottom: 1px solid var(--color-glass-border);
  flex-shrink: 0;
}

.cart-drawer__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.125rem;
  color: var(--color-text-primary);
}

.cart-drawer__count {
  color: var(--color-text-muted);
  font-weight: 400;
}

.cart-drawer__close {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-full);
  color: var(--color-text-secondary);
  transition: var(--transition-default);
}

.cart-drawer__close:hover {
  background: rgba(255, 0, 127, 0.15);
  color: var(--color-accent-neon-pink);
  transform: rotate(90deg);
}

.cart-drawer__close svg {
  width: 18px;
  height: 18px;
}

/* Body */
.cart-drawer__body {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-md) var(--space-xl);
}

/* Line items */
.cart-item {
  display: flex;
  gap: var(--space-md);
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--color-glass-border);
}

.cart-item__image {
  width: 80px;
  height: 80px;
  border-radius: var(--radius-md);
  object-fit: cover;
  flex-shrink: 0;
  background: var(--color-bg-primary);
}

.cart-item__details {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.cart-item__title {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.9375rem;
  color: var(--color-text-primary);
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.cart-item__variant {
  font-size: 0.8125rem;
  color: var(--color-text-muted);
}

.cart-item__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: auto;
}

/* Qty stepper */
.qty-stepper {
  display: flex;
  align-items: center;
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-sm);
  overflow: hidden;
}

.qty-stepper__btn {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-glass-bg);
  color: var(--color-text-primary);
  font-size: 1rem;
  font-weight: 600;
  transition: var(--transition-default);
}

.qty-stepper__btn:hover {
  background: rgba(255, 255, 255, 0.08);
}

.qty-stepper__btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.qty-stepper__input {
  width: 40px;
  height: 32px;
  text-align: center;
  background: none;
  border: none;
  color: var(--color-text-primary);
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  font-weight: 600;
  -moz-appearance: textfield;
}

.qty-stepper__input::-webkit-outer-spin-button,
.qty-stepper__input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.cart-item__price {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: 0.9375rem;
  color: var(--color-text-primary);
}

.cart-item__remove {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
  border-radius: var(--radius-full);
  transition: var(--transition-default);
  flex-shrink: 0;
}

.cart-item__remove:hover {
  color: var(--color-danger);
  background: rgba(255, 23, 68, 0.1);
}

/* Upsell */
.cart-upsell {
  margin-top: var(--space-lg);
  padding: var(--space-md);
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-md);
}

.cart-upsell__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.8125rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
  margin-bottom: var(--space-md);
}

.cart-upsell__item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.cart-upsell__img {
  width: 60px;
  height: 60px;
  border-radius: var(--radius-sm);
  object-fit: cover;
  flex-shrink: 0;
}

.cart-upsell__details {
  flex: 1;
  min-width: 0;
}

.cart-upsell__name {
  font-weight: 600;
  font-size: 0.875rem;
  margin-bottom: 2px;
}

.cart-upsell__price {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  color: var(--color-accent-neon-pink);
  font-weight: 600;
}

.cart-upsell__add {
  padding: 8px 16px;
  background: var(--color-accent-neon-pink);
  color: #ffffff;
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.8125rem;
  border-radius: var(--radius-pill);
  border: none;
  cursor: pointer;
  transition: var(--transition-default);
  flex-shrink: 0;
}

.cart-upsell__add:hover {
  background: #e60072;
  transform: scale(1.05);
}

/* Free shipping progress */
.cart-shipping {
  padding: var(--space-md) var(--space-xl);
  border-top: 1px solid var(--color-glass-border);
  background: rgba(0, 230, 118, 0.05);
}

.cart-shipping__text {
  font-size: 0.8125rem;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-sm);
  text-align: center;
}

.cart-shipping__text span {
  font-weight: 700;
  color: var(--color-success);
}

.cart-shipping__bar {
  width: 100%;
  height: 6px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 3px;
  overflow: hidden;
}

.cart-shipping__fill {
  height: 100%;
  background: linear-gradient(90deg, var(--color-success) 0%, #00c853 100%);
  border-radius: 3px;
  transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 0 8px rgba(0, 230, 118, 0.3);
}

/* Footer */
.cart-drawer__footer {
  padding: var(--space-lg) var(--space-xl);
  border-top: 1px solid var(--color-glass-border);
  background: var(--color-bg-secondary);
  flex-shrink: 0;
}

.cart-drawer__subtotal-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-md);
}

.cart-drawer__subtotal-label {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1rem;
  color: var(--color-text-secondary);
}

.cart-drawer__subtotal-value {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 1.25rem;
  color: var(--color-text-primary);
}

.cart-drawer__savings {
  font-size: 0.8125rem;
  color: var(--color-success);
  text-align: right;
  margin-bottom: var(--space-md);
}

.cart-drawer__checkout {
  width: 100%;
  padding: 16px;
  background: var(--color-accent-gradient);
  color: #ffffff;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1rem;
  border: none;
  border-radius: var(--radius-pill);
  cursor: pointer;
  transition: var(--transition-default);
  box-shadow: var(--shadow-glow-pink);
  margin-bottom: var(--space-sm);
}

.cart-drawer__checkout:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 30px rgba(255, 0, 127, 0.5);
}

.cart-drawer__continue {
  display: block;
  text-align: center;
  font-size: 0.875rem;
  color: var(--color-text-muted);
  transition: var(--transition-default);
}

.cart-drawer__continue:hover {
  color: var(--color-accent-neon-cyan);
}

/* Empty cart state */
.cart-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--space-3xl) var(--space-xl);
  flex: 1;
}

.cart-empty__icon {
  width: 80px;
  height: 80px;
  margin-bottom: var(--space-lg);
  color: var(--color-text-muted);
  opacity: 0.5;
}

.cart-empty__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.25rem;
  margin-bottom: var(--space-sm);
}

.cart-empty__text {
  color: var(--color-text-secondary);
  font-size: 0.9375rem;
  margin-bottom: var(--space-xl);
}

/* ============================================
   PART 18: PRODUCT PAGE
   ============================================ */

.product-main {
  padding-top: 96px;
  padding-bottom: var(--space-3xl);
}

.product-main__grid {
  display: grid;
  grid-template-columns: 55% 1fr;
  gap: var(--space-3xl);
  align-items: start;
}

/* Breadcrumb */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
  font-size: 0.8125rem;
  color: var(--color-text-muted);
  flex-wrap: wrap;
}

.breadcrumb__link {
  color: var(--color-text-secondary);
  transition: var(--transition-default);
}

.breadcrumb__link:hover {
  color: var(--color-accent-neon-cyan);
}

.breadcrumb__sep {
  width: 14px;
  height: 14px;
  opacity: 0.4;
}

/* Product gallery */
.product-gallery {
  position: sticky;
  top: 96px;
}

.product-gallery__main {
  position: relative;
  aspect-ratio: 1 / 1;
  background: var(--color-bg-secondary);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: var(--space-md);
}

.product-gallery__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s;
}

.product-gallery__thumbs {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-sm);
}

.product-gallery__thumb {
  aspect-ratio: 1 / 1;
  background: var(--color-bg-secondary);
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 2px solid transparent;
  cursor: pointer;
  transition: var(--transition-default);
  padding: 0;
}

.product-gallery__thumb:hover {
  border-color: var(--color-glass-border);
}

.product-gallery__thumb.active {
  border-color: #ffffff;
}

.product-gallery__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Product info */
.product-info__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: clamp(1.5rem, 3vw, 2rem);
  color: var(--color-text-primary);
  margin-bottom: var(--space-sm);
  line-height: 1.2;
}

/* Rating */
.product-info__rating {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
}

.product-info__rating-stars {
  display: flex;
  gap: 2px;
}

.product-info__rating-stars svg {
  width: 18px;
  height: 18px;
  fill: #ffc107;
}

.product-info__rating-count {
  font-size: 0.875rem;
  color: var(--color-text-muted);
}

/* Price block */
.product-info__price {
  display: flex;
  align-items: baseline;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
  padding-bottom: var(--space-lg);
  border-bottom: 1px solid var(--color-glass-border);
}

.product-info__price-sale {
  font-family: var(--font-mono);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-text-primary);
}

.product-info__price-compare {
  font-family: var(--font-mono);
  font-size: 1.125rem;
  color: var(--color-text-muted);
  text-decoration: line-through;
}

.product-info__price-save {
  padding: 4px 10px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--color-success);
}

/* Short description */
.product-info__desc {
  font-size: 0.9375rem;
  line-height: 1.7;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-lg);
}

.product-info__bullets {
  list-style: none;
  margin-bottom: var(--space-lg);
}

.product-info__bullets li {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 6px 0;
  font-size: 0.875rem;
  color: var(--color-text-secondary);
}

.product-info__bullets li svg {
  width: 18px;
  height: 18px;
  color: var(--color-success);
  flex-shrink: 0;
}

/* Variant selectors */
.product-variants {
  margin-bottom: var(--space-lg);
}

.product-variants__label {
  display: block;
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.875rem;
  margin-bottom: var(--space-sm);
  color: var(--color-text-primary);
}

.variant-options {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.variant-btn {
  padding: 10px 18px;
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-sm);
  color: var(--color-text-primary);
  font-family: var(--font-heading);
  font-weight: 500;
  font-size: 0.875rem;
  cursor: pointer;
  transition: var(--transition-default);
}

.variant-btn:hover {
  border-color: rgba(255,255,255,0.3);
}

.variant-btn.is-active {
  background: #ffffff;
  border-color: #ffffff;
  color: #0a0a0f;
  font-weight: 600;
}

.variant-btn.is-disabled {
  opacity: 0.4;
  cursor: not-allowed;
  text-decoration: line-through;
}

/* Color swatches */
.variant-color {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  border: 2px solid var(--color-glass-border);
  cursor: pointer;
  transition: var(--transition-default);
  position: relative;
}

.variant-color:hover {
  border-color: var(--color-text-secondary);
  transform: scale(1.15);
}

.variant-color.is-active {
  border-color: #ffffff;
  box-shadow: 0 0 0 2px var(--color-bg-primary), 0 0 0 3px #ffffff;
}

/* Quantity selector */
.product-qty {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}

.product-qty__label {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.875rem;
  color: var(--color-text-primary);
}

/* Add to cart button */
.atc-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-md);
  padding: 18px var(--space-xl);
  min-height: 56px;
  background: #ffffff;
  color: #0a0a0f;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.0625rem;
  border: none;
  border-radius: 14px;
  cursor: pointer;
  transition: var(--transition-default);
  margin-bottom: var(--space-md);
}

.atc-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(255,255,255,0.15);
}

.atc-btn:active {
  transform: translateY(0);
}

.atc-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.atc-btn__price {
  font-family: var(--font-mono);
  font-weight: 600;
  opacity: 0.7;
}

/* Stock urgency */
.stock-urgency {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
  font-size: 0.8125rem;
  font-weight: 600;
}

.stock-urgency--ok { color: var(--color-success); }
.stock-urgency--low { color: var(--color-warning); }
.stock-urgency--critical { color: var(--color-danger); }

.stock-urgency__bar {
  width: 80px;
  height: 4px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 2px;
  overflow: hidden;
}

.stock-urgency__fill { height: 100%; border-radius: 2px; transition: width 0.5s; }
.stock-urgency__fill--ok { background: var(--color-success); }
.stock-urgency__fill--low { background: var(--color-warning); }
.stock-urgency__fill--critical { background: var(--color-danger); }

/* Trust badges below ATC */
.product-trust {
  display: flex;
  justify-content: center;
  gap: var(--space-xl);
  padding: var(--space-md) 0;
  border-top: 1px solid var(--color-glass-border);
  margin-bottom: var(--space-lg);
}

.product-trust__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  font-size: 0.6875rem;
  color: var(--color-text-muted);
}

.product-trust__item svg { width: 24px; height: 24px; }

/* Shipping timeline */
.shipping-timeline {
  padding: var(--space-md);
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-lg);
}

.shipping-timeline__title {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.875rem;
  margin-bottom: var(--space-sm);
}

.shipping-timeline__bar {
  display: flex;
  align-items: center;
  gap: 4px;
}

.shipping-timeline__segment {
  flex: 1;
  height: 6px;
  border-radius: 3px;
  background: rgba(255, 255, 255, 0.08);
  position: relative;
}

.shipping-timeline__segment.is-active {
  background: linear-gradient(90deg, var(--color-success), #00c853);
}

.shipping-timeline__labels {
  display: flex;
  justify-content: space-between;
  margin-top: 6px;
  font-size: 0.6875rem;
  color: var(--color-text-muted);
}

/* Product tabs */
.product-tabs { margin-top: var(--space-2xl); }

.product-tabs__nav {
  display: flex;
  gap: var(--space-xs);
  border-bottom: 1px solid var(--color-glass-border);
  margin-bottom: var(--space-lg);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.product-tabs__btn {
  padding: var(--space-sm) var(--space-md);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--color-text-muted);
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.875rem;
  white-space: nowrap;
  cursor: pointer;
  transition: var(--transition-default);
  margin-bottom: -1px;
}

.product-tabs__btn:hover { color: var(--color-text-primary); }

.product-tabs__btn.is-active {
  color: #ffffff;
  border-bottom-color: #ffffff;
}

.product-tabs__panel { display: none; animation: fadeIn 0.3s ease; }
.product-tabs__panel.is-active { display: block; }

.product-tabs__panel p {
  color: var(--color-text-secondary);
  line-height: 1.7;
  margin-bottom: var(--space-md);
}

/* Sticky ATC bar */
.sticky-atc {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: var(--z-header);
  background: rgba(10, 10, 15, 0.95);
  backdrop-filter: blur(20px);
  border-top: 1px solid var(--color-glass-border);
  padding: var(--space-sm) 0;
  transform: translateY(100%);
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.sticky-atc.is-visible { transform: translateY(0); }

.sticky-atc__container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
}

.sticky-atc__product {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex: 1;
  min-width: 0;
}

.sticky-atc__thumb {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  object-fit: cover;
  flex-shrink: 0;
}

.sticky-atc__title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sticky-atc__price {
  font-family: var(--font-mono);
  font-weight: 700;
  color: var(--color-text-primary);
}

.sticky-atc__btn {
  padding: 12px 24px;
  min-height: 48px;
  background: #ffffff;
  color: #0a0a0f;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.9375rem;
  border: none;
  border-radius: 12px;
  cursor: pointer;
  transition: var(--transition-default);
  white-space: nowrap;
}

.sticky-atc__btn:hover { transform: scale(1.05); }

.sticky-atc__compare {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  text-decoration: line-through;
  margin-right: var(--space-sm);
}


/* --- HTML Class Aliases (template uses different class names) --- */

.product-title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  color: var(--color-text-primary);
  margin: 0 0 var(--space-sm);
  line-height: 1.15;
  letter-spacing: -0.5px;
}

.product-rating {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
}

.product-rating__stars {
  color: #ffc107;
  font-size: 16px;
  letter-spacing: 1px;
}

.product-rating__score {
  font-size: 14px;
  font-weight: 600;
  color: var(--color-text-primary);
}

.product-rating__count {
  font-size: 13px;
  color: var(--color-text-muted);
}

.price-sale {
  font-family: var(--font-mono);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-text-primary);
}

.price-compare {
  font-family: var(--font-mono);
  font-size: 1.125rem;
  color: var(--color-text-muted);
  text-decoration: line-through;
  margin-left: var(--space-md);
}

.price-savings {
  display: inline-block;
  margin-left: var(--space-md);
  padding: 4px 10px;
  background: rgba(255,255,255,0.06);
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: 600;
  color: var(--color-success);
}

.btn-atc-main {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 18px 32px;
  min-height: 56px;
  background: #ffffff;
  color: #0a0a0f;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 16px;
  border: none;
  border-radius: 14px;
  cursor: pointer;
  transition: var(--transition-default);
  margin-bottom: var(--space-md);
}

.btn-atc-main:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(255,255,255,0.15);
}

.btn-atc-main:active { transform: translateY(0); }

.btn-atc-main:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  transform: none;
}

.variant-option {
  padding: 10px 18px;
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-sm);
  color: var(--color-text-primary);
  font-family: var(--font-heading);
  font-weight: 500;
  font-size: 14px;
  cursor: pointer;
  transition: var(--transition-default);
}

.variant-option:hover {
  border-color: rgba(255,255,255,0.3);
}

.variant-option.selected {
  background: #ffffff;
  border-color: #ffffff;
  color: #0a0a0f;
  font-weight: 600;
}

.variant-label {
  display: block;
  font-weight: 600;
  font-size: 14px;
  margin-bottom: 10px;
  color: var(--color-text-primary);
}

.quantity-stepper {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-sm);
  overflow: hidden;
}

.qty-btn {
  width: 44px;
  height: 44px;
  border: none;
  background: transparent;
  color: var(--color-text-primary);
  font-size: 18px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
}

.qty-btn:hover { background: rgba(255,255,255,0.05); }

.qty-input {
  width: 56px;
  height: 44px;
  border: none;
  border-left: 1px solid var(--color-glass-border);
  border-right: 1px solid var(--color-glass-border);
  background: transparent;
  color: var(--color-text-primary);
  font-family: var(--font-mono);
  font-size: 15px;
  font-weight: 600;
  text-align: center;
  outline: none;
}

.tab-btn {
  padding: 12px 20px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--color-text-muted);
  font-weight: 600;
  font-size: 14px;
  white-space: nowrap;
  cursor: pointer;
  transition: var(--transition-default);
  margin-bottom: -1px;
}

.tab-btn:hover { color: var(--color-text-primary); }

.tab-btn.active {
  color: #ffffff;
  border-bottom-color: #ffffff;
}

.tab-panel {
  display: none;
  animation: fadeIn 0.3s ease;
}

.tab-panel.active { display: block; }

.product-description.rte {
  color: var(--color-text-secondary);
  line-height: 1.8;
  font-size: 15px;
}

.product-description.rte p { margin-bottom: 16px; }

.specs-table {
  width: 100%;
  border-collapse: collapse;
}

.specs-table th,
.specs-table td {
  padding: 14px 0;
  border-bottom: 1px solid var(--color-glass-border);
  text-align: left;
  font-size: 14px;
}

.specs-table th {
  color: var(--color-text-muted);
  font-weight: 500;
  width: 40%;
}

.specs-table td { color: var(--color-text-primary); }

.timeline-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  flex: 0 0 auto;
}

.timeline-item.active .timeline-dot {
  background: var(--color-success);
  box-shadow: 0 0 8px rgba(0,230,118,0.3);
}

.timeline-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: rgba(255,255,255,0.15);
  margin-bottom: 8px;
  transition: background 0.3s;
}

.timeline-line {
  flex: 1;
  height: 2px;
  background: rgba(255,255,255,0.08);
  margin: 0 8px;
  margin-bottom: 32px;
}

.timeline-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text-primary);
  white-space: nowrap;
}

.timeline-date {
  font-size: 11px;
  color: var(--color-text-muted);
  margin-top: 2px;
  white-space: nowrap;
}

.reviews-placeholder {
  text-align: center;
  padding: 40px 20px;
}

.reviews-placeholder__rating {
  font-size: 18px;
  color: var(--color-text-primary);
  margin-bottom: 8px;
}

.reviews-placeholder__text {
  font-size: 14px;
  color: var(--color-text-muted);
}

.product-trust-row {
  display: flex;
  justify-content: center;
  gap: 24px;
  padding: 14px 0;
  border-top: 1px solid var(--color-glass-border);
  margin-bottom: 24px;
}

.product-trust-row__item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--color-text-muted);
}

.product-trust-row__icon { font-size: 16px; }

.shipping-timeline {
  display: flex;
  align-items: center;
  gap: 0;
  padding: 16px;
  margin-bottom: 24px;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-md);
}

.btn-atc-sticky {
  padding: 12px 24px;
  background: #ffffff;
  color: #0a0a0f;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 14px;
  border: none;
  border-radius: 12px;
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.2s;
}

.btn-atc-sticky:hover { transform: scale(1.03); }

.badge--sale { background: rgba(255,255,255,0.1); color: #ffffff; border: 1px solid rgba(255,255,255,0.15); }
.badge--bestseller { background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.8); border: 1px solid rgba(255,255,255,0.1); }
.badge--trending { background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.6); border: 1px solid rgba(255,255,255,0.08); }

/* ===== SOCIAL PROOF NOTIFICATIONS ===== */
#sp-box { position: fixed; bottom: 20px; left: 20px; z-index: 99999; display: flex; flex-direction: column-reverse; gap: 10px; pointer-events: none; }
#sp-box .sp-toast { display: flex; align-items: center; gap: 12px; width: 340px; max-width: calc(100vw - 40px); padding: 14px 16px; background: #ffffff; border: 1px solid rgba(0,0,0,0.08); border-radius: 14px; box-shadow: 0 8px 32px rgba(0,0,0,0.15), 0 2px 8px rgba(0,0,0,0.08); pointer-events: all; position: relative; overflow: hidden; animation: sp-toast-in 0.5s ease forwards; }
#sp-box .sp-toast p { margin: 0; font-size: 13px; font-weight: 500; line-height: 1.5; color: #1a1a2e; }
#sp-box .sp-toast strong { color: #ff007f; font-weight: 700; }
#sp-box .sp-toast .sp-time { display: block; margin-top: 3px; font-size: 11px; color: rgba(0,0,0,0.4); }
@keyframes sp-toast-in { from { opacity: 0; transform: translateX(-120%); } to { opacity: 1; transform: translateX(0); } }
@keyframes sp-toast-out { from { opacity: 1; transform: translateX(0); } to { opacity: 0; transform: translateX(-120%); } }
@media(max-width:640px) { #sp-box { left: 12px; bottom: 12px; } }

.product-short-description {
  font-size: 15px;
  line-height: 1.7;
  color: var(--color-text-secondary);
  margin-bottom: 24px;
}

.product-quantity { margin-bottom: 20px; }

.product-info__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}


/* ═══════════════════════════════════════════
   PRODUCT PAGE CONVERSION ELEMENTS
   FOMO bar, countdown, FAQ accordion
   ═══════════════════════════════════════════ */

/* FOMO Bar */
.product-fomo {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  margin: 12px 0 20px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px;
  font-size: 13px;
  color: var(--color-text-secondary);
  position: relative;
  overflow: hidden;
}

.product-fomo__pulse {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--color-success);
  animation: fomo-pulse 2s ease-in-out infinite;
}

@keyframes fomo-pulse {
  0%, 100% { opacity: 0.4; }
  50% { opacity: 1; }
}

.product-fomo strong {
  color: var(--color-success);
  font-weight: 700;
}

.product-fomo svg {
  color: var(--color-success);
  flex-shrink: 0;
}

/* Product Countdown */
.product-countdown {
  padding: 14px 16px;
  margin-bottom: 20px;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--color-glass-border);
  border-radius: 12px;
}

.product-countdown__label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-primary);
  margin-bottom: 10px;
}

.product-countdown__label svg {
  color: var(--color-warning);
}

/* Product FAQ Accordion */
.product-faq {
  margin-top: 48px;
  border-top: 1px solid var(--color-glass-border);
  padding-top: 32px;
}

.product-faq__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.25rem;
  color: var(--color-text-primary);
  margin-bottom: 20px;
}

.faq-accordion__item {
  border-bottom: 1px solid var(--color-glass-border);
}

.faq-accordion__question {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 0;
  background: none;
  border: none;
  color: var(--color-text-primary);
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 15px;
  text-align: left;
  cursor: pointer;
  transition: color 0.2s;
}

.faq-accordion__question:hover {
  color: var(--color-text-secondary);
}

.faq-accordion__icon {
  width: 20px;
  height: 20px;
  color: var(--color-text-muted);
  transition: transform 0.3s ease;
  flex-shrink: 0;
  margin-left: 12px;
}

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

.faq-accordion__answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s ease;
}

.faq-accordion__item.is-open .faq-accordion__answer {
  max-height: 300px;
}

.faq-accordion__answer-inner {
  padding: 0 0 20px;
  font-size: 14px;
  line-height: 1.7;
  color: var(--color-text-secondary);
}

/* Payment icons */
.payment-icons {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 16px;
  flex-wrap: wrap;
}

.payment-icon {
  width: 40px;
  height: 26px;
  border-radius: 4px;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--color-glass-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  color: var(--color-text-muted);
  font-weight: 600;
}

/* Mobile product conversion elements */
@media (max-width: 749px) {
  .product-fomo {
    margin: 8px 0 16px;
    padding: 8px 12px;
    font-size: 12px;
    border-radius: 10px;
  }
  .product-countdown {
    padding: 12px;
    margin-bottom: 16px;
  }
  .product-countdown .countdown-timer__box {
    min-width: 52px;
    padding: 8px 4px;
  }
  .product-countdown .countdown-timer__number {
    font-size: 22px;
  }
  .product-faq {
    margin-top: 32px;
    padding-top: 24px;
  }
  .faq-accordion__question {
    font-size: 14px;
    padding: 14px 0;
  }
  .payment-icons {
    gap: 6px;
  }
  .payment-icon {
    width: 36px;
    height: 22px;
    font-size: 8px;
  }
}
/* ═══ MOBILE PRODUCT PAGE ═══ */
@media (max-width: 749px) {
  .product-main { padding-top: 72px; padding-bottom: 48px; }
  .product-main__grid { grid-template-columns: 1fr; gap: 24px; }
  .product-gallery { position: relative; top: 0; }
  .product-gallery__main { border-radius: 0; margin: 0 -16px 12px; aspect-ratio: 1/1; }
  .product-gallery__thumbs { padding: 0 16px; }
  .product-info__title { font-size: 7vw; }
  .product-info__price { flex-wrap: wrap; }
  .product-info__price-sale { font-size: 1.5rem; }
  .atc-btn { border-radius: 12px; font-size: 15px; position: sticky; bottom: 12px; z-index: 50; }
  .product-trust { gap: var(--space-md); }
  .sticky-atc { display: none !important; }
  .shipping-timeline { padding: 12px; }
}
/* ============================================
   PART 19: COLLECTION PAGE
   ============================================ */

.collection-header {
  position: relative;
  padding: 160px 0 80px;
  text-align: center;
  overflow: hidden;
}

.collection-header__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.collection-header__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.collection-header__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, var(--color-bg-primary) 0%, rgba(10, 10, 15, 0.7) 50%, rgba(10, 10, 15, 0.4) 100%);
  z-index: 1;
}

.collection-header__content {
  position: relative;
  z-index: 2;
  max-width: 700px;
  margin: 0 auto;
  padding: 0 var(--space-lg);
}

.collection-header__title {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(2rem, 5vw, 3rem);
  margin-bottom: var(--space-md);
}

.collection-header__desc {
  font-size: 1.0625rem;
  color: var(--color-text-secondary);
  line-height: 1.6;
}

/* Collection toolbar */
.collection-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--color-glass-border);
  margin-bottom: var(--space-lg);
  flex-wrap: wrap;
}

.collection-toolbar__left {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.collection-toolbar__filter-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 18px;
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-pill);
  color: var(--color-text-primary);
  font-family: var(--font-heading);
  font-weight: 500;
  font-size: 0.875rem;
  cursor: pointer;
  transition: var(--transition-default);
}

.collection-toolbar__filter-btn:hover {
  border-color: var(--color-accent-neon-cyan);
  color: var(--color-accent-neon-cyan);
}

.collection-toolbar__results {
  font-size: 0.875rem;
  color: var(--color-text-muted);
}

.collection-toolbar__sort {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.sort-label {
  font-size: 0.875rem;
  color: var(--color-text-muted);
}

.sort-select {
  padding: 10px 16px;
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-pill);
  color: var(--color-text-primary);
  font-family: var(--font-heading);
  font-size: 0.875rem;
  cursor: pointer;
  transition: var(--transition-default);
  appearance: none;
  -webkit-appearance: none;
  padding-right: 40px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.5)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
}

.sort-select:focus {
  border-color: var(--color-accent-neon-cyan);
  box-shadow: 0 0 0 3px rgba(0, 240, 255, 0.15);
}

/* Product grid */
.product-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
  margin-bottom: var(--space-2xl);
}

/* Active filter tags */
.active-filters {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}

.active-filters__label {
  font-size: 0.8125rem;
  color: var(--color-text-muted);
  font-weight: 500;
}

.filter-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-pill);
  font-size: 0.8125rem;
  color: var(--color-text-primary);
  cursor: pointer;
  transition: var(--transition-default);
}

.filter-tag:hover {
  background: rgba(255, 0, 127, 0.1);
  border-color: rgba(255, 0, 127, 0.3);
  color: var(--color-accent-neon-pink);
}

.filter-tag svg {
  width: 14px;
  height: 14px;
}

.filter-tag--clear {
  background: transparent;
  border-style: dashed;
  color: var(--color-text-muted);
}

.filter-tag--clear:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: var(--color-text-secondary);
  color: var(--color-text-primary);
}

/* Filter panel (sidebar/sheet) */
.filter-panel {
  position: fixed;
  top: 0;
  left: 0;
  width: 360px;
  max-width: 85vw;
  height: 100vh;
  background: var(--color-bg-secondary);
  border-right: 1px solid var(--color-glass-border);
  z-index: var(--z-drawer);
  transform: translateX(-100%);
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  overflow-y: auto;
}

.filter-panel.is-open {
  transform: translateX(0);
}

.filter-panel__overlay {
  position: fixed;
  inset: 0;
  background: rgba(10, 10, 15, 0.7);
  z-index: calc(var(--z-drawer) - 1);
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s;
}

.filter-panel__overlay.is-visible {
  opacity: 1;
  visibility: visible;
}

.filter-panel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-lg) var(--space-xl);
  border-bottom: 1px solid var(--color-glass-border);
  position: sticky;
  top: 0;
  background: var(--color-bg-secondary);
  z-index: 1;
}

.filter-panel__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.125rem;
}

.filter-panel__close {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-full);
  color: var(--color-text-secondary);
  transition: var(--transition-default);
}

.filter-panel__close:hover {
  background: rgba(255, 0, 127, 0.15);
  color: var(--color-accent-neon-pink);
}

.filter-group {
  padding: var(--space-lg) var(--space-xl);
  border-bottom: 1px solid var(--color-glass-border);
}

.filter-group__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.9375rem;
  margin-bottom: var(--space-md);
}

.filter-group__options {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.filter-checkbox {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  cursor: pointer;
  font-size: 0.875rem;
  color: var(--color-text-secondary);
  transition: var(--transition-default);
}

.filter-checkbox:hover {
  color: var(--color-text-primary);
}

.filter-checkbox input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--color-accent-neon-pink);
}

/* Price range */
.price-range {
  padding: var(--space-sm) 0;
}

.price-range__inputs {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
}

.price-range__input {
  flex: 1;
  padding: 10px 14px;
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-sm);
  color: var(--color-text-primary);
  font-family: var(--font-mono);
  font-size: 0.8125rem;
}

.price-range__input:focus {
  border-color: var(--color-accent-neon-pink);
}

.price-range__sep {
  color: var(--color-text-muted);
  font-size: 0.875rem;
}

/* Pagination */
.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  margin-top: var(--space-2xl);
  padding-top: var(--space-xl);
  border-top: 1px solid var(--color-glass-border);
}

.pagination__link {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 12px;
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-md);
  color: var(--color-text-secondary);
  font-family: var(--font-mono);
  font-size: 0.875rem;
  font-weight: 500;
  transition: var(--transition-default);
}

.pagination__link:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--color-text-primary);
  border-color: var(--color-text-secondary);
}

.pagination__link.is-active {
  background: var(--color-accent-neon-pink);
  border-color: var(--color-accent-neon-pink);
  color: #ffffff;
  box-shadow: var(--shadow-glow-pink);
}

.pagination__link:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

/* Empty collection state */
.collection-empty {
  text-align: center;
  padding: var(--space-3xl) var(--space-lg);
}

.collection-empty__icon {
  width: 80px;
  height: 80px;
  margin: 0 auto var(--space-lg);
  color: var(--color-text-muted);
  opacity: 0.4;
}

.collection-empty__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.25rem;
  margin-bottom: var(--space-sm);
}

.collection-empty__text {
  color: var(--color-text-secondary);
  margin-bottom: var(--space-xl);
}

/* ============================================
   PART 20: FOOTER
   ============================================ */

.site-footer {
  background: var(--color-bg-secondary);
  border-top: 1px solid var(--color-glass-border);
}

.site-footer__main {
  padding: var(--space-3xl) 0;
}

.site-footer__grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1.5fr;
  gap: var(--space-3xl);
}

/* Footer brand column */
.footer-brand__logo {
  max-height: 36px;
  width: auto;
  margin-bottom: var(--space-md);
}

.footer-brand__logo-text {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 1.5rem;
  color: var(--color-text-primary);
  margin-bottom: var(--space-sm);
}

.footer-brand__tagline {
  color: var(--color-text-secondary);
  font-size: 0.9375rem;
  line-height: 1.6;
  margin-bottom: var(--space-lg);
}

.footer-social {
  display: flex;
  gap: var(--space-sm);
}

.footer-social__link {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-full);
  color: var(--color-text-secondary);
  transition: var(--transition-default);
}

.footer-social__link:hover {
  background: rgba(255, 0, 127, 0.1);
  border-color: rgba(255, 0, 127, 0.3);
  color: var(--color-accent-neon-pink);
  transform: translateY(-2px);
  box-shadow: var(--shadow-glow-pink);
}

.footer-social__link svg {
  width: 18px;
  height: 18px;
}

/* Footer menu columns */
.footer-menu__title {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.8125rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
  margin-bottom: var(--space-lg);
}

.footer-menu__list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.footer-menu__link {
  display: block;
  color: var(--color-text-secondary);
  font-size: 0.9375rem;
  transition: var(--transition-default);
  padding: 2px 0;
}

.footer-menu__link:hover {
  color: var(--color-text-primary);
  padding-left: 4px;
}

/* Newsletter in footer */
.footer-newsletter__text {
  color: var(--color-text-secondary);
  font-size: 0.875rem;
  margin-bottom: var(--space-md);
  line-height: 1.6;
}

.footer-newsletter__form {
  display: flex;
  gap: var(--space-sm);
}

.footer-newsletter__input {
  flex: 1;
  padding: 12px 16px;
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  border-radius: var(--radius-pill);
  color: var(--color-text-primary);
  font-family: var(--font-heading);
  font-size: 0.875rem;
  transition: var(--transition-default);
}

.footer-newsletter__input:focus {
  border-color: var(--color-accent-neon-pink);
  box-shadow: 0 0 0 3px rgba(255, 0, 127, 0.15);
}

.footer-newsletter__input::placeholder {
  color: var(--color-text-muted);
}

.footer-newsletter__btn {
  padding: 12px 24px;
  background: var(--color-accent-gradient);
  color: #ffffff;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.875rem;
  border: none;
  border-radius: var(--radius-pill);
  cursor: pointer;
  transition: var(--transition-default);
  box-shadow: var(--shadow-glow-pink);
  flex-shrink: 0;
}

.footer-newsletter__btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 20px rgba(255, 0, 127, 0.5);
}

/* Footer bottom bar */
.site-footer__bottom {
  padding: var(--space-lg) 0;
  border-top: 1px solid var(--color-glass-border);
}

.site-footer__bottom-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  flex-wrap: wrap;
}

.footer-payment {
  display: flex;
  gap: var(--space-sm);
  flex-wrap: wrap;
}

.footer-payment__icon {
  width: 40px;
  height: 26px;
  background: var(--color-glass-bg);
  border: 1px solid var(--color-glass-border);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.6;
  transition: var(--transition-default);
}

.footer-payment__icon:hover {
  opacity: 1;
}

.footer-payment__icon svg {
  width: 28px;
  height: 18px;
}

.footer-copyright {
  font-size: 0.8125rem;
  color: var(--color-text-muted);
}

.footer-region {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.footer-region__link {
  font-size: 0.8125rem;
  color: var(--color-text-muted);
  transition: var(--transition-default);
}

.footer-region__link:hover {
  color: var(--color-text-primary);
}


/* ============================================
   PART 21: ANIMATIONS
   ============================================ */

/* Fade in up (scroll triggered) */
.animate-fade-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s cubic-bezier(0.4, 0, 0.2, 1), transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.animate-fade-up.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Slide in from left */
.animate-slide-left {
  opacity: 0;
  transform: translateX(-50px);
  transition: opacity 0.6s cubic-bezier(0.4, 0, 0.2, 1), transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.animate-slide-left.is-visible {
  opacity: 1;
  transform: translateX(0);
}

/* Slide in from right */
.animate-slide-right {
  opacity: 0;
  transform: translateX(50px);
  transition: opacity 0.6s cubic-bezier(0.4, 0, 0.2, 1), transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.animate-slide-right.is-visible {
  opacity: 1;
  transform: translateX(0);
}

/* Scale in */
.animate-scale {
  opacity: 0;
  transform: scale(0.9);
  transition: opacity 0.5s cubic-bezier(0.4, 0, 0.2, 1), transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.animate-scale.is-visible {
  opacity: 1;
  transform: scale(1);
}

/* Stagger delay utilities */
[data-delay="1"].animate-fade-up,
[data-delay="1"].animate-slide-left,
[data-delay="1"].animate-slide-right { transition-delay: 0.1s; }

[data-delay="2"].animate-fade-up,
[data-delay="2"].animate-slide-left,
[data-delay="2"].animate-slide-right { transition-delay: 0.2s; }

[data-delay="3"].animate-fade-up,
[data-delay="3"].animate-slide-left,
[data-delay="3"].animate-slide-right { transition-delay: 0.3s; }

[data-delay="4"].animate-fade-up,
[data-delay="4"].animate-slide-left,
[data-delay="4"].animate-slide-right { transition-delay: 0.4s; }

[data-delay="5"].animate-fade-up,
[data-delay="5"].animate-slide-left,
[data-delay="5"].animate-slide-right { transition-delay: 0.5s; }

[data-delay="6"].animate-fade-up,
[data-delay="6"].animate-slide-left,
[data-delay="6"].animate-slide-right { transition-delay: 0.6s; }

/* Keyframes */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes slideInLeft {
  from {
    opacity: 0;
    transform: translateX(-50px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes slideInRight {
  from {
    opacity: 0;
    transform: translateX(50px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes pulse {
  0%, 100% {
    opacity: 1;
    transform: scale(1);
  }
  50% {
    opacity: 0.8;
    transform: scale(1.02);
  }
}

@keyframes glow {
  0%, 100% {
    box-shadow: 0 0 5px rgba(255, 0, 127, 0.3), 0 0 10px rgba(255, 0, 127, 0.1);
  }
  50% {
    box-shadow: 0 0 20px rgba(255, 0, 127, 0.5), 0 0 40px rgba(255, 0, 127, 0.2);
  }
}

@keyframes shimmer {
  0% {
    background-position: -200% 0;
  }
  100% {
    background-position: 200% 0;
  }
}

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

@keyframes marquee {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

@keyframes bounce-down {
  0%, 20%, 50%, 80%, 100% {
    transform: translateY(0);
  }
  40% {
    transform: translateY(8px);
  }
  60% {
    transform: translateY(4px);
  }
}

@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

@keyframes shake {
  0%, 100% {
    transform: translateX(0);
  }
  25% {
    transform: translateX(-5px);
  }
  75% {
    transform: translateX(5px);
  }
}

/* Utility animation classes */
.animate-pulse {
  animation: pulse 2s ease-in-out infinite;
}

.animate-pulse-glow {
  animation: glow 2s ease-in-out infinite;
}

.animate-float {
  animation: float 4s ease-in-out infinite;
}

.animate-shimmer {
  background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.05) 50%, transparent 100%);
  background-size: 200% 100%;
  animation: shimmer 2s infinite;
}

.animate-shake {
  animation: shake 0.4s ease-in-out;
}

/* Cart notification */
.cart-notification {
  position: fixed;
  top: 90px;
  right: var(--space-lg);
  z-index: var(--z-toast);
  padding: var(--space-md) var(--space-lg);
  background: var(--color-glass-bg);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  border: 1px solid var(--color-success);
  border-radius: var(--radius-lg);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
  display: flex;
  align-items: center;
  gap: var(--space-md);
  transform: translateX(120%);
  opacity: 0;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.cart-notification.is-visible {
  transform: translateX(0);
  opacity: 1;
}

.cart-notification__icon {
  width: 28px;
  height: 28px;
  color: var(--color-success);
  flex-shrink: 0;
}

.cart-notification__text {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text-primary);
}

/* Loader / skeleton */
.skeleton {
  background: linear-gradient(90deg, var(--color-glass-bg) 25%, rgba(255, 255, 255, 0.03) 50%, var(--color-glass-bg) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: var(--radius-md);
}

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

  .animate-fade-up,
  .animate-slide-left,
  .animate-slide-right,
  .animate-scale {
    opacity: 1;
    transform: none;
  }
}

/* ============================================
   PART 22: RESPONSIVE
   ============================================ */

/* --- Tablet: max-width 1024px --- */
@media (max-width: 1024px) {
  /* Header */
  .site-nav {
    display: none;
  }

  .hamburger {
    display: flex;
  }

  /* Hero */
  .hero__grid {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .hero__content {
    max-width: 100%;
  }

  .hero__subtitle {
    margin-left: auto;
    margin-right: auto;
  }

  .hero__ctas {
    justify-content: center;
  }

  .hero__trust {
    justify-content: center;
  }

  .hero__media {
    display: none;
  }

  /* Benefits */
  .benefits__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Bundle */
  .bundle-grid {
    grid-template-columns: 1fr 1fr;
  }

  .bundle-card {
    grid-row: span 1;
    grid-column: span 2;
  }

  /* UGC */
  .ugc-grid {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 220px;
  }

  .ugc-item--large {
    grid-row: span 2;
    grid-column: span 2;
  }

  /* Footer */
  .site-footer__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-2xl);
  }

  /* Product page */
  .product-main__grid {
    grid-template-columns: 1fr;
  }

  .product-gallery {
    position: relative;
    top: 0;
  }

  /* Collection */
  .product-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* --- Mobile: max-width 768px --- */
@media (max-width: 768px) {
  :root {
    --space-section: 64px;
  }

  /* Container */
  .container {
    padding-left: var(--space-md);
    padding-right: var(--space-md);
  }

  /* Header */
  .site-header {
    height: 60px;
  }

  .header-icons {
    gap: 0;
  }

  /* Hero */
  .hero {
    padding-top: 100px;
    min-height: auto;
  }

  .hero__title {
    font-size: 2rem;
  }

  .hero__ctas {
    flex-direction: column;
    align-items: stretch;
  }

  .hero__ctas .btn {
    width: 100%;
  }

  /* Benefits */
  .benefits__grid {
    grid-template-columns: 1fr;
  }

  /* Bundle */
  .bundle-grid {
    grid-template-columns: 1fr;
  }

  .bundle-card {
    grid-column: span 1;
  }

  /* Countdown */
  .countdown__timer {
    gap: var(--space-sm);
  }

  .countdown__box {
    min-width: 60px;
    padding: var(--space-sm) var(--space-md);
  }

  .countdown__number {
    font-size: 1.75rem;
  }

  .countdown__separator {
    font-size: 1.25rem;
  }

  /* UGC */
  .ugc-grid {
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: 180px;
  }

  .ugc-item--large {
    grid-row: span 1;
    grid-column: span 2;
  }

  /* Trust badges */
  .trust-badges__row {
    gap: var(--space-md);
  }

  .trust-badge {
    flex: 0 0 calc(50% - var(--space-sm));
  }

  /* Testimonials */
  .testimonial-card {
    padding: var(--space-lg);
  }

  /* Footer */
  .site-footer__grid {
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
  }

  .site-footer__bottom-inner {
    flex-direction: column;
    text-align: center;
  }

  .footer-newsletter__form {
    flex-direction: column;
  }

  /* Product page */
  .product-main__grid {
    gap: var(--space-xl);
  }

  .product-gallery__thumbs {
    grid-template-columns: repeat(4, 1fr);
  }

  .atc-btn {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: var(--z-above);
    border-radius: 0;
    margin-bottom: 0;
  }

  .sticky-atc {
    display: none;
  }

  .product-tabs__nav {
    gap: 0;
  }

  /* Collection */
  .product-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
  }

  .collection-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  /* Cart drawer */
  .cart-drawer {
    width: 100%;
  }

  /* Popup */
  .popup {
    padding: var(--space-xl);
    margin: var(--space-md);
  }

  /* Filter panel */
  .filter-panel {
    width: 100%;
    max-width: 100%;
  }

  /* Mobile menu */
  .mobile-menu {
    width: 100%;
    max-width: 100%;
  }

  /* Quick add button always visible on mobile */
  .product-card__quick-add {
    opacity: 1;
    transform: none;
    position: relative;
    bottom: auto;
    left: auto;
    right: auto;
    margin-top: var(--space-sm);
  }
}

/* --- Small mobile: max-width 480px --- */
@media (max-width: 480px) {
  .hero__title {
    font-size: 1.75rem;
  }

  .hero__subtitle {
    font-size: 1rem;
  }

  .btn {
    padding: 12px 24px;
    font-size: 0.9375rem;
  }

  .countdown__box {
    min-width: 48px;
    padding: var(--space-sm);
  }

  .countdown__number {
    font-size: 1.25rem;
  }

  .countdown__label {
    font-size: 0.5625rem;
  }

  .countdown__separator {
    font-size: 1rem;
  }

  .ugc-grid {
    grid-template-columns: 1fr;
    grid-auto-rows: 240px;
  }

  .ugc-item--large {
    grid-column: span 1;
  }

  .product-grid {
    gap: var(--space-sm);
  }

  .trust-badge {
    flex: 0 0 100%;
  }

  .footer-payment {
    justify-content: center;
  }

  .site-header__inner {
    padding: 0 var(--space-md);
  }

  .hero__badge {
    font-size: 0.625rem;
    padding: 6px 14px;
  }
}

/* --- Touch-friendly tap targets --- */
@media (pointer: coarse) {
  button,
  a,
  input[type="submit"],
  input[type="button"],
  .btn,
  .header-icons__btn,
  .product-card__quick-add,
  .variant-btn,
  .qty-stepper__btn {
    min-height: 44px;
    min-width: 44px;
  }

  .site-nav__link {
    padding: 12px 16px;
  }

  .footer-menu__link {
    padding: 8px 0;
  }
}

/* --- High contrast mode --- */
@media (prefers-contrast: high) {
  .glass-card,
  .glass,
  .site-header,
  .popup,
  .cart-drawer,
  .mobile-menu {
    border-width: 2px;
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
  }
}

/* ============================================
   CUSTOM MERCHANT CSS INJECTION POINT
   ============================================ */

{{ settings.custom_css }}

/* ============================================
   MOBILE-FIRST RESPONSIVE OVERRIDES
   Gen Z Gaming Room Decor - 95% Mobile Traffic
   ============================================ */

/* === 1. HERO SECTION === */
@media (max-width: 749px) {
  .hero-section { min-height: 100svh; }
  .hero__container { padding: 100px 16px 40px !important; }
  .hero__content { text-align: left !important; }
  .hero__heading { font-size: 9vw !important; letter-spacing: -1.5px; }
  .hero__heading .hero__accent { display: block; font-size: 0.6em; opacity: 0.45; }
  .hero__subheading { font-size: 15px; margin: 12px 0 0; max-width: 100%; }
  .hero__cta-row { flex-direction: column; gap: 10px; margin-top: 24px; }
  .hero__cta { width: 100%; border-radius: 14px; padding: 16px 24px; font-size: 15px; }
  .hero__trust-row { justify-content: flex-start; gap: 12px; flex-wrap: wrap; margin-top: 16px; }
  .hero__trust-item--shipping { display: none; }
  .hero__social-proof { justify-content: flex-start; margin-top: 20px; }
  .hero__avatar svg { width: 32px; height: 32px; }
  .hero__scroll-indicator { display: none !important; }
  .hero__visual { display: none !important; }
  .hero__badge { font-size: 10px; padding: 6px 14px; margin-bottom: 16px; }
}

/* === 2. HEADER === */
@media (max-width: 749px) {
  .site-header { height: 56px; }
  .site-header__container { padding: 0 12px; }
  .site-header__logo-text { font-size: 17px; }
  .site-header__nav { display: none; }
  .site-header__menu-toggle { display: flex; }
  .header-icons { gap: 4px; }
  .header-icons__btn { width: 40px; height: 40px; }
}

/* === 3. PRODUCT CARDS === */
@media (max-width: 749px) {
  .product-card { border-radius: 14px; }
  .product-card__image-wrapper { aspect-ratio: 1 / 1; }
  .product-card__content { padding: 12px 14px 16px; }
  .product-card__title { font-size: 14px; }
  .product-card__price { font-size: 15px; }
  .product-grid { gap: 12px; }
  .product-grid--4,
  .product-grid--3 { grid-template-columns: repeat(2, 1fr); }
}

/* === 4. FEATURED PRODUCTS SECTION === */
@media (max-width: 749px) {
  .featured-products__container { padding: 60px 16px 12px; }
  .featured-products__header { margin-bottom: 32px; }
  .featured-products__title { font-size: 7vw; }
  .featured-products__subtitle { font-size: 14px; padding: 0 16px; }
}

/* === 5. COUNTDOWN TIMER === */
@media (max-width: 749px) {
  .countdown-section { padding: 8px 16px 12px; }
  .countdown__headline { font-size: 14px; margin-bottom: 8px; margin-top: 0; }
  .countdown__timer { gap: 6px; margin-bottom: 8px; }
  .countdown__box { min-width: 52px; padding: 8px 6px; border-radius: 8px; }
  .countdown__number { font-size: 24px; }
  .countdown__separator,
  .countdown__colon { font-size: 16px; }
  .countdown__label { font-size: 9px; margin-top: 4px; }
  .countdown__subtext { margin-top: 6px; font-size: 14px; font-weight: 700; color: #fff; text-shadow: 0 0 10px rgba(0, 240, 255, 0.4); }
  .countdown__cta { margin-top: 8px; padding: 8px 20px; font-size: 12px; }
}

/* === 6. BENEFITS SECTION === */
@media (max-width: 749px) {
  .benefits__grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .benefit-card { padding: 24px 16px; }
  .benefit-card__icon { width: 48px; height: 48px; }
  .benefit-card__icon svg { width: 22px; height: 22px; }
  .benefit-card__title { font-size: 14px; }
  .benefit-card__text { font-size: 12px; }
  .benefits::before { height: 8px; }
}

/* === 7. BUNDLE OFFER === */
@media (max-width: 749px) {
  .bundle-offer { padding: 60px 0; }
  .bundle-offer__bento { grid-template-columns: 1fr; }
  .bundle-offer__main-card { padding: 24px; }
  .bundle-offer__side { grid-template-columns: repeat(2, 1fr); }
}

/* === 8. TESTIMONIALS === */
@media (max-width: 749px) {
  .testimonials { padding: 60px 0; }
  .testimonial-card { padding: 24px; }
  .testimonial-card__text { font-size: 14px; }
}

/* === 9. TRUST BADGES === */
@media (max-width: 749px) {
  .trust-badges { padding: 24px 0; }
  .trust-badges__grid { flex-wrap: wrap; gap: 16px 12px; }
  .trust-badge { flex: 1 1 30%; min-width: 80px; }
  .trust-badge svg { width: 20px; height: 20px; }
  .trust-badge__text { font-size: 10px; }
}

/* === 10. FAQ === */
@media (max-width: 749px) {
  .faq { padding: 60px 0; }
  .faq__question { padding: 16px 0; font-size: 15px; }
  .faq__answer { padding: 0 0 16px; font-size: 14px; }
}

/* === 11. FOOTER === */
@media (max-width: 749px) {
  .site-footer { padding: 48px 0 0; }
  .footer__main { padding: 48px 0 24px; }
  .footer__grid { grid-template-columns: 1fr !important; gap: 32px; }
  .footer__col { text-align: center; }
  .footer__col--legal .footer__menu { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; text-align: left; }
  .footer__col--legal { order: 99; }
  .footer__menu-link { padding: 8px 0; font-size: 14px; }
  .footer__col-title { font-size: 13px; margin-bottom: 12px; }
  .footer__social { justify-content: center; }
  .footer__contact-mini { text-align: center; }
  .footer__bottom { padding: 16px; }
  .footer__bottom-inner { flex-direction: column; gap: 12px; text-align: center; }
  .footer__payments { justify-content: center; flex-wrap: wrap; }
}

/* === 12. NEWSLETTER POPUP === */
@media (max-width: 749px) {
  .newsletter-popup__modal { margin: 16px; max-width: 100%; padding: 32px 20px; border-radius: 20px; }
  .newsletter-popup__heading { font-size: 22px; }
  .newsletter-popup__email { padding: 14px 18px; font-size: 16px; }
}

/* === 13. CART DRAWER === */
@media (max-width: 480px) {
  .rv-cart__panel { max-width: 100%; border-radius: 0; }
  .rv-cart__header { padding: 14px 16px; }
  .rv-item { padding: 12px; gap: 12px; }
  .rv-item__img-wrap { width: 60px; height: 60px; min-width: 60px; }
  .rv-item__title { font-size: 12px; }
  .rv-btn-checkout { padding: 14px 20px; font-size: 14px; }
  .rv-ship { padding: 10px; }
  .rv-ship__bar-bg { height: 5px; }
  .rv-express__grid { gap: 6px; }
  .rv-express__btn { padding: 10px; font-size: 12px; }
  .rv-cart__trust { padding: 0 14px 10px; }
  .rv-cart__trust .rv-trust__item { font-size: 10px; }
}

/* === 14. GENERAL MOBILE FIXES === */
@media (max-width: 749px) {
  /* Larger tap targets everywhere */
  button, a, input, select, textarea { min-height: 44px; min-width: 44px; }

  /* Prevent text zoom on iOS inputs */
  input, select, textarea { font-size: 16px !important; }

  /* Container padding */
  .container { padding-left: 16px; padding-right: 16px; }

  /* Section spacing */
  section { padding-left: 0; padding-right: 0; }

  /* Typography */
  body { font-size: 15px; line-height: 1.6; }

