/*
Theme Name:  AURA Nutrition
Theme URI:   https://aura.ma
Author:      AURA Nutrition
Author URI:  https://aura.ma
Description: Premium supplement e-commerce theme for AURA Nutrition — Morocco's first world-class supplement brand. Built with WooCommerce, ACF Pro, and GSAP. Clean architecture, 95+ PageSpeed, fully responsive.
Version:     1.0.0
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 8.1
License:     Proprietary
Text Domain: aura
Tags:        woocommerce, e-commerce, custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* ============================================================
   AURA DESIGN TOKENS
   Single source of truth — all values derived from here
   ============================================================ */

:root {
  /* Brand colours */
  --aura-green:       #2a7a4b;
  --aura-green-light: #4db87a;
  --aura-green-pale:  #e8f5ee;
  --aura-green-mid:   #1f5c38;
  --aura-green-dark:  #0d3320;

  --aura-obsidian:    #0a0a0a;
  --aura-charcoal:    #1a1a1a;
  --aura-white:       #ffffff;
  --aura-pearl:       #f8f8f6;
  --aura-light:       #f0f0ec;

  /* Typography */
  --aura-mid:         #888882;
  --aura-text:        #0a0a0a;
  --aura-text-2:      #444441;
  --aura-text-3:      #888882;

  /* Borders */
  --aura-border:      #e8e8e4;
  --aura-border-dark: #c8c8c2;

  /* Typography scale */
  --font-serif:    'Playfair Display', Georgia, serif;
  --font-sans:     'Inter', system-ui, -apple-system, sans-serif;
  --font-mono:     'JetBrains Mono', 'Fira Code', monospace;

  --text-display: clamp(36px, 5vw, 64px);
  --text-h1:      clamp(28px, 4vw, 48px);
  --text-h2:      clamp(22px, 3vw, 36px);
  --text-h3:      clamp(18px, 2.5vw, 24px);
  --text-body-lg: 17px;
  --text-body:    15px;
  --text-sm:      13px;
  --text-xs:      12px;
  --text-caption: 11px;

  /* Spacing (8px base grid) */
  --space-1:  4px;
  --space-2:  8px;
  --space-3:  12px;
  --space-4:  16px;
  --space-5:  24px;
  --space-6:  32px;
  --space-7:  48px;
  --space-8:  64px;
  --space-9:  80px;
  --space-10: 120px;

  /* Section padding */
  --section-y:    80px;
  --section-y-sm: 48px;
  --container:    1280px;
  --container-sm: 960px;

  /* Radius */
  --radius-sm:  6px;
  --radius:     10px;
  --radius-lg:  16px;
  --radius-xl:  24px;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-sm:  0 1px 3px rgba(10,10,10,.06);
  --shadow:     0 4px 16px rgba(10,10,10,.08);
  --shadow-lg:  0 12px 40px rgba(10,10,10,.12);
  --shadow-xl:  0 24px 64px rgba(10,10,10,.16);

  /* Transitions */
  --ease:         cubic-bezier(.22,.1,.36,1);
  --ease-bounce:  cubic-bezier(.34,1.56,.64,1);
  --trans-fast:   150ms var(--ease);
  --trans:        250ms var(--ease);
  --trans-slow:   400ms var(--ease);

  /* Z-index scale */
  --z-base:    1;
  --z-card:    10;
  --z-sticky:  100;
  --z-drawer:  200;
  --z-modal:   300;
  --z-toast:   400;
}

/* ============================================================
   RESET & BASE
   ============================================================ */

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body {
  font-family: var(--font-sans);
  font-size: var(--text-body);
  line-height: 1.7;
  color: var(--aura-text);
  background: var(--aura-white);
  overflow-x: hidden;
}

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

a {
  color: inherit;
  text-decoration: none;
}

ul, ol { list-style: none; }

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

/* ============================================================
   TYPOGRAPHY
   ============================================================ */

.display {
  font-family: var(--font-serif);
  font-size: var(--text-display);
  font-weight: 700;
  line-height: 1.04;
  letter-spacing: -0.5px;
}

h1, .h1 {
  font-family: var(--font-serif);
  font-size: var(--text-h1);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.3px;
}

h2, .h2 {
  font-family: var(--font-serif);
  font-size: var(--text-h2);
  font-weight: 700;
  line-height: 1.18;
}

h3, .h3 {
  font-size: var(--text-h3);
  font-weight: 500;
  line-height: 1.3;
}

h4, .h4 {
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: .2px;
}

p { max-width: 65ch; }

.eyebrow {
  font-size: var(--text-caption);
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--aura-green);
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}

.eyebrow::before {
  content: '';
  display: block;
  width: 20px;
  height: 1px;
  background: var(--aura-green);
  flex-shrink: 0;
}

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

.eyebrow--center::before,
.eyebrow--center::after {
  content: '';
  display: block;
  width: 20px;
  height: 1px;
  background: var(--aura-green);
}

.eyebrow--light {
  color: var(--aura-green-light);
}

.eyebrow--light::before,
.eyebrow--light::after {
  background: var(--aura-green-light);
}

/* ============================================================
   LAYOUT UTILITIES
   ============================================================ */

.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--space-7);
}

.container--sm {
  max-width: var(--container-sm);
}

.section {
  padding-block: var(--section-y);
}

.section--sm {
  padding-block: var(--section-y-sm);
}

.section--pearl { background: var(--aura-pearl); }
.section--light { background: var(--aura-light); }
.section--dark  { background: var(--aura-obsidian); color: var(--aura-white); }
.section--green { background: var(--aura-green); color: var(--aura-white); }

.section-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: var(--space-7);
  gap: var(--space-5);
}

.section-link {
  font-size: var(--text-xs);
  color: var(--aura-mid);
  display: flex;
  align-items: center;
  gap: 4px;
  white-space: nowrap;
  transition: color var(--trans-fast);
}

.section-link:hover { color: var(--aura-obsidian); }

/* Grid systems */
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-5); }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4); }
.grid-5 { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--space-3); }

/* Flex helpers */
.flex     { display: flex; }
.flex-col { display: flex; flex-direction: column; }
.items-center  { align-items: center; }
.items-start   { align-items: flex-start; }
.justify-between { justify-content: space-between; }
.justify-center  { justify-content: center; }
.gap-1 { gap: var(--space-2); }
.gap-2 { gap: var(--space-3); }
.gap-3 { gap: var(--space-4); }
.gap-4 { gap: var(--space-5); }

/* ============================================================
   BUTTONS
   ============================================================ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  height: 44px;
  padding-inline: var(--space-5);
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: .2px;
  cursor: pointer;
  transition: background var(--trans-fast), color var(--trans-fast),
              border-color var(--trans-fast), transform var(--trans-fast),
              box-shadow var(--trans-fast);
  white-space: nowrap;
  user-select: none;
  text-decoration: none;
}

.btn:active { transform: scale(.98); }

.btn--primary {
  background: var(--aura-green);
  color: var(--aura-white);
  border-color: var(--aura-green);
}
.btn--primary:hover {
  background: var(--aura-green-mid);
  border-color: var(--aura-green-mid);
}

.btn--dark {
  background: var(--aura-obsidian);
  color: var(--aura-white);
  border-color: var(--aura-obsidian);
}
.btn--dark:hover {
  background: var(--aura-charcoal);
  border-color: var(--aura-charcoal);
}

.btn--outline {
  background: transparent;
  color: var(--aura-obsidian);
  border-color: var(--aura-obsidian);
}
.btn--outline:hover {
  background: var(--aura-obsidian);
  color: var(--aura-white);
}

.btn--outline-white {
  background: transparent;
  color: var(--aura-white);
  border-color: rgba(255,255,255,.3);
}
.btn--outline-white:hover {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.6);
}

.btn--ghost {
  background: transparent;
  color: var(--aura-mid);
  border-color: var(--aura-border);
}
.btn--ghost:hover {
  color: var(--aura-obsidian);
  border-color: var(--aura-border-dark);
}

.btn--sm {
  height: 34px;
  padding-inline: var(--space-3);
  font-size: var(--text-caption);
  border-radius: var(--radius-sm);
}

.btn--lg {
  height: 52px;
  padding-inline: var(--space-7);
  font-size: var(--text-body);
  border-radius: var(--radius);
}

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

.btn--loading { opacity: .6; pointer-events: none; }

/* ============================================================
   CARDS — BASE
   ============================================================ */

.card {
  background: var(--aura-white);
  border: 1px solid var(--aura-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: transform var(--trans), border-color var(--trans), box-shadow var(--trans);
}

.card:hover {
  transform: translateY(-4px);
  border-color: var(--aura-border-dark);
  box-shadow: var(--shadow-lg);
}

/* ============================================================
   FORM ELEMENTS
   ============================================================ */

.field {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.field label {
  font-size: var(--text-caption);
  font-weight: 600;
  color: var(--aura-mid);
  letter-spacing: .3px;
  text-transform: uppercase;
}

.field input,
.field select,
.field textarea {
  height: 44px;
  padding-inline: var(--space-4);
  border: 1px solid var(--aura-border-dark);
  border-radius: var(--radius-sm);
  background: var(--aura-white);
  color: var(--aura-text);
  font-size: var(--text-sm);
  outline: none;
  transition: border-color var(--trans-fast), box-shadow var(--trans-fast);
}

.field input:focus,
.field select:focus,
.field textarea:focus {
  border-color: var(--aura-green);
  box-shadow: 0 0 0 3px rgba(42,122,75,.12);
}

.field textarea {
  height: auto;
  min-height: 100px;
  padding-block: var(--space-3);
  resize: vertical;
}

/* ============================================================
   TRUST BADGES
   ============================================================ */

.trust-strip {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.trust-badge {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-caption);
  color: var(--aura-mid);
}

.trust-badge i { font-size: 16px; color: var(--aura-green); }

/* ============================================================
   STAR RATINGS
   ============================================================ */

.stars {
  display: flex;
  gap: 2px;
  color: var(--aura-green);
}
.stars i { font-size: 12px; }
.stars--lg i { font-size: 16px; }

/* ============================================================
   SECTION DIVIDER
   ============================================================ */

.divider {
  height: 1px;
  background: var(--aura-border);
  margin-block: 0;
}

/* ============================================================
   BADGE / PILL
   ============================================================ */

.badge {
  display: inline-block;
  padding: 3px 8px;
  border-radius: var(--radius-sm);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .4px;
  text-transform: uppercase;
}

.badge--green  { background: var(--aura-green); color: #fff; }
.badge--dark   { background: var(--aura-obsidian); color: #fff; }
.badge--pale   { background: var(--aura-green-pale); color: var(--aura-green-mid); }
.badge--gray   { background: var(--aura-light); color: var(--aura-mid); }

/* ============================================================
   SCROLL ANIMATIONS (initial hidden state)
   JS adds .is-visible class via IntersectionObserver
   ============================================================ */

.fade-up {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .7s var(--ease), transform .7s var(--ease);
}

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

.fade-in {
  opacity: 0;
  transition: opacity .7s var(--ease);
}
.fade-in.is-visible { opacity: 1; }

.stagger-children > * {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .6s var(--ease), transform .6s var(--ease);
}

.stagger-children.is-visible > *:nth-child(1) { opacity: 1; transform: none; transition-delay: 0s; }
.stagger-children.is-visible > *:nth-child(2) { opacity: 1; transform: none; transition-delay: .08s; }
.stagger-children.is-visible > *:nth-child(3) { opacity: 1; transform: none; transition-delay: .16s; }
.stagger-children.is-visible > *:nth-child(4) { opacity: 1; transform: none; transition-delay: .24s; }
.stagger-children.is-visible > *:nth-child(5) { opacity: 1; transform: none; transition-delay: .32s; }
.stagger-children.is-visible > *:nth-child(6) { opacity: 1; transform: none; transition-delay: .40s; }

/* ============================================================
   REDUCED MOTION OVERRIDES
   ============================================================ */

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
  }

  .fade-up, .fade-in, .stagger-children > * {
    opacity: 1 !important;
    transform: none !important;
  }
}

/* ============================================================
   RESPONSIVE BREAKPOINTS
   ============================================================ */

@media (max-width: 1200px) {
  :root { --container: 100%; }
  .grid-5 { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 960px) {
  :root {
    --section-y: 56px;
    --section-y-sm: 36px;
  }
  .container { padding-inline: var(--space-5); }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .section-header { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 640px) {
  .container { padding-inline: var(--space-4); }
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .grid-5 { grid-template-columns: repeat(2, 1fr); }
  .btn--lg { height: 48px; padding-inline: var(--space-5); }
}
/* ============================================================
   AURA Nutrition — main.css
   Full site styles: nav, hero, sections, cards, footer.
   Imports from style.css tokens via cascade.
   ============================================================ */

/* ── ANNOUNCEMENT BAR ── */
.aura-announcement {
    background: var(--aura-green);
    padding: 10px var(--space-5);
    text-align: center;
    font-size: var(--text-caption);
    font-weight: 600;
    color: #fff;
    letter-spacing: .3px;
    position: relative;
}

.aura-announcement i {
    font-size: 13px;
    vertical-align: -2px;
    margin-right: 5px;
}

.aura-announcement__close {
    position: absolute;
    right: var(--space-4);
    top: 50%;
    transform: translateY(-50%);
    background: transparent;
    border: none;
    color: rgba(255,255,255,.6);
    cursor: pointer;
    font-size: 16px;
    padding: 4px;
    line-height: 1;
}

/* ── NAVIGATION ── */
.site-header {
    position: sticky;
    top: 0;
    z-index: var(--z-sticky);
    transition: transform var(--trans-slow);
}

.site-header--hidden {
    transform: translateY(-100%);
}

.primary-nav {
    background: var(--aura-obsidian);
    border-bottom: 1px solid rgba(255,255,255,.06);
    transition: background var(--trans), backdrop-filter var(--trans);
}

.primary-nav--scrolled {
    background: rgba(10,10,10,.92);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom-color: rgba(255,255,255,.08);
}

.nav-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 64px;
    padding-inline: var(--space-7);
    gap: var(--space-5);
}

/* Logo */
.nav-logo { display: flex; align-items: center; flex-shrink: 0; }
.nav-logo__text {
    font-family: var(--font-serif);
    font-size: 22px;
    font-weight: 700;
    color: var(--aura-white);
    letter-spacing: 4px;
    line-height: 1;
}
.nav-logo img { height: 36px; width: auto; }

/* Nav links */
.nav-links {
    display: flex;
    align-items: center;
    gap: 4px;
    flex: 1;
    justify-content: center;
}

.nav-item { position: relative; }

.nav-link {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 8px 14px;
    font-size: var(--text-xs);
    color: rgba(255,255,255,.65);
    letter-spacing: .3px;
    cursor: pointer;
    border: none;
    background: transparent;
    border-radius: var(--radius-sm);
    transition: color var(--trans-fast), background var(--trans-fast);
}

.nav-link:hover,
.nav-link[aria-expanded="true"] {
    color: var(--aura-white);
    background: rgba(255,255,255,.06);
}

.nav-link i { font-size: 11px; transition: transform var(--trans-fast); }
.nav-link[aria-expanded="true"] i { transform: rotate(180deg); }

/* Mega menu */
.mega-menu {
    position: absolute;
    top: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    width: 640px;
    background: var(--aura-white);
    border: 1px solid var(--aura-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
    opacity: 0;
    pointer-events: none;
    transform-origin: top center;
    transition: opacity var(--trans), transform var(--trans);
    transform: translateX(-50%) translateY(-8px);
    z-index: var(--z-drawer);
}

.mega-menu.is-open {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
}

.mega-menu__inner {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: var(--space-5);
    padding: var(--space-5);
}

.mega-menu__heading {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--aura-mid);
    margin-bottom: var(--space-3);
}

.mega-menu__link {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: 6px 0;
    font-size: var(--text-xs);
    color: var(--aura-text-2);
    border-bottom: 1px solid var(--aura-border);
    transition: color var(--trans-fast);
}

.mega-menu__link:last-child { border-bottom: none; }
.mega-menu__link:hover { color: var(--aura-green); }

.mega-featured {
    padding: var(--space-4);
    background: var(--aura-pearl);
    border-radius: var(--radius);
}

.mega-featured__name {
    font-size: var(--text-sm);
    font-weight: 600;
    margin: var(--space-2) 0 var(--space-1);
}

.mega-featured__excerpt {
    font-size: var(--text-caption);
    color: var(--aura-mid);
    line-height: 1.6;
    margin-bottom: var(--space-3);
}

/* Dropdown */
.dropdown-menu {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    min-width: 200px;
    background: var(--aura-white);
    border: 1px solid var(--aura-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
    opacity: 0;
    pointer-events: none;
    transform: translateY(-6px);
    transition: opacity var(--trans), transform var(--trans);
    z-index: var(--z-drawer);
}

.dropdown-menu.is-open {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.dropdown-menu li a {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: 10px var(--space-4);
    font-size: var(--text-xs);
    color: var(--aura-text-2);
    transition: background var(--trans-fast), color var(--trans-fast);
}

.dropdown-menu li a:hover {
    background: var(--aura-pearl);
    color: var(--aura-green);
}

/* Nav actions */
.nav-actions {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-shrink: 0;
}

.nav-icon-btn {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: var(--radius-sm);
    border: none;
    background: transparent;
    color: rgba(255,255,255,.65);
    font-size: 20px;
    cursor: pointer;
    transition: color var(--trans-fast), background var(--trans-fast);
}

.nav-icon-btn:hover {
    color: var(--aura-white);
    background: rgba(255,255,255,.06);
}

.nav-badge {
    position: absolute;
    top: 2px;
    right: 2px;
    min-width: 16px;
    height: 16px;
    background: var(--aura-green);
    color: #fff;
    font-size: 9px;
    font-weight: 700;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 3px;
}

.nav-badge[data-count="0"] { display: none; }

/* Mobile hamburger */
.nav-hamburger {
    display: none;
    flex-direction: column;
    gap: 5px;
    width: 38px;
    height: 38px;
    padding: 9px;
    border: none;
    background: transparent;
    cursor: pointer;
    border-radius: var(--radius-sm);
}

.nav-hamburger span {
    display: block;
    height: 1.5px;
    background: rgba(255,255,255,.65);
    border-radius: 2px;
    transition: transform var(--trans), opacity var(--trans);
}

.nav-hamburger[aria-expanded="true"] span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-hamburger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-hamburger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* ── DRAWERS (mobile + cart) ── */
.mobile-drawer,
.cart-drawer {
    position: fixed;
    top: 0;
    bottom: 0;
    width: min(380px, 90vw);
    background: var(--aura-white);
    z-index: var(--z-modal);
    transform: translateX(100%);
    transition: transform var(--trans-slow);
    display: flex;
    flex-direction: column;
    box-shadow: var(--shadow-xl);
}

.mobile-drawer { left: 0; transform: translateX(-100%); }
.cart-drawer   { right: 0; }

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

.mobile-drawer__backdrop,
.cart-drawer__backdrop {
    position: fixed;
    inset: 0;
    background: rgba(10,10,10,.5);
    z-index: calc(var(--z-modal) - 1);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--trans-slow);
    backdrop-filter: blur(4px);
}

.mobile-drawer__backdrop.is-visible,
.cart-drawer__backdrop.is-visible {
    opacity: 1;
    pointer-events: auto;
}

.mobile-drawer__header,
.cart-drawer__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-4) var(--space-5);
    border-bottom: 1px solid var(--aura-border);
}

.mobile-drawer__body,
.cart-drawer__body {
    flex: 1;
    overflow-y: auto;
    padding: var(--space-4) var(--space-5);
    -webkit-overflow-scrolling: touch;
}

.cart-drawer__footer {
    padding: var(--space-4) var(--space-5);
    border-top: 1px solid var(--aura-border);
    background: var(--aura-pearl);
}

.drawer-close {
    width: 34px;
    height: 34px;
    border: 1px solid var(--aura-border);
    border-radius: var(--radius-sm);
    background: transparent;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 18px;
    color: var(--aura-mid);
    transition: color var(--trans-fast), border-color var(--trans-fast);
}

.drawer-close:hover { color: var(--aura-obsidian); border-color: var(--aura-border-dark); }

/* Cart item */
.cart-item {
    display: flex;
    gap: var(--space-3);
    padding: var(--space-3) 0;
    border-bottom: 1px solid var(--aura-border);
}

.cart-item:last-child { border-bottom: none; }

.cart-item__image { width: 64px; height: 72px; border-radius: var(--radius-sm); overflow: hidden; flex-shrink: 0; }
.cart-item__image img { width: 100%; height: 100%; object-fit: cover; }
.cart-item__info { flex: 1; min-width: 0; }
.cart-item__name { font-size: var(--text-xs); font-weight: 500; margin-bottom: 4px; }
.cart-item__price { font-size: var(--text-sm); color: var(--aura-mid); margin-bottom: 8px; }
.cart-item__qty { display: flex; align-items: center; gap: 8px; }

.qty-btn {
    width: 26px;
    height: 26px;
    border: 1px solid var(--aura-border);
    border-radius: 4px;
    background: transparent;
    cursor: pointer;
    font-size: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    transition: border-color var(--trans-fast);
}

.qty-btn:hover { border-color: var(--aura-border-dark); }
.qty-val { font-size: var(--text-sm); font-weight: 500; min-width: 20px; text-align: center; }

.cart-item__remove {
    width: 28px;
    height: 28px;
    border: none;
    background: transparent;
    color: var(--aura-mid);
    cursor: pointer;
    font-size: 16px;
    flex-shrink: 0;
    transition: color var(--trans-fast);
}

.cart-item__remove:hover { color: #e24b4a; }

/* Cart empty */
.cart-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--space-4);
    min-height: 200px;
    text-align: center;
    color: var(--aura-mid);
}

/* Free shipping bar */
.fs-bar { padding: var(--space-3) 0; }
.fs-bar__track { height: 4px; background: var(--aura-border); border-radius: 2px; overflow: hidden; margin-bottom: 8px; }
.fs-bar__fill { height: 100%; background: var(--aura-green); border-radius: 2px; transition: width .4s var(--ease); }
.fs-bar__label { font-size: var(--text-caption); color: var(--aura-mid); }
.fs-bar__label strong { color: var(--aura-obsidian); }
.fs-achieved { font-size: var(--text-caption); color: var(--aura-green); font-weight: 600; display: flex; align-items: center; gap: 5px; }

/* ── HERO ── */
.hero {
    position: relative;
    min-height: 100svh;
    display: flex;
    align-items: flex-end;
    padding-bottom: var(--space-10);
    overflow: hidden;
    background: var(--aura-obsidian);
}

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

.hero__video,
.hero__poster {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    will-change: transform;
}

.hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to top,
        rgba(5,15,9,.92) 0%,
        rgba(5,15,9,.35) 50%,
        rgba(5,15,9,.1) 100%
    );
}

.hero__glow {
    position: absolute;
    top: -100px;
    right: -80px;
    width: 500px;
    height: 500px;
    background: radial-gradient(circle, rgba(42,122,75,.22) 0%, transparent 70%);
    pointer-events: none;
}

.hero__content {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: var(--space-7);
    width: 100%;
}

.hero__body { max-width: 580px; }

.hero__eyebrow { margin-bottom: var(--space-4); }

.hero__headline {
    color: var(--aura-white);
    margin-bottom: var(--space-5);
}

.hero__headline em { font-style: italic; color: var(--aura-green-light); }

.hero__sub {
    font-size: var(--text-body-lg);
    color: rgba(255,255,255,.58);
    line-height: 1.75;
    margin-bottom: var(--space-6);
    max-width: 420px;
}

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

/* Hero stats */
.hero__stats {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    align-items: flex-end;
    padding-bottom: var(--space-3);
    flex-shrink: 0;
}

.hero__stat-num {
    display: block;
    font-size: 28px;
    font-weight: 700;
    color: var(--aura-white);
    line-height: 1;
    text-align: right;
}

.hero__stat-lbl {
    display: block;
    font-size: 10px;
    color: rgba(255,255,255,.38);
    text-transform: uppercase;
    letter-spacing: .8px;
    margin-top: 3px;
    text-align: right;
}

.hero__stat-divider {
    width: 1px;
    height: 24px;
    background: rgba(255,255,255,.1);
    align-self: flex-end;
}

/* Video badge */
.hero__vid-badge {
    position: absolute;
    bottom: 40px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: 8px 16px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: var(--radius-full);
    backdrop-filter: blur(12px);
    cursor: pointer;
    transition: background var(--trans-fast);
    color: inherit;
}

.hero__vid-badge:hover { background: rgba(255,255,255,.12); }

.hero__vid-play {
    width: 30px;
    height: 30px;
    background: var(--aura-green);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.hero__vid-play i { font-size: 11px; color: #fff; margin-left: 2px; }

.hero__vid-label { font-size: var(--text-caption); color: rgba(255,255,255,.7); }

/* Scroll indicator */
.hero__scroll {
    position: absolute;
    bottom: var(--space-5);
    right: var(--space-7);
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.hero__scroll-line {
    width: 1px;
    height: 48px;
    background: linear-gradient(to bottom, rgba(255,255,255,.4) 0%, transparent 100%);
    animation: scrollLine 1.5s ease-in-out infinite;
}

@keyframes scrollLine {
    0%   { transform: scaleY(0); transform-origin: top; }
    50%  { transform: scaleY(1); transform-origin: top; }
    51%  { transform: scaleY(1); transform-origin: bottom; }
    100% { transform: scaleY(0); transform-origin: bottom; }
}

/* ── GOAL SELECTOR ── */
.goals-section .section-sub { margin-bottom: 0; }

.goals-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--space-2);
    margin-bottom: var(--space-5);
}

.goal-card {
    padding: var(--space-5) var(--space-3);
    border-radius: var(--radius);
    border: 1px solid var(--aura-border);
    background: var(--aura-white);
    cursor: pointer;
    text-align: center;
    transition: background var(--trans), border-color var(--trans), transform var(--trans);
}

.goal-card:hover { transform: translateY(-2px); border-color: var(--aura-border-dark); }

.goal-card--active {
    background: var(--aura-obsidian);
    border-color: var(--aura-obsidian);
}

.goal-card__icon {
    font-size: 26px;
    display: block;
    margin-bottom: var(--space-2);
    color: var(--aura-mid);
    transition: color var(--trans);
}

.goal-card--active .goal-card__icon { color: var(--aura-green-light); }

.goal-card__title {
    display: block;
    font-size: var(--text-xs);
    font-weight: 500;
    color: var(--aura-obsidian);
    transition: color var(--trans);
}

.goal-card--active .goal-card__title { color: var(--aura-white); }

.goal-card__sub {
    display: block;
    font-size: 10px;
    color: var(--aura-mid);
    margin-top: 3px;
    line-height: 1.4;
    transition: color var(--trans);
}

.goal-card--active .goal-card__sub { color: rgba(255,255,255,.4); }

/* Goal products */
.goal-products { margin-top: var(--space-5); }

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

.goal-products__loading {
    grid-column: 1/-1;
    display: flex;
    justify-content: center;
    padding: var(--space-7);
}

.goal-product-card {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3);
    background: var(--aura-white);
    border: 1px solid var(--aura-border);
    border-radius: var(--radius);
}

.goal-product-card img {
    width: 52px;
    height: 64px;
    object-fit: cover;
    border-radius: var(--radius-sm);
    flex-shrink: 0;
}

.goal-product-card__info { flex: 1; min-width: 0; }
.goal-product-card__info h4 { font-size: var(--text-xs); font-weight: 500; margin-bottom: 4px; }
.goal-product-card__price { font-size: var(--text-sm); color: var(--aura-mid); }

/* Spinner */
.spinner {
    width: 24px;
    height: 24px;
    border: 2px solid var(--aura-border);
    border-top-color: var(--aura-green);
    border-radius: 50%;
    animation: spin .7s linear infinite;
}

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

/* ── CALCULATOR ── */
.calculator-section .section-sub { margin-bottom: 0; }

.calc-wrap {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-7);
    align-items: start;
}

.calc-form { display: flex; flex-direction: column; gap: var(--space-3); }
.calc-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); }
.calc-email-note { font-size: 10px; color: var(--aura-mid); text-align: center; display: flex; align-items: center; justify-content: center; gap: 4px; }

.calc-results {
    background: var(--aura-pearl);
    border: 1px solid var(--aura-border);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    min-height: 360px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.calc-results__placeholder {
    text-align: center;
    color: var(--aura-mid);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-3);
}

.calc-results__data { width: 100%; }

.calc-metrics {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-2);
    margin-bottom: var(--space-4);
}

.calc-metric {
    background: var(--aura-white);
    border-radius: var(--radius);
    padding: var(--space-3);
    text-align: center;
}

.calc-metric__val { font-size: 22px; font-weight: 700; color: var(--aura-obsidian); }
.calc-metric__unit { font-size: 10px; color: var(--aura-green); font-weight: 600; margin-left: 2px; }
.calc-metric__lbl { display: block; font-size: 10px; color: var(--aura-mid); margin-top: 3px; text-transform: uppercase; letter-spacing: .4px; }

.calc-macros { display: flex; flex-direction: column; gap: 8px; margin-bottom: var(--space-4); }

.macro-row { display: flex; align-items: center; gap: var(--space-2); }
.macro-label { font-size: var(--text-caption); color: var(--aura-mid); min-width: 54px; }
.macro-bg { flex: 1; height: 6px; background: var(--aura-light); border-radius: 3px; overflow: hidden; }
.macro-fill { height: 100%; border-radius: 3px; transition: width .6s var(--ease); }
.macro-val { font-size: var(--text-caption); font-weight: 500; min-width: 38px; text-align: right; }

.calc-recs h4 { font-size: 10px; color: var(--aura-mid); text-transform: uppercase; letter-spacing: .7px; margin-bottom: var(--space-2); padding-top: var(--space-3); border-top: 1px solid var(--aura-border); }

.calc-rec {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-2);
    padding: 8px 0;
    border-bottom: 1px solid var(--aura-border);
    font-size: var(--text-xs);
}

.calc-rec:last-child { border-bottom: none; }

/* ── PRODUCT CARDS ── */
.products-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-3); }

.product-card {
    background: var(--aura-white);
    border: 1px solid var(--aura-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    cursor: pointer;
    transition: transform var(--trans), border-color var(--trans), box-shadow var(--trans);
}

.product-card:hover {
    transform: translateY(-4px);
    border-color: var(--aura-border-dark);
    box-shadow: var(--shadow-lg);
}

.product-card__img {
    position: relative;
    aspect-ratio: 4/5;
    background: linear-gradient(135deg, #050f09 0%, #0d2015 100%);
    overflow: hidden;
}

.product-card__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--trans-slow);
}

.product-card:hover .product-card__img img { transform: scale(1.04); }

.product-card__badge {
    position: absolute;
    top: var(--space-2);
    left: var(--space-2);
}

.product-card__wishlist {
    position: absolute;
    top: var(--space-2);
    right: var(--space-2);
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(255,255,255,.12);
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    color: rgba(255,255,255,.5);
    cursor: pointer;
    backdrop-filter: blur(8px);
    transition: color var(--trans-fast), background var(--trans-fast);
}

.product-card__wishlist:hover,
.product-card__wishlist.wishlist-btn--active {
    color: #e24b4a;
    background: rgba(255,255,255,.2);
}

.product-card__stars { position: absolute; bottom: var(--space-2); left: var(--space-2); }

.product-card__info { padding: var(--space-3) var(--space-4); }
.product-card__cat { font-size: 10px; color: var(--aura-mid); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 4px; }
.product-card__name { font-size: var(--text-sm); font-weight: 500; margin-bottom: var(--space-2); }

.product-card__flavors {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-bottom: var(--space-2);
}

.flavor-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    border: 1.5px solid var(--aura-border);
    flex-shrink: 0;
}

.flavor-more { font-size: 10px; color: var(--aura-mid); }

.product-card__footer { display: flex; align-items: center; justify-content: space-between; }
.product-card__price { font-size: 15px; font-weight: 600; }

/* ── WHY US SECTION ── */
.why-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--space-3); }

.why-card {
    text-align: center;
    padding: var(--space-6) var(--space-3);
    background: var(--aura-pearl);
    border-radius: var(--radius-lg);
    border: 1px solid var(--aura-border);
    transition: transform var(--trans), box-shadow var(--trans);
}

.why-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); }

.why-card__icon {
    width: 48px;
    height: 48px;
    border-radius: var(--radius);
    background: var(--aura-green-pale);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto var(--space-3);
    font-size: 22px;
    color: var(--aura-green);
}

.why-card__title { font-size: var(--text-sm); font-weight: 500; margin-bottom: var(--space-2); }
.why-card__desc  { font-size: var(--text-caption); color: var(--aura-mid); line-height: 1.7; }

/* ── FOUNDER SECTION ── */
.founder-video-wrap {
    position: relative;
    border-radius: var(--radius-xl);
    overflow: hidden;
    min-height: 280px;
    display: flex;
    align-items: flex-end;
    padding: var(--space-7);
    background: linear-gradient(135deg, #050f09 0%, #0d2015 50%, #1a2a1e 100%);
}

.founder-video__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, rgba(5,15,9,.95) 0%, rgba(5,15,9,.5) 55%, transparent 100%);
}

.founder-video__content { position: relative; z-index: 2; max-width: 440px; }

.founder-quote {
    font-family: var(--font-serif);
    font-size: clamp(18px, 2.5vw, 24px);
    font-style: italic;
    color: var(--aura-white);
    line-height: 1.5;
    margin-bottom: var(--space-4);
    quotes: '\201C' '\201D';
}

.founder-quote::before { content: open-quote; }
.founder-quote::after  { content: close-quote; }

.founder-cite { display: block; }
.founder-name { display: block; font-size: var(--text-xs); color: var(--aura-green-light); font-weight: 600; letter-spacing: .5px; }
.founder-role { display: block; font-size: 11px; color: rgba(255,255,255,.35); margin-top: 2px; }

.founder-play-btn {
    position: absolute;
    right: var(--space-6);
    bottom: var(--space-6);
    z-index: 2;
    width: 56px;
    height: 56px;
    background: var(--aura-green);
    border-radius: 50%;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    color: #fff;
    cursor: pointer;
    transition: transform var(--trans), background var(--trans);
    box-shadow: 0 8px 24px rgba(42,122,75,.4);
}

.founder-play-btn:hover { transform: scale(1.08); background: var(--aura-green-mid); }
.founder-play-btn i { margin-left: 3px; }

/* ── BLOG SECTION ── */
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-3); }

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

.blog-card__img-link {
    position: relative;
    display: block;
    aspect-ratio: 3/2;
    overflow: hidden;
    background: linear-gradient(135deg, #050f09, #0d2015);
}

.blog-card__img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--trans-slow); }
.blog-card:hover .blog-card__img { transform: scale(1.04); }

.blog-card__img-placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, #050f09, #0d2015); }

.blog-card__cat { position: absolute; top: var(--space-2); left: var(--space-2); }

.blog-card__body { padding: var(--space-4); flex: 1; }

.blog-card__title {
    font-size: var(--text-sm);
    font-weight: 500;
    line-height: 1.5;
    margin-bottom: var(--space-2);
}

.blog-card__title a { color: inherit; }
.blog-card__title a:hover { color: var(--aura-green); }

.blog-card__meta { display: flex; gap: var(--space-3); font-size: 10px; color: var(--aura-mid); }
.blog-card__meta i { font-size: 11px; vertical-align: -1px; }

/* ── REVIEWS SECTION ── */
.reviews-aggregate {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.reviews-score { font-size: var(--text-h3); font-weight: 700; }
.reviews-count { font-size: var(--text-xs); color: var(--aura-mid); }

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

.review-card {
    background: var(--aura-pearl);
    border: 1px solid var(--aura-border);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
}

.review-card__top { display: flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-3); }

.review-avatar {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: var(--aura-green-pale);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--aura-green-mid);
    flex-shrink: 0;
}

.review-name { font-size: var(--text-xs); font-weight: 500; }
.review-loc  { font-size: 10px; color: var(--aura-mid); margin-top: 1px; }
.review-text { font-size: var(--text-xs); color: var(--aura-mid); line-height: 1.7; margin-top: var(--space-2); }

.review-footer {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-top: var(--space-3);
    padding-top: var(--space-3);
    border-top: 1px solid var(--aura-border);
    font-size: 10px;
    color: var(--aura-mid);
}

/* ── SOCIAL SECTION ── */
.social-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--space-2); }

.social-tile {
    aspect-ratio: 1;
    background: var(--aura-light);
    border-radius: var(--radius);
    overflow: hidden;
    position: relative;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

.social-tile img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--trans-slow); }
.social-tile:hover img { transform: scale(1.06); }

.social-tile__overlay {
    position: absolute;
    inset: 0;
    background: rgba(5,15,9,.55);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity var(--trans);
    font-size: 22px;
    color: #fff;
}

.social-tile:hover .social-tile__overlay { opacity: 1; }

/* ── FOOTER ── */
.site-footer {
    background: var(--aura-obsidian);
    padding: var(--space-10) 0 var(--space-5);
    color: rgba(255,255,255,.55);
}

.footer-top {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: var(--space-8);
    margin-bottom: var(--space-8);
    padding-bottom: var(--space-7);
    border-bottom: 1px solid rgba(255,255,255,.07);
}

.footer-brand {
    font-family: var(--font-serif);
    font-size: 24px;
    color: var(--aura-white);
    letter-spacing: 4px;
    margin-bottom: var(--space-3);
}

.footer-tagline {
    font-size: var(--text-xs);
    color: rgba(255,255,255,.3);
    line-height: 1.8;
    max-width: 220px;
    margin-bottom: var(--space-4);
}

.footer-badges { display: flex; gap: var(--space-2); }
.footer-badge {
    font-size: 9px;
    font-weight: 600;
    letter-spacing: .4px;
    padding: 4px 9px;
    border-radius: var(--radius-sm);
}
.footer-badge--green { background: rgba(42,122,75,.2); color: var(--aura-green-light); }
.footer-badge--gray  { background: rgba(255,255,255,.06); color: rgba(255,255,255,.35); }

.footer-col h4 {
    font-size: 10px;
    color: rgba(255,255,255,.28);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: var(--space-4);
}

.footer-col a {
    display: block;
    font-size: var(--text-xs);
    color: rgba(255,255,255,.5);
    margin-bottom: var(--space-2);
    transition: color var(--trans-fast);
}

.footer-col a:hover { color: var(--aura-white); }

.footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.footer-copyright { font-size: 11px; color: rgba(255,255,255,.22); }

.footer-socials { display: flex; gap: var(--space-3); }

.footer-social-link {
    font-size: 20px;
    color: rgba(255,255,255,.3);
    transition: color var(--trans-fast);
}

.footer-social-link:hover { color: var(--aura-white); }

/* ── WHATSAPP FLOAT ── */
.whatsapp-float {
    position: fixed;
    bottom: var(--space-5);
    right: var(--space-5);
    z-index: var(--z-sticky);
    width: 48px;
    height: 48px;
    background: #25d366;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    color: #fff;
    box-shadow: 0 4px 20px rgba(37,211,102,.35);
    opacity: 0;
    transform: scale(.8);
    transition: opacity var(--trans), transform var(--trans);
}

.whatsapp-float.is-visible { opacity: 1; transform: scale(1); }
.whatsapp-float.is-hidden  { opacity: 0; transform: scale(.8); }
.whatsapp-float:hover { transform: scale(1.1); }

/* ── VIDEO MODAL ── */
.video-modal {
    position: fixed;
    inset: 0;
    z-index: var(--z-modal);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity var(--trans);
}

.video-modal.is-open { opacity: 1; }

.video-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(5,15,9,.9);
    backdrop-filter: blur(8px);
}

.video-modal__inner {
    position: relative;
    z-index: 2;
    width: min(860px, 92vw);
}

.video-modal__close {
    position: absolute;
    top: -48px;
    right: 0;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.2);
    color: #fff;
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background var(--trans-fast);
}

.video-modal__close:hover { background: rgba(255,255,255,.2); }

.video-modal__frame {
    position: relative;
    padding-bottom: 56.25%;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: #000;
}

.video-modal__frame iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: none;
}

/* ── TOAST ── */
.aura-toast {
    position: fixed;
    bottom: var(--space-5);
    left: 50%;
    transform: translateX(-50%) translateY(20px);
    z-index: var(--z-toast);
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-5);
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    font-weight: 500;
    box-shadow: var(--shadow-xl);
    opacity: 0;
    transition: opacity var(--trans), transform var(--trans);
    pointer-events: none;
}

.aura-toast.is-visible { opacity: 1; transform: translateX(-50%) translateY(0); }
.aura-toast--success { background: var(--aura-obsidian); color: #fff; }
.aura-toast--error   { background: #e24b4a; color: #fff; }
.aura-toast i { font-size: 16px; }

/* ── SEARCH OVERLAY ── */
.search-overlay {
    position: fixed;
    inset: 0;
    z-index: var(--z-modal);
    background: rgba(5,15,9,.9);
    backdrop-filter: blur(20px);
    display: flex;
    align-items: flex-start;
    padding-top: 120px;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--trans-slow);
}

.search-overlay.is-open { opacity: 1; pointer-events: auto; }

.search-form {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-4) 0;
    border-bottom: 1px solid rgba(255,255,255,.2);
}

.search-form i { font-size: 24px; color: rgba(255,255,255,.4); flex-shrink: 0; }

.search-form input {
    flex: 1;
    background: transparent;
    border: none;
    color: var(--aura-white);
    font-size: 24px;
    font-weight: 300;
    outline: none;
}

.search-form input::placeholder { color: rgba(255,255,255,.25); }

.search-close {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,.2);
    background: transparent;
    color: rgba(255,255,255,.5);
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: color var(--trans-fast), border-color var(--trans-fast);
}

.search-close:hover { color: #fff; border-color: rgba(255,255,255,.5); }

/* ── BODY LOCK ── */
.drawer-open,
.search-open,
.modal-open { overflow: hidden; }

/* ── RESPONSIVE ── */
@media (max-width: 1100px) {
    .why-grid   { grid-template-columns: repeat(3, 1fr); }
    .social-grid { grid-template-columns: repeat(4, 1fr); }
}

@media (max-width: 960px) {
    .nav-links, .nav-shop-cta { display: none; }
    .nav-hamburger { display: flex; }
    .calc-wrap { grid-template-columns: 1fr; }
    .goals-grid { grid-template-columns: repeat(3, 1fr); }
    .goal-products__grid { grid-template-columns: repeat(2, 1fr); }
    .hero__stats { display: none; }
    .footer-top { grid-template-columns: 1fr 1fr; gap: var(--space-6); }
    .why-grid { grid-template-columns: repeat(2, 1fr); }
    .reviews-grid { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
    .hero { min-height: 100svh; padding-bottom: var(--space-7); }
    .goals-grid { grid-template-columns: repeat(2, 1fr); }
    .products-grid { grid-template-columns: repeat(2, 1fr); }
    .blog-grid  { grid-template-columns: 1fr; }
    .why-grid   { grid-template-columns: 1fr 1fr; }
    .social-grid { grid-template-columns: repeat(3, 1fr); }
    .footer-top { grid-template-columns: 1fr; }
    .hero__vid-badge { display: none; }
    .calc-row-2 { grid-template-columns: 1fr; }
}

/* ============================================================
   AURA v1.0.1 — CRITICAL FIXES
   Ensures nav, hero, and all sections render correctly
   on all WordPress/Hostinger environments
   ============================================================ */

/* ── NAV: force dark background always ── */
.primary-nav,
.site-header .primary-nav {
    background: #0a0a0a !important;
    border-bottom: 1px solid rgba(255,255,255,.08) !important;
}

.nav-inner {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    height: 64px !important;
    padding-inline: 48px !important;
}

.nav-logo__text {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-size: 22px !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    letter-spacing: 4px !important;
    text-decoration: none !important;
}

.nav-links {
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.nav-links li { list-style: none !important; }

.nav-link {
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
    padding: 8px 14px !important;
    font-size: 13px !important;
    color: rgba(255,255,255,.65) !important;
    cursor: pointer !important;
    border: none !important;
    background: transparent !important;
    border-radius: 6px !important;
    text-decoration: none !important;
    font-family: 'Inter', system-ui, sans-serif !important;
    letter-spacing: .3px !important;
}

.nav-link:hover { color: #ffffff !important; background: rgba(255,255,255,.06) !important; }

.nav-cta {
    background: #2a7a4b !important;
    color: #fff !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    padding: 8px 18px !important;
    border-radius: 6px !important;
    border: none !important;
    cursor: pointer !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
}

.nav-cta:hover { background: #1f5c38 !important; color: #fff !important; }

.nav-actions { display: flex !important; align-items: center !important; gap: 10px !important; }

.nav-icon-btn {
    width: 38px !important;
    height: 38px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: none !important;
    background: transparent !important;
    color: rgba(255,255,255,.65) !important;
    font-size: 20px !important;
    cursor: pointer !important;
    border-radius: 6px !important;
    text-decoration: none !important;
}

.nav-icon-btn:hover { color: #fff !important; background: rgba(255,255,255,.06) !important; }

/* ── HERO: deep dark green background ── */
.hero {
    position: relative !important;
    min-height: 100vh !important;
    background: #050f09 !important;
    display: flex !important;
    align-items: flex-end !important;
    overflow: hidden !important;
    padding-bottom: 80px !important;
}

.hero__bg {
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(135deg, #050f09 0%, #0d1f13 40%, #1a2a1e 100%) !important;
    z-index: 0 !important;
}

.hero__overlay {
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(to top, rgba(5,15,9,.92) 0%, rgba(5,15,9,.35) 55%, transparent 100%) !important;
    z-index: 1 !important;
}

.hero__glow {
    position: absolute !important;
    top: -80px !important;
    right: -60px !important;
    width: 500px !important;
    height: 500px !important;
    background: radial-gradient(circle, rgba(42,122,75,.2) 0%, transparent 70%) !important;
    pointer-events: none !important;
    z-index: 1 !important;
}

.hero__content {
    position: relative !important;
    z-index: 2 !important;
    width: 100% !important;
    max-width: 1280px !important;
    margin: 0 auto !important;
    padding: 0 48px !important;
    display: flex !important;
    align-items: flex-end !important;
    justify-content: space-between !important;
    gap: 48px !important;
}

.hero__body { max-width: 580px !important; }

.hero__eyebrow {
    font-size: 11px !important;
    letter-spacing: 2.5px !important;
    color: #4db87a !important;
    text-transform: uppercase !important;
    margin-bottom: 16px !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    font-family: 'Inter', system-ui, sans-serif !important;
}

.hero__eyebrow::before {
    content: '' !important;
    display: block !important;
    width: 24px !important;
    height: 1px !important;
    background: #4db87a !important;
}

.hero__headline {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-size: clamp(36px, 5vw, 64px) !important;
    line-height: 1.04 !important;
    color: #ffffff !important;
    margin-bottom: 20px !important;
    letter-spacing: -.5px !important;
}

.hero__headline em {
    font-style: italic !important;
    color: #4db87a !important;
}

.hero__sub {
    font-size: 16px !important;
    color: rgba(255,255,255,.6) !important;
    line-height: 1.75 !important;
    margin-bottom: 32px !important;
    max-width: 420px !important;
    font-family: 'Inter', system-ui, sans-serif !important;
}

.hero__ctas { display: flex !important; gap: 12px !important; flex-wrap: wrap !important; }

/* ── BTN: green primary everywhere ── */
.btn--primary,
.btn-green,
.btn.btn--primary {
    background: #2a7a4b !important;
    color: #fff !important;
    border-color: #2a7a4b !important;
}

.btn--primary:hover { background: #1f5c38 !important; }

.btn--outline-white {
    background: transparent !important;
    color: #fff !important;
    border: 1px solid rgba(255,255,255,.3) !important;
}

.btn--outline-white:hover { background: rgba(255,255,255,.1) !important; }

/* ── HERO STATS ── */
.hero__stats {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
    align-items: flex-end !important;
    flex-shrink: 0 !important;
    padding-bottom: 12px !important;
}

.hero__stat-num {
    display: block !important;
    font-size: 28px !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    line-height: 1 !important;
    text-align: right !important;
    font-family: 'Inter', system-ui, sans-serif !important;
}

.hero__stat-lbl {
    display: block !important;
    font-size: 10px !important;
    color: rgba(255,255,255,.38) !important;
    text-transform: uppercase !important;
    letter-spacing: .8px !important;
    margin-top: 3px !important;
    text-align: right !important;
    font-family: 'Inter', system-ui, sans-serif !important;
}

.hero__stat-divider {
    width: 1px !important;
    height: 24px !important;
    background: rgba(255,255,255,.12) !important;
    margin-left: auto !important;
}

/* ── ANNOUNCEMENT BAR ── */
.aura-announcement {
    background: #2a7a4b !important;
    color: #fff !important;
    text-align: center !important;
    padding: 10px 24px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: .3px !important;
    font-family: 'Inter', system-ui, sans-serif !important;
}

/* ── SECTIONS ── */
.section { padding: 80px 0 !important; }
.section--pearl { background: #f8f8f6 !important; }
.section--dark  { background: #0a0a0a !important; color: #fff !important; }
.container { max-width: 1280px !important; margin: 0 auto !important; padding: 0 48px !important; }

/* ── GOAL CARDS ── */
.goal-card {
    padding: 18px 12px !important;
    border-radius: 10px !important;
    border: 1px solid #e8e8e4 !important;
    background: #fff !important;
    cursor: pointer !important;
    text-align: center !important;
    transition: all .2s !important;
    list-style: none !important;
}

.goal-card--active, .goal-card.goal-card--active {
    background: #0a0a0a !important;
    border-color: #0a0a0a !important;
}

.goal-card__icon { font-size: 24px !important; display: block !important; margin-bottom: 8px !important; color: #888882 !important; }
.goal-card--active .goal-card__icon { color: #4db87a !important; }
.goal-card__title { font-size: 12px !important; font-weight: 500 !important; color: #0a0a0a !important; display: block !important; }
.goal-card--active .goal-card__title { color: #fff !important; }
.goal-card__sub { font-size: 10px !important; color: #888882 !important; margin-top: 3px !important; display: block !important; }
.goal-card--active .goal-card__sub { color: rgba(255,255,255,.4) !important; }

/* ── PRODUCT CARDS ── */
.product-card {
    background: #fff !important;
    border: 1px solid #e8e8e4 !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    transition: transform .2s, box-shadow .2s !important;
}

.product-card:hover { transform: translateY(-4px) !important; box-shadow: 0 12px 40px rgba(0,0,0,.12) !important; }
.product-card__img { background: linear-gradient(135deg, #050f09 0%, #0d2015 100%) !important; aspect-ratio: 4/5 !important; position: relative !important; overflow: hidden !important; }
.pc-add, .add-to-cart-btn.btn--primary { background: #2a7a4b !important; color: #fff !important; }

/* ── WHY CARDS ── */
.why-card { background: #f8f8f6 !important; border: 1px solid #e8e8e4 !important; border-radius: 12px !important; text-align: center !important; padding: 28px 16px !important; }
.why-card__icon { background: #e8f5ee !important; color: #2a7a4b !important; width: 48px !important; height: 48px !important; border-radius: 10px !important; display: flex !important; align-items: center !important; justify-content: center !important; margin: 0 auto 14px !important; font-size: 22px !important; }

/* ── REVIEWS ── */
.review-card, .rv-card { background: #f8f8f6 !important; border: 1px solid #e8e8e4 !important; border-radius: 12px !important; padding: 18px !important; }
.rv-stars i, .review-stars i { color: #2a7a4b !important; }
.rv-verified, .review-verified { background: #e8f5ee !important; color: #1f5c38 !important; }
.rv-avatar, .review-avatar { background: #e8f5ee !important; color: #1f5c38 !important; }

/* ── FOOTER ── */
.site-footer { background: #0a0a0a !important; color: rgba(255,255,255,.55) !important; padding: 80px 0 24px !important; }
.footer-brand { font-family: 'Playfair Display', Georgia, serif !important; font-size: 24px !important; color: #fff !important; letter-spacing: 4px !important; }
.footer-badge--green { background: rgba(42,122,75,.2) !important; color: #4db87a !important; }
.fc a { color: rgba(255,255,255,.5) !important; text-decoration: none !important; display: block !important; margin-bottom: 8px !important; font-size: 13px !important; }
.fc a:hover { color: #fff !important; }
.fc h4 { color: rgba(255,255,255,.28) !important; font-size: 10px !important; text-transform: uppercase !important; letter-spacing: 1px !important; margin-bottom: 14px !important; }

/* ── WHATSAPP FLOAT ── */
.whatsapp-float {
    position: fixed !important;
    bottom: 24px !important;
    right: 24px !important;
    z-index: 9999 !important;
    width: 52px !important;
    height: 52px !important;
    background: #25d366 !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 26px !important;
    color: #fff !important;
    box-shadow: 0 4px 20px rgba(37,211,102,.4) !important;
    text-decoration: none !important;
    opacity: 1 !important;
    transform: scale(1) !important;
}

/* ── EYEBROW LINE ── */
.eyebrow {
    font-size: 11px !important;
    letter-spacing: 2px !important;
    color: #2a7a4b !important;
    text-transform: uppercase !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin-bottom: 10px !important;
    font-family: 'Inter', system-ui, sans-serif !important;
}

.eyebrow::before {
    content: '' !important;
    display: block !important;
    width: 18px !important;
    height: 1px !important;
    background: #2a7a4b !important;
    flex-shrink: 0 !important;
}

/* ── SECTION HEADINGS ── */
.sec-h2, .h2 {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-size: clamp(24px, 3vw, 38px) !important;
    line-height: 1.15 !important;
    color: #0a0a0a !important;
    margin-bottom: 8px !important;
}

/* ── MOBILE ── */
@media (max-width: 960px) {
    .nav-links { display: none !important; }
    .nav-hamburger { display: flex !important; }
    .nav-shop-cta { display: none !important; }
    .nav-inner { padding-inline: 20px !important; }
    .container { padding: 0 20px !important; }
    .hero__stats { display: none !important; }
    .hero__content { padding: 0 20px !important; }
    .section { padding: 56px 0 !important; }
    .goals-grid { grid-template-columns: repeat(2, 1fr) !important; }
    .products-grid { grid-template-columns: repeat(2, 1fr) !important; }
    .blog-grid { grid-template-columns: 1fr !important; }
    .why-grid { grid-template-columns: repeat(2, 1fr) !important; }
    .reviews-grid { grid-template-columns: 1fr !important; }
    .footer-top { grid-template-columns: 1fr 1fr !important; }
    .calc-wrap { grid-template-columns: 1fr !important; }
}

@media (max-width: 640px) {
    .goals-grid { grid-template-columns: repeat(2, 1fr) !important; }
    .products-grid { grid-template-columns: repeat(2, 1fr) !important; }
    .why-grid { grid-template-columns: 1fr 1fr !important; }
    .footer-top { grid-template-columns: 1fr !important; }
    .hero { padding-bottom: 60px !important; }
}
