/* ===========================
   MindsetStack — Premium Dark Theme
   Complete Redesign
   =========================== */

/* --- Design Tokens --- */
:root {
    --bg: #06080c;
    --bg-raised: #0c1018;
    --bg-card: rgba(14, 18, 30, 0.65);
    --bg-card-solid: #101624;
    --bg-overlay: rgba(6, 8, 12, 0.8);
    --text: #eef0f6;
    --text-2: #7d869c;
    --text-3: #454d62;
    --accent: #c8ff00;
    --accent-hover: #d4ff33;
    --accent-dim: rgba(200,255,0,0.06);
    --accent-glow: rgba(200,255,0,0.12);
    --text-accent: #c8ff00;
    --border: rgba(255,255,255,0.06);
    --border-hover: rgba(255,255,255,0.12);
    --r-sm: 12px;
    --r-md: 16px;
    --r-lg: 24px;
    --r-xl: 32px;
    --r-full: 9999px;
    --shadow-glow: 0 0 50px rgba(200,255,0,0.08);
    --shadow-glow-strong: 0 0 80px rgba(200,255,0,0.15);
    --font: 'Inter', -apple-system, sans-serif;
    --ease: cubic-bezier(0.4,0,0.2,1);
    /* Aliases for JS compatibility */
    --bg-primary: var(--bg);
    --bg-secondary: var(--bg-raised);
    --text-primary: var(--text);
    --text-secondary: var(--text-2);
    --text-muted: var(--text-3);
    --border-color: var(--border);
    --accent-hover: var(--accent-hover);
    --shadow-md: 0 8px 32px rgba(0,0,0,0.35);
    --shadow-lg: 0 16px 64px rgba(0,0,0,0.45);
    --transition-fast: 0.15s ease;
    --transition-base: 0.3s cubic-bezier(0.4,0,0.2,1);
    --radius-sm: var(--r-sm);
    --radius-md: var(--r-md);
    --radius-lg: var(--r-lg);
    --radius-full: var(--r-full);
}

/* --- Reset --- */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body {
    font-family: var(--font);
    background: var(--bg);
    color: var(--text);
    line-height: 1.65; overflow-x:hidden;
    letter-spacing: -0.01em;
}
a { color:inherit; text-decoration:none; }
button { background:none; border:none; cursor:pointer; font-family:inherit; color:inherit; }
img { max-width:100%; height:auto; display:block; }
.container { max-width:1200px; margin:0 auto; padding:0 24px; }
::selection { background:var(--accent); color:#000; }
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:rgba(255,255,255,0.1); border-radius:3px; }

/* Theme bar removed - managed in admin panel */

/* ===========================
   Header
   =========================== */
.header {
    position:sticky; top:0; z-index:100;
    background: rgba(6,8,12,0.7);
    backdrop-filter: blur(30px) saturate(1.5);
    -webkit-backdrop-filter: blur(30px) saturate(1.5);
    border-bottom: 1px solid var(--border);
    height: 64px;
    transition: all 0.3s var(--ease);
}
.header.scrolled {
    background: rgba(6,8,12,0.95);
    box-shadow: 0 4px 40px rgba(0,0,0,0.5);
}
.header-inner {
    max-width:1200px; margin:0 auto; padding:0 24px;
    height:100%; display:flex; align-items:center; justify-content:space-between;
}
.logo { font-size:20px; font-weight:800; letter-spacing:-0.5px; }
.logo span { color:var(--accent); }
.nav { display:flex; gap:32px; }
.nav-link {
    font-size:13px; font-weight:500; color:var(--text-2);
    transition:color 0.2s; position:relative; letter-spacing:0.2px;
}
.nav-link:hover { color:var(--text); }
.nav-link::after {
    content:''; position:absolute; bottom:-4px; left:0;
    width:0; height:1.5px; background:var(--accent);
    transition:width 0.3s var(--ease);
}
.nav-link:hover::after { width:100%; }
.header-actions { display:flex; align-items:center; gap:12px; }
.cart-btn {
    position:relative; display:flex; align-items:center; justify-content:center;
    padding:8px; color:var(--text-2); transition:color 0.2s;
}
.cart-btn:hover { color:var(--accent); }
.cart-count {
    position:absolute; top:-2px; right:-4px;
    background:var(--accent); color:#000;
    font-size:9px; font-weight:800;
    width:16px; height:16px; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    transform:scale(0); transition:transform 0.2s;
}
.cart-count.show { transform:scale(1); }
.header-cta { display:block; }
.menu-toggle { display:none; flex-direction:column; gap:4px; padding:8px; }
.menu-toggle span { width:20px; height:2px; background:var(--text); border-radius:2px; transition:all 0.3s; }

/* ===========================
   Mobile Nav
   =========================== */
.mobile-nav-overlay {
    position:fixed; inset:0; background:rgba(0,0,0,0.7);
    z-index:98; opacity:0; visibility:hidden; transition:all 0.3s;
    backdrop-filter:blur(4px);
}
.mobile-nav-overlay.active { opacity:1; visibility:visible; }
.mobile-nav {
    position:fixed; top:0; left:0;
    width:300px; max-width:85vw; height:100vh;
    background:var(--bg-raised); z-index:99;
    transform:translateX(-100%); transition:transform 0.3s var(--ease);
    display:flex; flex-direction:column; border-right:1px solid var(--border);
}
.mobile-nav.active { transform:translateX(0); }
.mobile-nav-header {
    display:flex; align-items:center; justify-content:space-between;
    padding:16px 24px; border-bottom:1px solid var(--border);
}
.mobile-nav-title { font-size:14px; font-weight:700; text-transform:uppercase; letter-spacing:1px; }
.mobile-nav-links { display:flex; flex-direction:column; padding:8px 0; }
.mobile-nav-link {
    padding:14px 24px; font-size:15px; font-weight:500; color:var(--text-2);
    transition:all 0.2s; border-bottom:1px solid var(--border);
}
.mobile-nav-link:hover { color:var(--text); background:var(--accent-dim); padding-left:32px; }

/* ===========================
   Cart Drawer
   =========================== */
.cart-overlay {
    position:fixed; inset:0; background:rgba(0,0,0,0.7);
    z-index:95; opacity:0; visibility:hidden; transition:all 0.3s;
    backdrop-filter:blur(4px);
}
.cart-overlay.active { opacity:1; visibility:visible; }
.cart-drawer {
    position:fixed; top:0; right:0;
    width:400px; max-width:90vw; height:100vh;
    background:var(--bg-raised); z-index:96;
    transform:translateX(100%); transition:transform 0.3s var(--ease);
    display:flex; flex-direction:column; border-left:1px solid var(--border);
}
.cart-drawer.active { transform:translateX(0); }
.cart-drawer-header {
    display:flex; align-items:center; justify-content:space-between;
    padding:20px 24px; border-bottom:1px solid var(--border);
}
.cart-drawer-header h3 { font-size:16px; font-weight:700; }
.cart-drawer-body { flex:1; overflow-y:auto; padding:24px; }
.cart-empty { text-align:center; padding:48px 0; }
.cart-empty p { color:var(--text-2); margin:12px 0 20px; }
.cart-items { display:flex; flex-direction:column; gap:16px; }
.cart-item {
    display:flex; align-items:center; gap:14px;
    padding:14px; background:var(--bg-card); border-radius:var(--r-md);
    border:1px solid var(--border);
}
.cart-item-img { width:56px; height:56px; border-radius:var(--r-sm); overflow:hidden; flex-shrink:0; }
.cart-item-img img { width:100%; height:100%; object-fit:cover; }
.cart-item-info { flex:1; }
.cart-item-name { font-size:13px; font-weight:600; }
.cart-item-price { font-size:13px; color:var(--accent); font-weight:700; }
.cart-item-remove { color:var(--text-3); font-size:18px; padding:4px; transition:color 0.2s; }
.cart-item-remove:hover { color:var(--accent); }
.cart-drawer-footer { padding:20px 24px; border-top:1px solid var(--border); }
.cart-subtotal { display:flex; justify-content:space-between; margin-bottom:14px; font-size:16px; font-weight:700; }

/* ===========================
   Buttons
   =========================== */
.btn {
    display:inline-flex; align-items:center; justify-content:center; gap:8px;
    padding:12px 28px; border-radius:var(--r-sm);
    font-size:14px; font-weight:600; cursor:pointer;
    transition:all 0.3s var(--ease); border:none; position:relative; overflow:hidden;
}
.btn-primary {
    background:var(--accent); color:#000;
}
.btn-primary::after {
    content:''; position:absolute; inset:0; border-radius:inherit;
    background:linear-gradient(135deg, rgba(255,255,255,0.2), transparent 60%);
    pointer-events:none;
}
.btn-primary:hover {
    background:var(--accent-hover);
    box-shadow: 0 8px 30px var(--accent-glow), var(--shadow-glow-strong);
    transform:translateY(-2px);
}
.btn-primary:active { transform:translateY(0); }
.btn-sm { padding:8px 18px; font-size:12px; }
.btn-lg { padding:16px 40px; font-size:15px; font-weight:700; }
.btn-full { width:100%; }
.btn-add-to-cart { padding:16px; font-size:15px; font-weight:800; letter-spacing:0.3px; }
.btn-add-to-cart .btn-loader { display:flex; }
.spinner { width:20px; height:20px; animation:spin 1s linear infinite; }
@keyframes spin { to { transform:rotate(360deg); } }

/* ===========================
   Hero — Split Layout
   =========================== */
.hero {
    position:relative; min-height:92vh;
    display:flex; align-items:center;
    overflow:hidden; padding:60px 0;
}
.hero-bg { position:absolute; inset:0; pointer-events:none; }
.hero-grid-pattern {
    position:absolute; inset:0;
    background-image:
        linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
    background-size: 60px 60px;
    mask-image: radial-gradient(ellipse 60% 50% at 50% 50%, black, transparent);
    -webkit-mask-image: radial-gradient(ellipse 60% 50% at 50% 50%, black, transparent);
}
.hero-orb {
    position:absolute; border-radius:50%; filter:blur(120px);
}
.hero-orb-1 {
    width:600px; height:600px;
    background:rgba(200,255,0,0.05);
    top:-200px; right:10%;
    animation: orbPulse 8s ease-in-out infinite;
}
.hero-orb-2 {
    width:400px; height:400px;
    background:rgba(100,130,255,0.04);
    bottom:-200px; left:5%;
    animation: orbPulse 12s ease-in-out infinite reverse;
}
@keyframes orbPulse {
    0%,100% { opacity:0.5; transform:scale(1); }
    50% { opacity:0.8; transform:scale(1.15); }
}
.hero-particles { position:absolute; inset:0; }
.particle { position:absolute; background:var(--accent); border-radius:50%; opacity:0; animation:particleFloat 5s ease-in-out infinite; }
@keyframes particleFloat {
    0% { opacity:0; transform:translateY(0) scale(0.5); }
    30% { opacity:0.6; }
    100% { opacity:0; transform:translateY(-120px) scale(0); }
}

.hero-inner {
    position:relative; z-index:2;
    max-width:1200px; margin:0 auto; padding:0 24px;
    display:grid; grid-template-columns:1fr 1fr;
    gap:60px; align-items:center;
}
.hero-text { max-width:560px; }
.hero-badge {
    display:inline-flex; align-items:center; gap:6px;
    padding:8px 16px; border-radius:var(--r-full);
    background:var(--accent-dim); border:1px solid rgba(200,255,0,0.1);
    font-size:12px; font-weight:600; color:var(--accent);
    margin-bottom:28px;
}
.hero-badge .material-icons-outlined { font-size:14px; }
.hero-title {
    font-size:clamp(36px, 5vw, 64px);
    font-weight:900; line-height:1.05;
    letter-spacing:-2.5px; margin-bottom:20px;
}
.hero-title-accent {
    background:linear-gradient(135deg, var(--accent), var(--accent-hover));
    -webkit-background-clip:text; -webkit-text-fill-color:transparent;
    background-clip:text;
}
.hero-subtitle {
    font-size:17px; color:var(--text-2); line-height:1.7;
    margin-bottom:32px; max-width:440px;
}
.hero-cta-row { display:flex; align-items:center; gap:24px; margin-bottom:28px; flex-wrap:wrap; }
.hero-meta { display:flex; flex-direction:column; gap:2px; }
.hero-stars { color:#fbbf24; font-size:14px; letter-spacing:2px; }
.hero-meta span { font-size:12px; color:var(--text-2); }
.hero-trust-row {
    display:flex; gap:20px; flex-wrap:wrap;
}
.hero-trust-row span {
    display:flex; align-items:center; gap:4px;
    font-size:12px; color:var(--text-3);
}
.hero-trust-row .material-icons-outlined { font-size:14px; color:var(--text-2); }

.hero-visual { position:relative; display:flex; align-items:center; justify-content:center; }
.hero-img-wrapper {
    position:relative; border-radius:var(--r-xl);
    overflow:hidden; border:1px solid var(--border);
    box-shadow: 0 32px 80px rgba(0,0,0,0.5);
}
.hero-img { width:100%; border-radius:var(--r-xl); }
.hero-img-glow {
    position:absolute; inset:-40px;
    background: radial-gradient(circle at 50% 50%, var(--accent-glow), transparent 70%);
    pointer-events:none; z-index:-1;
}
.hero-floating-card {
    position:absolute; padding:14px 18px;
    background:var(--bg-card-solid); border:1px solid var(--border);
    border-radius:var(--r-md); display:flex; align-items:center; gap:10px;
    box-shadow: 0 16px 48px rgba(0,0,0,0.5);
    animation: floatCard 4s ease-in-out infinite;
}
.hero-floating-card .material-icons-outlined { font-size:24px; color:var(--accent); }
.hero-floating-card strong { font-size:16px; font-weight:800; }
.hero-floating-card small { font-size:11px; color:var(--text-2); }
.hero-floating-1 { bottom:20px; left:-20px; animation-delay:0s; }
.hero-floating-2 { top:20px; right:-20px; animation-delay:2s; }
@keyframes floatCard {
    0%,100% { transform:translateY(0); }
    50% { transform:translateY(-10px); }
}

/* ===========================
   Marquee
   =========================== */
.marquee-section {
    padding:20px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border);
    background:var(--bg-raised); overflow:hidden;
}
.marquee-track { overflow:hidden; }
.marquee-content {
    display:flex; gap:40px; white-space:nowrap;
    animation: marquee 30s linear infinite;
}
.marquee-content span {
    font-size:13px; font-weight:600; color:var(--text-2);
    text-transform:uppercase; letter-spacing:1.5px;
    flex-shrink:0;
}
@keyframes marquee {
    0% { transform:translateX(0); }
    100% { transform:translateX(-50%); }
}

/* ===========================
   Section Shared
   =========================== */
.section-header { text-align:center; margin-bottom:56px; }
.section-tag {
    display:inline-block; padding:6px 16px; border-radius:var(--r-full);
    background:var(--accent-dim); border:1px solid rgba(200,255,0,0.08);
    font-size:11px; font-weight:700; color:var(--accent);
    text-transform:uppercase; letter-spacing:1.5px;
    margin-bottom:16px;
}
.section-title {
    font-size:clamp(28px, 4vw, 48px);
    font-weight:800; letter-spacing:-2px; line-height:1.1;
    margin-bottom:14px;
}
.text-accent {
    background:linear-gradient(135deg, var(--accent), var(--accent-hover));
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.section-subtitle { font-size:16px; color:var(--text-2); max-width:520px; margin:0 auto; }

/* ===========================
   Bento Features
   =========================== */
.features-section {
    padding:120px 0;
    background:
        radial-gradient(ellipse 50% 40% at 50% 0%, rgba(200,255,0,0.02), transparent 70%),
        var(--bg);
}
.bento-grid {
    display:grid;
    grid-template-columns:repeat(2, 1fr);
    gap:20px;
}
.bento-card {
    padding:36px;
    background:var(--bg-card);
    border-radius:var(--r-lg);
    border:1px solid var(--border);
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
    transition:all 0.4s var(--ease);
    overflow:hidden; position:relative;
}
.bento-card::before {
    content:''; position:absolute; top:0; left:0; right:0; height:2px;
    background:linear-gradient(90deg, transparent, var(--accent), transparent);
    opacity:0; transition:opacity 0.3s;
}
.bento-card:hover {
    border-color:rgba(200,255,0,0.12);
    transform:translateY(-6px);
    box-shadow: 0 24px 64px rgba(0,0,0,0.3), 0 0 40px var(--accent-dim);
}
.bento-card:hover::before { opacity:1; }
.bento-large { grid-column:span 1; }
.bento-icon {
    width:52px; height:52px; border-radius:var(--r-sm);
    background:var(--accent-dim); border:1px solid rgba(200,255,0,0.1);
    display:flex; align-items:center; justify-content:center;
    margin-bottom:20px;
}
.bento-icon .material-icons-outlined { font-size:26px; color:var(--accent); }
.bento-card h3 { font-size:18px; font-weight:700; margin-bottom:8px; letter-spacing:-0.3px; }
.bento-card p { font-size:14px; color:var(--text-2); line-height:1.65; }
.bento-img {
    margin-top:24px; border-radius:var(--r-md);
    border:1px solid var(--border); width:100%;
}

/* ===========================
   Product Section
   =========================== */
.product-section {
    padding:120px 0;
    background:
        radial-gradient(circle at 30% 50%, rgba(200,255,0,0.02), transparent 50%),
        var(--bg-raised);
}
.product-layout {
    display:grid; grid-template-columns:1fr 1fr;
    gap:48px; align-items:start; margin-top:0;
}
.product-gallery { position:sticky; top:120px; }
.product-image-main {
    position:relative; border-radius:var(--r-lg);
    overflow:hidden; border:1px solid var(--border);
    background:#0a0c14; margin-bottom:12px;
}
.product-image-main img { width:100%; }
.zoom-btn {
    position:absolute; top:12px; right:12px;
    padding:8px; background:rgba(0,0,0,0.6);
    border-radius:var(--r-sm); color:#fff;
    display:flex; transition:all 0.2s;
}
.zoom-btn:hover { background:var(--accent); color:#000; }
.product-thumbnails { display:flex; gap:8px; }
.thumb {
    width:72px; height:72px; border-radius:var(--r-sm);
    overflow:hidden; border:2px solid transparent;
    cursor:pointer; transition:all 0.2s; opacity:0.5;
}
.thumb.active { border-color:var(--accent); opacity:1; }
.thumb:hover { opacity:0.8; }
.thumb img { width:100%; height:100%; object-fit:cover; }

.product-info { padding-top:8px; }
.product-rating { display:flex; align-items:center; gap:8px; margin-bottom:12px; }
.stars { color:#fbbf24; font-size:14px; letter-spacing:2px; }
.rating-text { font-size:13px; color:var(--text-2); }
.product-title { font-size:28px; font-weight:800; letter-spacing:-1px; margin-bottom:12px; }
.product-desc { font-size:14px; color:var(--text-2); line-height:1.7; margin-bottom:24px; }

.price-block { display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.price-current { font-size:32px; font-weight:900; color:var(--accent); letter-spacing:-1px; }
.price-original { font-size:16px; color:var(--text-3); text-decoration:line-through; }
.price-badge {
    padding:4px 12px; border-radius:var(--r-full);
    background:var(--accent); color:#000;
    font-size:11px; font-weight:800;
}

.sale-timer-bar {
    display:flex; align-items:center; gap:8px;
    padding:10px 16px; border-radius:var(--r-sm);
    background:rgba(255,100,100,0.06); border:1px solid rgba(255,100,100,0.1);
    font-size:13px; color:var(--text-2); margin-bottom:20px;
}
.sale-timer-bar .material-icons-outlined { font-size:16px; color:#f87171; }
.sale-timer-bar strong { color:#f87171; }

.variants { display:flex; flex-direction:column; gap:10px; margin-bottom:16px; }
.variant-option { display:block; cursor:pointer; }
.variant-option input { display:none; }
.variant-content {
    display:flex; align-items:center; justify-content:space-between;
    padding:14px 18px; border:2px solid var(--border);
    border-radius:var(--r-md); transition:all 0.2s;
}
.variant-option.active .variant-content,
.variant-option input:checked + .variant-content {
    border-color:var(--accent);
    background:var(--accent-dim);
}
.variant-info { display:flex; align-items:center; gap:10px; }
.variant-dot {
    width:16px; height:16px; border-radius:50%;
    border:2px solid var(--text-3); position:relative;
    flex-shrink:0; transition:all 0.2s;
}
.variant-option.active .variant-dot,
.variant-option input:checked + .variant-content .variant-dot {
    border-color:var(--accent);
}
.variant-option.active .variant-dot::after,
.variant-option input:checked + .variant-content .variant-dot::after {
    content:''; position:absolute; inset:3px;
    background:var(--accent); border-radius:50%;
}
.variant-info strong { font-size:14px; }
.variant-info small { font-size:11px; color:var(--text-3); display:block; margin-top:1px; }
.variant-price { font-size:14px; font-weight:700; color:var(--accent); white-space:nowrap; }
.variant-popular {
    display:inline-block; padding:2px 8px; border-radius:var(--r-full);
    background:var(--accent); color:#000;
    font-size:9px; font-weight:800; margin-left:6px; vertical-align:middle;
}

.product-guarantees {
    display:flex; justify-content:center; flex-wrap:wrap; gap:20px;
    padding-top:16px; margin-top:12px; border-top:1px solid var(--border);
}
.guarantee-item {
    font-size:12px; color:var(--text-3); display:flex; align-items:center; gap:4px;
}
.guarantee-item .material-icons-outlined { font-size:14px; }

/* ===========================
   Stats
   =========================== */
.stats-section {
    padding:100px 0;
    background:var(--bg);
    border-top:1px solid var(--border);
    border-bottom:1px solid var(--border);
}
.stats-row {
    display:flex; align-items:center; justify-content:center;
    gap:48px; flex-wrap:wrap;
}
.stat-item { text-align:center; }
.stat-number {
    font-size:clamp(48px, 6vw, 72px); font-weight:900;
    background:linear-gradient(135deg, var(--accent), var(--accent-hover));
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
    letter-spacing:-3px; line-height:1;
}
.stat-item p { font-size:14px; color:var(--text-2); margin-top:8px; }
.stat-item p strong { color:var(--text); }
.stat-divider { width:1px; height:60px; background:var(--border); }

/* ===========================
   Testimonials
   =========================== */
.testimonials-section {
    padding:120px 0;
    background:
        radial-gradient(circle at 70% 30%, rgba(200,255,0,0.02), transparent 50%),
        var(--bg-raised);
}
.testimonials-grid {
    display:grid; grid-template-columns:repeat(3, 1fr);
    gap:20px;
}
.testimonial-card {
    padding:28px; background:var(--bg-card);
    border-radius:var(--r-lg); border:1px solid var(--border);
    transition:all 0.4s var(--ease);
    backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
}
.testimonial-card:hover {
    border-color:rgba(200,255,0,0.1); transform:translateY(-4px);
    box-shadow:0 20px 50px rgba(0,0,0,0.3);
}
.testimonial-stars { color:#fbbf24; font-size:14px; margin-bottom:14px; letter-spacing:2px; }
.testimonial-card p { font-size:14px; color:var(--text-2); line-height:1.65; font-style:italic; margin-bottom:18px; }
.testimonial-author { display:flex; align-items:center; gap:10px; }
.author-avatar {
    width:34px; height:34px; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    color:#fff; font-weight:700; font-size:14px; flex-shrink:0;
}
.testimonial-author span { font-size:13px; font-weight:600; }

/* ===========================
   FAQ
   =========================== */
.faq-section {
    padding:120px 0;
    background:var(--bg);
}
.faq-list { max-width:700px; margin:0 auto; }
.faq-item {
    border-bottom:1px solid var(--border);
}
.faq-question {
    display:flex; align-items:center; justify-content:space-between;
    width:100%; padding:22px 0; text-align:left;
    font-size:15px; font-weight:600; color:var(--text);
    transition:color 0.2s; gap:12px;
}
.faq-question:hover { color:var(--accent); }
.faq-icon { font-size:20px; color:var(--text-3); transition:transform 0.3s; flex-shrink:0; }
.faq-item.active .faq-icon { transform:rotate(180deg); color:var(--accent); }
.faq-answer {
    max-height:0; overflow:hidden;
    transition:max-height 0.4s var(--ease), padding 0.3s;
}
.faq-item.active .faq-answer { max-height:300px; padding-bottom:20px; }
.faq-answer p { font-size:14px; color:var(--text-2); line-height:1.7; }

/* ===========================
   Final CTA
   =========================== */
.final-cta-section {
    padding:120px 0;
    background:var(--bg-raised);
}
.final-cta {
    position:relative; text-align:center;
    padding:80px 40px; border-radius:var(--r-xl);
    background:var(--bg-card); border:1px solid var(--border);
    overflow:hidden;
}
.final-cta-orb {
    position:absolute; width:500px; height:500px;
    border-radius:50%; filter:blur(120px);
    background:var(--accent-glow);
    top:50%; left:50%; transform:translate(-50%,-50%);
    pointer-events:none;
}
.final-cta h2 {
    font-size:clamp(28px, 4vw, 48px); font-weight:900;
    letter-spacing:-2px; margin-bottom:14px; line-height:1.1;
    position:relative;
}
.final-cta p { font-size:16px; color:var(--text-2); margin-bottom:28px; position:relative; }
.final-cta .btn { position:relative; }

/* ===========================
   Footer Waves & Body
   =========================== */
.footer { position:relative; overflow:hidden; padding:0; background:var(--bg); }
.footer-waves { position:relative; height:200px; overflow:hidden; background:var(--bg); }
.footer-waves .wave { position:absolute; bottom:0; left:0; width:200%; height:100%; will-change:transform; }
.footer-waves .wave-1 { animation:waveSlide 12s linear infinite; opacity:0.5; z-index:1; }
.footer-waves .wave-2 { animation:waveSlide 9s linear infinite reverse; opacity:0.7; z-index:2; }
.footer-waves .wave-3 { animation:waveSlide 7s linear infinite; z-index:3; }
.footer-waves .wave-4 { animation:waveSlide 11s linear infinite reverse; z-index:4; }
@keyframes waveSlide { 0%{transform:translateX(0);} 100%{transform:translateX(-50%);} }

.footer-shimmer {
    position:absolute; top:0; left:-100%; width:50%; height:100%;
    background:linear-gradient(90deg, transparent, rgba(255,255,255,0.06), transparent);
    animation:shimmer 6s ease-in-out infinite; pointer-events:none; z-index:2;
}
@keyframes shimmer { 0%{left:-50%;} 100%{left:150%;} }

.footer-gradient-body {
    background:linear-gradient(180deg, #8ab800 0%, #a5d600 25%, #c8ff00 50%, #d4ff33 75%, #e0ff66 100%);
    padding:60px 0 32px; position:relative; z-index:1;
}
.footer-quicklinks { text-align:center; margin-bottom:40px; }
.footer-quicklinks h3 { font-size:20px; font-weight:700; color:#1a1a1a; margin-bottom:20px; }
.footer-quicklinks-row { display:flex; justify-content:center; gap:32px; flex-wrap:wrap; }
.footer-quicklinks-row a { font-size:14px; font-weight:500; color:rgba(0,0,0,0.65); transition:color 0.2s; }
.footer-quicklinks-row a:hover { color:#000; }
.footer-payments { margin-bottom:24px; }
.payment-icons { display:flex; justify-content:center; gap:8px; flex-wrap:wrap; }
.payment-icon { border-radius:4px; overflow:hidden; box-shadow:0 2px 8px rgba(0,0,0,0.1); transition:all 0.2s; }
.payment-icon:hover { transform:translateY(-2px); box-shadow:0 4px 16px rgba(0,0,0,0.2); }
.footer-copy { font-size:13px; color:rgba(0,0,0,0.5); text-align:center; }
.footer-copy a { color:#1a1a1a; font-weight:600; }

.footer-orb {
    position:absolute; border-radius:50%; filter:blur(80px);
    pointer-events:none; z-index:0;
}
.footer-orb-1 { width:400px; height:400px; background:rgba(200,255,0,0.2); bottom:-100px; left:-80px; animation:orbF1 8s ease-in-out infinite; }
.footer-orb-2 { width:350px; height:350px; background:rgba(160,220,0,0.15); bottom:0; right:-60px; animation:orbF2 10s ease-in-out infinite; }
.footer-orb-3 { width:250px; height:250px; background:rgba(180,240,0,0.12); top:20px; left:40%; animation:orbF3 12s ease-in-out infinite; }
@keyframes orbF1 { 0%,100%{transform:translate(0,0) scale(1);} 50%{transform:translate(40px,-30px) scale(1.1);} }
@keyframes orbF2 { 0%,100%{transform:translate(0,0) scale(1);} 50%{transform:translate(-30px,-40px) scale(1.15);} }
@keyframes orbF3 { 0%,100%{transform:translate(0,0) scale(1); opacity:0.5;} 50%{transform:translate(20px,20px) scale(1.2); opacity:0.8;} }

/* ===========================
   Sticky Bar, Modal, Back to Top
   =========================== */
.sticky-product-bar {
    position:fixed; bottom:0; left:0; right:0; z-index:85;
    background:var(--bg-raised); border-top:1px solid var(--border);
    box-shadow:0 -4px 30px rgba(0,0,0,0.4);
    transform:translateY(100%); transition:transform 0.4s var(--ease);
    backdrop-filter:blur(16px);
}
.sticky-product-bar.show { transform:translateY(0); }
.sticky-product-bar-inner {
    max-width:1200px; margin:0 auto; padding:12px 24px;
    display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.sticky-product-info { display:flex; align-items:center; gap:14px; flex:1; min-width:0; }
.sticky-product-img { width:46px; height:46px; border-radius:var(--r-sm); object-fit:cover; border:1px solid var(--border); flex-shrink:0; }
.sticky-product-details { min-width:0; }
.sticky-product-name { display:block; font-size:13px; font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-bottom:1px; }
.sticky-product-pricing { display:flex; align-items:center; gap:8px; }
.sticky-price-current { font-size:15px; font-weight:800; color:var(--accent); }
.sticky-price-original { font-size:12px; color:var(--text-3); text-decoration:line-through; }
.sticky-price-badge { font-size:9px; font-weight:800; color:#000; background:var(--accent); padding:2px 8px; border-radius:var(--r-full); }
.sticky-add-btn { padding:12px 28px; font-size:13px; font-weight:700; white-space:nowrap; flex-shrink:0; }

.image-modal {
    position:fixed; inset:0; z-index:300;
    background:rgba(0,0,0,0.92); display:none;
    align-items:center; justify-content:center;
    backdrop-filter:blur(8px);
}
.image-modal.active { display:flex; }
.image-modal-close { position:absolute; top:20px; right:20px; color:#fff; z-index:2; }
.image-modal img { max-width:90vw; max-height:90vh; border-radius:var(--r-md); }

.back-to-top {
    position:fixed; bottom:24px; right:24px;
    width:44px; height:44px; border-radius:50%;
    background:var(--accent); color:#000;
    display:flex; align-items:center; justify-content:center;
    z-index:80; opacity:0; transform:translateY(20px);
    transition:all 0.3s;
    box-shadow:0 4px 20px var(--accent-glow);
}
.back-to-top.show { opacity:1; transform:translateY(0); }

/* ===========================
   Scroll Animations
   =========================== */
.reveal { opacity:0; transform:translateY(40px); transition:all 0.7s var(--ease); }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ===========================
   Responsive
   =========================== */
@media (max-width:1024px) {
    .hero-inner { grid-template-columns:1fr; text-align:center; }
    .hero-text { max-width:100%; }
    .hero-subtitle { margin-left:auto; margin-right:auto; }
    .hero-cta-row { justify-content:center; }
    .hero-trust-row { justify-content:center; }
    .hero-visual { margin-top:40px; }
    .hero-floating-1 { left:10px; }
    .hero-floating-2 { right:10px; }
    .product-layout { grid-template-columns:1fr; }
    .product-gallery { position:static; }
    .bento-grid { grid-template-columns:1fr; }
    .bento-large { grid-column:span 1; }
    .testimonials-grid { grid-template-columns:1fr 1fr; }
}
@media (max-width:768px) {
    .nav { display:none; }
    .header-cta { display:none; }
    .menu-toggle { display:flex; }
    .hero { min-height:auto; padding:40px 0 60px; }
    .hero-title { font-size:clamp(28px,6vw,40px); letter-spacing:-1.5px; }
    .testimonials-grid { grid-template-columns:1fr; }
    .stats-row { flex-direction:column; gap:32px; }
    .stat-divider { width:40px; height:1px; }
    .final-cta { padding:60px 24px; }
}
@media (max-width:480px) {
    .hero-floating-card { display:none; }
    .sticky-product-img { display:none; }
}

/* ===========================
   Checkout Modal
   =========================== */
.checkout-overlay {
    position:fixed; inset:0; background:rgba(0,0,0,0.8);
    z-index:250; opacity:0; visibility:hidden; transition:all 0.3s;
    backdrop-filter:blur(8px);
}
.checkout-overlay.active { opacity:1; visibility:visible; }
.checkout-modal {
    position:fixed; top:50%; left:50%; transform:translate(-50%,-50%) scale(0.95);
    width:520px; max-width:95vw; max-height:90vh;
    background:var(--bg-raised); border:1px solid var(--border);
    border-radius:var(--r-xl); z-index:251;
    opacity:0; visibility:hidden; transition:all 0.3s var(--ease);
    display:flex; flex-direction:column;
    box-shadow:0 32px 80px rgba(0,0,0,0.6);
}
.checkout-modal.active { opacity:1; visibility:visible; transform:translate(-50%,-50%) scale(1); }
.checkout-modal-header {
    display:flex; align-items:center; justify-content:space-between;
    padding:20px 28px; border-bottom:1px solid var(--border);
}
.checkout-modal-header h3 {
    font-size:18px; font-weight:700; display:flex; align-items:center; gap:8px;
}
.checkout-modal-header h3 .material-icons-outlined { color:var(--accent); font-size:20px; }
.checkout-modal-body { padding:28px; overflow-y:auto; flex:1; }
.checkout-summary {
    background:var(--bg-card); border:1px solid var(--border);
    border-radius:var(--r-md); padding:16px; margin-bottom:20px;
}
.checkout-summary-item {
    display:flex; justify-content:space-between; align-items:center;
    padding:8px 0; font-size:14px;
}
.checkout-summary-item + .checkout-summary-item { border-top:1px solid var(--border); }
.checkout-summary-total {
    display:flex; justify-content:space-between; align-items:center;
    padding-top:12px; margin-top:8px; border-top:2px solid var(--accent);
    font-size:16px; font-weight:800;
}
.checkout-summary-total span:last-child { color:var(--accent); }
.checkout-form { margin-bottom:20px; }
.checkout-field { margin-bottom:14px; }
.checkout-field label {
    display:block; font-size:12px; font-weight:600;
    color:var(--text-2); margin-bottom:6px; text-transform:uppercase; letter-spacing:0.5px;
}
.checkout-field input {
    width:100%; padding:12px 16px; border:1px solid var(--border);
    border-radius:var(--r-sm); background:var(--bg-card);
    color:var(--text); font-size:14px; font-family:var(--font);
    transition:all 0.2s; outline:none;
}
.checkout-field input:focus { border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-dim); }
.checkout-field input::placeholder { color:var(--text-3); }
.checkout-field-error {
    display: none;
    color: #991b1b; /* dark red */
    font-size: 11px;
    font-weight: 600;
    margin-top: 6px;
    letter-spacing: 0.3px;
}
.checkout-divider {
    text-align:center; margin:20px 0; position:relative;
}
.checkout-divider::before {
    content:''; position:absolute; top:50%; left:0; right:0;
    height:1px; background:var(--border);
}
.checkout-divider span {
    position:relative; background:var(--bg-raised);
    padding:0 16px; font-size:13px; font-weight:600; color:var(--text-2);
}
#paypal-button-container { min-height:50px; }
.checkout-processing {
    text-align:center; padding:40px 20px;
}
#paypal-button-container {
    padding: 10px;
    background-color: white;
}
.checkout-spinner {
    width:48px; height:48px; border:4px solid var(--border);
    border-top-color:var(--accent); border-radius:50%;
    margin:0 auto 16px; animation:spin 0.8s linear infinite;
}
.checkout-processing p { color:var(--text-2); font-size:14px; }
.checkout-success {
    text-align:center; padding:40px 20px;
}
.checkout-success h3 { font-size:22px; font-weight:800; margin:16px 0 8px; }
.checkout-success p { color:var(--text-2); font-size:14px; margin-bottom:8px; line-height:1.6; }
.checkout-order-id { font-size:12px; color:var(--text-3); font-family:monospace; margin-bottom:20px !important; }
.checkout-error {
    text-align:center; padding:40px 20px;
}
.checkout-error p { color:var(--text-2); font-size:14px; margin:12px 0 20px; }
