.elementor-2112 .elementor-element.elementor-element-2b801db{--display:flex;}/* Start custom CSS for html, class: .elementor-element-ae4c0e7 *//* ===== RESET & BASE ===== */
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; -webkit-tap-highlight-color: transparent; }
    body {
      font-family: 'Inter', sans-serif;
      color: #111111;
      background: #ffffff;
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
      font-size: 16px;
      line-height: 1.6;
      overflow-x: hidden;
    }
    @media (min-width: 768px) { body { font-size: 18px; } }
    h1, h2, h3, h4, h5, h6 {
      font-family: 'Cormorant Garamond', serif;
      font-weight: 600;
      letter-spacing: -0.02em;
      line-height: 1.15;
      color: #111111 !important;
    }
    img { max-width: 100%; height: auto; display: block; }
    a { text-decoration: none; color: inherit; }
    a:visited, a:active, a:-webkit-any-link:active { color: inherit; }
    button { cursor: pointer; border: none; background: none; font-family: inherit; }
    button:focus, button:active, button:focus-visible,
    a:focus, a:active, a:focus-visible { outline: none !important; }
    *:focus-visible { outline: 2px solid var(--copper) !important; outline-offset: 2px; }
    ::selection { background: var(--copper-light); color: var(--text-primary); }
    /* Override WordPress theme accent/highlight colors */
    button:active, button:focus { background-color: inherit !important; color: inherit !important; }
    .gallery-nav-btn:hover, .gallery-nav-btn:focus, .gallery-nav-btn:active {
      background: white !important; color: var(--text-primary) !important;
      border-color: var(--copper-light) !important;
    }
    .qty-option:hover, .qty-option:focus, .qty-option:active {
      background: var(--cream) !important; color: var(--text-primary) !important;
    }
    .qty-option.selected:hover, .qty-option.selected:focus {
      background: white !important; border-color: var(--text-primary) !important;
    }
    .purchase-option:hover, .purchase-option:focus, .purchase-option:active {
      color: var(--text-primary) !important;
    }
    .gallery-thumb:hover, .gallery-thumb:focus, .gallery-thumb:active {
      background: white !important;
    }
    ul { list-style: none; }

    /* ===== DESIGN TOKENS ===== */
    :root {
      --copper: #C48B6E;
      --copper-light: #F0D3CC;
      --copper-dark: #A0694E;
      --cream: #FDF8F6;
      --bg-light: #F5F6F7;
      --border: #E6E6E6;
      --text-primary: #111111;
      --text-secondary: #4B4B4B;
      --white: #ffffff;
      --shadow-soft: 0 4px 20px -4px rgba(196, 139, 110, 0.15);
      --shadow-card: 0 8px 30px -8px rgba(0, 0, 0, 0.08);
      --shadow-elevated: 0 20px 50px -12px rgba(0, 0, 0, 0.12);
      --shadow-product: 0 25px 60px -15px rgba(196, 139, 110, 0.25);
      --radius: 1rem;
      --max-w: 1280px;
    }

    /* ===== UTILITY CLASSES ===== */
    .container { max-width: var(--max-w); margin: 0 auto; }
    .section-padding { padding: 2.5rem 1rem; }
@media (min-width: 768px) { .section-padding { padding: 3.5rem 2rem; } }

    /* ===== BUTTONS ===== */
    .btn-primary {
      display: inline-flex; align-items: center; justify-content: center;
      padding: 1rem 2rem; font-weight: 600; font-size: 0.95rem;
      border-radius: 9999px; transition: all 0.3s ease;
      background: #111111; color: #ffffff;
      box-shadow: var(--shadow-soft);
    }
    .btn-primary:hover { opacity: 0.9; transform: scale(1.05); box-shadow: var(--shadow-elevated); background: #222222 !important; color: #ffffff !important; }
    .btn-primary:active { background: #333333 !important; color: #ffffff !important; transform: scale(1.02); }
    .btn-copper {
      display: inline-flex; align-items: center; justify-content: center;
      padding: 1rem 2rem; font-weight: 500; font-size: 0.95rem;
      border-radius: 9999px; transition: all 0.3s ease;
      background: var(--copper-light); color: var(--text-primary);
      box-shadow: 0 4px 14px rgba(240, 211, 204, 0.4);
    }
    .btn-copper:hover { opacity: 0.9; transform: scale(1.05); background: var(--copper-light) !important; color: var(--text-primary) !important; }
    .btn-copper:active { background: #E8C4BC !important; color: var(--text-primary) !important; transform: scale(1.02); }

    /* ===== ANIMATIONS ===== */
    @keyframes fadeInUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
    @keyframes marquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
    @keyframes float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
    .animate-fade-in { animation: fadeInUp 0.6s ease-out forwards; }
    .animate-marquee { display: flex; animation: marquee 25s linear infinite; }
    .animate-float { animation: float 6s ease-in-out infinite; }

    /* ===== HEADER ===== */
    .header {
      position: sticky; top: 0; z-index: 50;
      background: rgba(255,255,255,0.95); backdrop-filter: blur(12px);
      border-bottom: 1px solid var(--border);
    }
    .header-inner {
      max-width: var(--max-w); margin: 0 auto;
      display: flex; align-items: center; justify-content: space-between;
      height: 64px; padding: 0 1rem;
    }
    @media (min-width: 768px) { .header-inner { height: 80px; padding: 0 2rem; } }
    .header-logo img { height: 32px; width: auto; }
    @media (min-width: 768px) { .header-logo img { height: 40px; } }
    .header-nav { display: none; gap: 2rem; align-items: center; }
    @media (min-width: 768px) { .header-nav { display: flex; } }
    .header-nav a {
      font-size: 0.875rem; font-weight: 500; color: var(--text-secondary);
      transition: color 0.2s;
    }
    .header-nav a:hover { color: var(--text-primary); }
    .header-actions { display: none; gap: 1rem; align-items: center; }
    @media (min-width: 768px) { .header-actions { display: flex; } }
    .header-cart {
      display: flex; align-items: center; gap: 0.5rem;
      font-size: 0.875rem; font-weight: 500; color: var(--text-secondary);
      transition: color 0.2s; background: none; border: none;
    }
    .header-cart:hover { color: var(--text-primary); }
    .header-shop-btn {
      display: inline-flex; align-items: center; justify-content: center;
      padding: 0.625rem 1.5rem; font-size: 0.875rem; font-weight: 500;
      border-radius: 9999px; background: var(--copper-light); color: var(--text-primary);
      transition: all 0.3s;
    }
    .header-shop-btn:hover { opacity: 0.9; background: var(--copper-light) !important; color: var(--text-primary) !important; }
    .header-shop-btn:active { background: #E8C4BC !important; }
    .mobile-menu-btn { display: block; padding: 0.5rem; background: none; border: none; }
    
    .mobile-menu-btn:hover { background: none; }
    @media (min-width: 768px) { .mobile-menu-btn { display: none; } }
    .mobile-menu {
      display: none; background: var(--white); border-top: 1px solid var(--border);
      padding: 1rem; flex-direction: column; gap: 1rem;
    }
    .mobile-menu.active { display: flex; }
    .mobile-menu a {
      font-size: 1rem; font-weight: 500; color: var(--text-secondary);
      padding: 0.5rem 0; transition: color 0.2s;
    }
    .mobile-menu a:hover { color: var(--text-primary); }
    .mobile-menu-divider { border-top: 1px solid var(--border); padding-top: 1rem; display: flex; flex-direction: column; gap: 0.55rem; }

    /* ===== HERO ===== */
    .hero {
      position: relative; width: 100%; min-height: 700px;
    }
    @media (min-width: 768px) { .hero { min-height: 600px; } }
    @media (min-width: 1024px) { .hero { min-height: 700px; } }
    .hero-bg-desktop {
      display: none; position: absolute; inset: 0;
      background-size: cover; background-position: center; background-repeat: no-repeat;
    }
    @media (min-width: 768px) { .hero-bg-desktop { display: block; } }
    .hero-bg-mobile {
      position: absolute; inset: 0;
      background-size: cover; background-position: top center; background-repeat: no-repeat;
    }
    @media (min-width: 768px) { .hero-bg-mobile { display: none; } }
    .hero-content {
      position: relative; z-index: 10; height: 100%; min-height: inherit;
      display: flex; align-items: flex-start;
    }
    @media (min-width: 768px) { .hero-content { align-items: center; } }
    .hero-inner {
      max-width: var(--max-w); margin: 0 auto; width: 100%;
      padding: 2.5rem 1.5rem 0;
    }
    @media (min-width: 768px) { .hero-inner { padding: 0 3rem; } }
    @media (min-width: 1024px) { .hero-inner { padding: 0 4rem; } }
    .hero-text {
      text-align: center; max-width: 32rem;
    }
    @media (min-width: 768px) {
      .hero-text { text-align: right; margin-left: auto; max-width: 32rem; }
    }
    @media (min-width: 1024px) { .hero-text { max-width: 28rem; } }
    .hero-eyebrow {
      display: inline-block; font-size: 0.875rem; font-weight: 500;
      letter-spacing: 0.15em; text-transform: uppercase; color: var(--text-secondary);
      margin-bottom: 1rem;
    }
    @media (min-width: 768px) { .hero-eyebrow { font-size: 1rem; } }
    .hero-title {
      font-size: 1.875rem; font-weight: 700; color: #111111 !important;
      line-height: 1.1; margin-bottom: 1.25rem;
    }
    @media (min-width: 640px) { .hero-title { font-size: 2.25rem; } }
    @media (min-width: 768px) { .hero-title { font-size: 3rem; } }
    @media (min-width: 1024px) { .hero-title { font-size: 3.25rem; } }
    .hero-subtitle {
      font-size: 1rem; color: #222222; line-height: 1.7; margin-bottom: 2rem;
      max-width: 28rem; font-weight: 500;
    }
    @media (min-width: 640px) { .hero-subtitle { font-size: 1.125rem; } }
    @media (min-width: 768px) { .hero-subtitle { font-size: 1.25rem; margin-left: auto; } }

    /* ===== WHY SECTION / BENEFITS ===== */
    .benefits-grid {
      display: grid; grid-template-columns: 1fr; gap: 1.5rem;
    }
    @media (min-width: 768px) { .benefits-grid { grid-template-columns: repeat(2, 1fr); } }
    @media (min-width: 1024px) { .benefits-grid { grid-template-columns: repeat(3, 1fr); } }
    .benefit-card {
      padding: 1.5rem; background: var(--bg-light); border-radius: 1rem;
      border: 1px solid var(--border); transition: all 0.3s;
    }
    .benefit-card:hover { border-color: var(--copper-light); box-shadow: var(--shadow-card); }
    .benefit-icon {
      width: 48px; height: 48px; border-radius: 0.75rem;
      background: var(--copper-light); display: flex; align-items: center; justify-content: center;
      margin-bottom: 1rem; transition: transform 0.3s;
    }
    .benefit-card:hover .benefit-icon { transform: scale(1.1); }
    .benefit-icon svg { width: 24px; height: 24px; color: var(--text-primary); }
    .benefit-title { font-family: 'Inter', sans-serif; font-size: 1.125rem; font-weight: 600; color: var(--text-primary); margin-bottom: 0.5rem; }
    .benefit-desc { font-size: 0.875rem; color: var(--text-secondary); line-height: 1.6; }

    /* ===== SECTION HEADERS ===== */
    .section-header { text-align: center; margin-bottom: 3rem; }
    @media (min-width: 768px) { .section-header { margin-bottom: 4rem; } }
    .section-title {
      font-size: 1.875rem; font-weight: 700; color: #111111 !important; margin-bottom: 1rem;
    }
    @media (min-width: 768px) { .section-title { font-size: 2.5rem; } }
    @media (min-width: 1024px) { .section-title { font-size: 3rem; } }
    .section-subtitle { font-size: 1.125rem; color: var(--text-secondary); max-width: 42rem; margin: 0 auto; }

    /* ===== INGREDIENTS ===== */
    .ingredients-section {
      position: relative; background-size: cover; background-position: center; background-repeat: no-repeat;
    }
    .ingredients-overlay {
      position: absolute; inset: 0; background: rgba(240, 211, 204, 0.35); pointer-events: none;
    }
    .ingredients-content { position: relative; z-index: 10; }
    .ingredients-grid {
      display: grid; grid-template-columns: 1fr; gap: 1.5rem;
    }
    @media (min-width: 768px) { .ingredients-grid { grid-template-columns: repeat(2, 1fr); } }
    @media (min-width: 1024px) { .ingredients-grid { grid-template-columns: repeat(3, 1fr); } }
    .ingredient-card {
      position: relative; padding: 1.5rem; background: var(--white); border-radius: 1rem;
      border: 1px solid var(--border); transition: all 0.3s; overflow: hidden;
    }
    .ingredient-card:hover { border-color: var(--copper-light); box-shadow: var(--shadow-elevated); }
    .ingredient-icon {
      width: 56px; height: 56px; border-radius: 1rem;
      background: linear-gradient(135deg, #F0D3CC 0%, #E8C4BC 100%);
      box-shadow: 0 4px 14px rgba(240, 211, 204, 0.4);
      display: flex; align-items: center; justify-content: center;
      margin-bottom: 1rem; transition: transform 0.3s;
    }
    .ingredient-card:hover .ingredient-icon { transform: scale(1.1); }
    .ingredient-icon svg { width: 28px; height: 28px; color: var(--text-primary); }
    .ingredient-name { font-family: 'Inter', sans-serif; font-size: 1.125rem; font-weight: 700; color: var(--text-primary); }
    .ingredient-tagline { font-size: 0.75rem; font-weight: 500; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-secondary); }
    .ingredient-desc { font-size: 0.875rem; color: var(--text-secondary); line-height: 1.6; margin-top: 0.5rem; margin-bottom: 0.75rem; }
    .ingredient-callout {
      font-size: 0.75rem; font-weight: 500; padding: 0.5rem 0.75rem; border-radius: 0.5rem;
      background: rgba(240, 211, 204, 0.3); color: var(--text-primary);
    }
    .ingredient-card::after {
      content: ''; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
      width: 0; height: 4px; border-radius: 4px 4px 0 0; background: var(--copper-light);
      transition: width 0.3s;
    }
    .ingredient-card:hover::after { width: 50%; }

    /* ===== LIFESTYLE BANNER ===== */
    .lifestyle-banner {
      position: relative; overflow: hidden; min-height: 400px;
      background-size: cover; background-position: center; background-repeat: no-repeat;
    }
    @media (min-width: 768px) { .lifestyle-banner { min-height: 500px; } }
    .lifestyle-overlay {
      position: absolute; inset: 0;
      background: linear-gradient(to right, rgba(0,0,0,0.4), rgba(0,0,0,0.2), transparent);
    }
    .lifestyle-content {
      position: relative; z-index: 10; max-width: var(--max-w); margin: 0 auto;
      padding: 4rem 1rem;
    }
    @media (min-width: 768px) { .lifestyle-content { padding: 6rem 2rem; } }
    .lifestyle-text { max-width: 28rem; text-align: center; }
    @media (min-width: 768px) { .lifestyle-text { text-align: left; } }
    .lifestyle-title {
      font-size: 1.5rem; font-weight: 700; color: #ffffff !important; margin-bottom: 1rem;
      text-shadow: 0 2px 8px rgba(0,0,0,0.3);
    }
    @media (min-width: 640px) { .lifestyle-title { font-size: 1.875rem; } }
    @media (min-width: 768px) { .lifestyle-title { font-size: 2.5rem; } }
    @media (min-width: 1024px) { .lifestyle-title { font-size: 3rem; } }
    .lifestyle-subtitle {
      font-size: 1.125rem; color: rgba(255,255,255,0.9); margin-bottom: 2rem;
      max-width: 28rem; text-shadow: 0 1px 4px rgba(0,0,0,0.2);
    }
    @media (min-width: 640px) { .lifestyle-subtitle { font-size: 1.25rem; } }

    /* ===== HOW TO USE ===== */
    .steps-grid {
      display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem;
    }
    @media (min-width: 640px) { .steps-grid { grid-template-columns: repeat(3, 1fr); } }
    @media (min-width: 768px) { .steps-grid { grid-template-columns: repeat(5, 1fr); gap: 1.5rem; } }
    .step-item { text-align: center; }
    .step-icon-wrap {
      position: relative; width: 64px; height: 64px; margin: 0 auto 1rem;
      border-radius: 1rem; background: var(--bg-light); border: 2px solid var(--border);
      display: flex; align-items: center; justify-content: center; transition: transform 0.3s;
    }
    .step-item:hover .step-icon-wrap { transform: scale(1.1); }
    .step-icon-wrap svg { width: 28px; height: 28px; color: var(--text-primary); }
    .step-number {
      position: absolute; top: -8px; right: -8px;
      width: 24px; height: 24px; border-radius: 50%;
      background: var(--copper-light); font-size: 0.75rem; font-weight: 700;
      display: flex; align-items: center; justify-content: center; color: var(--text-primary);
    }
    .step-title { font-family: 'Inter', sans-serif; font-weight: 600; font-size: 0.875rem; color: var(--text-primary); margin-bottom: 0.25rem; }
    @media (min-width: 768px) { .step-title { font-size: 1rem; } }
    .step-desc { font-size: 0.75rem; color: var(--text-secondary); }
    @media (min-width: 768px) { .step-desc { font-size: 0.875rem; } }

    /* Pro Tips */
    .pro-tips-card {
      border-radius: 1rem; overflow: hidden; border: 1px solid var(--border);
      box-shadow: var(--shadow-card); margin-top: 3rem;
    }
    .pro-tips-banner { position: relative; height: 192px; overflow: hidden; }
    @media (min-width: 768px) { .pro-tips-banner { height: 256px; } }
    .pro-tips-banner img { width: 100%; height: 100%; object-fit: cover; }
    .pro-tips-banner-overlay {
      position: absolute; inset: 0;
      background: linear-gradient(to bottom, transparent, transparent 50%, rgba(245, 246, 247, 0.9));
    }
    .pro-tips-banner h3 {
      position: absolute; bottom: 1rem; left: 1.5rem;
      font-family: 'Cormorant Garamond', serif; font-weight: 700;
      font-size: 1.25rem; color: var(--text-primary);
    }
    @media (min-width: 768px) { .pro-tips-banner h3 { font-size: 1.5rem; } }
    .pro-tips-content {
      background: var(--bg-light); padding: 1.5rem;
    }
    @media (min-width: 768px) { .pro-tips-content { padding: 2rem; } }
    .pro-tips-grid {
      display: grid; grid-template-columns: 1fr; gap: 1.5rem;
    }
    @media (min-width: 768px) { .pro-tips-grid { grid-template-columns: repeat(3, 1fr); } }
    .pro-tip {
      display: flex; align-items: flex-start; gap: 1rem;
      background: rgba(255,255,255,0.6); border-radius: 0.75rem;
      padding: 1.25rem; border: 1px solid var(--border);
    }
    .pro-tip-icon {
      width: 56px; height: 56px; min-width: 56px; border-radius: 0.75rem;
      background: var(--copper-light); display: flex; align-items: center; justify-content: center;
    }
    .pro-tip-icon svg { width: 28px; height: 28px; color: var(--text-primary); }
    .pro-tip-title { font-family: 'Inter', sans-serif; font-weight: 600; color: var(--text-primary); margin-bottom: 0.25rem; }
    .pro-tip-desc { font-size: 0.875rem; color: var(--text-secondary); }

    /* ===== BEFORE/AFTER ===== */
    .before-after-section {
      background: linear-gradient(to bottom, #F0D3CC 0%, #F8EDE8 40%, #FDF8F6 75%, #FFFFFF 100%);
    }
    .ba-grid { display: grid; grid-template-columns: 1fr; gap: 2rem; }
    @media (min-width: 768px) { .ba-grid { grid-template-columns: repeat(2, 1fr); } }
    .ba-slider {
      position: relative; aspect-ratio: 1; border-radius: 1rem; overflow: hidden;
      cursor: ew-resize; user-select: none; box-shadow: var(--shadow-elevated);
    }
    .ba-slider img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; pointer-events: none; }
    .ba-before-wrap { position: absolute; inset: 0; overflow: hidden; }
    .ba-divider {
      position: absolute; top: 0; bottom: 0; width: 4px; background: white;
      box-shadow: 0 0 8px rgba(0,0,0,0.3); z-index: 10; transform: translateX(-50%);
    }
    .ba-handle {
      position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
      width: 48px; height: 48px; background: white; border-radius: 50%;
      box-shadow: 0 4px 12px rgba(0,0,0,0.2); display: flex; align-items: center; justify-content: center;
      border: 2px solid var(--copper-light);
    }
    .ba-label {
      position: absolute; bottom: 1rem; padding: 0.375rem 0.75rem;
      font-size: 0.875rem; font-weight: 500; border-radius: 9999px;
    }
    .ba-label-before { left: 1rem; background: rgba(0,0,0,0.7); color: white; }
    .ba-label-after { right: 1rem; background: rgba(255,255,255,0.9); color: var(--text-primary); }
    .ba-caption { text-align: center; font-size: 0.875rem; color: var(--text-secondary); margin-top: 1rem; }
    .stats-grid {
      display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.75rem; margin-top: 3rem; text-align: center;
    }
    @media (min-width: 640px) { .stats-grid { gap: 1.5rem; margin-top: 4rem; } }
    .stat-number {
      font-size: 1.875rem; font-weight: 700; color: var(--text-primary);
      font-variant-numeric: tabular-nums;
    }
    @media (min-width: 640px) { .stat-number { font-size: 3rem; } }
    @media (min-width: 768px) { .stat-number { font-size: 3.75rem; } }
    @media (min-width: 1024px) { .stat-number { font-size: 4.5rem; } }
    .stat-label { font-size: 1rem; color: var(--text-secondary); }
    @media (min-width: 768px) { .stat-label { font-size: 1.125rem; } }

    /* ===== SPECS STRIP ===== */
    .specs-strip {
      padding: 1.5rem 0; overflow: hidden !important; background: #111111; max-width: var(--max-w); margin-left: auto; margin-right: auto;
    }
    .specs-track { display: flex; animation: marquee 25s linear infinite; width: fit-content; will-change: transform; }
    .spec-item {
      display: inline-flex; align-items: center; gap: 0.5rem;
      padding: 0.5rem 1.5rem; margin: 0 1rem; white-space: nowrap;
    }
    .spec-item svg { width: 20px; height: 20px; color: white; flex-shrink: 0; }
    .spec-item span { font-size: 0.875rem; font-weight: 500; color: white; }

    /* ===== PURCHASE SECTION ===== */
    .purchase-layout {
      display: grid; grid-template-columns: 1fr; gap: 2rem;
    }
    @media (min-width: 1024px) { .purchase-layout { grid-template-columns: repeat(2, 1fr); gap: 3rem; } }
    .gallery-wrap {
      background: var(--bg-light); border-radius: 1rem; border: 1px solid var(--border);
      padding: 0.75rem; display: flex; flex-direction: column;
      min-width: 0; overflow: hidden;
    }
    @media (min-width: 768px) { .gallery-wrap { padding: 1rem; } }
    .gallery-main { position: relative; display: flex; align-items: center; justify-content: center; }
    .gallery-main img { width: 100%; max-height: 480px; object-fit: contain; margin: 0 auto; border-radius: 0.5rem; }
    .gallery-nav-btn {
      position: absolute; top: 50%; transform: translateY(-50%); z-index: 10;
      width: 40px; height: 40px; border-radius: 50%;
      background: rgba(255,255,255,0.8); border: 1px solid var(--border);
      display: flex; align-items: center; justify-content: center; transition: background 0.2s;
    }
    .gallery-nav-btn:hover { background: white; border-color: var(--copper-light); }
    .gallery-nav-btn:active { background: var(--cream); }
    .gallery-nav-btn.prev { left: 0; }
    .gallery-nav-btn.next { right: 0; }
    .gallery-nav-btn svg { width: 20px; height: 20px; color: var(--text-primary); }
    .gallery-thumbs {
      display: flex; gap: 0.5rem; margin-top: 1.5rem;
      overflow-x: auto; overflow-y: hidden; padding-bottom: 0.5rem;
      width: 100%;
      scrollbar-width: thin;
      scrollbar-color: var(--copper-light) transparent;
      -webkit-overflow-scrolling: touch;
    }
    .gallery-thumbs::-webkit-scrollbar { height: 4px; }
    .gallery-thumbs::-webkit-scrollbar-track { background: transparent; }
    .gallery-thumbs::-webkit-scrollbar-thumb { background: var(--copper-light); border-radius: 4px; }
    @media (min-width: 640px) { .gallery-thumbs { gap: 0.75rem; } }
    .gallery-thumb {
      width: 44px; height: 44px; flex-shrink: 0; background: white;
      border-radius: 0.5rem; overflow: hidden; border: 2px solid transparent;
      transition: border-color 0.2s; cursor: pointer;
      padding: 0 !important; position: relative;
    }
    @media (min-width: 640px) { .gallery-thumb { width: 56px; height: 56px; } }
    @media (min-width: 768px) { .gallery-thumb { width: 64px; height: 64px; } }
    .gallery-thumb.active { border-color: var(--text-primary); }
    .gallery-thumb:hover:not(.active) { border-color: var(--copper-light); }
    .gallery-thumb:active { border-color: var(--copper); }
    .gallery-thumb img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }

    /* Purchase box */
    .purchase-box { display: flex; flex-direction: column; gap: 1rem; }
    .purchase-card {
      background: var(--bg-light); border-radius: 1rem; border: 1px solid var(--border);
      padding: 1.25rem;
    }
    .purchase-card h3 {
      font-family: 'Inter', sans-serif; font-size: 1rem; font-weight: 600;
      color: var(--text-primary); margin-bottom: 1rem;
    }
    .purchase-option {
      width: 100%; padding: 0.75rem 1rem; border-radius: 0.75rem;
      border: 2px solid var(--border); display: flex; align-items: center;
      justify-content: space-between; transition: all 0.2s; background: transparent;
      cursor: pointer; text-align: left;
    }
    @media (min-width: 640px) { .purchase-option { padding: 1rem; } }
    .purchase-option.selected { border-color: var(--text-primary) !important; background: white !important; }
    .purchase-option:not(.selected):hover { border-color: var(--copper-light); background: transparent; }
    .purchase-option:active { border-color: var(--copper); }
    .purchase-option + .purchase-option { margin-top: 0.75rem; }
    .radio-dot {
      width: 20px; height: 20px; border-radius: 50%; border: 2px solid var(--text-secondary);
      display: flex; align-items: center; justify-content: center; flex-shrink: 0;
    }
    .purchase-option.selected .radio-dot { border-color: var(--text-primary); }
    .radio-dot-inner {
      width: 12px; height: 12px; border-radius: 50%; background: var(--copper-light);
      display: none;
    }
    .purchase-option.selected .radio-dot-inner { display: block; }
    .option-left { display: flex; align-items: center; gap: 0.5rem; }
    @media (min-width: 640px) { .option-left { gap: 0.75rem; } }
    .option-label { font-weight: 600; font-size: 0.875rem; color: var(--text-primary); }
    @media (min-width: 640px) { .option-label { font-size: 1rem; } }
    .option-sublabel { font-size: 0.75rem; color: var(--text-secondary); }
    .option-price-old { font-size: 0.75rem; color: var(--text-secondary); text-decoration: line-through; }
    @media (min-width: 640px) { .option-price-old { font-size: 0.875rem; } }
    .option-price { font-size: 1rem; font-weight: 700; color: var(--text-primary); margin-left: 0.25rem; }
    @media (min-width: 640px) { .option-price { font-size: 1.125rem; margin-left: 0.5rem; } }

    /* Quantity .elementor-2112 .elementor-element.elementor-element-ae4c0e7 */
    .qty-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.5rem; }
    @media (min-width: 640px) { .qty-grid { gap: 0.75rem; } }
    .qty-option {
      position: relative; padding: 0.75rem; border-radius: 0.75rem;
      border: 2px solid var(--border); background: white; transition: all 0.2s;
      cursor: pointer; text-align: center;
    }
    @media (min-width: 640px) { .qty-option { padding: 1rem; } }
    .qty-option.selected { border-color: var(--text-primary) !important; box-shadow: var(--shadow-soft); background: white !important; color: var(--text-primary) !important; }
    .qty-option:not(.selected):hover { border-color: var(--copper); background: var(--cream); box-shadow: 0 2px 8px rgba(0,0,0,0.04); }
    .qty-option:active { border-color: var(--copper-dark); }
    .qty-badge {
      position: absolute; top: -8px; right: 8px;
      font-size: 0.6875rem; padding: 0.125rem 0.5rem; border-radius: 9999px;
      font-weight: 500; background: var(--copper-light); color: var(--text-primary);
    }
    .qty-number { font-size: 1.5rem; font-weight: 700; color: var(--text-primary); margin-bottom: 0.5rem; }
    .qty-price-wrap {
      background: var(--bg-light); border-radius: 0.5rem; padding: 0.5rem; text-align: center;
    }
    .qty-old-price { font-size: 0.75rem; color: var(--text-secondary); text-decoration: line-through; margin-bottom: 0.125rem; }
    .qty-price { font-size: 1.125rem; font-weight: 700; color: var(--text-primary); }
    .qty-per { font-size: 0.75rem; color: var(--text-secondary); }

    /* Total & CTA */
    .total-row {
  display: flex; flex-direction: column; align-items: stretch; gap: 1rem; margin-bottom: 1rem;
}
    @media (min-width: 640px) { .total-row { flex-direction: row; justify-content: space-between; } }
    .total-label { font-size: 1.125rem; font-weight: 700; color: var(--text-primary); text-align: left !important; }
    .total-prices { display: flex; align-items: baseline; gap: 0.5rem; }
    .total-old { font-size: 1.125rem; color: var(--text-secondary); text-decoration: line-through; }
    .total-current { font-size: 1.5rem; font-weight: 700; color: var(--text-primary); }
    .free-shipping-badge {
      display: inline-block; margin-top: 0.25rem; font-size: 0.75rem; font-weight: 600;
      padding: 0.25rem 0.5rem; border-radius: 0.25rem;
      background: var(--copper-light); color: var(--text-primary);
    }
    .add-to-cart-btn {
      display: inline-flex; align-items: center; justify-content: center;
      padding: 1rem 2rem; font-weight: 500; font-size: 0.95rem;
      border-radius: 9999px; background: var(--copper-light); color: var(--text-primary);
      transition: all 0.3s; width: 100%;
    }
    @media (min-width: 640px) { .add-to-cart-btn { width: auto; } }
    .add-to-cart-btn:hover { opacity: 0.9; transform: scale(1.05); background: var(--copper-light) !important; color: var(--text-primary) !important; }
    .add-to-cart-btn:active { background: #E8C4BC !important; transform: scale(1.02); }
    .shipping-note { font-size: 0.75rem; color: var(--text-secondary); margin-top: 1rem; }

    /* Trust bullets */
    .trust-bullets {
      display: flex; flex-direction: column; gap: 1rem; justify-content: center;
      font-size: 0.875rem; color: var(--text-secondary);
    }
    @media (min-width: 640px) { .trust-bullets { flex-direction: row; gap: 1.5rem; } }
    .trust-bullet { display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; }
    .trust-bullet svg { width: 20px; height: 20px; color: var(--copper-dark); }

    /* ===== QUALITY SECTION ===== */
    .quality-grid {
      display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem;
    }
    @media (min-width: 1024px) { .quality-grid { grid-template-columns: repeat(4, 1fr); gap: 1.5rem; } }
    .quality-card {
      padding: 1.5rem; background: white; border-radius: 1rem;
      border: 1px solid var(--border); text-align: center; transition: all 0.3s;
    }
    .quality-card:hover { border-color: var(--copper-light); box-shadow: var(--shadow-card); }
    .quality-icon {
      width: 56px; height: 56px; margin: 0 auto 1rem; border-radius: 1rem;
      background: var(--copper-light); display: flex; align-items: center; justify-content: center;
      transition: transform 0.3s;
    }
    .quality-card:hover .quality-icon { transform: scale(1.1); }
    .quality-icon svg { width: 28px; height: 28px; color: var(--text-primary); }
    .quality-title { font-family: 'Inter', sans-serif; font-size: 1.125rem; font-weight: 600; color: var(--text-primary); margin-bottom: 0.5rem; }
    .quality-desc { font-size: 0.875rem; color: var(--text-secondary); line-height: 1.6; }

    /* ===== REVIEWS ===== */
    .reviews-section { background: var(--bg-light); overflow: hidden !important;  margin-left: auto; margin-right: auto; }
    /* Override Elementor/WP containers that may allow overflow */
    .marquee-wrap,
.specs-strip,
.reviews-section { overflow: hidden !important; }
    .reviews-stars { display: flex; justify-content: center; gap: 0.25rem; margin-bottom: 1rem; }
    .reviews-stars svg { width: 24px; height: 24px; fill: var(--copper-light); color: var(--copper-light); }
    .marquee-wrap { overflow: hidden; margin-bottom: 3rem; width: 100%; max-width: 1000px; margin-left: auto; margin-right: auto; position: relative; }
    .marquee-track {
      display: flex; animation: marquee 35s linear infinite;
      width: fit-content;
      will-change: transform;
    }
    .marquee-item { flex-shrink: 0; margin: 0 0.5rem; }
    .marquee-item img {
      width: 140px; height: 160px; object-fit: cover; border-radius: 1rem;
      box-shadow: var(--shadow-soft);
    }
    @media (min-width: 768px) { .marquee-item img { width: 160px; height: 180px; } }
    .reviews-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; padding: 0 1rem; }
    @media (min-width: 768px) { .reviews-grid { grid-template-columns: repeat(2, 1fr); padding: 0 2rem; } }
    .review-card {
      background: white; border-radius: 1rem; border: 1px solid var(--border);
      padding: 1.5rem; transition: box-shadow 0.3s;
    }
    .review-card:hover { box-shadow: var(--shadow-card); }
    .review-stars { display: flex; gap: 0.25rem; margin-bottom: 1rem; }
    .review-stars svg { width: 20px; height: 20px; fill: var(--copper-light); color: var(--copper-light); }
    .review-text { color: var(--text-primary); line-height: 1.7; margin-bottom: 1.5rem; }
    .review-footer { display: flex; align-items: center; justify-content: space-between; }
    .review-author { font-weight: 600; color: var(--text-primary); }
    .review-date { font-size: 0.875rem; color: var(--text-secondary); }
    .review-badge {
      font-size: 0.875rem; font-weight: 500; padding: 0.375rem 1rem; border-radius: 9999px;
      background: #E8F5E9; color: #4A7C59;
    }

    /* ===== GUARANTEE ===== */
    .guarantee-section {
      position: relative; background-size: cover; background-position: center;
    }
    .guarantee-badge {
      width: 96px; height: 96px; margin: 0 auto 1.5rem; border-radius: 50%;
      background: linear-gradient(135deg, #F0D3CC 0%, #E8C4BC 100%);
      box-shadow: 0 8px 24px rgba(240, 211, 204, 0.4);
      display: flex; align-items: center; justify-content: center;
    }
    .guarantee-badge svg { width: 48px; height: 48px; color: var(--text-primary); }
    .guarantee-title {
      font-size: 1.5rem; font-weight: 700; color: #111111 !important; margin-bottom: 1rem; padding: 0 0.5rem;
    }
    @media (min-width: 640px) { .guarantee-title { font-size: 1.875rem; } }
    @media (min-width: 768px) { .guarantee-title { font-size: 2.5rem; } }
    @media (min-width: 1024px) { .guarantee-title { font-size: 3rem; } }
    .guarantee-subtitle {
      font-size: 1.125rem; color: var(--text-secondary); max-width: 42rem;
      margin: 0 auto 2rem;
    }

    /* ===== FAQ ===== */
    .faq-list { max-width: 48rem; margin: 0 auto; display: flex; flex-direction: column; gap: 1rem; }
    .faq-item {
      background: var(--bg-light); border-radius: 1rem; border: 1px solid var(--border);
      overflow: hidden; transition: border-color 0.3s;
    }
    .faq-question:hover {
    background: #ededed !important;  
    color: #111;
    }
    
    .faq-question:active {
    background: var(--bg-light)  
    }
    .faq-item.open { border-color: var(--copper-light); }
    .faq-question {
      width: 100%; padding: 1rem 1.5rem; display: flex; align-items: center; font-family: 'Cormorant Garamond', serif;
      justify-content: space-between; text-align: left; font-weight: 700;
      font-size: 1.3rem !important; color: var(--text-primary); background: none; border: none;
      cursor: pointer; gap: 1rem;
    }
    @media (min-width: 640px) { .faq-question { font-size: 1.25rem; padding: 1.25rem 1.5rem; } }
    @media (min-width: 768px) { .faq-question { font-size: 1.5rem; } }
    .faq-question svg { width: 20px; height: 20px; flex-shrink: 0; transition: transform 0.3s; }
    .faq-item.open .faq-question svg { transform: rotate(180deg); }
    .faq-answer {
      max-height: 0; overflow: hidden; transition: max-height 0.3s ease, padding 0.3s ease;
      padding: 0 1.5rem; color: var(--text-secondary); line-height: 1.7; font-size: 16px !important;
    }
    .faq-item.open .faq-answer { max-height: 300px; padding: 0 1.5rem 1.25rem;  }

/* FOOTER – Dark Organixx style */
.oxx-footer {
  background: #000; /* dark green */
  color: #fff;
  padding: 3rem 0;
  font-size: 0.9rem;
}

.oxx-footer-inner {
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 20px;
}

.oxx-footer-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 2rem 3rem;
  margin-bottom: 2.5rem;
}

.oxx-footer-brand {
  grid-column: span 2;
}

.oxx-footer-logo {
  height: 40px;
  margin-bottom: 1rem;
  filter: brightness(0) invert(1); /* make logo white on dark bg */
}

/* Contact */
.oxx-footer-contact {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.oxx-footer-contact-link {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: rgba(247, 249, 244, 0.7);
  text-decoration: none;
  transition: color 0.2s ease;
}

.oxx-footer-contact-link:hover {
  color: var(--background, #f7f9f4);
}

.oxx-footer-contact-icon {
  font-size: 0.9rem;
}

/* Social icons */
.oxx-footer-social {
  display: flex;
  gap: 0.6rem;
  margin-top: 1rem;
}

.oxx-footer-social-link {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(247, 249, 244, 0.14);
  color: var(--background, #f7f9f4);
  text-decoration: none;
  font-size: 0.7rem;
  font-weight: 600;
  transition: background 0.2s ease, transform 0.2s ease;
}

.oxx-footer-social-link:hover {
  background: rgba(247, 249, 244, 0.22);
  transform: translateY(-1px);
  color: #fff;
}

.oxx-footer-social-icon {
  width: 16px;
  height: 16px;
}

.oxx-footer-social-bbb {
  font-size: 0.65rem;
  letter-spacing: 0.06em;
}

/* Columns */
.oxx-footer-column {
  min-width: 0;
}

.oxx-footer-heading {
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin-bottom: 1rem;
  font-family: 'Lato';
  color: #fff !important;
}

.oxx-footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
  color: #fff;
}

.oxx-footer-link {
  display: block;
  color: rgba(247, 249, 244, 0.7) !important;
  text-decoration: none;
  margin-bottom: 0.4rem;
  transition: color 0.2s ease;
}

.oxx-footer-link:hover {
  color: #fff !important;
}

.oxx-footer-link-strong {
  font-weight: 600;
}

/* Bottom strip */
.oxx-footer-bottom {
  border-top: 1px solid rgba(247, 249, 244, 0.16);
  padding-top: 1.5rem;
  text-align: center;
  color: rgba(247, 249, 244, 0.6);
  font-size: 0.8rem;
}

/* Responsive */
@media (min-width: 768px) {
  .oxx-footer-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .oxx-footer-brand {
    grid-column: span 1;
  }
}


    /* ===== PURCHASE SECTION HEADER ===== */
    .purchase-header { text-align: center; margin-bottom: 2rem; }
    .purchase-rating { display: flex; justify-content: center; margin-bottom: 0.75rem; }
    .purchase-rating svg { width: 20px; height: 20px; fill: var(--copper-light); color: var(--copper-light); }
    .purchase-reviews-count { font-size: 0.875rem; color: var(--text-secondary); margin-bottom: 0.5rem; }
    .purchase-desc { color: var(--text-secondary); max-width: 42rem; margin: 0 auto; }

    /* Text centering helpers */
    .text-center { text-align: center; }
    @media (min-width: 768px) { .text-center-md { text-align: center; } }
    @media (min-width: 1024px) {
      .footer-brand { text-align: left; }
      .footer-brand .footer-logo { margin-left: 0; margin-right: auto; }
      .footer-socials { justify-content: flex-start; }
    }
    .footer-brand { text-align: center; }
    @media (min-width: 1024px) { .footer-brand { text-align: left; } }
    .footer-brand .footer-brand-text { margin-left: auto; margin-right: auto; }
    @media (min-width: 1024px) { .footer-brand .footer-brand-text { margin-left: 0; } }
    .footer-brand .footer-contact-label,
    .footer-brand .footer-phone { text-align: center; }
    @media (min-width: 1024px) {
      .footer-brand .footer-contact-label,
      .footer-brand .footer-phone { text-align: left; }
    }
    .footer-socials { justify-content: center; }
    @media (min-width: 1024px) { .footer-socials { justify-content: flex-start; } }

.quality-grid {
  display: grid; grid-template-columns: 1fr; gap: 1rem;
}
@media (min-width: 640px) { .quality-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .quality-grid { grid-template-columns: repeat(4, 1fr); gap: 1.5rem; } }

/* ===== RESPONSIVE OVERRIDES ===== */

/* Small phones (up to 480px) */
@media (max-width: 480px) {
  .hero {
    min-height: 580px;
  }
  .hero-inner {
    padding: 1.25rem 1.25rem 0;
  }
  .hero-eyebrow {
    font-size: 0.75rem;
    margin-bottom: 0.5rem;
  }
  .hero-title {
    font-size: 1.5rem;
    margin-bottom: 0.625rem;
  }
  .hero-subtitle {
    font-size: 0.8125rem;
    line-height: 1.45;
    margin-bottom: 1rem;
  }
}

/* Large phones / small tablets (481px–767px) */
@media (min-width: 481px) and (max-width: 767px) {
  .hero {
    min-height: 600px !important;
  }
  .hero-inner {
    padding: 1.5rem 1.5rem 0 !important;
  }
  .hero-text {
    max-width: 100% !important;
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .hero-eyebrow {
    font-size: 0.8rem !important;
    margin-bottom: 0.5rem !important;
  }
  .hero-title {
    font-size: 1.75rem !important;
    margin-bottom: 0.625rem !important;
    line-height: 1.15 !important;
  }
  .hero-subtitle {
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
    margin-bottom: 1rem !important;
    margin-left: auto !important;
    margin-right: auto !important;
    max-width: 28rem !important;
  }
  .hero-bg-mobile {
    background-size: cover !important;
    background-position: center bottom !important;
}
.hero {
    min-height: 650px !important;
 }
}



/* ===== FIX: Add to Cart button size ===== */
.add-to-cart-btn {
  padding: 1rem 2.5rem !important;
  width: auto !important;
  max-width: 220px !important;
  height: auto !important;
  min-height: unset !important;
  aspect-ratio: unset !important;
  align-self: center !important;
}

@media (max-width: 639px) {
  .add-to-cart-btn {
    width: 100% !important;
    max-width: 100% !important;
  }
}

@media (max-width: 767px) {
  /* ... your existing hero fixes ... */

  .faq-question {
    font-size: 1rem !important;
    padding: 0.875rem 1rem !important;
  }

  .faq-answer {
    font-size: 0.875rem !important;
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }

  .faq-item.open .faq-answer {
    padding: 0 1rem 1rem !important;
  }
}

@media (max-width: 767px) {
  .faq-question {
    word-break: break-word !important;
    overflow-wrap: anywhere !important;
    white-space: normal !important;
  }
}

@media (max-width: 767px) {
  .mobile-menu {
    flex-wrap: wrap !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0.25rem 0.75rem !important;
    padding: 0.75rem 1rem !important;
  }
  .mobile-menu a:not(.header-shop-btn) {
    font-size: 0.8rem !important;
    padding: 0.5rem 0 !important;
  }
  .mobile-menu-divider {
    width: 100% !important;
    flex-basis: 100% !important;
    padding-top: 0.475rem !important;
    border-top: none !important;
    align-items: stretch !important;
  }
}

@media (max-width: 767px) {
  .oxx-footer-logo {
    height: 35px !important;
  }
}

@media (max-width: 767px) {
  .oxx-footer-brand {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
  }

  .oxx-footer-logo {
    order: 1 !important;
    height: 35px !important;
  }

.oxx-footer-social {
    order: 2 !important;
    margin-top: 0 !important;
    margin-left: 3rem !important;
    margin-bottom: 15px;
}

  .oxx-footer-contact {
    order: 3 !important;
    width: 100% !important;
    margin-top: 1rem !important;
  }
}

@media (max-width: 639px) {
  .trust-bullets {
    align-items: flex-start !important;
  }
  .trust-bullet {
    justify-content: flex-start !important;
  }
}

@media (max-width: 639px) {
  .steps-grid {
    justify-items: center;
  }
  .steps-grid .step-item:last-child {
    grid-column: 1 / -1;
  }
}

/* ===== PURCHASE TYPE TOGGLE (Subscribe vs One-Time) ===== */
.purchase-option {
  width: 100%; padding: 0.75rem 1rem; border-radius: 0.75rem;
  border: 2px solid var(--border); display: flex; align-items: center;
  justify-content: space-between; transition: all 0.2s; background: transparent;
  cursor: pointer; text-align: left;
}
@media (min-width: 640px) { .purchase-option { padding: 1rem; } }
.purchase-option.selected { border-color: var(--text-primary) !important; background: white !important; }
.purchase-option:not(.selected):hover { border-color: var(--copper-light); background: transparent; }
.purchase-option + .purchase-option { margin-top: 0.75rem; }

.radio-dot {
  width: 20px; height: 20px; border-radius: 50%; border: 2px solid var(--text-secondary);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.purchase-option.selected .radio-dot { border-color: var(--text-primary); }
.radio-dot-inner {
  width: 12px; height: 12px; border-radius: 50%; background: var(--copper-light);
  display: none;
}
.purchase-option.selected .radio-dot-inner { display: block; }

.option-left { display: flex; align-items: center; gap: 0.5rem; }
@media (min-width: 640px) { .option-left { gap: 0.75rem; } }
.option-label { font-weight: 600; font-size: 0.875rem; color: var(--text-primary); }
@media (min-width: 640px) { .option-label { font-size: 1rem; } }
.option-sublabel { font-size: 0.75rem; color: var(--text-secondary); }
.option-price-old { font-size: 0.75rem; color: var(--text-secondary); text-decoration: line-through; }
@media (min-width: 640px) { .option-price-old { font-size: 0.875rem; } }
.option-price { font-size: 1rem; font-weight: 700; color: var(--text-primary); margin-left: 0.25rem; }
@media (min-width: 640px) { .option-price { font-size: 1.125rem; margin-left: 0.5rem; } }

/* Subscribe benefits row (below both options) */
.subscribe-perks {
  display: flex; flex-wrap: wrap; gap: 0.5rem 1rem;
  margin-top: 1rem; padding-top: 0;
  border-top: none;
}
.subscribe-perk {
  display: inline-flex; align-items: center; gap: 0.35rem;
  font-size: 0.75rem; color: var(--text-secondary); font-weight: 500;
}
.subscribe-perk svg { width: 14px; height: 14px; color: #4A7C59; flex-shrink: 0; }

/* Save pill on qty cards */
.save-pill {
  position: absolute; top: -12px; left: 50%;
  transform: translateX(-50%);
  background: #d4734a; color: #fff;
  font-size: 11px; font-weight: 700;
  padding: 2px 10px; border-radius: 12px;
  white-space: nowrap; z-index: 2; letter-spacing: 0.3px;
}

/* OT price strikethrough in header row */
.ot-price-old {
  text-decoration: line-through; color: #999;
  font-size: 0.875rem; font-weight: 400; margin-right: 6px;
}
@media (max-width: 380px) {
  /* Purchase option rows — tighter, price inline */
  .purchase-option {
    flex-wrap: wrap !important;
    gap: 0.15rem !important;
    padding: 0.5rem 0.625rem !important;
  }
  .purchase-option > div[style*="text-align:right"] {
    width: 100% !important;
    text-align: left !important;
    padding-left: 2rem !important;
  }

  /* Bigger prices */
  .option-price {
    font-size: 1.125rem !important;
    font-weight: 700 !important;
  }
  .option-price-old {
    font-size: 0.8rem !important;
  }
  .option-label {
    font-size: 0.8rem !important;
  }
  .option-sublabel {
    font-size: 0.675rem !important;
  }

  /* Purchase card padding */
  .purchase-card {
    padding: 0.75rem !important;
  }

  /* Qty cards */
  .qty-number {
    font-size: 1.25rem !important;
  }
  .qty-price {
    font-size: 0.95rem !important;
  }
  .qty-old-price {
    font-size: 0.65rem !important;
  }
  .qty-per {
    font-size: 0.65rem !important;
  }
  .qty-option {
    padding: 0.5rem 0.25rem !important;
  }
  .save-pill {
    font-size: 9px !important;
    padding: 2px 6px !important;
    top: -10px !important;
  }

  /* Subscribe perks */
  .subscribe-perks {
    flex-direction: column !important;
    gap: 0.25rem !important;
  }

  /* Total */
  .total-row {
    flex-direction: column !important;
    align-items: stretch !important;
  }
  .total-current {
    font-size: 24px !important;
  }
}

  /* ===== WHY ORGANIXX (scoped) ===== */
  .oxx-why {
    --oxx-green: #2f7d32;           /* brand-ish green */
    --oxx-cream: #e9e2d6;           /* warm beige panel */
    --oxx-card:  #ffffff;
    --oxx-text:  #3b3b3b;
    --oxx-muted: #5c5c5c;

    /* If Elementor adds weird spacing, this keeps it stable */
    margin: 0;
  }

  .oxx-why__frame {

    overflow: hidden;
    background: #fff;
    max-width: 1140px;  /* matches typical Elementor section width */
    margin: 0 auto;
    font-family: Lato;
  }

  .oxx-why__hero {
    display: block;
    width: 100%;
    height: auto;
  }

  /* Desktop vs mobile image swap */
  .oxx-why__hero--mobile { display: none; }
  @media (max-width: 767px) {
    .oxx-why__hero--desktop { display: none; }
    .oxx-why__hero--mobile  { display: block; }
  }

  .oxx-why__panel {
    background: var(--oxx-cream);
    padding: 26px;
  }

  .oxx-why__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
  }

  .oxx-why__card {
    background: var(--oxx-card);
    border-radius: 18px;
    padding: 26px 26px 24px;
    text-align: center;
    box-shadow: 0 0 0 1px rgba(0,0,0,0.03);
  }

  .oxx-why__icon {
    width: 120px;
    height: auto;
    margin: 0 auto 14px;
    display: block;
  }

  .oxx-why__title {
    margin: 0 0 12px;
    font-weight: 800;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--oxx-green);
    font-size: 24px;
    line-height: 1.2;
    font-family: Lato;
  }

  .oxx-why__text {
    margin: 0;
    color: var(--oxx-muted);
    font-size: 18px;
    line-height: 1.55;
  }

  /* Tablet */
  @media (max-width: 1024px) {
    .oxx-why__panel { padding: 20px; }
    .oxx-why__grid  { gap: 18px; }
    .oxx-why__card  { padding: 22px; }
  }

  /* Mobile */
  @media (max-width: 767px) {
    .oxx-why__panel { padding: 18px; }
    .oxx-why__grid  { grid-template-columns: 1fr; }
    .oxx-why__icon  { width: 110px; }
    .oxx-why__title { font-size: 22px; }
    .oxx-why__text  { font-size: 18px; }
  }

  /* Small phones */
  @media (max-width: 450px) {
    .oxx-why__panel { padding: 14px; }
    .oxx-why__card  { padding: 18px; }
  }
  
    /* ===== FIX #1: Badge “float up” like the original ===== */
  .oxx-why .oxx-why__icon{
    /* pick ONE approach; translate feels closest to Elementor */
    transform: translateY(-88px);
    margin-bottom: -65px; /* helps keep spacing tight after moving up */
  }

  /* If your theme is also applying transforms, force it: */
  /* .oxx-why .oxx-why__icon{ transform: translateY(-18px) !important; } */

  /* Mobile tweak (often needs slightly less lift) */
  @media (max-width: 767px){
    .oxx-why .oxx-why__icon{
      transform: translateY(-14px);
      margin-bottom: 0;
    }
  }

  /* ===== FIX #2: Heading color getting overridden to white ===== */
  .oxx-why .oxx-why__card .oxx-why__title{
    color: var(--oxx-green) !important;
  }

  /* Optional: if you want the heading closer to your screenshot */
  .oxx-why .oxx-why__title{
    font-weight: 800;
    letter-spacing: 0.02em;
    text-transform: uppercase;
  }
  
  /* Add vertical space to account for lifted badge */
.oxx-why .oxx-why__grid{
  row-gap: 86px;
}


/* Give the cream section breathing room from the hero image */
.oxx-why .oxx-why__panel{
  padding-top: 80px; /* key fix */
}

/* =========================
   MOBILE OPTIMIZATION OVERRIDES
   Paste at BOTTOM of CSS
   ========================= */
@media (max-width: 767px){

  /* Make the cream panel feel intentional (less dead space) */
  .oxx-why .oxx-why__panel{
    padding: 18px;
    padding-top: 34px;  /* was 80px — too much on mobile */
  }

  /* 1-column stack spacing */
  .oxx-why .oxx-why__grid{
    grid-template-columns: 1fr;
    row-gap: 26px;      /* was 86px — causes big gaps */
    gap: 50px;          /* keeps horizontal/vertical consistent */
  }

  /* Keep cards from touching screen edges + keep it pretty */
  .oxx-why .oxx-why__card{
    padding: 22px 18px 20px;
    max-width: 520px;   /* optional: prevents super-wide cards on tablets */
    margin: 0 auto;     /* centers the card */
  }

  /* Badge “overlap” on mobile (smaller + less aggressive lift) */
  .oxx-why .oxx-why__icon{
    width: 104px;                 /* slightly smaller */
    transform: translateY(-54px); /* keeps the overlap feel */
    margin-bottom: -28px;         /* pulls title upward */
  }

  /* Typography scale for mobile */
  .oxx-why .oxx-why__title{
    font-size: 20px;
    line-height: 1.2;
    margin-bottom: 10px;
  }

  .oxx-why .oxx-why__text{
    font-size: 15.5px;
    line-height: 1.6;
  }
}

/* Small phones */
@media (max-width: 450px){
  .oxx-why .oxx-why__panel{
    padding: 14px;
    padding-top: 48px;
  }

  .oxx-why .oxx-why__card{
    padding: 20px 16px 18px;
  }

  .oxx-why .oxx-why__icon{
    width: 96px;
    transform: translateY(-50px);
    margin-bottom: -30px;
  }

  .oxx-why .oxx-why__title{ font-size: 19px; }
  .oxx-why .oxx-why__text{ font-size: 15px; }
}
@media (max-width: 1024px) {
    .oxx-testimonials-section {
        padding-top: 3rem;
        padding-bottom: 3rem;
    }
}

@media (max-width: 1024px) {
    .oxx-faq-section {
        padding-top: 3rem;
        padding-bottom: 3rem;
    }
}

@media (max-width: 1024px) {
    .oxx-ingredients-section {
        padding-top: 3rem;
        padding-bottom: 3rem;
    }
}

/* ===== Fix: Stop gallery from stretching to match purchase-box height ===== */
.gallery-wrap {
  align-self: start !important;
}

/* ===== Condense purchase box to align with gallery height ===== */

/* Tighter padding on all purchase cards */
.purchase-card {
  padding: 0.875rem !important;
}

/* Reduce h3 margins inside cards */
.purchase-card h3 {
  margin-bottom: 0.625rem !important;
  margin-top: 0 !important;
}

/* Compact the purchase option buttons */
.purchase-option {
  padding: 0.5rem 0.75rem !important;
}

/* Reduce gap between subscribe and OTP */
.purchase-option + .purchase-option {
  margin-top: 0.5rem !important;
}

/* Tighter subscribe perks */
.subscribe-perks {
  margin-top: 0.625rem !important;
}

/* Smaller qty card padding and number */
.qty-option {
  padding: 0.5rem !important;
}
.qty-number {
  font-size: 1.25rem !important;
  margin-bottom: 0.25rem !important;
}
.qty-price-wrap {
  padding: 0.35rem !important;
}

/* Reduce gap between purchase cards */
.purchase-box {
  gap: 0.625rem !important;
}

/* Tighter total row */
.total-row {
  margin-bottom: 0.5rem !important;
  gap: 0.75rem !important;
}
.shipping-note {
  margin-top: 0.5rem !important;
}

/* Trust bullets tighter */
.trust-bullets {
  gap: 0.5rem !important;
}/* End custom CSS */