/**
 * ESSENCESOFLIFE.LOVE Stylesheet
 * Version: 1.0
 *
 * Organic Luxury Design System
 * Mobile-first, accessible, performant
 */

/* =====================================================
   CSS VARIABLES
   ===================================================== */

:root {
    /* Colors - Light Mode */
    --color-primary: #768563;
    --color-primary-dark: #5a6b4a;
    --color-primary-light: #9aab88;
    --color-accent: #d9973f;
    --color-accent-dark: #c4852e;
    --color-accent-light: #e8b76a;

    --color-bg: #fefdfb;
    --color-bg-alt: #f8f6f3;
    --color-bg-card: #ffffff;
    --color-bg-dark: #1a2e1a;

    --color-text: #2d3a2e;
    --color-text-muted: #6b7c6c;
    --color-text-light: #8a9a8b;

    --color-border: #e5e2dd;
    --color-border-light: #f0ede8;

    --color-success: #4ade80;
    --color-error: #ef4444;
    --color-warning: #f59e0b;

    /* Typography */
    --font-display: 'Playfair Display', Georgia, 'Times New Roman', serif;
    --font-body: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;

    --text-xs: 0.75rem;
    --text-sm: 0.875rem;
    --text-base: 1rem;
    --text-lg: 1.125rem;
    --text-xl: 1.25rem;
    --text-2xl: 1.5rem;
    --text-3xl: 2rem;
    --text-4xl: 2.5rem;
    --text-5xl: 3.5rem;

    --leading-tight: 1.2;
    --leading-normal: 1.5;
    --leading-relaxed: 1.75;

    /* Spacing */
    --space-xs: 0.25rem;
    --space-sm: 0.5rem;
    --space-md: 1rem;
    --space-lg: 1.5rem;
    --space-xl: 2rem;
    --space-2xl: 3rem;
    --space-3xl: 4rem;
    --space-4xl: 6rem;

    /* Borders */
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --radius-xl: 24px;
    --radius-2xl: 1.5rem;
    --radius-full: 9999px;

    /* Shadows */
    --shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
    --shadow-md: 0 4px 6px rgba(0,0,0,0.07);
    --shadow-lg: 0 10px 25px rgba(0,0,0,0.1);
    --shadow-xl: 0 20px 40px rgba(0,0,0,0.12);

    /* Blur - Apple frosted glass */
    --blur-sm: 8px;
    --blur-md: 20px;
    --blur-lg: 30px;

    /* Touch */
    --touch-min: 44px;

    /* Layout */
    --container-max: 1200px;
    --container-narrow: 800px;
    --header-height: 64px;
    --header-height-mobile: 56px;

    /* Transitions */
    --transition-fast: 150ms ease;
    --transition-base: 250ms ease;
    --transition-slow: 400ms ease;

    /* Easing & Duration - Apple style */
    --ease-out: cubic-bezier(0, 0, 0.2, 1);
    --ease-spring: cubic-bezier(0.175, 0.885, 0.32, 1.275);
    --duration-fast: 0.15s;
    --duration-normal: 0.3s;
    --duration-slow: 0.5s;
}

/* Dark Mode - Organic Luxury (warm forest tones) */
[data-theme="dark"] {
    /* Backgrounds - warm dark forest greens, not cold blues */
    --color-bg: #0f1512;
    --color-bg-alt: #171f1a;
    --color-bg-card: #1e2822;
    --color-bg-dark: #0a0e0b;

    /* Text - warm cream tones for readability */
    --color-text: #f4f2ed;
    --color-text-muted: #a9b5a6;
    --color-text-light: #7a8a79;

    /* Borders - subtle sage green */
    --color-border: #3a4d3e;
    --color-border-light: #2a3a2e;

    /* Primary - rich sage green, elegant for dark backgrounds */
    --color-primary: #6a7d5a;
    --color-primary-dark: #536348;
    --color-primary-light: #8a9d7a;

    /* Accent - warm amber/gold, slightly brighter for visibility */
    --color-accent: #e8a94d;
    --color-accent-dark: #d9973f;
    --color-accent-light: #f5c77a;

    /* Shadows - deeper for dark mode */
    --shadow-sm: 0 1px 3px rgba(0,0,0,0.3);
    --shadow-md: 0 4px 8px rgba(0,0,0,0.4);
    --shadow-lg: 0 10px 30px rgba(0,0,0,0.5);
    --shadow-xl: 0 20px 50px rgba(0,0,0,0.6);
}

/* Dark Mode Specific Overrides */
[data-theme="dark"] .btn-secondary {
    color: #1a2420;
}

[data-theme="dark"] .btn-buy {
    box-shadow: 0 4px 15px rgba(106, 125, 90, 0.3);
}

[data-theme="dark"] .btn-buy:hover {
    box-shadow: 0 6px 20px rgba(106, 125, 90, 0.4);
}

[data-theme="dark"] .form-group input:focus,
[data-theme="dark"] .form-group select:focus,
[data-theme="dark"] .form-group textarea:focus {
    box-shadow: 0 0 0 3px rgba(106, 125, 90, 0.25);
}

/* Dark mode tables in prose/article content */
[data-theme="dark"] .prose table,
[data-theme="dark"] .content-table {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
}

[data-theme="dark"] .prose th,
[data-theme="dark"] .content-table th {
    background-color: #242f28;
    border-bottom: 2px solid var(--color-primary);
}

[data-theme="dark"] .prose td,
[data-theme="dark"] .content-table td {
    border-bottom: 1px solid var(--color-border);
}

[data-theme="dark"] .prose tr:hover,
[data-theme="dark"] .content-table tr:hover {
    background-color: rgba(106, 125, 90, 0.08);
}

/* Dark mode callouts */
[data-theme="dark"] .callout {
    background-color: var(--color-bg-alt);
    border-left: 4px solid var(--color-primary);
}

[data-theme="dark"] .callout-info {
    background-color: rgba(106, 125, 90, 0.12);
    border-left-color: var(--color-primary);
}

[data-theme="dark"] .callout-warning {
    background-color: rgba(232, 169, 77, 0.1);
    border-left-color: var(--color-accent);
}

[data-theme="dark"] .callout-warning h4 {
    color: #e8a94d;
}

[data-theme="dark"] .callout h4 {
    color: var(--color-text);
}

[data-theme="dark"] .callout p {
    color: var(--color-text-muted);
}

/* Dark mode details/FAQ inline */
[data-theme="dark"] .faq-inline {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
}

[data-theme="dark"] .faq-inline summary {
    background-color: var(--color-bg-alt);
}

[data-theme="dark"] .faq-inline[open] summary {
    border-bottom: 1px solid var(--color-border);
}

/* Dark mode code/pre blocks */
[data-theme="dark"] pre,
[data-theme="dark"] code {
    background-color: #0a0e0b;
    border: 1px solid var(--color-border);
}

/* Dark mode product images - subtle brightness boost */
[data-theme="dark"] .product-image img {
    filter: brightness(0.95);
}

/* Dark mode hero adjustments */
[data-theme="dark"] .hero-gradient {
    background: linear-gradient(135deg, rgba(15, 21, 18, 0.95) 0%, rgba(30, 40, 34, 0.9) 100%);
}

/* Dark mode announcement bar - darker forest green */
[data-theme="dark"] .announcement-bar {
    background: linear-gradient(135deg, #1a2e1f 0%, #2a4233 100%);
}

/* Dark mode section-dark and newsletter - cohesive dark forest palette */
[data-theme="dark"] .section-dark,
[data-theme="dark"] .section-newsletter {
    background: linear-gradient(135deg, #0d1510 0%, #1a2e1f 100%);
}

/* Dark mode footer */
[data-theme="dark"] footer {
    background-color: #0a0e0b;
}

/* Dark mode expert card on product page */
[data-theme="dark"] .expert-card {
    background: linear-gradient(135deg, rgba(232, 169, 77, 0.08) 0%, rgba(232, 169, 77, 0.03) 100%);
    border-color: rgba(232, 169, 77, 0.15);
}

[data-theme="dark"] .expert-header {
    border-bottom-color: rgba(232, 169, 77, 0.15);
}

/* Dark mode badges and highlights */
[data-theme="dark"] .badge-bestseller {
    background-color: var(--color-accent);
    color: #1a2420;
}

/* Trust Badges - Dark Mode Fix */
/* Card-style badges with proper contrast in dark mode */
[data-theme="dark"] .trust-badges {
    background-color: var(--color-bg-alt);
    border-color: var(--color-border);
}

[data-theme="dark"] .badge-item {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
}

[data-theme="dark"] .badge-label {
    color: #f4f2ed;
}

[data-theme="dark"] .badge-desc {
    color: #a9b5a6;
}

[data-theme="dark"] .badge-icon {
    color: #8a9d7a;
}

/* Dark mode links in text */
[data-theme="dark"] a:not(.btn):not(.share-btn) {
    transition: color var(--transition-fast);
}

/* Dark mode scrollbar (webkit) */
[data-theme="dark"] ::-webkit-scrollbar {
    width: 10px;
}

[data-theme="dark"] ::-webkit-scrollbar-track {
    background: var(--color-bg-alt);
}

[data-theme="dark"] ::-webkit-scrollbar-thumb {
    background: var(--color-border);
    border-radius: 5px;
}

[data-theme="dark"] ::-webkit-scrollbar-thumb:hover {
    background: var(--color-primary);
}

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

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

html {
    font-size: 16px;
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: transparent;
    overscroll-behavior-y: none;
}

body {
    font-family: var(--font-body);
    font-size: var(--text-base);
    line-height: var(--leading-normal);
    color: var(--color-text);
    background-color: var(--color-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

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

input, button, textarea, select {
    font: inherit;
    color: inherit;
}

/* iOS anti-zoom: 16px minimum prevents zoom on focus */
input, textarea, select {
    font-size: 16px;
}

button {
    cursor: pointer;
    background: none;
    border: none;
}

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

ul, ol {
    list-style: none;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-display);
    font-weight: 600;
    line-height: var(--leading-tight);
}

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

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

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

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

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

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

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

.section-dark {
    background-color: var(--color-bg-dark);
    color: #fff;
}

.section-newsletter {
    background: linear-gradient(135deg, var(--color-bg-dark) 0%, #2d4a2d 100%);
    color: #fff;
}

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

/* Section Headers */
.section-header {
    margin-bottom: var(--space-2xl);
}

.section-header:not(.text-center) {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-end;
    gap: var(--space-lg);
}

.section-eyebrow {
    display: inline-block;
    font-size: var(--text-sm);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-primary);
    margin-bottom: var(--space-sm);
}

.section-eyebrow-light {
    color: var(--color-accent);
}

.section-title {
    font-size: var(--text-3xl);
    margin-bottom: var(--space-sm);
}

.section-title-light {
    color: #fff;
}

.section-subtitle {
    font-size: var(--text-lg);
    color: var(--color-text-muted);
}

.section-cta {
    margin-top: var(--space-2xl);
}

@media (min-width: 768px) {
    .section {
        padding: var(--space-4xl) 0;
    }

    .section-title {
        font-size: var(--text-4xl);
    }
}

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

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-sm);
    padding: 0.75rem 1.5rem;
    font-size: var(--text-base);
    font-weight: 600;
    line-height: 1;
    border-radius: var(--radius-lg);
    transition: all var(--transition-base);
    white-space: nowrap;
}

.btn-sm {
    padding: 0.5rem 1rem;
    font-size: var(--text-sm);
    border-radius: var(--radius-md);
}

.btn-lg {
    padding: 1rem 2rem;
    font-size: var(--text-lg);
}

.btn-block {
    width: 100%;
}

.btn-primary {
    background-color: var(--color-primary);
    color: #fff;
}

.btn-primary:hover {
    background-color: var(--color-primary-dark);
    transform: translateY(-1px);
}

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

.btn-secondary:hover {
    background-color: var(--color-accent-dark);
}

.btn-outline {
    background-color: transparent;
    border: 2px solid var(--color-border);
    color: var(--color-text);
}

.btn-outline:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
}

.btn-buy {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
    color: #fff;
    padding: 1rem 2rem;
    font-size: var(--text-lg);
    border-radius: var(--radius-xl);
    box-shadow: 0 4px 15px rgba(118, 133, 99, 0.3);
}

.btn-buy:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(118, 133, 99, 0.4);
}

/* =====================================================
   MOBILE HEADER
   ===================================================== */

.mobile-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: 48px;
    background-color: rgba(255, 255, 255, 0.72);
    backdrop-filter: blur(var(--blur-md)) saturate(180%);
    -webkit-backdrop-filter: blur(var(--blur-md)) saturate(180%);
    border-bottom: 1px solid transparent;
    z-index: 1000;
    transition: border-color var(--duration-normal) var(--ease-out);
}

.mobile-header.scrolled {
    border-bottom-color: var(--color-border);
}

[data-theme="dark"] .mobile-header {
    background-color: rgba(30, 30, 30, 0.72);
}

.mh-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 100%;
    padding: 0 var(--space-md);
}

.mh-menu-btn {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: var(--touch-min);
    height: var(--touch-min);
    padding: 8px;
}

.mh-line {
    display: block;
    width: 100%;
    height: 2px;
    background-color: var(--color-text);
    border-radius: 2px;
    transition: var(--transition-base);
}

.mh-logo {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    color: var(--color-text);
}

.mh-logo-icon {
    color: var(--color-primary);
    max-height: 28px;
}

.mh-brand {
    font-family: var(--font-display);
    font-size: var(--text-lg);
    font-weight: 600;
}

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

.mh-theme-btn {
    width: var(--touch-min);
    height: var(--touch-min);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-muted);
}

.mh-sun, .mh-moon {
    display: none;
}

[data-theme="light"] .mh-moon { display: block; }
[data-theme="dark"] .mh-sun { display: block; }

@media (min-width: 1024px) {
    .mobile-header {
        display: none;
    }
}

/* =====================================================
   SIDEBAR
   ===================================================== */

/* Scroll lock when mobile nav is open */
body.menu-open {
    overflow: hidden;
    position: fixed;
    width: 100%;
}

.sidebar-overlay {
    position: fixed;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.4);
    -webkit-backdrop-filter: blur(30px);
    backdrop-filter: blur(30px);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.35s var(--ease-spring, cubic-bezier(0.175, 0.885, 0.32, 1.1));
    z-index: 1001;
}

.sidebar-overlay.active {
    opacity: 1;
    visibility: visible;
}

.sidebar {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: 280px;
    max-width: 85vw;
    background-color: var(--color-bg);
    -webkit-backdrop-filter: blur(30px);
    backdrop-filter: blur(30px);
    transform: translateX(100%);
    transition: transform 0.35s var(--ease-spring, cubic-bezier(0.175, 0.885, 0.32, 1.1));
    z-index: 1002;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
}

.sidebar.active {
    transform: translateX(0);
}

.sidebar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-lg);
    border-bottom: 1px solid var(--color-border);
}

.sidebar-logo {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    color: var(--color-text);
}

.sidebar-logo svg {
    color: var(--color-primary);
}

.sidebar-logo-text {
    display: flex;
    flex-direction: column;
}

.sidebar-brand {
    font-family: var(--font-display);
    font-size: var(--text-lg);
    font-weight: 600;
}

.sidebar-tagline {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
}

.sidebar-close {
    font-size: 28px;
    color: var(--color-text-muted);
    padding: var(--space-sm);
}

.sidebar-nav {
    flex: 1;
    padding: var(--space-md) 0;
}

.sidebar-nav li a {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md) var(--space-lg);
    min-height: 56px;
    color: var(--color-text);
    transition: var(--transition-fast);
}

.sidebar-nav li a:hover,
.sidebar-nav li a.active {
    background-color: var(--color-bg-alt);
    color: var(--color-primary);
}

.nav-icon {
    font-size: var(--text-lg);
}

.sidebar-divider {
    font-size: var(--text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
    padding: var(--space-lg) var(--space-lg) var(--space-sm);
    margin-top: var(--space-sm);
}

.sidebar-cta {
    padding: var(--space-lg);
    border-top: 1px solid var(--color-border);
}

.sidebar-discount {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    text-align: center;
    margin-top: var(--space-md);
}

@media (min-width: 1024px) {
    .sidebar, .sidebar-overlay {
        display: none;
    }
}

/* =====================================================
   DESKTOP HEADER
   ===================================================== */

.desktop-header {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: var(--header-height);
    background-color: rgba(255, 255, 255, 0.72);
    backdrop-filter: blur(var(--blur-md)) saturate(180%);
    -webkit-backdrop-filter: blur(var(--blur-md)) saturate(180%);
    border-bottom: 1px solid transparent;
    z-index: 1000;
    transition: border-color var(--duration-normal) var(--ease-out);
}

.desktop-header.scrolled {
    border-bottom-color: var(--color-border);
}

[data-theme="dark"] .desktop-header {
    background-color: rgba(30, 30, 30, 0.72);
}

.desktop-header .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 100%;
}

.dh-logo {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    color: var(--color-text);
}

.dh-logo-icon {
    color: var(--color-primary);
}

.dh-logo-text {
    display: flex;
    flex-direction: column;
}

.dh-brand {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: 600;
}

.dh-tagline {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
}

.dh-nav {
    display: flex;
    align-items: center;
    gap: var(--space-xl);
}

.dh-nav > a {
    font-weight: 500;
    color: var(--color-text);
    padding: var(--space-sm) 0;
    position: relative;
    transition: var(--transition-fast);
}

.dh-nav > a:hover,
.dh-nav > a.active {
    color: var(--color-primary);
}

.dh-nav > a::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 2px;
    background-color: var(--color-primary);
    transition: var(--transition-fast);
}

.dh-nav > a:hover::after,
.dh-nav > a.active::after {
    width: 100%;
}

.dh-dropdown {
    position: relative;
}

.dh-dropdown-btn {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    font-weight: 500;
    color: var(--color-text);
    padding: var(--space-sm) 0;
}

.dh-arrow {
    font-size: 10px;
    transition: var(--transition-fast);
}

.dh-dropdown-content {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    min-width: 200px;
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    padding: var(--space-sm);
    opacity: 0;
    visibility: hidden;
    transition: var(--transition-fast);
}

.dh-dropdown:hover .dh-dropdown-content {
    opacity: 1;
    visibility: visible;
}

.dh-dropdown:hover .dh-arrow {
    transform: rotate(180deg);
}

.dh-dropdown-content a {
    display: block;
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-md);
    white-space: nowrap;
}

.dh-dropdown-content a:hover {
    background-color: var(--color-bg-alt);
    color: var(--color-primary);
}

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

.dh-theme-btn {
    padding: var(--space-sm);
    color: var(--color-text-muted);
}

.dh-sun, .dh-moon {
    display: none;
}

[data-theme="light"] .dh-moon { display: block; }
[data-theme="dark"] .dh-sun { display: block; }

@media (min-width: 1024px) {
    .desktop-header {
        display: block;
    }

    main {
        padding-top: var(--header-height);
    }
}

@media (max-width: 1023px) {
    main {
        padding-top: var(--header-height-mobile);
    }
}

/* =====================================================
   HERO SECTION
   ===================================================== */

.hero {
    position: relative;
    min-height: calc(100vh - var(--header-height-mobile));
    display: flex;
    align-items: center;
    padding: var(--space-3xl) 0;
    overflow: hidden;
}

.hero-bg {
    position: absolute;
    inset: 0;
    z-index: -1;
}

.hero-gradient {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, var(--color-bg) 0%, var(--color-bg-alt) 50%, rgba(118, 133, 99, 0.1) 100%);
}

.hero-pattern {
    position: absolute;
    inset: 0;
    opacity: 0.03;
    background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23768563' fill-opacity='1'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

.hero-grid {
    display: grid;
    gap: var(--space-2xl);
    align-items: center;
}

.hero-content {
    max-width: 600px;
}

.hero-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
    background-color: rgba(118, 133, 99, 0.1);
    color: var(--color-primary);
    font-size: var(--text-sm);
    font-weight: 600;
    border-radius: var(--radius-full);
    margin-bottom: var(--space-lg);
}

.hero-title {
    font-size: var(--text-3xl);
    margin-bottom: var(--space-lg);
    line-height: 1.1;
}

.title-accent {
    color: var(--color-primary);
}

.hero-description {
    font-size: var(--text-lg);
    color: var(--color-text-muted);
    margin-bottom: var(--space-xl);
    line-height: var(--leading-relaxed);
}

.hero-cta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-md);
    margin-bottom: var(--space-xl);
}

.hero-trust {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-lg);
}

.trust-item {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.trust-item svg {
    color: var(--color-primary);
}

.hero-visual {
    display: none;
}

.hero-image-wrapper {
    position: relative;
}

.hero-image {
    width: 100%;
    max-width: 500px;
    margin: 0 auto;
}

.hero-badge-cteo,
.hero-badge-natural {
    position: absolute;
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
    background-color: var(--color-bg-card);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-lg);
    font-size: var(--text-sm);
    font-weight: 600;
}

.hero-badge-cteo {
    top: 10%;
    left: -10%;
}

.hero-badge-natural {
    bottom: 20%;
    right: -10%;
}

.badge-icon {
    font-size: var(--text-xl);
}

.badge-text {
    line-height: 1.2;
}

/* Mobile Hero Enhancements */
.hero-image-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(transparent 40%, rgba(0,0,0,0.6));
    pointer-events: none;
}

@media (max-width: 767px) {
    .hero {
        width: 100%;
        margin-bottom: var(--space-2xl);
    }
    .hero-title {
        font-size: 28px;
        line-height: 1.15;
    }
    .hero-cta .btn {
        width: 100%;
        border-radius: var(--radius-md);
        min-height: 50px;
    }
}

@media (min-width: 768px) {
    .hero {
        min-height: calc(100vh - var(--header-height));
    }

    .hero-title {
        font-size: var(--text-4xl);
    }
}

@media (min-width: 1024px) {
    .hero-grid {
        grid-template-columns: 1fr 1fr;
    }

    .hero-title {
        font-size: var(--text-5xl);
    }

    .hero-visual {
        display: block;
    }
}

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

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

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

.badge-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--space-sm);
    padding: var(--space-md);
    background-color: #f6f9f4;
    border-radius: var(--radius-md);
}

.badge-icon {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary);
}

.badge-label {
    font-weight: 600;
    font-size: 13px;
    color: var(--color-text);
}

.badge-desc {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    font-weight: 500;
}

@media (min-width: 768px) {
    .badges-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .badge-item {
        flex-direction: row;
        text-align: left;
    }

    .badge-text {
        display: flex;
        flex-direction: column;
    }
}

@media (min-width: 1024px) {
    .badges-grid {
        grid-template-columns: repeat(6, 1fr);
    }
}

/* =====================================================
   FEATURES GRID
   ===================================================== */

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

.feature-card {
    padding: var(--space-xl);
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    transition: var(--transition-base);
}

.feature-card:hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-md);
}

.feature-icon {
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--color-bg-alt);
    border-radius: var(--radius-xl);
    color: var(--color-primary);
    margin-bottom: var(--space-lg);
}

.feature-title {
    font-size: var(--text-xl);
    margin-bottom: var(--space-sm);
}

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

@media (min-width: 768px) {
    .features-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .features-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* =====================================================
   CATEGORIES GRID
   ===================================================== */

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

.category-card {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-lg);
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    transition: var(--transition-base);
}

.category-card:hover {
    border-color: var(--color-primary);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.category-icon {
    font-size: var(--text-2xl);
}

.category-name {
    font-size: var(--text-base);
    font-weight: 600;
    flex: 1;
}

.category-arrow {
    color: var(--color-text-muted);
    transition: var(--transition-fast);
}

.category-card:hover .category-arrow {
    color: var(--color-primary);
    transform: translateX(4px);
}

@media (min-width: 768px) {
    .categories-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .category-name {
        font-size: var(--text-lg);
    }
}

@media (min-width: 1024px) {
    .categories-grid {
        grid-template-columns: repeat(6, 1fr);
    }

    .category-card {
        flex-direction: column;
        text-align: center;
        padding: var(--space-xl);
    }

    .category-icon {
        font-size: var(--text-3xl);
    }

    .category-arrow {
        display: none;
    }
}

/* =====================================================
   PRODUCTS GRID
   ===================================================== */

.products-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

.products-grid-4 {
    grid-template-columns: 1fr;
}

@media (min-width: 640px) {
    .products-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 16px;
    }

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

@media (min-width: 1024px) {
    .products-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 24px;
    }

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

/* Product Card */
.product-card {
    position: relative;
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: var(--transition-base);
    box-shadow: var(--shadow-sm);
}

.product-card:hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-lg);
}

.product-badge {
    position: absolute;
    top: var(--space-md);
    left: var(--space-md);
    padding: var(--space-xs) var(--space-sm);
    font-size: var(--text-xs);
    font-weight: 600;
    border-radius: var(--radius-md);
    z-index: 1;
}

.badge-bestseller {
    background-color: var(--color-accent);
    color: #fff;
}

.badge-new {
    background-color: var(--color-primary);
    color: #fff;
}

.badge-sale {
    background: rgba(79,107,76,0.9);
    color: #fff;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.product-image {
    display: block;
    aspect-ratio: 1/1;
    overflow: hidden;
    background-color: #f6f9f4;
}

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

.product-card:hover .product-image img {
    transform: scale(1.02);
}

.product-info {
    padding: var(--space-md);
}

.product-name {
    font-size: 16px;
    font-family: var(--font-body);
    font-weight: 600;
    margin-bottom: var(--space-xs);
    line-height: 1.3;
}

.product-name a:hover {
    color: var(--color-primary);
}

.product-desc {
    font-size: 14px;
    line-height: 1.5;
    color: var(--color-text-muted);
    margin-bottom: var(--space-sm);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.product-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
    font-size: var(--text-sm);
}

.product-rating {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
}

.rating-star {
    color: var(--color-accent);
}

.rating-value {
    font-weight: 600;
}

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

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

.product-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-sm);
}

.product-price {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: var(--space-xs);
}

.price-current {
    font-size: 20px;
    font-weight: 700;
    color: var(--color-text);
}

.price-original {
    font-size: 14px;
    color: #8a9a8b;
    text-decoration: line-through;
}

/* Product certifications - elegant badges on image */
.product-image {
    position: relative;
}

.product-certifications {
    position: absolute;
    bottom: var(--space-sm);
    right: var(--space-sm);
    display: flex;
    gap: 6px;
    z-index: 2;
}

.cert-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px 8px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.5px;
    color: #fff;
    border-radius: var(--radius-md);
    box-shadow: 0 2px 8px rgba(0,0,0,0.3);
    text-shadow: 0 1px 2px rgba(0,0,0,0.2);
}

/* CTEO badge - warm sage/olive with white text */
.cert-badge.cert-cteo {
    background: linear-gradient(135deg, #5a6b4a 0%, #4a5a3d 100%);
    color: #fff;
}

/* Vegan badge - natural leaf green with white text */
.cert-badge.cert-vegan {
    background: linear-gradient(135deg, #6b8e5a 0%, #5a7d4a 100%);
    color: #fff;
}

/* Dark mode - brighter backgrounds, crisp white text */
[data-theme="dark"] .cert-badge.cert-cteo {
    background: linear-gradient(135deg, #8a9d7a 0%, #7a8d6a 100%);
    color: #fff;
    text-shadow: 0 1px 3px rgba(0,0,0,0.4);
}

[data-theme="dark"] .cert-badge.cert-vegan {
    background: linear-gradient(135deg, #7a9d6a 0%, #6a8d5a 100%);
    color: #fff;
    text-shadow: 0 1px 3px rgba(0,0,0,0.4);
}

/* Product Card Mobile - Full-width Shop Now button */
@media (max-width: 639px) {
    .product-footer {
        flex-direction: column;
        align-items: stretch;
        gap: var(--space-sm);
    }

    .product-footer .btn {
        width: 100%;
        min-height: var(--touch-min);
        justify-content: center;
        font-weight: 600;
        border-radius: var(--radius-md);
    }

    .product-footer .btn:active {
        transform: scale(0.97);
    }
}

/* =====================================================
   COMPARISON TABLE
   ===================================================== */

.comparison-table-wrapper {
    overflow-x: auto;
    margin: 0 calc(-1 * var(--space-md));
    padding: 0 var(--space-md);
}

.comparison-table {
    width: 100%;
    min-width: 600px;
    border-collapse: collapse;
    background-color: rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-xl);
    overflow: hidden;
}

.comparison-table th,
.comparison-table td {
    padding: var(--space-md);
    text-align: left;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.comparison-table th {
    font-weight: 600;
    background-color: rgba(255, 255, 255, 0.05);
}

.comparison-table th.highlight {
    background-color: var(--color-primary);
    color: #fff;
}

.comparison-table td.highlight {
    background-color: rgba(118, 133, 99, 0.1);
    color: #fff;
}

.comparison-table .check {
    color: var(--color-success);
    margin-right: var(--space-xs);
}

/* =====================================================
   SPOTLIGHT SECTION
   ===================================================== */

.spotlight-grid {
    display: grid;
    gap: var(--space-2xl);
    align-items: center;
}

.spotlight-image {
    position: relative;
}

.spotlight-image img {
    width: 100%;
    max-width: 400px;
    margin: 0 auto;
    border-radius: var(--radius-2xl);
}

.spotlight-badge {
    position: absolute;
    top: var(--space-lg);
    right: var(--space-lg);
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
    background-color: var(--color-accent);
    color: var(--color-bg-dark);
    font-size: var(--text-sm);
    font-weight: 600;
    border-radius: var(--radius-xl);
}

.spotlight-tagline {
    display: block;
    color: var(--color-accent);
    font-size: var(--text-sm);
    font-weight: 600;
    margin-bottom: var(--space-sm);
}

.spotlight-title {
    font-size: var(--text-3xl);
    margin-bottom: var(--space-md);
}

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

.spotlight-rating .stars {
    color: var(--color-accent);
}

.spotlight-rating .rating-text {
    color: var(--color-text-muted);
    font-size: var(--text-sm);
}

.spotlight-description {
    color: var(--color-text-muted);
    margin-bottom: var(--space-lg);
    line-height: var(--leading-relaxed);
}

.spotlight-benefits {
    margin-bottom: var(--space-xl);
}

.spotlight-benefits li {
    display: flex;
    align-items: flex-start;
    gap: var(--space-sm);
    margin-bottom: var(--space-sm);
}

.check-icon {
    color: var(--color-primary);
    font-weight: 700;
}

.spotlight-price {
    display: flex;
    align-items: baseline;
    gap: var(--space-sm);
    margin-bottom: var(--space-xl);
}

.spotlight-price .price-current {
    font-size: var(--text-3xl);
    font-weight: 700;
}

.spotlight-price .price-original {
    font-size: var(--text-xl);
    color: var(--color-text-muted);
    text-decoration: line-through;
}

.spotlight-price .price-discount {
    padding: var(--space-xs) var(--space-sm);
    background: rgba(79,107,76,0.9);
    color: #fff;
    font-size: var(--text-sm);
    font-weight: 600;
    border-radius: var(--radius-md);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.spotlight-cta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-md);
}

@media (min-width: 1024px) {
    .spotlight-grid {
        grid-template-columns: 1fr 1fr;
    }

    .spotlight-title {
        font-size: var(--text-4xl);
    }
}

/* =====================================================
   BLOG CARDS
   ===================================================== */

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

.blog-card {
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    overflow: hidden;
    transition: var(--transition-base);
}

.blog-card:hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-md);
}

.blog-image {
    display: block;
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    background-color: #f6f9f4;
}

.blog-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transition: transform var(--transition-slow);
}

.blog-card:hover .blog-image img {
    transform: scale(1.05);
}

.blog-badge {
    position: absolute;
    top: var(--space-md);
    left: var(--space-md);
    padding: var(--space-xs) var(--space-sm);
    background-color: var(--color-primary);
    color: #fff;
    font-size: var(--text-xs);
    font-weight: 600;
    border-radius: var(--radius-md);
}

.blog-content {
    padding: var(--space-lg);
}

.blog-meta {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-bottom: var(--space-sm);
}

.blog-category {
    color: var(--color-primary);
    font-weight: 600;
}

.blog-title {
    font-size: var(--text-xl);
    font-family: var(--font-body);
    font-weight: 600;
    margin-bottom: var(--space-sm);
    line-height: var(--leading-tight);
}

.blog-title a:hover {
    color: var(--color-primary);
}

.blog-excerpt {
    color: var(--color-text-muted);
    font-size: var(--text-sm);
    margin-bottom: var(--space-md);
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.blog-link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    color: var(--color-primary);
    font-weight: 600;
    font-size: var(--text-sm);
}

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

@media (min-width: 768px) {
    .blog-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .blog-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Featured Blog Grid */
.featured-grid {
    display: grid;
    gap: var(--space-lg);
    margin-bottom: var(--space-2xl);
}

.blog-card-featured {
    display: grid;
}

.blog-card-featured .blog-image {
    aspect-ratio: 16/9;
}

.blog-card-featured .blog-title {
    font-size: var(--text-2xl);
}

@media (min-width: 768px) {
    .featured-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* =====================================================
   NEWSLETTER
   ===================================================== */

.newsletter-card {
    max-width: 600px;
    margin: 0 auto;
    text-align: center;
}

.newsletter-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    background-color: rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-2xl);
    margin-bottom: var(--space-lg);
}

.newsletter-icon svg {
    color: var(--color-accent);
}

.newsletter-title {
    font-size: var(--text-3xl);
    color: #fff;
    margin-bottom: var(--space-md);
}

.newsletter-description {
    color: rgba(255, 255, 255, 0.8);
    margin-bottom: var(--space-xl);
}

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

.newsletter-form-hero .newsletter-input-group {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.newsletter-form input[type="email"] {
    flex: 1;
    padding: var(--space-md) var(--space-lg);
    font-size: 16px; /* iOS anti-zoom */
    min-height: 50px;
    border: 2px solid rgba(255, 255, 255, 0.2);
    border-radius: var(--radius-md);
    background-color: rgba(255, 255, 255, 0.1);
    color: #fff;
}

.newsletter-form input[type="email"]::placeholder {
    color: rgba(255, 255, 255, 0.5);
}

.newsletter-form input[type="email"]:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(79, 107, 76, 0.1);
}

.newsletter-success {
    color: var(--color-success);
    margin-top: var(--space-md);
}

.newsletter-error {
    color: var(--color-error);
    margin-top: var(--space-md);
}

.newsletter-note {
    font-size: var(--text-sm);
    color: rgba(255, 255, 255, 0.6);
    margin-top: var(--space-lg);
}

.newsletter-gdpr {
    display: flex;
    align-items: flex-start;
    gap: var(--space-sm);
    margin-top: var(--space-md);
    font-size: var(--text-sm);
    color: rgba(255, 255, 255, 0.8);
    cursor: pointer;
}

.newsletter-gdpr input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin-top: 2px;
    flex-shrink: 0;
    accent-color: var(--color-primary);
}

.newsletter-gdpr span {
    line-height: 1.4;
}

.footer-newsletter .newsletter-gdpr,
.newsletter-card-inline .newsletter-gdpr {
    color: var(--color-text-muted);
}

.popup-gdpr {
    margin: var(--space-md) 0;
    color: var(--color-text-muted);
}

@media (min-width: 768px) {
    .newsletter-form-hero .newsletter-input-group {
        flex-direction: row;
    }
}

/* Inline Newsletter - Fully Responsive */
.newsletter-card-inline {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-xl);
    padding: var(--space-xl);
    background-color: var(--color-bg-alt);
    border-radius: var(--radius-xl);
    text-align: left;
}

.newsletter-card-inline .newsletter-content h3 {
    font-size: var(--text-xl);
    margin-bottom: var(--space-sm);
}

.newsletter-card-inline .newsletter-content p {
    color: var(--color-text-muted);
    margin: 0;
}

.newsletter-card-inline .newsletter-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.newsletter-card-inline .newsletter-input-row {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.newsletter-card-inline .newsletter-form input[type="email"] {
    width: 100%;
    padding: var(--space-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background-color: var(--color-bg-card);
    color: var(--color-text);
    font-size: var(--text-base);
}

.newsletter-card-inline .newsletter-form input[type="email"]:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(118, 133, 99, 0.1);
}

.newsletter-card-inline .newsletter-gdpr {
    display: flex;
    align-items: flex-start;
    gap: var(--space-sm);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    cursor: pointer;
    line-height: 1.4;
}

.newsletter-card-inline .newsletter-gdpr input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin-top: 2px;
    flex-shrink: 0;
    accent-color: var(--color-primary);
}

.newsletter-card-inline .newsletter-gdpr span {
    flex: 1;
}

.newsletter-card-inline .newsletter-form .btn {
    width: 100%;
    min-height: 50px;
    border-radius: var(--radius-md);
}

.newsletter-form .btn {
    min-height: 50px;
    border-radius: var(--radius-md);
    width: 100%;
}

@media (min-width: 640px) {
    .newsletter-card-inline .newsletter-input-row {
        flex-direction: row;
        align-items: center;
    }

    .newsletter-card-inline .newsletter-form input[type="email"] {
        flex: 1;
    }

    .newsletter-card-inline .newsletter-form .btn {
        width: auto;
        flex-shrink: 0;
    }
}

@media (min-width: 1024px) {
    .newsletter-card-inline {
        grid-template-columns: 1fr 1.5fr;
        align-items: center;
    }
}

/* =====================================================
   FOOTER
   ===================================================== */

.footer {
    background-color: var(--color-bg-dark);
    color: rgba(255, 255, 255, 0.8);
    padding: var(--space-3xl) 0 var(--space-xl);
}

.footer-grid {
    display: grid;
    gap: var(--space-2xl);
    margin-bottom: var(--space-2xl);
}

.footer-brand {
    max-width: 300px;
}

.footer-logo {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    color: #fff;
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: 600;
    margin-bottom: var(--space-md);
}

.footer-logo svg {
    color: var(--color-primary-light);
}

.footer-desc {
    font-size: var(--text-sm);
    line-height: var(--leading-relaxed);
    margin-bottom: var(--space-lg);
}

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

.social-link {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-lg);
    transition: var(--transition-fast);
}

.social-link:hover {
    background-color: var(--color-primary);
    color: #fff;
}

.footer-links h4 {
    color: #fff;
    font-size: var(--text-base);
    font-family: var(--font-body);
    margin-bottom: var(--space-lg);
}

.footer-links ul {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.footer-links a {
    font-size: var(--text-sm);
    transition: var(--transition-fast);
}

.footer-links a:hover {
    color: var(--color-primary-light);
}

.footer-newsletter h4 {
    color: #fff;
    font-size: var(--text-base);
    font-family: var(--font-body);
    margin-bottom: var(--space-md);
}

.footer-newsletter p {
    font-size: var(--text-sm);
    margin-bottom: var(--space-md);
}

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

.footer-newsletter .newsletter-input-wrap {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.footer-newsletter input[type="email"] {
    flex: 1;
    padding: var(--space-sm) var(--space-md);
    font-size: var(--text-sm);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: var(--radius-md);
    background-color: rgba(255, 255, 255, 0.1);
    color: #fff;
}

.footer-newsletter input[type="email"]::placeholder {
    color: rgba(255, 255, 255, 0.5);
}

.footer-newsletter input[type="email"]:focus {
    outline: none;
    border-color: var(--color-primary-light);
}

.footer-newsletter .newsletter-gdpr {
    display: flex;
    align-items: flex-start;
    gap: var(--space-sm);
    font-size: var(--text-xs);
    color: rgba(255, 255, 255, 0.7);
    cursor: pointer;
    line-height: 1.4;
}

.footer-newsletter .newsletter-gdpr input[type="checkbox"] {
    width: 16px;
    height: 16px;
    margin-top: 1px;
    flex-shrink: 0;
    accent-color: var(--color-primary-light);
}

.footer-newsletter .newsletter-gdpr span {
    flex: 1;
}

.footer-newsletter .newsletter-note {
    font-size: var(--text-xs);
    margin-top: var(--space-sm);
    color: rgba(255, 255, 255, 0.5);
}

@media (min-width: 480px) {
    .footer-newsletter .newsletter-input-wrap {
        flex-direction: row;
    }
}

@media (min-width: 768px) {
    .footer-grid {
        grid-template-columns: 2fr 1fr 1fr 2fr;
    }
}

/* =====================================================
   PAGE STYLES
   ===================================================== */

/* Page Header */
.page-header {
    padding: var(--space-xl) 0 var(--space-2xl);
}

.page-title {
    font-size: var(--text-3xl);
    margin-bottom: var(--space-sm);
}

.page-description {
    font-size: var(--text-lg);
    color: var(--color-text-muted);
}

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

.breadcrumb a:hover {
    color: var(--color-primary);
}

.breadcrumb .separator {
    opacity: 0.5;
}

.breadcrumb .current {
    color: var(--color-text);
}

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

/* Filter Bar */
.filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    margin-bottom: var(--space-2xl);
    padding-bottom: var(--space-lg);
    border-bottom: 1px solid var(--color-border);
}

.filter-item {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    padding: var(--space-sm) var(--space-md);
    font-size: var(--text-sm);
    font-weight: 500;
    background-color: var(--color-bg-alt);
    border-radius: var(--radius-full);
    transition: var(--transition-fast);
}

.filter-item:hover,
.filter-item.active {
    background-color: var(--color-primary);
    color: #fff;
}

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

.empty-icon {
    font-size: 4rem;
    margin-bottom: var(--space-lg);
}

.empty-state h3 {
    font-size: var(--text-xl);
    margin-bottom: var(--space-sm);
}

.empty-state p {
    color: var(--color-text-muted);
    margin-bottom: var(--space-xl);
}

/* Page CTA */
.page-cta {
    margin-top: var(--space-3xl);
}

.cta-card {
    text-align: center;
    padding: var(--space-2xl);
    background-color: var(--color-bg-alt);
    border-radius: var(--radius-2xl);
}

.cta-card h3 {
    font-size: var(--text-xl);
    margin-bottom: var(--space-sm);
}

.cta-card p {
    color: var(--color-text-muted);
    margin-bottom: var(--space-lg);
}

/* =====================================================
   PRODUCT DETAIL PAGE
   ===================================================== */

.product-layout {
    display: grid;
    gap: var(--space-2xl);
    margin-bottom: var(--space-3xl);
}

.product-gallery {
    position: relative;
}

.gallery-main {
    position: relative;
    aspect-ratio: 1/1;
    background-color: #f6f9f4;
    border-radius: var(--radius-2xl);
    overflow: hidden;
}

.gallery-main img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.gallery-badge {
    position: absolute;
    top: var(--space-md);
    left: var(--space-md);
    padding: var(--space-sm) var(--space-md);
    font-size: var(--text-sm);
    font-weight: 600;
    border-radius: var(--radius-lg);
}

.gallery-badges {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    margin-top: var(--space-md);
}

.gallery-cert {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    padding: var(--space-sm) var(--space-md);
    font-size: var(--text-sm);
    font-weight: 600;
    background-color: var(--color-bg-alt);
    border-radius: var(--radius-lg);
    color: var(--color-primary);
}

.product-info .product-category-link {
    display: inline-block;
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--color-primary);
    margin-bottom: var(--space-sm);
}

.product-info .product-title {
    font-size: var(--text-3xl);
    margin-bottom: var(--space-md);
}

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

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

.star {
    color: var(--color-border);
}

.star.filled {
    color: var(--color-accent);
}

.product-short-desc {
    font-size: var(--text-lg);
    color: var(--color-text-muted);
    margin-bottom: var(--space-lg);
    line-height: var(--leading-relaxed);
}

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

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

.volume-value {
    font-weight: 600;
}

/* Buy Button Component */
.buy-button {
    padding: var(--space-xl);
    background-color: var(--color-bg-alt);
    border-radius: var(--radius-xl);
    margin-bottom: var(--space-xl);
}

.buy-discount-badge {
    display: inline-block;
    padding: var(--space-xs) var(--space-sm);
    background: rgba(79,107,76,0.9);
    color: #fff;
    font-size: var(--text-sm);
    font-weight: 700;
    border-radius: var(--radius-md);
    margin-bottom: var(--space-md);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.buy-price {
    display: flex;
    align-items: baseline;
    gap: var(--space-sm);
    margin-bottom: var(--space-lg);
}

.buy-price-current {
    font-size: var(--text-3xl);
    font-weight: 700;
}

.buy-price-original {
    font-size: var(--text-xl);
    color: var(--color-text-muted);
    text-decoration: line-through;
}

.buy-trust {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-md);
    margin-top: var(--space-md);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.buy-trust span {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
}

.buy-trust svg {
    color: var(--color-primary);
}

/* Product Benefits */
.product-benefits {
    padding: var(--space-lg);
    background-color: var(--color-bg-alt);
    border-radius: var(--radius-xl);
}

.benefits-title {
    font-size: var(--text-lg);
    font-family: var(--font-body);
    margin-bottom: var(--space-md);
}

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

.benefits-list li {
    display: flex;
    align-items: flex-start;
    gap: var(--space-sm);
}

.benefits-list svg {
    flex-shrink: 0;
    margin-top: 2px;
    color: var(--color-primary);
}

/* Product Tabs */
.product-tabs {
    margin-bottom: var(--space-3xl);
}

.tabs-nav {
    display: flex;
    gap: var(--space-md);
    border-bottom: 1px solid var(--color-border);
    margin-bottom: var(--space-xl);
}

.tab-btn {
    padding: var(--space-md) 0;
    font-weight: 600;
    color: var(--color-text-muted);
    border-bottom: 2px solid transparent;
    transition: var(--transition-fast);
}

.tab-btn:hover,
.tab-btn.active {
    color: var(--color-primary);
    border-bottom-color: var(--color-primary);
}

.tab-panel {
    display: none;
}

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

/* Related Products */
.related-products,
.related-articles {
    padding-top: var(--space-3xl);
    border-top: 1px solid var(--color-border);
}

.related-title {
    font-size: var(--text-2xl);
    margin-bottom: var(--space-xl);
}

@media (min-width: 1024px) {
    .product-layout {
        grid-template-columns: 1fr 1fr;
    }
}

/* =====================================================
   ARTICLE PAGE
   ===================================================== */

.article-header {
    padding: var(--space-2xl) 0;
}

.article-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-sm);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-bottom: var(--space-lg);
}

.article-category {
    color: var(--color-primary);
    font-weight: 600;
}

.article-title {
    font-size: var(--text-3xl);
    margin-bottom: var(--space-lg);
    line-height: var(--leading-tight);
}

.article-excerpt {
    font-size: var(--text-xl);
    color: var(--color-text-muted);
    margin-bottom: var(--space-xl);
    line-height: var(--leading-relaxed);
}

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

.author-avatar {
    width: 48px;
    height: 48px;
    color: var(--color-text-muted);
}

.author-info {
    display: flex;
    flex-direction: column;
}

.author-name {
    font-weight: 600;
}

.author-title {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.article-featured-image {
    margin-bottom: var(--space-2xl);
}

.article-featured-image img {
    width: 100%;
    border-radius: var(--radius-2xl);
}

/* Prose Styling */
.prose {
    font-size: var(--text-lg);
    line-height: var(--leading-relaxed);
    color: var(--color-text);
}

.prose p {
    margin-bottom: var(--space-lg);
}

.prose h2 {
    font-size: var(--text-2xl);
    margin-top: var(--space-2xl);
    margin-bottom: var(--space-lg);
}

.prose h3 {
    font-size: var(--text-xl);
    margin-top: var(--space-xl);
    margin-bottom: var(--space-md);
}

.prose ul, .prose ol {
    margin-bottom: var(--space-lg);
    padding-left: var(--space-xl);
}

.prose ul {
    list-style-type: disc;
}

.prose ol {
    list-style-type: decimal;
}

.prose li {
    margin-bottom: var(--space-sm);
}

.prose a {
    color: var(--color-primary);
    text-decoration: underline;
}

.prose strong {
    font-weight: 600;
}

.prose blockquote {
    padding: var(--space-lg);
    background-color: var(--color-bg-alt);
    border-left: 4px solid var(--color-primary);
    border-radius: var(--radius-md);
    margin: var(--space-xl) 0;
    font-style: italic;
}

/* Callout Boxes - Professional Info/Warning Cards */
.callout {
    padding: var(--space-lg) var(--space-xl);
    background-color: var(--color-bg-alt);
    border-left: 4px solid var(--color-primary);
    border-radius: var(--radius-lg);
    margin: var(--space-xl) 0;
}

.callout h4 {
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--color-text);
    margin: 0 0 var(--space-sm) 0;
}

.callout p {
    margin: 0 0 var(--space-md) 0;
    color: var(--color-text-muted);
}

.callout p:last-child {
    margin-bottom: 0;
}

.callout-info {
    background-color: rgba(106, 125, 90, 0.08);
    border-left-color: var(--color-primary);
}

.callout-warning {
    background-color: rgba(232, 169, 77, 0.08);
    border-left-color: #e8a94d;
}

.callout-warning h4 {
    color: #b8860b;
}

/* Button styling inside prose and callout - reset link styles */
.prose .btn,
.callout .btn {
    color: #fff !important;
    text-decoration: none !important;
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    margin-top: var(--space-sm);
}

.prose .btn-primary,
.callout .btn-primary {
    background-color: var(--color-primary);
}

.prose .btn-primary:hover,
.callout .btn-primary:hover {
    background-color: var(--color-primary-dark);
    transform: translateY(-1px);
}

/* Article CTA Box */
.article-cta-box {
    padding: var(--space-xl);
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
    color: #fff;
    border-radius: var(--radius-xl);
    text-align: center;
    margin: var(--space-2xl) 0;
}

.article-cta-box h3 {
    font-size: var(--text-xl);
    margin-bottom: var(--space-sm);
}

.article-cta-box p {
    margin-bottom: var(--space-lg);
    opacity: 0.9;
}

/* =====================================================
   SOCIAL ENGAGEMENT - Premium Share & Connect Section
   ===================================================== */

.social-engagement {
    margin-top: var(--space-3xl);
    padding-top: var(--space-2xl);
    border-top: 1px solid var(--color-border);
}

/* Share Section */
.share-section {
    margin-bottom: var(--space-2xl);
}

.share-heading,
.connect-heading {
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: var(--space-lg);
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.share-heading::before {
    content: '';
    width: 4px;
    height: 20px;
    background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
    border-radius: 2px;
}

.connect-heading::before {
    content: '';
    width: 4px;
    height: 20px;
    background: linear-gradient(135deg, #E1306C, #833AB4);
    border-radius: 2px;
}

/* Share Buttons - Professional Style */
.share-buttons-pro {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
}

.share-btn-pro {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-lg);
    font-size: var(--text-sm);
    font-weight: 500;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: all 0.2s ease;
    color: white;
}

.share-btn-pro span {
    display: none;
}

@media (min-width: 480px) {
    .share-btn-pro span {
        display: inline;
    }
}

.share-btn-pro svg {
    flex-shrink: 0;
}

/* Facebook Share */
.share-btn-pro.share-facebook {
    background: #1877F2;
}

.share-btn-pro.share-facebook:hover {
    background: #166FE5;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(24, 119, 242, 0.4);
}

/* WhatsApp Share */
.share-btn-pro.share-whatsapp {
    background: #25D366;
}

.share-btn-pro.share-whatsapp:hover {
    background: #20BD5A;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(37, 211, 102, 0.4);
}

/* Copy Link */
.share-btn-pro.share-copy {
    background: var(--color-bg-card);
    color: var(--color-text);
    border: 1px solid var(--color-border);
}

.share-btn-pro.share-copy:hover {
    background: var(--color-primary);
    color: white;
    border-color: var(--color-primary);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.share-btn-pro.share-copy.copied {
    background: #22C55E;
    color: white;
    border-color: #22C55E;
}

/* Email Share */
.share-btn-pro.share-email {
    background: var(--color-text-muted);
}

.share-btn-pro.share-email:hover {
    background: var(--color-text);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

/* Connect Section - Follow Us */
.connect-section {
    background: linear-gradient(135deg, rgba(225, 48, 108, 0.05), rgba(131, 58, 180, 0.05));
    border-radius: var(--radius-2xl);
    padding: var(--space-xl);
    border: 1px solid rgba(225, 48, 108, 0.1);
}

.connect-buttons {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: var(--space-md);
}

.connect-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-xs);
    padding: var(--space-lg) var(--space-md);
    background: var(--color-bg-card);
    border-radius: var(--radius-xl);
    text-decoration: none;
    transition: all 0.3s ease;
    border: 1px solid var(--color-border);
    text-align: center;
}

.connect-btn:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.connect-btn svg {
    transition: transform 0.3s ease;
}

.connect-btn:hover svg {
    transform: scale(1.1);
}

.connect-label {
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--color-text);
}

.connect-action {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Instagram Connect */
.connect-instagram svg {
    color: #E1306C;
}

.connect-instagram:hover {
    background: linear-gradient(135deg, rgba(225, 48, 108, 0.1), rgba(131, 58, 180, 0.1));
    border-color: #E1306C;
}

.connect-instagram:hover .connect-action {
    color: #E1306C;
}

/* Facebook Connect */
.connect-facebook svg {
    color: #1877F2;
}

.connect-facebook:hover {
    background: rgba(24, 119, 242, 0.1);
    border-color: #1877F2;
}

.connect-facebook:hover .connect-action {
    color: #1877F2;
}

/* YouTube Connect */
.connect-youtube svg {
    color: #FF0000;
}

.connect-youtube:hover {
    background: rgba(255, 0, 0, 0.1);
    border-color: #FF0000;
}

.connect-youtube:hover .connect-action {
    color: #FF0000;
}

/* Dark Mode Adjustments */
[data-theme="dark"] .connect-section {
    background: linear-gradient(135deg, rgba(225, 48, 108, 0.08), rgba(131, 58, 180, 0.08));
    border-color: rgba(225, 48, 108, 0.2);
}

[data-theme="dark"] .connect-btn {
    background: var(--color-bg);
}

[data-theme="dark"] .share-btn-pro.share-copy {
    background: var(--color-bg);
}

/* Mobile Responsiveness */
@media (max-width: 479px) {
    .share-buttons-pro {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
    }

    .share-btn-pro {
        justify-content: center;
        padding: var(--space-md);
    }

    .connect-buttons {
        grid-template-columns: 1fr;
    }

    .connect-btn {
        flex-direction: row;
        justify-content: flex-start;
        padding: var(--space-md) var(--space-lg);
    }

    .connect-btn svg {
        width: 28px;
        height: 28px;
    }

    .connect-action {
        margin-left: auto;
    }
}

@media (min-width: 768px) {
    .article-title {
        font-size: var(--text-4xl);
    }
}

/* =====================================================
   CONTACT PAGE - Premium Design
   ===================================================== */

.contact-page {
    padding-bottom: var(--space-3xl);
}

.contact-grid {
    display: grid;
    gap: var(--space-3xl);
}

.contact-form-section h2,
.contact-faq-section h2 {
    font-size: var(--text-2xl);
    margin-bottom: var(--space-xl);
}

/* Contact Form Card */
.contact-form-card {
    background: var(--color-bg-card);
    border-radius: var(--radius-2xl);
    padding: var(--space-xl);
    box-shadow: var(--shadow-lg);
    border: 1px solid var(--color-border);
}

.contact-form-card h2 {
    font-size: var(--text-xl);
    margin-bottom: var(--space-lg);
    padding-bottom: var(--space-md);
    border-bottom: 1px solid var(--color-border);
}

/* Contact Form */
.contact-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
}

/* Honeypot hiding */
.form-field-hidden {
    display: none !important;
}

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

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

.form-group label {
    font-weight: 600;
    font-size: 14px;
    color: var(--color-text);
    display: flex;
    align-items: center;
    gap: var(--space-xs);
}

.form-group label .required {
    color: var(--color-error);
}

/* Input wrapper with icon */
.input-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.input-wrapper input,
.input-wrapper select,
.input-wrapper textarea {
    width: 100%;
    padding: var(--space-md) var(--space-lg);
    padding-right: calc(var(--space-lg) + 24px);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-md);
    background-color: var(--color-bg);
    font-size: 16px; /* iOS anti-zoom */
    transition: var(--transition-fast);
    color: var(--color-text);
    min-height: 50px;
}

.input-wrapper .input-icon {
    position: absolute;
    right: var(--space-md);
    color: var(--color-text-muted);
    pointer-events: none;
    transition: var(--transition-fast);
}

.input-wrapper input:focus,
.input-wrapper select:focus,
.input-wrapper textarea:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 4px rgba(118, 133, 99, 0.15);
}

.input-wrapper input:focus + .input-icon,
.input-wrapper select:focus + .input-icon {
    color: var(--color-primary);
}

.input-wrapper input::placeholder,
.input-wrapper textarea::placeholder {
    color: var(--color-text-muted);
    opacity: 0.7;
}

/* Select wrapper */
.select-wrapper select {
    appearance: none;
    cursor: pointer;
}

.select-wrapper .select-icon {
    pointer-events: none;
}

/* Textarea */
.textarea-wrapper textarea {
    padding-right: var(--space-lg);
    resize: vertical;
    min-height: 150px;
    line-height: 1.6;
}

/* Form hint */
.form-hint {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    margin-top: var(--space-xs);
}

/* Submit button */
.contact-form .btn-lg {
    width: 100%;
    min-height: 50px;
    padding: var(--space-md) var(--space-xl);
    font-size: var(--text-base);
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-sm);
    border-radius: var(--radius-md);
}

.contact-form .btn-text,
.contact-form .btn-loading {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
}

.contact-form .spinner {
    animation: spin 1s linear infinite;
}

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

/* Form messages */
.form-message {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-md);
    border-radius: var(--radius-lg);
    font-weight: 500;
}

.form-success {
    background-color: rgba(34, 197, 94, 0.1);
    color: var(--color-success);
    border: 1px solid rgba(34, 197, 94, 0.3);
}

.form-error {
    background-color: rgba(239, 68, 68, 0.1);
    color: var(--color-error);
    border: 1px solid rgba(239, 68, 68, 0.3);
}

/* Dark mode adjustments */
[data-theme="dark"] .contact-form-card {
    background: var(--color-bg-card);
    border-color: var(--color-border);
}

[data-theme="dark"] .input-wrapper input,
[data-theme="dark"] .input-wrapper select,
[data-theme="dark"] .input-wrapper textarea {
    background-color: var(--color-bg-alt);
    border-color: var(--color-border);
}

/* FAQ - Improved Design */
.faq-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    margin-bottom: var(--space-2xl);
}

.faq-item {
    border-bottom: 1px solid rgba(0,0,0,0.06);
    background: var(--color-bg-card);
}
[data-theme="dark"] .faq-item {
    border-bottom-color: rgba(255,255,255,0.06);
}

.faq-question {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
    padding: var(--space-md) var(--space-lg);
    min-height: var(--touch-min, 44px);
    font-weight: 600;
    font-size: 16px;
    cursor: pointer;
    background-color: transparent;
    transition: var(--transition-fast);
    list-style: none;
}

.faq-question::-webkit-details-marker {
    display: none;
}

/* Hide ::after icon when SVG .faq-icon is present (contact page FAQ) */
.faq-list .faq-question::after {
    display: none !important;
    content: none !important;
}

.faq-question span {
    flex: 1;
}

.faq-question .faq-icon {
    flex-shrink: 0;
    color: var(--color-text-muted);
    transition: var(--transition-fast);
}

.faq-question:hover {
    background-color: var(--color-bg-alt);
}

.faq-item[open] .faq-question {
    background-color: var(--color-bg-alt);
    border-bottom: 1px solid var(--color-border);
}

.faq-item[open] .faq-question .faq-icon {
    transform: rotate(45deg);
    color: var(--color-primary);
}

.faq-answer {
    max-height: 0;
    overflow: hidden;
    padding: 0 var(--space-lg);
    color: var(--color-text-muted);
    line-height: var(--leading-relaxed);
    font-size: var(--text-sm);
    transition: max-height var(--duration-normal, 0.3s) ease-out,
                padding var(--duration-normal, 0.3s) ease-out;
}
.faq-item[open] .faq-answer {
    padding: var(--space-md) var(--space-lg) var(--space-lg);
}

.faq-answer a {
    color: var(--color-primary);
    text-decoration: underline;
}

/* Quick Links - Improved */
.contact-links {
    margin-top: var(--space-xl);
    padding: var(--space-lg);
    background: var(--color-bg-alt);
    border-radius: var(--radius-xl);
}

.contact-links h3 {
    font-size: var(--text-base);
    font-family: var(--font-body);
    font-weight: 600;
    margin-bottom: var(--space-md);
}

.contact-links ul {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.contact-links li {
    list-style: none;
}

.contact-links a {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    color: var(--color-primary);
    font-size: var(--text-sm);
    padding: var(--space-xs) 0;
    transition: var(--transition-fast);
}

.contact-links a:hover {
    color: var(--color-primary-dark);
    transform: translateX(4px);
}

.contact-links a svg {
    flex-shrink: 0;
    opacity: 0.7;
}

/* Responsive */
@media (min-width: 768px) {
    .contact-form-card {
        padding: var(--space-2xl);
    }
}

@media (min-width: 1024px) {
    .contact-grid {
        grid-template-columns: 1fr 1fr;
        gap: var(--space-2xl);
    }
}

/* =====================================================
   ABOUT PAGE
   ===================================================== */

.about-hero {
    padding: var(--space-3xl) 0;
    background: linear-gradient(135deg, var(--color-bg) 0%, var(--color-bg-alt) 100%);
    text-align: center;
}

.about-title {
    font-size: var(--text-4xl);
    margin-bottom: var(--space-md);
}

.about-subtitle {
    font-size: var(--text-xl);
    color: var(--color-text-muted);
}

.story-grid,
.values-grid {
    display: grid;
    gap: var(--space-2xl);
    align-items: center;
}

.story-content h2,
.values-content h2 {
    font-size: var(--text-3xl);
    margin-bottom: var(--space-lg);
}

.story-content p,
.values-content p {
    color: var(--color-text-muted);
    margin-bottom: var(--space-md);
    line-height: var(--leading-relaxed);
}

.story-image img,
.values-image img {
    width: 100%;
    border-radius: var(--radius-2xl);
}

/* CTEO Grid */
.cteo-grid {
    display: grid;
    gap: var(--space-lg);
}

.cteo-card {
    padding: var(--space-xl);
    background-color: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    text-align: center;
}

.cteo-icon {
    width: 64px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--color-bg-alt);
    border-radius: var(--radius-xl);
    color: var(--color-primary);
    margin: 0 auto var(--space-lg);
}

.cteo-card h3 {
    font-size: var(--text-lg);
    font-family: var(--font-body);
    margin-bottom: var(--space-sm);
}

.cteo-card p {
    color: var(--color-text-muted);
    font-size: var(--text-sm);
}

/* Values List */
.values-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.values-list li {
    display: flex;
    align-items: flex-start;
    gap: var(--space-md);
}

.values-list svg {
    flex-shrink: 0;
    margin-top: 4px;
    color: var(--color-primary);
}

/* Why Grid */
.why-grid {
    display: grid;
    gap: var(--space-lg);
}

.why-card {
    padding: var(--space-xl);
    background-color: rgba(255, 255, 255, 0.05);
    border-radius: var(--radius-xl);
}

.why-card h3 {
    font-size: var(--text-lg);
    font-family: var(--font-body);
    color: var(--color-accent);
    margin-bottom: var(--space-sm);
}

.why-card p {
    color: rgba(255, 255, 255, 0.7);
    font-size: var(--text-sm);
}

.about-cta {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-md);
    margin-top: var(--space-xl);
}

@media (min-width: 768px) {
    .cteo-grid {
        grid-template-columns: repeat(2, 1fr);
    }

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

@media (min-width: 1024px) {
    .story-grid,
    .values-grid {
        grid-template-columns: 1fr 1fr;
    }

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

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

/* =====================================================
   ERROR PAGE
   ===================================================== */

.error-page {
    min-height: calc(100vh - var(--header-height-mobile) - 200px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-3xl) 0;
}

.error-content {
    text-align: center;
    max-width: 500px;
}

.error-icon {
    color: var(--color-text-muted);
    margin-bottom: var(--space-lg);
}

.error-title {
    font-size: 6rem;
    line-height: 1;
    color: var(--color-primary);
    margin-bottom: var(--space-sm);
}

.error-subtitle {
    font-size: var(--text-2xl);
    margin-bottom: var(--space-lg);
}

.error-description {
    color: var(--color-text-muted);
    margin-bottom: var(--space-xl);
}

.error-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-md);
    margin-bottom: var(--space-2xl);
}

.error-suggestions h3 {
    font-size: var(--text-lg);
    font-family: var(--font-body);
    margin-bottom: var(--space-md);
}

.error-suggestions ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-md);
}

.error-suggestions a {
    color: var(--color-primary);
}

.error-suggestions a:hover {
    text-decoration: underline;
}

/* =====================================================
   UTILITY CLASSES
   ===================================================== */

.hidden {
    display: none !important;
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}

/* Category Page */
.category-header {
    display: flex;
    align-items: center;
    gap: var(--space-lg);
}

.category-icon-large {
    font-size: var(--text-4xl);
}

.category-info {
    flex: 1;
}

/* Blog Page */
.blog-all {
    margin-top: var(--space-2xl);
}

.section-subtitle {
    font-size: var(--text-xl);
    font-family: var(--font-body);
    margin-bottom: var(--space-xl);
}

.blog-newsletter {
    margin-top: var(--space-3xl);
}

/* =====================================================
   LEGAL PAGES - Privacy Policy & Terms of Service
   ===================================================== */

.legal-page {
    padding: var(--space-2xl) 0 var(--space-3xl);
    min-height: 60vh;
}

/* Legal Header */
.legal-header {
    text-align: center;
    margin-bottom: var(--space-3xl);
    padding-bottom: var(--space-2xl);
    border-bottom: 1px solid var(--color-border);
}

.legal-icon {
    width: 72px;
    height: 72px;
    background: linear-gradient(135deg, var(--color-primary) 0%, #4a9c2d 100%);
    border-radius: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto var(--space-lg);
    box-shadow: 0 8px 24px rgba(45, 80, 22, 0.2);
}

.legal-icon svg {
    width: 36px;
    height: 36px;
    color: white;
}

.legal-header h1 {
    font-size: clamp(2rem, 4vw, 2.75rem);
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: var(--space-sm);
    letter-spacing: -0.02em;
}

.legal-updated {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    background: var(--color-bg-alt);
    padding: 8px 16px;
    border-radius: var(--radius-full);
}

.legal-updated svg {
    width: 16px;
    height: 16px;
}

/* Legal Layout - Sidebar + Content */
.legal-layout {
    display: grid;
    gap: var(--space-2xl);
    max-width: 1100px;
    margin: 0 auto;
}

@media (min-width: 1024px) {
    .legal-layout {
        grid-template-columns: 260px 1fr;
        gap: var(--space-3xl);
    }
}

/* Table of Contents Sidebar */
.legal-toc {
    position: relative;
}

@media (min-width: 1024px) {
    .legal-toc {
        position: sticky;
        top: 100px;
        align-self: start;
        max-height: calc(100vh - 120px);
        overflow-y: auto;
    }
}

.legal-toc-title {
    font-size: var(--text-sm);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
    margin-bottom: var(--space-md);
}

.legal-toc-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.legal-toc-list li {
    margin-bottom: 2px;
}

.legal-toc-list a {
    display: block;
    padding: 10px 14px;
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    border-radius: var(--radius-md);
    transition: all 0.2s ease;
    text-decoration: none;
    border-left: 3px solid transparent;
}

.legal-toc-list a:hover {
    background: var(--color-bg-alt);
    color: var(--color-text);
    border-left-color: var(--color-primary);
}

.legal-toc-list a.active {
    background: var(--color-bg-alt);
    color: var(--color-primary);
    font-weight: 500;
    border-left-color: var(--color-primary);
}

/* Mobile TOC Toggle */
.legal-toc-mobile {
    display: block;
    margin-bottom: var(--space-xl);
}

@media (min-width: 1024px) {
    .legal-toc-mobile {
        display: none;
    }
}

.legal-toc-toggle {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-md) var(--space-lg);
    background: var(--color-bg-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-text);
    cursor: pointer;
    transition: all 0.2s ease;
}

.legal-toc-toggle:hover {
    border-color: var(--color-primary);
}

.legal-toc-toggle svg {
    width: 20px;
    height: 20px;
    transition: transform 0.2s ease;
}

.legal-toc-toggle.active svg {
    transform: rotate(180deg);
}

.legal-toc-dropdown {
    display: none;
    margin-top: var(--space-sm);
    padding: var(--space-md);
    background: var(--color-bg-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
}

.legal-toc-dropdown.active {
    display: block;
}

.legal-toc-desktop {
    display: none;
}

@media (min-width: 1024px) {
    .legal-toc-desktop {
        display: block;
    }
}

/* Legal Content */
.legal-content {
    font-size: var(--text-base);
    line-height: 1.8;
    color: var(--color-text);
}

.legal-content h2 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-text);
    margin: var(--space-2xl) 0 var(--space-md);
    padding-top: var(--space-lg);
    scroll-margin-top: 100px;
    letter-spacing: -0.01em;
}

.legal-content h2:first-child {
    margin-top: 0;
    padding-top: 0;
}

.legal-content h3 {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--color-text);
    margin: var(--space-xl) 0 var(--space-sm);
}

.legal-content p {
    margin-bottom: var(--space-md);
    color: var(--color-text-muted);
}

.legal-content ul,
.legal-content ol {
    margin: var(--space-md) 0;
    padding-left: var(--space-xl);
}

.legal-content li {
    margin-bottom: var(--space-sm);
    color: var(--color-text-muted);
}

.legal-content li strong {
    color: var(--color-text);
}

.legal-content a {
    color: var(--color-primary);
    text-decoration: underline;
    text-underline-offset: 3px;
    transition: color 0.2s ease;
}

.legal-content a:hover {
    color: var(--color-primary-dark);
}

/* Cookie Table */
.legal-content .content-table {
    width: 100%;
    margin: var(--space-lg) 0;
    border-collapse: collapse;
    font-size: var(--text-sm);
    background: var(--color-bg);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
    border: 1px solid var(--color-border);
}

.legal-content .content-table th,
.legal-content .content-table td {
    padding: var(--space-md);
    text-align: left;
    border-bottom: 1px solid var(--color-border);
}

.legal-content .content-table th {
    background: var(--color-bg-alt);
    font-weight: 600;
    color: var(--color-text);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.legal-content .content-table td {
    color: var(--color-text-muted);
}

.legal-content .content-table tr:last-child td {
    border-bottom: none;
}

.legal-content .content-table tr:hover td {
    background: var(--color-bg-alt);
}

/* Info Box */
.legal-info-box {
    background: linear-gradient(135deg, rgba(45, 80, 22, 0.05) 0%, rgba(74, 156, 45, 0.05) 100%);
    border: 1px solid rgba(45, 80, 22, 0.15);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    margin: var(--space-xl) 0;
}

.legal-info-box h4 {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    font-weight: 600;
    color: var(--color-primary-dark);
    margin-bottom: var(--space-sm);
}

.legal-info-box h4 svg {
    width: 20px;
    height: 20px;
}

.legal-info-box p {
    margin: 0;
    color: var(--color-text);
}

/* Contact Box at Bottom */
.legal-contact-box {
    background: var(--color-bg-alt);
    border-radius: var(--radius-xl);
    padding: var(--space-xl);
    margin-top: var(--space-2xl);
    text-align: center;
}

.legal-contact-box h3 {
    font-size: var(--text-lg);
    margin: 0 0 var(--space-sm);
    color: var(--color-text);
}

.legal-contact-box p {
    color: var(--color-text-muted);
    margin-bottom: var(--space-lg);
}

.legal-contact-box .btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
}

.legal-contact-box .btn-primary {
    background-color: var(--color-primary);
    color: #fff !important;
}

.legal-contact-box .btn-primary:hover {
    background-color: var(--color-primary-dark);
    transform: translateY(-1px);
}

/* Legal Page Dark Mode */
[data-theme="dark"] .legal-page {
    background-color: var(--color-bg);
}

[data-theme="dark"] .legal-header {
    border-bottom-color: var(--color-border);
}

[data-theme="dark"] .legal-icon {
    background: linear-gradient(135deg, rgba(106, 125, 90, 0.2), rgba(138, 157, 122, 0.1));
}

[data-theme="dark"] .legal-toc {
    background-color: var(--color-bg-card);
    border-color: var(--color-border);
}

[data-theme="dark"] .legal-toc a {
    color: var(--color-text-muted);
}

[data-theme="dark"] .legal-toc a:hover {
    color: var(--color-primary-light);
    background-color: rgba(106, 125, 90, 0.1);
}

[data-theme="dark"] .legal-content h2 {
    color: var(--color-text);
    border-bottom-color: var(--color-border);
}

[data-theme="dark"] .legal-content h3 {
    color: var(--color-text);
}

[data-theme="dark"] .legal-content p,
[data-theme="dark"] .legal-content li {
    color: var(--color-text-muted);
}

[data-theme="dark"] .legal-info-box {
    background-color: rgba(106, 125, 90, 0.1);
    border-color: rgba(106, 125, 90, 0.3);
}

[data-theme="dark"] .legal-contact-box {
    background: linear-gradient(135deg, rgba(106, 125, 90, 0.15), rgba(138, 157, 122, 0.08));
    border: 1px solid rgba(106, 125, 90, 0.2);
}

[data-theme="dark"] .legal-contact-box h3 {
    color: var(--color-text);
}

[data-theme="dark"] .legal-contact-box p {
    color: var(--color-text-muted);
}

[data-theme="dark"] .legal-contact-box .btn-primary {
    background-color: var(--color-primary);
    color: #fff !important;
}

[data-theme="dark"] .legal-contact-box .btn-primary:hover {
    background-color: var(--color-primary-light);
}

/* Legal Page Responsive */
@media (max-width: 640px) {
    .legal-page {
        padding: var(--space-xl) 0 var(--space-2xl);
    }

    .legal-header {
        margin-bottom: var(--space-xl);
        padding-bottom: var(--space-xl);
    }

    .legal-icon {
        width: 60px;
        height: 60px;
        border-radius: 16px;
    }

    .legal-icon svg {
        width: 28px;
        height: 28px;
    }

    .legal-content h2 {
        font-size: 1.25rem;
    }

    .legal-content h3 {
        font-size: 1rem;
    }

    .legal-content .content-table {
        display: block;
        overflow-x: auto;
    }
}

/* =====================================================
   ANNOUNCEMENT BAR
   ===================================================== */

.announcement-bar {
    position: relative;
    background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 100%);
    color: #fff;
    font-size: var(--text-sm);
    padding: var(--space-sm) var(--space-xl);
    text-align: center;
    z-index: 100;
}

.announcement-content {
    max-width: var(--container-max);
    margin: 0 auto;
    overflow: hidden;
}

.announcement-slider {
    position: relative;
    height: 24px;
}

.announcement-item {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-sm);
    opacity: 0;
    transform: translateY(10px);
    transition: all 0.3s ease;
    pointer-events: none;
}

.announcement-item.active {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.announcement-item svg {
    color: var(--color-accent);
    flex-shrink: 0;
}

.announcement-item a {
    color: var(--color-accent);
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 2px;
    margin-left: var(--space-xs);
}

.announcement-item a:hover {
    color: #fff;
}

.announcement-close {
    position: absolute;
    right: var(--space-md);
    top: 50%;
    transform: translateY(-50%);
    background: transparent;
    border: none;
    color: rgba(255, 255, 255, 0.6);
    cursor: pointer;
    padding: var(--space-xs);
    transition: color 0.2s;
}

.announcement-close:hover {
    color: #fff;
}

.announcement-dots {
    position: absolute;
    bottom: 2px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 4px;
}

.announcement-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.3);
    border: none;
    cursor: pointer;
    transition: background 0.2s;
}

.announcement-dot.active {
    background: var(--color-accent);
}

.announcement-bar.hidden {
    display: none;
}

/* =====================================================
   HERO STATS
   ===================================================== */

.hero-stats {
    display: flex;
    gap: var(--space-xl);
    margin-top: var(--space-xl);
    padding-top: var(--space-xl);
    border-top: 1px solid var(--color-border-light);
}

.stat-item {
    display: flex;
    flex-direction: column;
}

.stat-number {
    font-family: var(--font-display);
    font-size: var(--text-3xl);
    font-weight: 700;
    color: var(--color-primary);
    line-height: 1;
}

.stat-label {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-top: var(--space-xs);
}

@media (max-width: 767px) {
    .hero-stats {
        gap: var(--space-lg);
    }

    .stat-number {
        font-size: var(--text-2xl);
    }
}

/* =====================================================
   TESTIMONIALS SECTION
   ===================================================== */

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

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

@media (min-width: 768px) {
    .testimonials-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.testimonial-card {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-xl);
    padding: var(--space-xl);
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.testimonial-card:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-4px);
}

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

.testimonial-rating .star {
    color: var(--color-accent);
    font-size: var(--text-lg);
}

.testimonial-text {
    font-size: var(--text-base);
    line-height: 1.7;
    color: var(--color-text);
    font-style: italic;
    flex: 1;
    margin: 0;
}

.testimonial-author {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding-top: var(--space-md);
    border-top: 1px solid var(--color-border-light);
}

.author-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-primary-light), var(--color-primary));
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: var(--text-lg);
}

.author-info {
    display: flex;
    flex-direction: column;
    flex: 1;
}

.author-name {
    font-weight: 600;
    color: var(--color-text);
}

.author-location {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.verified-badge {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: var(--text-xs);
    color: var(--color-success);
    background: rgba(74, 222, 128, 0.1);
    padding: 4px 8px;
    border-radius: var(--radius-full);
}

.verified-badge svg {
    width: 14px;
    height: 14px;
}

.testimonial-product {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.testimonial-product strong {
    color: var(--color-primary);
}

/* =====================================================
   PREMIUM PRODUCT PAGE - UK FIRST DESIGN
   ===================================================== */

.product-page-premium {
    padding-bottom: var(--space-4xl);
}

/* Floating Buy Bar (Mobile) */
.floating-buy-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: var(--color-bg-card);
    border-top: 1px solid var(--color-border);
    padding: var(--space-md);
    z-index: 100;
    transform: translateY(100%);
    transition: transform var(--transition-base);
    box-shadow: 0 -4px 20px rgba(0,0,0,0.1);
}

.floating-buy-bar.visible {
    transform: translateY(0);
}

.fbb-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: var(--container-max);
    margin: 0 auto;
}

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

.fbb-current {
    font-size: var(--text-xl);
    font-weight: 700;
}

.fbb-discount {
    background: rgba(79,107,76,0.9);
    color: #fff;
    padding: 2px 6px;
    border-radius: var(--radius-sm);
    font-size: var(--text-xs);
    font-weight: 700;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.btn-buy-floating {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
    color: #fff;
    padding: var(--space-sm) var(--space-lg);
    border-radius: var(--radius-lg);
    font-weight: 600;
}

@media (min-width: 768px) {
    .floating-buy-bar {
        display: none;
    }
}

/* Product Hero Section */
.product-hero {
    display: grid;
    gap: var(--space-2xl);
    margin-bottom: var(--space-3xl);
}

@media (min-width: 1024px) {
    .product-hero {
        grid-template-columns: 1fr 1fr;
        gap: var(--space-3xl);
    }
}

/* Premium Gallery */
.product-gallery-premium {
    position: relative;
}

.gallery-main-wrapper {
    position: relative;
    margin-bottom: var(--space-md);
}

.gallery-main {
    position: relative;
    aspect-ratio: 1/1;
    background: #f6f9f4;
    border-radius: var(--radius-2xl);
    overflow: hidden;
}

.gallery-main img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    transition: opacity var(--transition-fast);
}

.gallery-badges-floating {
    position: absolute;
    top: var(--space-md);
    left: var(--space-md);
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    z-index: 2;
}

.badge-float {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    padding: var(--space-sm) var(--space-md);
    border-radius: var(--radius-full);
    font-size: var(--text-sm);
    font-weight: 700;
    box-shadow: var(--shadow-md);
}

.badge-bestseller {
    background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
    color: #fff;
}

.badge-new {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
    color: #fff;
}

.badge-sale {
    background: rgba(79,107,76,0.9);
    color: #fff;
    flex-direction: column;
    padding: var(--space-sm) var(--space-md);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.sale-percent {
    font-size: var(--text-lg);
    line-height: 1;
}

.sale-text {
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Gallery Navigation */
.gallery-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-full);
    color: var(--color-text);
    cursor: pointer;
    opacity: 0;
    transition: all var(--transition-fast);
    z-index: 3;
    box-shadow: var(--shadow-md);
}

.gallery-main-wrapper:hover .gallery-nav {
    opacity: 1;
}

.gallery-nav:hover {
    background: var(--color-primary);
    color: #fff;
    border-color: var(--color-primary);
}

.gallery-prev {
    left: var(--space-md);
}

.gallery-next {
    right: var(--space-md);
}

/* Gallery Thumbnails */
.gallery-thumbnails {
    display: flex;
    gap: var(--space-sm);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding-bottom: var(--space-sm);
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.gallery-thumbnails::-webkit-scrollbar {
    display: none;
}

.thumb-item {
    flex-shrink: 0;
    width: 64px;
    height: 64px;
    border-radius: var(--radius-md);
    overflow: hidden;
    border: 2px solid var(--color-border);
    cursor: pointer;
    transition: all var(--transition-fast);
    background: var(--color-bg-alt);
    scroll-snap-align: start;
}

.thumb-item:hover {
    border-color: var(--color-primary-light);
}

.thumb-item.active {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px rgba(118, 133, 99, 0.2);
}

.thumb-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Certifications Bar */
.product-certifications-bar {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-md);
    padding: var(--space-lg);
    background: var(--color-bg-alt);
    border-radius: var(--radius-xl);
    margin-top: var(--space-lg);
}

.cert-item {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    flex: 1;
    min-width: 140px;
}

.cert-icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-lg);
}

.cert-cteo {
    background: rgba(118, 133, 99, 0.15);
    color: var(--color-primary);
}

.cert-vegan {
    background: rgba(74, 222, 128, 0.15);
    color: var(--color-success);
}

.cert-lab {
    background: rgba(59, 130, 246, 0.15);
    color: #3b82f6;
}

.cert-text {
    display: flex;
    flex-direction: column;
}

.cert-label {
    font-weight: 700;
    font-size: var(--text-sm);
}

.cert-desc {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
}

/* Premium Product Info */
.product-info-premium {
    display: flex;
    flex-direction: column;
}

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

.product-category-badge {
    display: inline-block;
    padding: var(--space-xs) var(--space-md);
    background: var(--color-bg-alt);
    color: var(--color-primary);
    font-size: var(--text-sm);
    font-weight: 600;
    border-radius: var(--radius-full);
    transition: all var(--transition-fast);
}

.product-category-badge:hover {
    background: var(--color-primary);
    color: #fff;
}

.product-sku {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.product-title-premium {
    font-size: var(--text-3xl);
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: var(--space-md);
}

@media (min-width: 1024px) {
    .product-title-premium {
        font-size: var(--text-4xl);
    }
}

/* Premium Rating */
.product-rating-premium {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    margin-bottom: var(--space-lg);
}

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

.star-wrapper {
    position: relative;
    font-size: var(--text-lg);
}

.star-bg {
    color: var(--color-border);
}

.star-fill {
    position: absolute;
    top: 0;
    left: 0;
    overflow: hidden;
    color: var(--color-accent);
}

.rating-number {
    font-weight: 700;
    font-size: var(--text-lg);
}

.rating-reviews {
    color: var(--color-text-muted);
    font-size: var(--text-sm);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.rating-reviews:hover {
    color: var(--color-primary);
}

/* Product Tagline */
.product-tagline {
    font-size: var(--text-lg);
    color: var(--color-text-muted);
    line-height: 1.6;
    margin-bottom: var(--space-xl);
}

/* Variant Selector */
.product-variant-selector {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    margin-bottom: var(--space-xl);
}

.variant-label {
    font-weight: 600;
}

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

.variant-option {
    padding: var(--space-sm) var(--space-lg);
    border: 2px solid var(--color-border);
    border-radius: var(--radius-lg);
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.variant-option:hover {
    border-color: var(--color-primary-light);
}

.variant-option.active {
    border-color: var(--color-primary);
    background: rgba(118, 133, 99, 0.1);
}

/* Premium Price Box */
.price-box-premium {
    background: linear-gradient(135deg, rgba(118, 133, 99, 0.08) 0%, rgba(118, 133, 99, 0.03) 100%);
    border: 1px solid rgba(118, 133, 99, 0.2);
    border-radius: var(--radius-xl);
    padding: var(--space-xl);
    margin-bottom: var(--space-lg);
}

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

.savings-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
    color: #fff;
    padding: var(--space-xs) var(--space-sm);
    border-radius: var(--radius-md);
    font-size: var(--text-sm);
    font-weight: 700;
}

.savings-original {
    color: var(--color-text-muted);
    text-decoration: line-through;
    font-size: var(--text-lg);
}

.price-main {
    display: flex;
    align-items: baseline;
    gap: var(--space-xs);
    margin-bottom: var(--space-sm);
}

.price-currency {
    font-size: var(--text-2xl);
    font-weight: 700;
    color: var(--color-primary-dark);
}

.price-amount {
    font-size: var(--text-4xl);
    font-weight: 800;
    color: var(--color-text);
    line-height: 1;
}

.price-vat {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

/* Premium Buy Button */
.buy-section {
    margin-bottom: var(--space-xl);
}

.btn-buy-premium {
    display: flex;
    align-items: center;
    width: 100%;
    padding: var(--space-lg);
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
    color: #fff;
    border-radius: var(--radius-xl);
    text-decoration: none;
    transition: all var(--transition-base);
    box-shadow: 0 4px 15px rgba(118, 133, 99, 0.3);
}

.btn-buy-premium:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(118, 133, 99, 0.4);
}

.btn-buy-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    background: rgba(255,255,255,0.2);
    border-radius: var(--radius-lg);
    margin-right: var(--space-md);
}

.btn-buy-text {
    flex: 1;
    display: flex;
    flex-direction: column;
    text-align: left;
}

.btn-text-main {
    font-size: var(--text-lg);
    font-weight: 700;
}

.btn-text-sub {
    font-size: var(--text-sm);
    opacity: 0.9;
}

.btn-buy-arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: rgba(255,255,255,0.2);
    border-radius: var(--radius-full);
    transition: transform var(--transition-fast);
}

.btn-buy-premium:hover .btn-buy-arrow {
    transform: translate(4px, -4px);
}

.btn-buy-large {
    padding: var(--space-xl) var(--space-2xl);
}

.btn-buy-large .btn-text-main {
    font-size: var(--text-xl);
}

/* Trust Strip */
.trust-strip {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-md);
    margin-top: var(--space-md);
    padding-top: var(--space-md);
    border-top: 1px solid var(--color-border-light);
}

.trust-strip .trust-item {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.trust-strip .trust-item svg {
    color: var(--color-primary);
    flex-shrink: 0;
}

/* Benefits Card */
.benefits-card {
    background: var(--color-bg-alt);
    border-radius: var(--radius-xl);
    padding: var(--space-xl);
}

.benefits-heading {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    font-size: var(--text-lg);
    font-family: var(--font-body);
    font-weight: 700;
    margin-bottom: var(--space-md);
    color: var(--color-primary-dark);
}

.benefits-list-premium {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.benefits-list-premium li {
    display: flex;
    align-items: flex-start;
    gap: var(--space-sm);
}

.benefit-check {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    background: var(--color-primary);
    color: #fff;
    border-radius: var(--radius-full);
    flex-shrink: 0;
    margin-top: 2px;
}

/* Expert Section */
.expert-section {
    margin-bottom: var(--space-3xl);
}

.expert-card {
    background: linear-gradient(135deg, rgba(217, 151, 63, 0.1) 0%, rgba(217, 151, 63, 0.05) 100%);
    border: 1px solid rgba(217, 151, 63, 0.2);
    border-radius: var(--radius-2xl);
    padding: var(--space-xl);
}

.expert-header {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    margin-bottom: var(--space-lg);
    padding-bottom: var(--space-lg);
    border-bottom: 1px solid rgba(217, 151, 63, 0.2);
}

.expert-avatar {
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-accent);
    color: #fff;
    border-radius: var(--radius-xl);
}

.expert-badge {
    display: inline-block;
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-accent);
    margin-bottom: var(--space-xs);
}

.expert-title {
    font-size: var(--text-xl);
    font-family: var(--font-body);
    font-weight: 700;
    margin: 0;
}

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

.tip-item {
    display: flex;
    align-items: flex-start;
    gap: var(--space-md);
}

.tip-icon {
    font-size: var(--text-xl);
    line-height: 1.4;
}

.tip-item p {
    margin: 0;
    line-height: 1.6;
}

/* Premium Tabs */
.product-details-section {
    margin-bottom: var(--space-3xl);
}

.tabs-premium {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-2xl);
    overflow: hidden;
}

.tabs-nav-premium {
    display: flex;
    overflow-x: auto;
    background: var(--color-bg-alt);
    border-bottom: 1px solid var(--color-border);
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.tabs-nav-premium::-webkit-scrollbar {
    display: none;
}

.tab-btn-premium {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-lg) var(--space-xl);
    font-weight: 600;
    color: var(--color-text-muted);
    border-bottom: 3px solid transparent;
    white-space: nowrap;
    transition: all var(--transition-fast);
    margin-bottom: -1px;
}

.tab-btn-premium:hover {
    color: var(--color-text);
    background: rgba(118, 133, 99, 0.05);
}

.tab-btn-premium.active {
    color: var(--color-primary);
    border-bottom-color: var(--color-primary);
    background: var(--color-bg-card);
}

.tabs-content-premium {
    padding: var(--space-xl);
}

.tab-panel-premium {
    display: none;
}

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

/* Prose Premium */
.prose-premium {
    font-size: var(--text-base);
    line-height: 1.8;
}

.prose-premium h3 {
    font-size: var(--text-xl);
    margin-top: var(--space-xl);
    margin-bottom: var(--space-md);
}

.prose-premium p {
    margin-bottom: var(--space-md);
}

/* Usage Guide */
.usage-guide {
    display: flex;
    flex-direction: column;
    gap: var(--space-xl);
}

.usage-method {
    display: flex;
    gap: var(--space-lg);
}

.method-icon {
    width: 64px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-bg-alt);
    border-radius: var(--radius-xl);
    color: var(--color-primary);
    flex-shrink: 0;
}

.method-content h4 {
    font-size: var(--text-lg);
    font-family: var(--font-body);
    margin-bottom: var(--space-sm);
}

.method-content p {
    color: var(--color-text-muted);
    line-height: 1.6;
    margin: 0;
}

.usage-warning {
    display: flex;
    align-items: flex-start;
    gap: var(--space-md);
    padding: var(--space-lg);
    background: rgba(245, 158, 11, 0.1);
    border: 1px solid rgba(245, 158, 11, 0.3);
    border-radius: var(--radius-xl);
    color: #92400e;
}

.usage-warning svg {
    flex-shrink: 0;
    margin-top: 2px;
}

.usage-warning p {
    margin: 0;
    font-size: var(--text-sm);
}

/* Ingredients Section */
.ingredients-section {
    display: flex;
    flex-direction: column;
    gap: var(--space-xl);
}

.inci-block h4 {
    font-size: var(--text-base);
    font-family: var(--font-body);
    margin-bottom: var(--space-sm);
}

.inci-text {
    font-family: var(--font-body);
    font-size: var(--text-sm);
    line-height: 1.8;
    color: var(--color-text-muted);
    padding: var(--space-lg);
    background: var(--color-bg-alt);
    border-radius: var(--radius-lg);
}

.purity-badges {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
}

@media (min-width: 768px) {
    .purity-badges {
        grid-template-columns: repeat(4, 1fr);
    }
}

.purity-item {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-md);
    background: var(--color-bg-alt);
    border-radius: var(--radius-lg);
}

.purity-item svg {
    color: var(--color-success);
    flex-shrink: 0;
}

.purity-item span {
    font-size: var(--text-sm);
    font-weight: 600;
}

.cteo-info {
    padding: var(--space-lg);
    background: linear-gradient(135deg, rgba(118, 133, 99, 0.1) 0%, rgba(118, 133, 99, 0.05) 100%);
    border-radius: var(--radius-xl);
}

.cteo-info h4 {
    font-family: var(--font-body);
    margin-bottom: var(--space-sm);
}

.cteo-info p {
    color: var(--color-text-muted);
    font-size: var(--text-sm);
    line-height: 1.6;
    margin: 0;
}

/* Shipping Info */
.shipping-info {
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
}

.shipping-option {
    display: flex;
    align-items: flex-start;
    gap: var(--space-lg);
    padding: var(--space-lg);
    background: var(--color-bg-alt);
    border-radius: var(--radius-xl);
}

.shipping-icon {
    font-size: 2rem;
}

.shipping-details h4 {
    font-family: var(--font-body);
    margin-bottom: var(--space-xs);
}

.shipping-details p {
    margin: 0;
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.shipping-time {
    font-weight: 600;
    color: var(--color-primary) !important;
}

.guarantee-box {
    display: flex;
    align-items: flex-start;
    gap: var(--space-lg);
    padding: var(--space-xl);
    background: linear-gradient(135deg, rgba(118, 133, 99, 0.15) 0%, rgba(118, 133, 99, 0.05) 100%);
    border: 1px solid rgba(118, 133, 99, 0.2);
    border-radius: var(--radius-xl);
}

.guarantee-box svg {
    color: var(--color-primary);
    flex-shrink: 0;
}

.guarantee-box h4 {
    font-family: var(--font-body);
    margin-bottom: var(--space-sm);
}

.guarantee-box p {
    margin: 0;
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    line-height: 1.6;
}

/* Why Us Section */
.why-us-section {
    padding: var(--space-2xl);
    background: var(--color-bg-alt);
    border-radius: var(--radius-2xl);
    margin-bottom: var(--space-3xl);
}

.why-us-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-xl);
}

@media (min-width: 768px) {
    .why-us-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.why-us-item {
    text-align: center;
}

.why-icon {
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-bg-card);
    border-radius: var(--radius-xl);
    color: var(--color-primary);
    margin: 0 auto var(--space-md);
    box-shadow: var(--shadow-sm);
}

.why-us-item h4 {
    font-size: var(--text-base);
    font-family: var(--font-body);
    margin-bottom: var(--space-sm);
}

.why-us-item p {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    line-height: 1.5;
    margin: 0;
}

/* Related Section */
.related-section {
    margin-bottom: var(--space-3xl);
}

.section-header-premium {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-xl);
}

.section-header-premium h2 {
    font-size: var(--text-2xl);
    margin: 0;
}

.see-all-link {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    color: var(--color-primary);
    font-weight: 600;
    font-size: var(--text-sm);
}

.see-all-link:hover {
    text-decoration: underline;
}

/* Final CTA Section */
.final-cta-section {
    padding: var(--space-3xl) 0;
}

.final-cta-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: var(--space-2xl);
    background: linear-gradient(135deg, rgba(118, 133, 99, 0.1) 0%, rgba(217, 151, 63, 0.1) 100%);
    border: 1px solid rgba(118, 133, 99, 0.2);
    border-radius: var(--radius-2xl);
}

.cta-content {
    max-width: 600px;
    margin-bottom: var(--space-xl);
}

.cta-content h2 {
    font-size: var(--text-2xl);
    margin-bottom: var(--space-md);
}

.cta-content p {
    color: var(--color-text-muted);
    margin: 0;
}

@media (min-width: 768px) {
    .final-cta-card {
        flex-direction: row;
        text-align: left;
        gap: var(--space-2xl);
    }

    .cta-content {
        margin-bottom: 0;
    }
}

/* ============================================
   COOKIE CONSENT - World-Class GDPR Implementation
   ============================================ */

/* Footer Cookie Settings Link */
.cookie-settings-link {
    background: none;
    border: none;
    padding: 0;
    font: inherit;
    color: var(--color-text-muted);
    cursor: pointer;
    text-decoration: none;
    transition: color 0.2s ease;
}

.cookie-settings-link:hover {
    color: var(--color-primary);
    text-decoration: underline;
}

/* Cookie Consent Banner - Prominent & Clear */
.cookie-consent-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 99998;
    transform: translateY(100%);
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    padding: var(--space-md);
}

.cookie-consent-banner.visible {
    transform: translateY(0);
}

.cookie-consent-content {
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
    border-radius: var(--radius-xl);
    box-shadow: 0 -8px 40px rgba(0, 0, 0, 0.25), 0 0 0 1px rgba(255, 255, 255, 0.1);
    padding: var(--space-xl);
    max-width: 1000px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
    color: white;
}

@media (min-width: 900px) {
    .cookie-consent-content {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        padding: var(--space-lg) var(--space-xl);
    }
}

.cookie-consent-text {
    flex: 1;
    display: flex;
    gap: var(--space-md);
    align-items: flex-start;
}

.cookie-consent-text::before {
    content: '';
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    background: linear-gradient(135deg, var(--color-primary) 0%, #4a9c2d 100%);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8 0-.29.02-.58.05-.86.35.12.72.18 1.11.18 1.76 0 3.28-1.02 4.01-2.5.22.07.46.11.7.11 1.24 0 2.31-.75 2.78-1.82.36-.06.72-.1 1.09-.1.55 0 1.08.08 1.58.22.13.36.35.69.62.97.84.87 1.06 2.16.54 3.24-.08.16-.12.33-.12.5 0 .55.45 1 1 1 .17 0 .33-.04.48-.11.58.7.94 1.59.94 2.56 0 1.11-.45 2.11-1.18 2.83-.4-.25-.88-.39-1.39-.39-1.45 0-2.62 1.17-2.62 2.62 0 .14.01.28.03.41C14.04 19.38 13.06 20 12 20zm3.5-8.5c-.83 0-1.5-.67-1.5-1.5s.67-1.5 1.5-1.5 1.5.67 1.5 1.5-.67 1.5-1.5 1.5z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 28px;
}

.cookie-consent-title {
    font-size: var(--text-lg);
    font-weight: 700;
    color: white;
    margin-bottom: var(--space-xs);
    letter-spacing: -0.01em;
}

.cookie-consent-description {
    color: rgba(255, 255, 255, 0.75);
    font-size: var(--text-sm);
    line-height: 1.6;
    margin: 0;
}

.cookie-consent-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    flex-shrink: 0;
}

/* Cookie Buttons - Clear Visual Hierarchy */
.cookie-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-xs);
    padding: 14px 28px;
    border-radius: 12px;
    font-size: var(--text-sm);
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    border: none;
    white-space: nowrap;
    letter-spacing: 0.01em;
}

.cookie-btn-primary {
    background: linear-gradient(135deg, var(--color-primary) 0%, #4a9c2d 100%);
    color: white;
    box-shadow: 0 4px 14px rgba(45, 80, 22, 0.4);
}

.cookie-btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(45, 80, 22, 0.5);
}

.cookie-btn-outline {
    background: rgba(255, 255, 255, 0.1);
    color: white;
    border: 1px solid rgba(255, 255, 255, 0.3);
    backdrop-filter: blur(4px);
}

.cookie-btn-outline:hover {
    background: rgba(255, 255, 255, 0.2);
    border-color: rgba(255, 255, 255, 0.5);
}

.cookie-btn-secondary {
    background: transparent;
    color: rgba(255, 255, 255, 0.8);
    padding: 14px 20px;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.cookie-btn-secondary:hover {
    color: white;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    text-decoration: none;
}

/* Cookie Settings Modal - Premium Design */
.cookie-settings-modal {
    position: fixed;
    inset: 0;
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-md);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.cookie-settings-modal.visible {
    opacity: 1;
    visibility: visible;
}

.cookie-settings-modal .cookie-settings-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(12px);
}

.cookie-settings-content {
    position: relative;
    background: var(--color-bg);
    border-radius: 20px;
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.3), 0 0 0 1px rgba(0, 0, 0, 0.05);
    max-width: 520px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    transform: scale(0.9) translateY(30px);
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.cookie-settings-modal.visible .cookie-settings-content {
    transform: scale(1) translateY(0);
}

.cookie-settings-header {
    position: sticky;
    top: 0;
    background: var(--color-bg);
    padding: var(--space-xl) var(--space-xl) var(--space-md);
    display: flex;
    align-items: center;
    justify-content: space-between;
    z-index: 1;
    border-bottom: 1px solid var(--color-border);
}

.cookie-settings-title {
    font-size: 1.375rem;
    font-weight: 700;
    margin: 0;
    color: var(--color-text);
    letter-spacing: -0.02em;
}

.cookie-settings-close {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: var(--color-bg-alt);
    border-radius: 12px;
    cursor: pointer;
    color: var(--color-text-muted);
    transition: all 0.2s ease;
}

.cookie-settings-close:hover {
    background: var(--color-border);
    color: var(--color-text);
    transform: rotate(90deg);
}

.cookie-settings-body {
    padding: var(--space-lg) var(--space-xl);
}

.cookie-settings-intro {
    color: var(--color-text-muted);
    font-size: var(--text-sm);
    line-height: 1.7;
    margin-bottom: var(--space-lg);
    padding-bottom: var(--space-lg);
    border-bottom: 1px solid var(--color-border);
}

.cookie-category {
    padding: var(--space-lg);
    background: var(--color-bg-alt);
    border-radius: 16px;
    margin-bottom: var(--space-md);
    border: 2px solid transparent;
    transition: all 0.2s ease;
}

.cookie-category:last-child {
    margin-bottom: 0;
}

.cookie-category:hover {
    border-color: var(--color-primary);
    box-shadow: 0 4px 12px rgba(45, 80, 22, 0.1);
}

.cookie-category-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-lg);
}

.cookie-category-info {
    flex: 1;
}

.cookie-category-title {
    font-weight: 600;
    font-size: var(--text-base);
    color: var(--color-text);
    margin: 0 0 6px 0;
}

.cookie-category-desc {
    color: var(--color-text-muted);
    font-size: 13px;
    line-height: 1.5;
    margin: 0;
}

/* Toggle Switch - Premium Style */
.cookie-toggle {
    position: relative;
    flex-shrink: 0;
}

.cookie-toggle input {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}

.cookie-toggle-label {
    display: block;
    width: 56px;
    height: 30px;
    cursor: pointer;
}

.cookie-toggle-switch {
    display: block;
    width: 100%;
    height: 100%;
    background: #d1d5db;
    border-radius: 15px;
    position: relative;
    transition: all 0.3s ease;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.1);
}

.cookie-toggle-switch::after {
    content: '';
    position: absolute;
    top: 3px;
    left: 3px;
    width: 24px;
    height: 24px;
    background: white;
    border-radius: 50%;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.cookie-toggle input:checked + .cookie-toggle-label .cookie-toggle-switch {
    background: linear-gradient(135deg, var(--color-primary) 0%, #4a9c2d 100%);
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.1), 0 2px 8px rgba(45, 80, 22, 0.3);
}

.cookie-toggle input:checked + .cookie-toggle-label .cookie-toggle-switch::after {
    transform: translateX(26px);
}

.cookie-toggle input:disabled + .cookie-toggle-label {
    cursor: not-allowed;
}

.cookie-toggle input:disabled + .cookie-toggle-label .cookie-toggle-switch {
    background: linear-gradient(135deg, var(--color-primary) 0%, #4a9c2d 100%);
    opacity: 0.6;
}

.cookie-toggle input:disabled + .cookie-toggle-label .cookie-toggle-switch::after {
    transform: translateX(26px);
}

.cookie-toggle-disabled {
    opacity: 0.6;
}

/* Focus states for accessibility */
.cookie-toggle input:focus-visible + .cookie-toggle-label .cookie-toggle-switch {
    outline: 3px solid var(--color-primary);
    outline-offset: 3px;
}

.cookie-btn:focus-visible {
    outline: 3px solid var(--color-primary);
    outline-offset: 3px;
}

.cookie-settings-footer {
    position: sticky;
    bottom: 0;
    background: var(--color-bg);
    padding: var(--space-lg) var(--space-xl);
    border-top: 1px solid var(--color-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
}

.cookie-privacy-link {
    color: var(--color-text-muted);
    font-size: var(--text-sm);
    text-decoration: underline;
    text-underline-offset: 3px;
    transition: color 0.2s ease;
}

.cookie-privacy-link:hover {
    color: var(--color-primary);
}

.cookie-settings-actions {
    display: flex;
    gap: var(--space-sm);
}

/* Modal buttons - standard style for settings modal */
.cookie-settings-modal .cookie-btn {
    background: var(--color-bg-alt);
    color: var(--color-text);
    border: 1px solid var(--color-border);
}

.cookie-settings-modal .cookie-btn:hover {
    background: var(--color-border);
}

.cookie-settings-modal .cookie-btn-primary {
    background: linear-gradient(135deg, var(--color-primary) 0%, #4a9c2d 100%);
    color: white;
    border: none;
    box-shadow: 0 4px 12px rgba(45, 80, 22, 0.3);
}

.cookie-settings-modal .cookie-btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(45, 80, 22, 0.4);
}

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

/* Cookie Consent - Mobile Responsive */
@media (max-width: 640px) {
    .cookie-consent-banner {
        padding: var(--space-sm);
    }

    .cookie-consent-content {
        padding: var(--space-lg);
        border-radius: var(--radius-lg);
    }

    .cookie-consent-text::before {
        width: 40px;
        height: 40px;
        background-size: 22px;
    }

    .cookie-consent-actions {
        flex-direction: column;
        width: 100%;
    }

    .cookie-btn {
        width: 100%;
        justify-content: center;
        padding: 16px 24px;
    }

    .cookie-settings-modal {
        padding: var(--space-sm);
    }

    .cookie-settings-content {
        max-height: 90vh;
        border-radius: 16px;
    }

    .cookie-settings-header {
        padding: var(--space-lg) var(--space-lg) var(--space-md);
    }

    .cookie-settings-body {
        padding: var(--space-md) var(--space-lg);
    }

    .cookie-settings-footer {
        padding: var(--space-md) var(--space-lg);
        flex-direction: column;
        gap: var(--space-md);
    }

    .cookie-settings-actions {
        width: 100%;
        flex-direction: column;
    }

    .cookie-settings-actions .cookie-btn {
        width: 100%;
    }

    .cookie-category {
        padding: var(--space-md);
    }

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

/* Product Gallery - Mobile */
@media (max-width: 640px) {
    .gallery-main {
        aspect-ratio: 4/3;
        width: 100%;
    }
    .gallery-thumbnails {
        padding: var(--space-sm) 0;
    }
    .thumb-item {
        width: 64px;
        height: 64px;
    }
}

/* Product Detail - Price & CTA Stack Mobile */
@media (max-width: 640px) {
    .price-amount {
        font-size: 28px;
        font-weight: 700;
    }
    .buy-section,
    .product-actions,
    .cta-buttons {
        display: flex;
        flex-direction: column;
        gap: 10px;
    }
    .buy-section .btn,
    .product-actions .btn,
    .cta-buttons .btn,
    .btn-buy-premium,
    .btn-primary,
    .btn-secondary {
        width: 100%;
    }
    .btn-primary {
        background: var(--color-primary-dark, #4f6b4c);
        color: #fff;
    }
    .btn-secondary {
        background: transparent;
        border: 1px solid var(--color-primary, #768563);
        color: var(--color-primary, #768563);
    }
}

/* Light mode banner adjustments */
[data-theme="light"] .cookie-consent-content {
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
}

/* Dark mode adjustments */
[data-theme="dark"] .cookie-consent-content {
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
    box-shadow: 0 -8px 40px rgba(0, 0, 0, 0.4), 0 0 0 1px rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .cookie-settings-content {
    background: var(--color-bg);
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(255, 255, 255, 0.05);
}

[data-theme="dark"] .cookie-category {
    background: rgba(255, 255, 255, 0.03);
    border-color: rgba(255, 255, 255, 0.08);
}

[data-theme="dark"] .cookie-category:hover {
    border-color: var(--color-primary);
    background: rgba(255, 255, 255, 0.05);
}

[data-theme="dark"] .cookie-toggle-switch {
    background: rgba(255, 255, 255, 0.15);
}

[data-theme="dark"] .cookie-settings-modal .cookie-btn {
    background: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .cookie-settings-modal .cookie-btn:hover {
    background: rgba(255, 255, 255, 0.1);
}

/* =====================================================
   LANGUAGE SWITCHER
   ===================================================== */

/* Language Switcher - Clean text design: EN | PL | SK */
.lang-switcher-text {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.dh-lang-switcher {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-right: var(--space-md);
}

.lang-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 36px;
    padding: 0 var(--space-sm);
    font-size: var(--text-sm);
    font-weight: 500;
    text-decoration: none;
    color: #4f6b4c;
    background: #f6f9f4;
    border-radius: var(--radius-sm);
    transition: var(--transition-fast);
    cursor: pointer;
}

.lang-link:hover {
    background: #e8f0e6;
    color: #3d5a3a;
}

.lang-link.active {
    font-weight: 600;
    color: #fff;
    background: #4f6b4c;
}

.lang-pipe {
    display: none;
}

/* Mobile Language Switcher (Sidebar) */
.sidebar-lang {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: var(--space-md);
    border-bottom: 1px solid var(--color-border-light);
    background: var(--color-bg-alt);
}

.sidebar-lang .lang-link {
    font-size: var(--text-base);
    padding: 0.25rem 0;
}

/* Dark Mode Adjustments */
[data-theme="dark"] .lang-link {
    color: #a8c4a5;
    background: rgba(79, 107, 76, 0.15);
}

[data-theme="dark"] .lang-link:hover {
    background: rgba(79, 107, 76, 0.25);
}

[data-theme="dark"] .lang-link.active {
    color: #fff;
    background: #4f6b4c;
}

[data-theme="dark"] .sidebar-lang {
    background: var(--color-bg-alt);
    border-color: rgba(255, 255, 255, 0.1);
}

/* =====================================================
   SAFETY BOX - EU Compliance
   ===================================================== */

.safety-box {
    margin-top: var(--space-lg);
    padding: var(--space-lg);
    background: #FFFAF0;
    border: 1px solid rgba(200, 160, 80, 0.15);
    border-radius: var(--radius-lg);
}

.safety-header {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    margin-bottom: var(--space-sm);
    color: #946800;
    font-weight: 600;
    font-size: var(--text-sm);
}

.safety-header svg {
    flex-shrink: 0;
    color: #946800;
}

.safety-text {
    font-size: var(--text-sm);
    color: #7A6840;
    line-height: var(--leading-relaxed);
    margin: 0;
}

/* Affiliate Disclosure */
.affiliate-disclosure {
    margin-top: var(--space-md);
    padding: var(--space-sm) var(--space-md);
    background: var(--color-bg-alt);
    border-radius: var(--radius-md);
    text-align: center;
}

.affiliate-disclosure small {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    line-height: var(--leading-relaxed);
}

/* Dark Mode Safety Box */
[data-theme="dark"] .safety-box {
    background: #2C2416;
    border-color: rgba(200, 160, 80, 0.2);
}

[data-theme="dark"] .safety-header {
    color: #D4A656;
}

[data-theme="dark"] .safety-text {
    color: #C4A870;
}

[data-theme="dark"] .affiliate-disclosure {
    background: rgba(255, 255, 255, 0.05);
}

[data-theme="dark"] .affiliate-disclosure small {
    color: var(--color-text-muted);
}

/* Dark Mode Mobile Components - Apple Style */
[data-theme="dark"] .product-card,
[data-theme="dark"] .blog-card,
[data-theme="dark"] .benefit-card {
    background: #1C1C1E;
    border-color: rgba(255, 255, 255, 0.06);
}

[data-theme="dark"] .sticky-cta,
[data-theme="dark"] .sticky-cta-bar {
    background: rgba(30, 30, 30, 0.85);
}

[data-theme="dark"] .mobile-nav,
[data-theme="dark"] .nav-drawer {
    background: rgba(30, 30, 30, 0.72);
}

[data-theme="dark"] .faq-item {
    border-color: rgba(255, 255, 255, 0.06);
}

[data-theme="dark"] input,
[data-theme="dark"] textarea,
[data-theme="dark"] select {
    background: #2C2C2E;
    border-color: rgba(255, 255, 255, 0.1);
}

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

.footer-trust {
    margin-top: var(--space-2xl);
    padding: var(--space-xl) 0;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.trust-badges {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-lg) var(--space-2xl);
}

.trust-badge {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    color: rgba(255, 255, 255, 0.7);
    font-size: var(--text-sm);
    font-weight: 500;
    transition: color 0.2s ease;
}

.trust-badge:hover {
    color: rgba(255, 255, 255, 1);
}

.trust-badge svg {
    color: var(--color-primary-light);
    opacity: 0.8;
}

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

/* =====================================================
   FOOTER DISCLAIMERS - Professional Cards
   ===================================================== */

.footer-disclaimers {
    margin-top: var(--space-xl);
    padding: 0;
}

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

@media (min-width: 768px) {
    .disclaimers-grid {
        grid-template-columns: 1fr 1fr;
    }
}

.disclaimer-card {
    display: flex;
    gap: var(--space-md);
    padding: var(--space-lg);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03));
    border-radius: var(--radius-lg);
    border: 1px solid rgba(255, 255, 255, 0.08);
    transition: all 0.2s ease;
}

.disclaimer-card:hover {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.05));
    border-color: rgba(255, 255, 255, 0.12);
}

.disclaimer-icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(138, 157, 122, 0.2);
    border-radius: var(--radius-md);
    color: var(--color-primary-light);
}

.disclaimer-content {
    flex: 1;
}

.disclaimer-content strong {
    display: block;
    color: rgba(255, 255, 255, 0.95);
    font-size: var(--text-sm);
    font-weight: 600;
    margin-bottom: var(--space-xs);
}

.disclaimer-content p {
    font-size: var(--text-xs);
    color: rgba(255, 255, 255, 0.65);
    line-height: var(--leading-relaxed);
    margin: 0;
}

/* =====================================================
   FOOTER BOTTOM - Premium Design
   ===================================================== */

.footer-bottom {
    display: grid;
    gap: var(--space-lg);
    padding-top: var(--space-xl);
    margin-top: var(--space-xl);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    font-size: var(--text-sm);
}

@media (min-width: 768px) {
    .footer-bottom {
        grid-template-columns: 1fr auto 1fr;
        align-items: center;
    }
}

.footer-bottom-left {
    text-align: center;
}

@media (min-width: 768px) {
    .footer-bottom-left {
        text-align: left;
    }
}

.footer-bottom-left .copyright {
    color: rgba(255, 255, 255, 0.8);
    margin: 0;
    font-weight: 500;
}

.footer-bottom-left .made-with {
    color: rgba(255, 255, 255, 0.5);
    font-size: var(--text-xs);
    margin: var(--space-xs) 0 0;
}

.footer-legal {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-sm) var(--space-lg);
}

.footer-legal a,
.footer-legal button {
    color: rgba(255, 255, 255, 0.6);
    font-size: var(--text-xs);
    transition: color 0.2s ease;
    text-decoration: none;
}

.footer-legal a:hover,
.footer-legal button:hover {
    color: var(--color-primary-light);
}

.cookie-settings-link {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    font-family: inherit;
}

.footer-bottom-right {
    display: flex;
    justify-content: center;
}

@media (min-width: 768px) {
    .footer-bottom-right {
        justify-content: flex-end;
    }
}

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

.social-mini a {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255, 255, 255, 0.5);
    background: rgba(255, 255, 255, 0.08);
    border-radius: var(--radius-md);
    transition: all 0.2s ease;
}

.social-mini a:hover {
    color: #fff;
    background: var(--color-primary);
    transform: translateY(-2px);
}

/* =====================================================
   MOBILE STICKY CTA
   ===================================================== */

.mobile-sticky-cta {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 100;
    display: flex;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
    padding-bottom: calc(var(--space-sm) + env(safe-area-inset-bottom));
    background: rgba(255, 255, 255, 0.85);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    backdrop-filter: blur(20px) saturate(180%);
    border-top: 1px solid rgba(0, 0, 0, 0.06);
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.08);
    animation: slideUp 0.3s ease;
}

@keyframes slideUp {
    from { transform: translateY(100%); }
    to { transform: translateY(0); }
}

.mobile-cta-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-xs);
    min-height: var(--touch-min);
    padding: var(--space-sm) var(--space-md);
    font-size: var(--text-sm);
    font-weight: 600;
    border-radius: var(--radius-md);
    text-decoration: none;
    transition: all var(--duration-fast);
    background: transparent;
    color: var(--sage-700, #4f6b4c);
    border: 1.5px solid var(--sage-700, #4f6b4c);
}

.mobile-cta-btn:hover {
    background: var(--color-border-light);
}

.mobile-cta-primary {
    background: var(--sage-700, #4f6b4c);
    color: white;
    border-color: var(--sage-700, #4f6b4c);
}

.mobile-cta-primary:hover {
    background: var(--sage-800, #3d5a3a);
}

.mobile-cta-primary:active {
    transform: scale(0.97);
}

[data-theme="dark"] .mobile-sticky-cta {
    background: rgba(30, 30, 30, 0.85);
    border-color: rgba(255, 255, 255, 0.08);
}

[data-theme="dark"] .mobile-cta-btn {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.1);
    color: var(--color-text);
}

/* Hide on desktop */
@media (min-width: 768px) {
    .mobile-sticky-cta {
        display: none !important;
    }
}

/* Add padding to footer on mobile to account for sticky bar */
@media (max-width: 767px) {
    .footer {
        padding-bottom: calc(var(--space-2xl) + 60px);
    }
}

/* =====================================================
   NEWSLETTER POPUP
   ===================================================== */

.newsletter-popup {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-md);
}

.popup-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
    animation: fadeIn 0.3s ease;
}

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

.popup-content {
    position: relative;
    max-width: 420px;
    width: 100%;
    padding: var(--space-xl);
    background: var(--color-bg);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    text-align: center;
    animation: scaleIn 0.3s ease;
}

@keyframes scaleIn {
    from { transform: scale(0.9); opacity: 0; }
    to { transform: scale(1); opacity: 1; }
}

.popup-close {
    position: absolute;
    top: var(--space-sm);
    right: var(--space-sm);
    padding: var(--space-xs);
    background: none;
    border: none;
    color: var(--color-text-muted);
    cursor: pointer;
    border-radius: var(--radius-full);
    transition: all var(--transition-fast);
}

.popup-close:hover {
    background: var(--color-bg-alt);
    color: var(--color-text);
}

.popup-icon {
    margin-bottom: var(--space-md);
    color: var(--color-primary);
}

.popup-title {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: var(--space-sm);
}

.popup-text {
    color: var(--color-text-muted);
    font-size: var(--text-sm);
    line-height: var(--leading-relaxed);
    margin-bottom: var(--space-lg);
}

.popup-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
}

.popup-input {
    width: 100%;
    padding: var(--space-sm) var(--space-md);
    font-size: var(--text-base);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-bg);
    color: var(--color-text);
    transition: all var(--transition-fast);
}

.popup-input:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(118, 133, 99, 0.15);
}

.popup-btn {
    width: 100%;
    padding: var(--space-sm) var(--space-md);
}

.popup-privacy {
    font-size: var(--text-xs);
    color: var(--color-text-light);
}

[data-theme="dark"] .popup-content {
    background: var(--color-bg-dark);
}

[data-theme="dark"] .popup-input {
    background: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.1);
}

/* =====================================================
   PARTNER PAGE
   ===================================================== */

.partner-hero {
    padding: var(--space-2xl) 0;
    background: var(--color-bg-alt);
    text-align: center;
}

.partner-title {
    font-family: var(--font-display);
    font-size: var(--text-4xl);
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: var(--space-sm);
}

.partner-subtitle {
    font-size: var(--text-lg);
    color: var(--color-text-muted);
    max-width: 600px;
    margin: 0 auto;
}

.partner-benefits {
    padding: var(--space-3xl) 0;
}

.benefits-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--space-lg);
    margin-top: var(--space-xl);
}

.benefit-card {
    padding: var(--space-xl);
    background: var(--color-bg-card);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    text-align: center;
    transition: all var(--transition-normal);
}

.benefit-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.benefit-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto var(--space-md);
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-primary-light);
    color: var(--color-primary-dark);
    border-radius: var(--radius-full);
}

.benefit-card h3 {
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: var(--space-sm);
}

.benefit-card p {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    line-height: var(--leading-relaxed);
}

.partner-steps {
    padding: var(--space-3xl) 0;
    background: var(--color-bg-alt);
}

.steps-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--space-lg);
    margin-top: var(--space-xl);
}

.step-card {
    padding: var(--space-lg);
    background: var(--color-bg-card);
    border-radius: var(--radius-lg);
    text-align: center;
    position: relative;
}

.step-number {
    width: 48px;
    height: 48px;
    margin: 0 auto var(--space-md);
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-primary);
    color: white;
    font-size: var(--text-xl);
    font-weight: 700;
    border-radius: var(--radius-full);
}

.step-card p {
    font-size: var(--text-base);
    color: var(--color-text);
    font-weight: 500;
}

.partner-cta {
    padding: var(--space-3xl) 0;
}

.cta-box {
    max-width: 600px;
    margin: 0 auto;
    padding: var(--space-2xl);
    background: linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));
    border-radius: var(--radius-xl);
    text-align: center;
    color: white;
}

.cta-box h2 {
    font-family: var(--font-display);
    font-size: var(--text-3xl);
    font-weight: 600;
    margin-bottom: var(--space-sm);
}

.cta-box p {
    font-size: var(--text-lg);
    opacity: 0.9;
    margin-bottom: var(--space-lg);
}

.cta-box .btn {
    background: white;
    color: var(--color-primary-dark);
}

.cta-box .btn:hover {
    background: var(--color-bg-alt);
}

[data-theme="dark"] .benefit-card {
    background: var(--color-bg-dark);
    border-color: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .step-card {
    background: var(--color-bg-dark);
}

/* =====================================================
   SHARE COMPONENT
   ===================================================== */

.share-component {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-md) 0;
    border-top: 1px solid var(--color-border);
    margin-top: var(--space-lg);
}

.share-label {
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-text-muted);
}

.share-buttons {
    display: flex;
    gap: var(--space-xs);
}

.share-btn {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-bg-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    color: var(--color-text-muted);
    cursor: pointer;
    transition: all var(--transition-fast);
}

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

.share-btn.copied {
    background: var(--color-success);
    border-color: var(--color-success);
    color: white;
}

/* =====================================================
   PRODUCT FAQ
   ===================================================== */

.product-faq {
    margin-top: var(--space-4);
    padding: var(--space-4);
    background: var(--color-bg-alt);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border-light);
}

.product-faq-title {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--text-base);
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: var(--space-3);
}

.product-faq-title svg {
    color: var(--color-primary);
}

.faq-items {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.faq-item {
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.faq-question {
    padding: var(--space-3);
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-text);
    cursor: pointer;
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    transition: background var(--transition-fast);
}

.faq-question::-webkit-details-marker {
    display: none;
}

.faq-question::after {
    content: '+';
    font-size: var(--text-lg);
    color: var(--color-primary);
    font-weight: 300;
    transition: transform var(--transition-fast);
}

.faq-item[open] .faq-question::after {
    content: '−';
}

.faq-question:hover {
    background: var(--color-bg-alt);
}

.faq-answer {
    padding: 0 var(--space-3) var(--space-3);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    line-height: 1.6;
}

/* ═══════════════════════════════════════
   M22: Mobile Benefits & Daily Tip
   ═══════════════════════════════════════ */

/* Daily Tip Card - Premium Design */
.daily-tip-card {
    background: linear-gradient(135deg, #f8faf6 0%, #f0f4ed 100%);
    border: 1px solid rgba(118, 133, 99, 0.15);
    border-radius: var(--radius-xl);
    padding: var(--space-xl) var(--space-2xl);
    text-align: center;
    max-width: 540px;
    margin: 0 auto;
    box-shadow: 0 4px 20px rgba(118, 133, 99, 0.08);
    position: relative;
    overflow: hidden;
}

.daily-tip-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--color-primary-light), var(--color-primary), var(--color-primary-light));
}

.daily-tip-icon {
    font-size: 2.5rem;
    display: block;
    margin-bottom: var(--space-md);
    filter: drop-shadow(0 2px 4px rgba(0,0,0,0.1));
}

.daily-tip-title {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: 600;
    color: var(--color-primary-dark);
    margin-bottom: var(--space-md);
    letter-spacing: 0.02em;
}

.daily-tip-oil {
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--color-accent-dark);
    margin-bottom: var(--space-sm);
    letter-spacing: 0.01em;
}

.daily-tip-text {
    font-size: var(--text-base);
    color: #4a5a4b;
    line-height: 1.7;
    max-width: 400px;
    margin: 0 auto;
}

/* Daily Tip - Dark Mode */
[data-theme="dark"] .daily-tip-card {
    background: linear-gradient(135deg, #1e2822 0%, #242f28 100%);
    border-color: var(--color-border);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.3);
}

[data-theme="dark"] .daily-tip-card::before {
    background: linear-gradient(90deg, var(--color-primary), var(--color-accent), var(--color-primary));
}

[data-theme="dark"] .daily-tip-title {
    color: #f4f2ed;
}

[data-theme="dark"] .daily-tip-oil {
    color: var(--color-accent-light);
}

[data-theme="dark"] .daily-tip-text {
    color: #a9b5a6;
}

/* Mobile benefits single column */
@media (max-width: 639px) {
    .benefits-card,
    .spotlight-benefits {
        padding: var(--space-lg);
        border-radius: var(--radius-lg);
        box-shadow: var(--shadow-sm);
    }
}

/* M24: Blog Article Reading Experience */
.article-body {
    font-size: 16px;
    line-height: 1.8;
    color: var(--color-text);
}

.article-body .article-title,
.prose .article-title {
    font-size: 26px;
    font-weight: 700;
    letter-spacing: -0.02em;
    margin-bottom: var(--space-lg);
}

.article-body blockquote,
.prose blockquote {
    border-left: 3px solid var(--color-primary);
    padding-left: var(--space-lg);
    margin: var(--space-xl) 0;
    font-style: italic;
    color: var(--color-text-muted);
}

.article-body img,
.prose img {
    border-radius: var(--radius-md);
    max-width: 100%;
    height: auto;
}

/* ═══════════════════════════════════════
   COMMENTS SECTION — World-Class Design
   ═══════════════════════════════════════ */

.comments-section {
    margin-top: var(--space-3xl);
    margin-bottom: var(--space-4xl);
    padding-top: var(--space-2xl);
    padding-bottom: var(--space-2xl);
    border-top: 1px solid var(--color-border);
}

/* Comments List */
.comments-list {
    margin-bottom: var(--space-3xl);
    max-width: 720px;
    margin-left: auto;
    margin-right: auto;
}

.comments-title {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: var(--space-lg);
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.comment-count {
    font-size: var(--text-sm);
    font-weight: 400;
    color: var(--color-text-muted);
}

/* Individual Comment */
.comment-item {
    display: flex;
    gap: var(--space-md);
    padding: var(--space-lg) 0;
    border-bottom: 1px solid var(--color-border-light);
}

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

.comment-avatar {
    width: 48px;
    height: 48px;
    min-width: 48px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-primary-light) 0%, var(--color-primary) 100%);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: var(--text-lg);
}

.comment-content {
    flex: 1;
}

.comment-header {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    margin-bottom: var(--space-xs);
    flex-wrap: wrap;
}

.comment-author {
    font-weight: 600;
    color: var(--color-text);
}

.comment-date {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.comment-body {
    color: var(--color-text);
    line-height: 1.7;
}

/* Comment Form Wrapper */
.comment-form-wrapper {
    background: var(--color-bg-alt);
    border-radius: var(--radius-xl);
    padding: var(--space-xl) var(--space-lg);
    border: 1px solid var(--color-border-light);
    max-width: 720px;
    margin: 0 auto;
}

@media (min-width: 640px) {
    .comment-form-wrapper {
        padding: var(--space-2xl);
    }
}

@media (min-width: 1024px) {
    .comment-form-wrapper {
        padding: var(--space-2xl) var(--space-3xl);
    }
}

.form-title {
    font-family: var(--font-display);
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: var(--space-sm);
}

.moderation-notice {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-bottom: var(--space-lg);
    padding: var(--space-sm) var(--space-md);
    background: rgba(79, 107, 76, 0.08);
    border-radius: var(--radius-md);
}

.moderation-notice svg {
    flex-shrink: 0;
    color: var(--color-primary);
}

/* Form Row */
.comment-form .form-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
    margin-bottom: var(--space-md);
}

@media (min-width: 640px) {
    .comment-form .form-row {
        grid-template-columns: 1fr 1fr;
    }
}

.comment-form .form-group {
    margin-bottom: var(--space-md);
}

.comment-form label {
    display: block;
    font-weight: 500;
    margin-bottom: var(--space-xs);
    color: var(--color-text);
}

.comment-form .required {
    color: var(--color-accent);
}

.comment-form input,
.comment-form textarea {
    width: 100%;
    padding: var(--space-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-bg);
    color: var(--color-text);
    font-size: var(--text-base);
    transition: border-color 0.2s, box-shadow 0.2s;
}

.comment-form input::placeholder,
.comment-form textarea::placeholder {
    color: var(--color-text-muted);
    opacity: 0.7;
}

.comment-form input:focus,
.comment-form textarea:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(79, 107, 76, 0.1);
}

.comment-form textarea {
    min-height: 140px;
    resize: vertical;
    line-height: 1.6;
}

.form-hint {
    display: block;
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    margin-top: var(--space-xs);
}

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

/* Form Actions */
.form-actions {
    margin-top: var(--space-lg);
}

.comment-form .btn {
    min-height: 48px;
    padding: var(--space-md) var(--space-xl);
}

.btn-loading {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
}

.spinner {
    animation: spin 1s linear infinite;
}

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

/* Form Message */
.form-message {
    margin-top: var(--space-lg);
    padding: var(--space-md) var(--space-lg);
    border-radius: var(--radius-md);
    display: flex;
    align-items: flex-start;
    gap: var(--space-sm);
    font-size: var(--text-sm);
}

.form-message svg {
    flex-shrink: 0;
    margin-top: 2px;
}

.form-message.success {
    background: rgba(34, 197, 94, 0.1);
    color: #166534;
    border: 1px solid rgba(34, 197, 94, 0.2);
}

.form-message.error {
    background: rgba(239, 68, 68, 0.1);
    color: #991b1b;
    border: 1px solid rgba(239, 68, 68, 0.2);
}

/* Dark Mode Comments */
[data-theme="dark"] .comment-form-wrapper {
    background: var(--color-bg-card);
    border-color: var(--color-border);
}

[data-theme="dark"] .moderation-notice {
    background: rgba(168, 190, 138, 0.1);
}

[data-theme="dark"] .comment-form input,
[data-theme="dark"] .comment-form textarea {
    background: var(--color-bg);
    border-color: var(--color-border);
}

[data-theme="dark"] .form-message.success {
    background: rgba(34, 197, 94, 0.15);
    color: #86efac;
    border-color: rgba(34, 197, 94, 0.3);
}

[data-theme="dark"] .form-message.error {
    background: rgba(239, 68, 68, 0.15);
    color: #fca5a5;
    border-color: rgba(239, 68, 68, 0.3);
}

/* ═══════════════════════════════════════
   M25: Blog Comments — Mobile (Legacy)
   ═══════════════════════════════════════ */

.comment-form textarea,
.comments-section textarea {
    min-height: 120px;
    border-radius: var(--radius-md);
    font-size: 16px;
    width: 100%;
    padding: var(--space-md);
    border: 1px solid var(--color-border);
    background: var(--color-bg);
    color: var(--color-text);
    resize: vertical;
}

.comment-form textarea:focus,
.comments-section textarea:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(79, 107, 76, 0.1);
}

.comment-form button[type="submit"],
.comments-section .comment-submit {
    width: 100%;
    min-height: 44px;
    border-radius: var(--radius-md);
    font-weight: 600;
    font-size: 16px;
}

.comment-reply,
.reply-comment {
    margin-left: var(--space-md);
    padding-left: var(--space-md);
    border-left: 2px solid var(--color-border-light);
}

/* =====================================================
   ABOUT PAGE — Mobile
   ===================================================== */
.about-page,
.page-about {
    padding: var(--space-lg);
}

.about-page section,
.page-about section {
    margin-bottom: var(--space-2xl);
}

.about-page img,
.page-about img {
    border-radius: var(--radius-lg);
    width: 100%;
    height: auto;
}

.about-page blockquote,
.page-about blockquote,
.pull-quote {
    font-size: 20px;
    border-left: 3px solid #9aab88;
    padding-left: var(--space-lg);
    margin: var(--space-lg) 0;
    font-style: italic;
    color: var(--color-text-muted);
}

/* =====================================================
   ABOUT US SECTION — Premium Affiliate Disclosure
   ===================================================== */
.about-us {
    background: linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-alt) 100%);
    padding: var(--space-3xl) 0 var(--space-4xl);
}

.about-us .container {
    background: linear-gradient(135deg, #ffffff 0%, #f9faf8 50%, #f4f7f2 100%);
    border: 1px solid rgba(118, 133, 99, 0.12);
    border-radius: var(--radius-2xl);
    padding: var(--space-2xl) var(--space-xl);
    box-shadow:
        0 4px 6px rgba(0, 0, 0, 0.02),
        0 12px 24px rgba(118, 133, 99, 0.06),
        0 24px 48px rgba(118, 133, 99, 0.04);
    position: relative;
    overflow: hidden;
}

.about-us .container::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg,
        var(--color-primary-light) 0%,
        var(--color-primary) 30%,
        var(--color-accent) 70%,
        var(--color-primary-light) 100%);
}

.about-us .section-eyebrow {
    font-size: var(--text-xs);
    font-weight: 700;
    letter-spacing: 0.15em;
    color: var(--color-primary);
    margin-bottom: var(--space-md);
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
}

.about-us .section-eyebrow::before,
.about-us .section-eyebrow::after {
    content: '';
    width: 24px;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--color-primary));
}

.about-us .section-eyebrow::after {
    background: linear-gradient(90deg, var(--color-primary), transparent);
}

.about-us h2 {
    font-family: var(--font-display);
    font-size: var(--text-3xl);
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: var(--space-lg);
    letter-spacing: -0.01em;
}

.about-us p {
    font-size: var(--text-base);
    line-height: 1.8;
    color: #4a5a4b;
    margin-bottom: var(--space-md);
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
}

.about-us p:last-of-type {
    margin-bottom: var(--space-xl);
    padding-bottom: var(--space-lg);
    border-bottom: 1px solid rgba(118, 133, 99, 0.1);
}

.about-us .about-cta {
    margin-top: var(--space-lg);
    padding-top: var(--space-md);
}

/* About Us — Dark Mode */
[data-theme="dark"] .about-us {
    background: linear-gradient(180deg, var(--color-bg) 0%, #0d1210 100%);
}

[data-theme="dark"] .about-us .container {
    background: linear-gradient(135deg, #1a2420 0%, #1e2822 50%, #212c26 100%);
    border-color: var(--color-border);
    box-shadow:
        0 4px 6px rgba(0, 0, 0, 0.1),
        0 12px 24px rgba(0, 0, 0, 0.2),
        0 24px 48px rgba(0, 0, 0, 0.15);
}

[data-theme="dark"] .about-us .container::before {
    background: linear-gradient(90deg,
        var(--color-primary) 0%,
        var(--color-accent) 50%,
        var(--color-primary) 100%);
}

[data-theme="dark"] .about-us .section-eyebrow {
    color: var(--color-accent-light);
}

[data-theme="dark"] .about-us .section-eyebrow::before {
    background: linear-gradient(90deg, transparent, var(--color-accent-light));
}

[data-theme="dark"] .about-us .section-eyebrow::after {
    background: linear-gradient(90deg, var(--color-accent-light), transparent);
}

[data-theme="dark"] .about-us h2 {
    color: #f4f2ed;
}

[data-theme="dark"] .about-us p {
    color: #b8c4b5;
}

[data-theme="dark"] .about-us p:last-of-type {
    border-bottom-color: var(--color-border);
}

/* About Us — Desktop */
@media (min-width: 768px) {
    .about-us .container {
        padding: var(--space-3xl) var(--space-2xl);
    }

    .about-us h2 {
        font-size: var(--text-4xl);
    }

    .about-us p {
        font-size: var(--text-lg);
    }

    .about-us .section-eyebrow::before,
    .about-us .section-eyebrow::after {
        width: 40px;
    }
}

@media (min-width: 1024px) {
    .about-us .container {
        padding: var(--space-4xl) var(--space-3xl);
    }
}

/* =====================================================
   LEGAL PAGES — Privacy, Terms, Cookies
   ===================================================== */
.legal-page,
.page-privacy,
.page-terms,
.page-cookies {
    padding: var(--space-lg);
}

.legal-page h1,
.page-privacy h1,
.page-terms h1,
.page-cookies h1 {
    font-size: 22px;
    line-height: 1.3;
    margin-bottom: var(--space-lg);
}

.legal-page h2,
.page-privacy h2,
.page-terms h2,
.page-cookies h2 {
    font-size: 18px;
    line-height: 1.4;
    margin-top: var(--space-xl);
    margin-bottom: var(--space-md);
}

.legal-page p,
.page-privacy p,
.page-terms p,
.page-cookies p {
    font-size: 15px;
    line-height: 1.7;
    margin-bottom: var(--space-md);
}

.legal-page ul,
.legal-page ol,
.page-privacy ul,
.page-privacy ol,
.page-terms ul,
.page-terms ol,
.page-cookies ul,
.page-cookies ol {
    padding-left: var(--space-lg);
    margin-bottom: var(--space-md);
}

.legal-page li,
.page-privacy li,
.page-terms li,
.page-cookies li {
    font-size: 15px;
    line-height: 1.7;
    margin-bottom: var(--space-xs);
}

/* ═══════════════════════════════════════════════════════════════
   M29: 21-Day Challenge - Mobile Styles
   ═══════════════════════════════════════════════════════════════ */

.challenge-page {
    padding: var(--space-lg);
}

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

.challenge-hero h1 {
    font-size: 26px;
    font-weight: 700;
    letter-spacing: -0.02em;
    margin-bottom: var(--space-md);
}

.challenge-hero .lead {
    font-size: 16px;
    color: var(--color-text-muted);
    line-height: 1.6;
}

.challenge-benefits {
    padding: var(--space-xl) 0;
}

.benefits-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.benefits-list li {
    background: var(--color-bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    padding: var(--space-lg);
    font-size: 15px;
    line-height: 1.6;
    position: relative;
    padding-left: calc(var(--space-lg) + 36px);
}

.benefits-list li::before {
    content: counter(day);
    counter-increment: day;
    position: absolute;
    left: var(--space-lg);
    top: 50%;
    transform: translateY(-50%);
    width: 28px;
    height: 28px;
    background: var(--color-primary, #4f6b4c);
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: 600;
}

.benefits-list {
    counter-reset: day;
}

.challenge-benefits .btn-primary {
    min-height: var(--touch-min, 44px);
    width: 100%;
    max-width: 300px;
    border-radius: var(--radius-md);
    font-weight: 600;
}

@media (min-width: 768px) {
    .challenge-hero h1 {
        font-size: 36px;
    }

    .benefits-list li {
        padding: var(--space-xl);
        padding-left: calc(var(--space-xl) + 44px);
    }

    .benefits-list li::before {
        left: var(--space-xl);
        width: 36px;
        height: 36px;
        font-size: 15px;
    }
}

/* =====================================================
   ADMIN PANEL — Mobile
   ===================================================== */

.admin-login-card {
    max-width: 400px;
    margin: var(--space-2xl) auto;
    padding: var(--space-xl);
    background: var(--color-bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
}

.admin-login-card input {
    width: 100%;
    height: 50px;
    padding: 0 var(--space-md);
    font-size: 16px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-md);
}

.admin-login-card input:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(79, 107, 76, 0.1);
}

.admin-dashboard {
    padding: var(--space-lg);
}

@media (max-width: 768px) {
    .admin-dashboard {
        display: flex;
        flex-direction: column;
        gap: var(--space-lg);
    }

    .admin-dashboard .sidebar,
    .admin-dashboard .content {
        width: 100%;
    }
}

.admin-table-wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.admin-table {
    width: 100%;
    min-width: 600px;
    border-collapse: collapse;
}

.admin-table th,
.admin-table td {
    padding: var(--space-md);
    text-align: left;
    border-bottom: 1px solid var(--color-border);
}

/* ═══════════════════════════════════════════════════════════════
   M32: Touch States & Interactions
   ═══════════════════════════════════════════════════════════════ */

/* Focus-visible outline for accessibility */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[role="button"]:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

/* Active scale for buttons */
button:active,
.btn:active,
.cta-primary:active,
.cta-secondary:active,
[role="button"]:active {
    transform: scale(0.97);
}

/* Active scale for cards */
.product-card:active,
.blog-card:active,
.benefit-card:active {
    transform: scale(0.98);
}

/* Disable hover effects on touch devices */
@media (hover: none) {
    .product-card:hover,
    .blog-card:hover,
    .benefit-card:hover {
        transform: none;
        box-shadow: var(--shadow-sm);
    }

    .btn:hover,
    .cta-primary:hover,
    .cta-secondary:hover {
        filter: none;
    }
}

/* =====================================================
   SCROLL FADE-IN ANIMATIONS
   ===================================================== */

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(16px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.fade-in-up {
    opacity: 0;
    transform: translateY(16px);
}

.fade-in-up.visible {
    animation: fadeInUp 0.5s var(--ease-out) forwards;
}

@media (prefers-reduced-motion: reduce) {
    .fade-in-up {
        opacity: 1;
        transform: none;
    }
    .fade-in-up.visible {
        animation: none;
    }
}

/* =====================================================
   iOS SAFE AREAS
   ===================================================== */

@supports (padding-top: env(safe-area-inset-top)) {
    .mobile-header {
        padding-top: env(safe-area-inset-top);
        height: calc(48px + env(safe-area-inset-top));
    }

    .footer {
        padding-bottom: calc(var(--space-xl) + env(safe-area-inset-bottom));
    }
}

/* Backdrop-filter fallbacks for older browsers */
@supports not (backdrop-filter: blur(1px)) {
    .mobile-header,
    .desktop-header {
        background-color: rgba(255, 255, 255, 0.97);
    }
    [data-theme="dark"] .mobile-header,
    [data-theme="dark"] .desktop-header {
        background-color: rgba(30, 30, 30, 0.97);
    }
    .sidebar-overlay {
        background-color: rgba(0, 0, 0, 0.7);
    }
    .sidebar {
        background-color: var(--color-bg);
    }
    .mobile-sticky-cta {
        background: rgba(255, 255, 255, 0.97);
    }
    [data-theme="dark"] .mobile-sticky-cta {
        background: rgba(30, 30, 30, 0.97);
    }
}
