/*
Theme Name: Biggenz
Theme URI: https://biggenz.com
Author: Biggenz Editorial Team
Author URI: https://biggenz.com
Description: A premium, editorial-style luxury home décor affiliate theme for Biggenz.com.
Version: 3.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: biggenz
Tags: e-commerce, blog, custom-menu, featured-images
*/

/* NOTE: Google Fonts loaded via wp_enqueue_style in functions.php — no @import needed here */

:root {
  --color-bg: #FAF8F5;
  --color-bg-warm: #F5EFE8;
  --color-accent: #C4956A;
  --color-accent-hover: #a37952;
  --color-text: #2C2420;
  --color-text-light: #5c4e45;
  --color-white: #ffffff;
  --font-heading: 'Playfair Display', serif;
  --font-body: 'Jost', sans-serif;
  --shadow-subtle: 0 4px 20px rgba(44,36,32,0.05);
  --shadow-medium: 0 8px 30px rgba(44,36,32,0.10);
  --shadow-hover: 0 10px 30px rgba(44,36,32,0.1);
  --transition: all 0.3s ease;
}

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

/* ============================================================
   CORE OVERRIDES — !important used to defeat:
   1. Elementor Kit CSS (elementor-post-7.css sets global fonts)
   2. WooCommerce CSS (woocommerce.css resets buttons/forms)
   3. WordPress global-styles-inline-css (:root variable injection)
   ============================================================ */
html body,
body { 
    font-family:'Jost',sans-serif !important; 
    font-family:var(--font-body) !important; 
    background-color:#FAF8F5 !important; 
    background-color:var(--color-bg) !important; 
    color:#2C2420 !important; 
    color:var(--color-text) !important; 
    line-height:1.6; 
    -webkit-font-smoothing:antialiased; 
}

h1,h2,h3,h4,h5,h6 { 
    font-family:'Playfair Display',serif !important; 
    font-family:var(--font-heading) !important; 
    font-weight:600 !important; 
    color:#2C2420; 
    color:var(--color-text); 
    line-height:1.2; 
}

a { text-decoration:none !important; color:inherit; transition:var(--transition); }
img { max-width:100%; display:block; }

/* ============================================================
   WORDPRESS STRUCTURAL OVERRIDES
   WP adds margin-top:32px to body when admin bar is visible.
   It also wraps content in .site, .site-content, #primary, #main
   divs that introduce unwanted padding/margin.
   ============================================================ */

/* 1. Kill the admin bar body bump entirely */
html { margin-top: 0 !important; }
* html body { margin-top: 0 !important; }

/* 2. Admin bar navbar offset — only when WP admin bar is showing */
.admin-bar .navbar { top: 68px; } /* 36px original + 32px admin bar */
.admin-bar .navbar.scrolled { top: 32px; }
.admin-bar .announcement-bar { margin-top: 32px; }

/* 3. Strip WP wrapper div padding/margins that push content down */
.site,
#page,
#content,
.site-content,
#primary,
#main,
.wp-site-blocks,
.entry-content,
.post-content {
    margin: 0 !important;
    padding: 0 !important;
    max-width: none !important;
    width: 100% !important;
}

/* 4. Kill Twenty-* theme base styles that bleed through */
body.wp-singular .entry-header,
body.wp-singular .entry-footer { display: none; }

/* 5. Prevent Gutenberg block gap variable from affecting our layout */
:root {
    --wp--style--block-gap: 0px !important;
    --wp--preset--spacing--20: 0px !important;
}

/* Defeat Elementor Kit global typography injection */
.elementor-widget-heading .elementor-heading-title { font-family:'Playfair Display',serif !important; }
body.elementor-page { background-color:#FAF8F5 !important; background-color:var(--color-bg) !important; }
/* Prevent WooCommerce from styling our .btn class */
.btn, a.btn, button.btn { 
    display:inline-block !important; 
    background-color:#C4956A !important; 
    background-color:var(--color-accent) !important; 
    color:#ffffff !important; 
    padding:12px 32px !important; 
    border-radius:2px !important; 
    font-weight:500 !important; 
    letter-spacing:0.5px !important; 
    border:none !important; 
    cursor:pointer; 
    transition:var(--transition); 
    font-family:'Jost',sans-serif !important;
    text-transform:none !important;
    font-size:14px !important;
}
.btn:hover, a.btn:hover { background-color:#a37952 !important; background-color:var(--color-accent-hover) !important; color:#ffffff !important; }


.container { max-width:1200px; margin:0 auto; padding:0 20px; }
.text-center { text-align:center; }
.text-gold { color:var(--color-accent); }
.bg-warm { background-color:var(--color-bg-warm); }
.bg-dark { background-color:var(--color-text); color:var(--color-white); }
.bg-dark h1,.bg-dark h2,.bg-dark h3 { color:var(--color-white); }

.btn { display:inline-block; background-color:#C4956A; background-color:var(--color-accent); color:#ffffff; color:var(--color-white); padding:12px 32px; border-radius:2px; font-weight:500; letter-spacing:0.5px; border:none; cursor:pointer; transition:var(--transition); }
.btn:hover { background-color:#a37952; background-color:var(--color-accent-hover); color:#ffffff; }

.link-gold { color:var(--color-accent); font-weight:500; display:inline-flex; align-items:center; gap:5px; }
.link-gold:hover { color:var(--color-text); }

.section-padding { padding:80px 0; }
.section-title { font-size:36px; margin-bottom:16px; }
.section-subtitle { font-size:16px; color:var(--color-text-light); margin-bottom:40px; }

/* Announcement Bar */
.announcement-bar { background:#2C2420 !important; background:var(--color-text) !important; color:#ffffff !important; color:var(--color-white) !important; text-align:center; padding:10px 20px; font-size:12px; letter-spacing:2px; text-transform:uppercase; font-family:'Jost',sans-serif; }

/* Navbar */
.navbar { position:fixed; top:36px; left:0; right:0; z-index:1000; padding:20px 0; transition:var(--transition); }
.navbar.scrolled { top:0; background:var(--color-white); padding:15px 0; box-shadow:var(--shadow-subtle); }
.logo { font-family:var(--font-heading); font-size:28px; font-weight:700; color:var(--color-white); letter-spacing:1px; }
.navbar.scrolled .logo { color:var(--color-text) !important; }
.nav-links { display:flex; list-style:none; gap:35px; }
.nav-links a { font-size:12px; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,0.9); font-weight:500; }
.navbar.scrolled .nav-links a { color:var(--color-text) !important; }
.nav-links a:hover { color:var(--color-accent) !important; }
.nav-icon { cursor:pointer; color:rgba(255,255,255,0.9); }
.navbar.scrolled .nav-icon { color:var(--color-text) !important; }

/* Hamburger */
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:5px; }
.hamburger span { display:block; width:24px; height:2px; background:var(--color-white); transition:var(--transition); }
.navbar.scrolled .hamburger span { background:var(--color-text) !important; }

/* Mobile Nav */
.mobile-nav-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:1999; opacity:0; pointer-events:none; transition:opacity 0.3s; }
.mobile-nav-overlay.open { opacity:1; pointer-events:all; }
.mobile-nav { position:fixed; top:0; right:-320px; width:300px; height:100%; background:var(--color-white); z-index:2000; padding:40px 30px; transition:right 0.4s cubic-bezier(0.23,1,0.32,1); display:flex; flex-direction:column; }
.mobile-nav.open { right:0; }
.mobile-nav-close { font-size:28px; cursor:pointer; align-self:flex-end; color:var(--color-text-light); line-height:1; }
.mobile-nav-logo { font-family:var(--font-heading); font-size:24px; font-weight:700; color:var(--color-text); margin:20px 0 30px; }
.mobile-nav-links { list-style:none; display:flex; flex-direction:column; gap:0; }
.mobile-nav-links li a { display:block; padding:15px 0; border-bottom:1px solid var(--color-bg-warm); font-size:13px; letter-spacing:2px; text-transform:uppercase; color:var(--color-text); font-weight:500; }

/* Page Header */
.page-header { background:var(--color-text); padding:140px 0 80px; text-align:center; position:relative; overflow:hidden; }
.page-header.blog-header { background-image:url(''); background-size:cover; background-position:center; }
.page-header::after { content:''; position:absolute; inset:0; background:rgba(44,36,32,0.55); }
.page-header-content { position:relative; z-index:1; }
.page-title { font-size:48px; color:var(--color-white); margin-bottom:15px; }
.page-meta { color:var(--color-accent); letter-spacing:3px; font-size:12px; text-transform:uppercase; font-family:var(--font-body); }
.page-header.light { background:var(--color-bg-warm); }
.page-header.light::after { display:none; }
.page-header.light .page-title { color:var(--color-text); }
.page-header.light .page-meta { color:var(--color-text-light); }

/* Hero */
.hero { min-height:100vh; background-size:cover; background-position:center; display:flex; align-items:center; justify-content:center; position:relative; }
.hero::after { content:''; position:absolute; inset:0; background:linear-gradient(to bottom, rgba(44,36,32,0.5) 0%, rgba(44,36,32,0.3) 50%, rgba(44,36,32,0.6) 100%); }
.hero-content { position:relative; z-index:1; text-align:center; max-width:800px; padding:0 20px; }
.hero-title { font-size:clamp(36px,6vw,72px); color:var(--color-white); margin-bottom:24px; line-height:1.1; }
.hero-subtitle { font-size:18px; color:rgba(255,255,255,0.85); margin-bottom:40px; max-width:550px; margin-left:auto; margin-right:auto; }

/* Grids */
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.grid-6 { display:grid; grid-template-columns:repeat(6,1fr); gap:20px; }

/* Cards */
.editorial-card { background:var(--color-white); overflow:hidden; transition:var(--transition); }
.editorial-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-hover); }
.editorial-card .img-wrap { overflow:hidden; aspect-ratio:4/3; }
.editorial-card .img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease; }
.editorial-card:hover .img-wrap img { transform:scale(1.05); }
/* Editorial card content — applies to blog/style cards only, NOT product cards */
.editorial-card:not(.product-card) .content { padding:25px; }
/* Product card content override — flush sides, vertical padding only */
.product-card.editorial-card .content,
.product-card .content { padding:20px 0 25px !important; }
.product-card .content .category-label { margin-top:0; }
.category-label { font-size:10px; letter-spacing:3px; text-transform:uppercase; color:var(--color-accent); font-weight:600; margin-bottom:8px; display:block; }
.card-title { font-size:22px; margin-bottom:10px; }
.card-desc { font-size:14px; color:var(--color-text-light); margin-bottom:15px; line-height:1.7; }
.card-rating { font-size:14px; color:var(--color-accent); margin-bottom:10px; }
.price-range { font-size:12px; letter-spacing:1.5px; text-transform:uppercase; color:var(--color-accent); font-weight:600; }

/* Product Card */
.product-card { position:relative; }
.top-rated-badge { position:absolute; top:12px; left:12px; background:var(--color-accent); color:var(--color-white); font-size:9px; letter-spacing:1.5px; text-transform:uppercase; padding:4px 10px; border-radius:2px; z-index:1; font-weight:600; }
.product-card .img-wrap { aspect-ratio:1/1; }
/* Product card content — 20px top/bottom padding, flush sides */
.product-card .content { padding:20px 0 25px !important; }
.product-card .content .category-label { margin-top:0; }

/* Room Cards */
.room-card { display:block; background:var(--color-white); overflow:hidden; transition:var(--transition); border-radius:2px; }
.room-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-hover); }
.room-img-wrap { overflow:hidden; aspect-ratio:1/1; }
.room-img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease; }
.room-card:hover .room-img-wrap img { transform:scale(1.05); }
.room-card-content { padding:15px; text-align:center; }
.room-title { font-size:14px; font-family:var(--font-heading); margin-bottom:4px; }
.room-desc { font-size:11px; color:var(--color-text-light); }
.section-rooms { background:var(--color-bg-warm); }
.rooms-title { margin-bottom:12px !important; }
.rooms-subtitle-wrap { display:flex; justify-content:center; }
.rooms-subtitle { max-width:400px; text-align:center; }

/* Steps — bg-dark section forces everything white */
.steps-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:60px; }
.step-number {
    width:60px; height:60px;
    border:2px solid var(--color-accent) !important;
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-family:var(--font-heading); font-size:24px;
    color:var(--color-accent) !important;
    margin:0 auto 20px;
    background:transparent !important;
}
.step-title { font-size:20px; color:#ffffff !important; margin-bottom:15px; }
.bg-dark .step-title,
.bg-dark h3 { color:#ffffff !important; }
/* Override WP heading color reset inside dark sections */
.bg-dark h1, .bg-dark h2, .bg-dark h3, .bg-dark h4 { color:#ffffff !important; }

/* Filter Bar */
.filter-container { display:flex; flex-wrap:wrap; gap:10px; justify-content:center; padding:30px 0; }
.filter-btn { padding:8px 20px; border:1px solid var(--color-bg-warm); background:transparent; cursor:pointer; font-family:var(--font-body); font-size:12px; letter-spacing:1.5px; text-transform:uppercase; color:var(--color-text); transition:var(--transition); border-radius:2px; }
.filter-btn:hover,.filter-btn.active { background:var(--color-accent); color:var(--color-white); border-color:var(--color-accent); }

/* Products Grid */
.products-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:30px; padding-bottom:60px; }

/* Blog Layout */
.blog-layout { display:grid; grid-template-columns:1fr 340px; gap:80px; padding:80px 0 120px; align-items:start; }
.article-content { min-width:0; font-family:var(--font-body); }
.article-content p { font-size:17px; line-height:1.9; color:var(--color-text-light); margin-bottom:28px; }
.article-content h1,.article-content h2 { font-family:var(--font-heading); color:var(--color-text); margin:50px 0 20px; font-size:32px; line-height:1.3; }
.article-content h3 { font-family:var(--font-heading); color:var(--color-text); margin:40px 0 16px; font-size:24px; }
.article-content h4 { font-family:var(--font-heading); color:var(--color-text); margin:30px 0 12px; font-size:20px; }
.article-content ul,.article-content ol { padding-left:28px; margin-bottom:28px; color:var(--color-text-light); line-height:1.9; font-size:17px; }
.article-content li { margin-bottom:10px; }
.article-content strong { color:var(--color-text); font-weight:600; }
.article-content a { color:var(--color-accent); text-decoration:none; border-bottom:1px solid rgba(196,149,106,0.3); }
.article-content a:hover { border-color:var(--color-accent); }
.article-content img { max-width:100%; height:auto; border-radius:2px; margin:30px 0; display:block; }
.article-content blockquote { border-left:3px solid var(--color-accent); padding:20px 30px; margin:40px 0; background:var(--color-bg-warm); font-style:italic; color:var(--color-text-light); font-size:18px; }
/* Post body — maximum specificity to override Gutenberg/WoodMart content */
.article-content .post-body,
.article-content .post-body * { max-width:100% !important; }
.article-content .post-body p { font-size:17px !important; line-height:1.9 !important; color:#5C4F47 !important; margin-bottom:28px !important; padding:0 !important; }
.article-content .post-body h1,
.article-content .post-body h2 { font-family:'Playfair Display',serif !important; font-size:32px !important; color:#2C2420 !important; margin:50px 0 20px !important; line-height:1.3 !important; }
.article-content .post-body h3 { font-family:'Playfair Display',serif !important; font-size:24px !important; color:#2C2420 !important; margin:40px 0 16px !important; }
.article-content .post-body h4 { font-family:'Playfair Display',serif !important; font-size:20px !important; color:#2C2420 !important; margin:30px 0 12px !important; }
.article-content .post-body ul,
.article-content .post-body ol { padding-left:28px !important; margin-bottom:28px !important; color:#5C4F47 !important; font-size:17px !important; line-height:1.9 !important; }
.article-content .post-body li { margin-bottom:10px !important; }
.article-content .post-body strong,
.article-content .post-body b { color:#2C2420 !important; font-weight:600 !important; }
.article-content .post-body a { color:#C4956A !important; text-decoration:none !important; border-bottom:1px solid rgba(196,149,106,0.3) !important; }
.article-content .post-body img { max-width:100% !important; height:auto !important; margin:30px 0 !important; display:block !important; }
/* Kill ALL Gutenberg block wrappers that add layout */
.article-content .post-body .wp-block-group,
.article-content .post-body .wp-block-columns,
.article-content .post-body .wp-block-column,
.article-content .post-body .wp-block-cover,
.article-content .post-body .entry-content,
.article-content .post-body .wp-block-post-content { all:unset; display:block !important; }
/* Kill Gutenberg spacing variables on post content */
.article-content .post-body { --wp--style--block-gap:0px; }
/* Affiliate disclosure box */
.affiliate-disclosure { background:var(--color-bg-warm); border-left:3px solid var(--color-accent); padding:16px 20px; margin-bottom:40px; font-size:13px; color:var(--color-text-light); border-radius:0 2px 2px 0; display:flex !important; align-items:flex-start; gap:12px; width:100%; box-sizing:border-box; }

/* Product Spotlight */
.product-spotlight { display:flex; gap:30px; background:var(--color-white); padding:30px; margin:40px 0; box-shadow:var(--shadow-subtle); border-radius:4px; align-items:center; }
.spotlight-image { width:160px; height:160px; object-fit:cover; flex-shrink:0; border-radius:4px; }
.spotlight-badge { display:inline-block; background:var(--color-accent); color:var(--color-white); font-size:9px; letter-spacing:2px; text-transform:uppercase; padding:4px 12px; margin-bottom:10px; }
.spotlight-title { font-size:20px; margin-bottom:8px; }
.spotlight-rating { color:var(--color-accent); font-size:14px; margin-bottom:12px; }
.spotlight-btn { display:inline-block; background:var(--color-text); color:var(--color-white); padding:12px 24px; font-size:11px; letter-spacing:2px; text-transform:uppercase; font-weight:600; transition:var(--transition); border:none; cursor:pointer; }
.spotlight-btn:hover { background:var(--color-accent); color:var(--color-white); }

/* Comparison Table */
.comparison-container { margin:40px 0; }
.comp-table { width:100%; border-collapse:collapse; }
.comp-table th,.comp-table td { padding:14px 20px; text-align:left; border-bottom:1px solid var(--color-bg-warm); font-size:14px; }
.comp-table thead th { background:var(--color-bg-warm); font-family:var(--font-heading); font-size:16px; }
.comp-winner { background:rgba(196,149,106,0.08); font-weight:600; }
.winner-tag { display:block; font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--color-accent); font-family:var(--font-body); margin-bottom:4px; }
.comp-label { color:var(--color-text-light); font-size:13px; }

/* Sidebar */
.sidebar { position:sticky; top:100px; align-self:start; }
.widget { background:var(--color-white); padding:25px; margin-bottom:30px; box-shadow:var(--shadow-subtle); }
.widget-title { font-size:16px; letter-spacing:2px; text-transform:uppercase; padding-bottom:15px; border-bottom:1px solid var(--color-bg-warm); margin-bottom:20px; }
.recent-posts-list { list-style:none; }
.recent-posts-list li { padding:10px 0; border-bottom:1px solid var(--color-bg-warm); font-size:13px; }
.recent-posts-list li:last-child { border-bottom:none; }
.recent-posts-list a:hover { color:var(--color-accent); }
.sidebar-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-top:15px; }
.sidebar-grid img { width:100%; height:100px; object-fit:cover; border-radius:2px; }

/* Sticky Shop Bar */
.sticky-shop-bar { position:fixed; bottom:0; left:0; right:0; background:var(--color-text); color:var(--color-white); padding:15px 20px; display:flex; justify-content:space-between; align-items:center; z-index:999; transform:translateY(100%); transition:transform 0.4s ease; }
.sticky-shop-bar.active { transform:translateY(0); }
.sticky-shop-text { font-size:14px; font-weight:500; }
.sticky-shop-btn { background:var(--color-accent); color:var(--color-white); padding:8px 20px; font-size:12px; letter-spacing:1px; text-transform:uppercase; font-weight:600; border-radius:2px; }

/* Blog List Grid */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.blog-card { background:var(--color-white); overflow:hidden; transition:var(--transition); border-radius:2px; }
.blog-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-hover); }
.blog-card-img { overflow:hidden; aspect-ratio:16/9; width:100%; display:block; }
.blog-card-img img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 0.5s ease; }
.blog-card:hover .blog-card-img img { transform:scale(1.05); }
/* Blog card content — needs explicit padding unlike product cards */
.blog-card .blog-card-content,
.blog-card .content { padding:25px !important; }
/* Fix: WordPress auto-adds <p> tags inside blog excerpts with margin */
.blog-card .card-desc p,
.blog-card p { margin-bottom:0; }

/* Quiz */
.quiz-section { padding:80px 0; background-color:var(--color-bg); }
.quiz-container { max-width:800px; margin:0 auto; background:var(--color-white); padding:60px; box-shadow:var(--shadow-medium); text-align:center; border-radius:8px; }
.quiz-step { display:none; animation:fadeIn 0.5s ease; }
.quiz-step.active { display:block; }
.quiz-options { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:30px; }
.quiz-opt { padding:20px; border:1px solid var(--color-bg-warm); cursor:pointer; transition:var(--transition); font-family:var(--font-heading); font-size:18px; }
.quiz-opt:hover { border-color:var(--color-accent); background:var(--color-bg-warm); }

/* Newsletter */
.newsletter-section { padding:80px 0; background-color:var(--color-bg-warm); text-align:center; }
.newsletter-container { max-width:600px; margin:0 auto; }
.newsletter-title { font-size:32px; margin-bottom:15px; }
.newsletter-subtitle { color:var(--color-text-light); margin-bottom:35px; }
.newsletter-form { display:flex; gap:0; max-width:480px; margin:0 auto; }
.newsletter-input { flex:1; padding:14px 20px; border:1px solid rgba(196,149,106,0.4); background:var(--color-white); font-family:var(--font-body); font-size:14px; color:var(--color-text); outline:none; border-radius:2px 0 0 2px; }
.newsletter-btn { padding:14px 28px; background:var(--color-accent); color:var(--color-white); border:none; font-family:var(--font-body); font-weight:600; font-size:12px; letter-spacing:1.5px; text-transform:uppercase; cursor:pointer; border-radius:0 2px 2px 0; transition:var(--transition); }
.newsletter-btn:hover { background:var(--color-accent-hover); }
.vip-perks-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-bottom:40px; }
.vip-perk-card { background:var(--color-white); padding:25px 20px; text-align:center; border-radius:4px; }
.vip-icon { width:32px; height:32px; stroke:var(--color-accent); margin:0 auto 12px; display:block; }
.vip-title { font-size:14px; margin-bottom:8px; }
.vip-desc { font-size:13px; color:var(--color-text-light); line-height:1.6; }

/* Footer */
.footer { padding:60px 0 30px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr 1fr; gap:40px; margin-bottom:40px; }
.footer-brand { font-family:var(--font-heading); font-size:24px; font-weight:700; color:var(--color-white); margin-bottom:15px; }
.footer-desc { font-size:13px; color:rgba(255,255,255,0.6); line-height:1.8; }
.footer-title { font-size:11px; letter-spacing:2.5px; text-transform:uppercase; color:var(--color-white); margin-bottom:20px; font-family:var(--font-body); }
.footer-links { list-style:none; }
.footer-links li { margin-bottom:10px; }
.footer-links a { font-size:13px; color:rgba(255,255,255,0.55); }
.footer-links a:hover { color:var(--color-accent); }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.1); padding-top:25px; display:flex; justify-content:space-between; align-items:center; font-size:12px; color:rgba(255,255,255,0.4); }

/* Search Modal */
.search-modal { position:fixed; inset:0; background:rgba(44,36,32,0.95); z-index:9999; display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity 0.3s; }
.search-modal.active { opacity:1; pointer-events:all; }
.search-close { position:absolute; top:30px; right:40px; font-size:36px; color:var(--color-white); cursor:pointer; line-height:1; }
.search-form { display:flex; align-items:center; gap:20px; width:90%; max-width:600px; }
.search-input { flex:1; background:transparent; border:none; border-bottom:2px solid rgba(255,255,255,0.3); padding:15px 0; font-size:24px; color:var(--color-white); font-family:var(--font-heading); outline:none; }
.search-input::placeholder { color:rgba(255,255,255,0.4); }
.search-submit { background:none; border:none; cursor:pointer; color:var(--color-white); }

/* Lead Slide-in */
.lead-slide-in { position:fixed; bottom:30px; right:-400px; width:350px; background:var(--color-white); padding:35px; box-shadow:0 10px 30px rgba(0,0,0,0.15); border-left:4px solid var(--color-accent); z-index:1000; transition:right 0.6s cubic-bezier(0.23,1,0.32,1); border-radius:4px; }
.lead-slide-in.active { right:30px; }
.lead-close { position:absolute; top:10px; right:15px; font-size:24px; cursor:pointer; color:var(--color-text-light); }
.lead-title { font-family:var(--font-heading); font-size:22px; margin-bottom:10px; color:var(--color-text); }
.lead-text { font-size:14px; color:var(--color-text-light); margin-bottom:20px; line-height:1.6; }
.lead-form input { width:100%; padding:12px; margin-bottom:10px; border:1px solid var(--color-bg-warm); font-family:var(--font-body); }
.lead-form button { width:100%; padding:12px; background:var(--color-accent); color:var(--color-white); border:none; font-weight:700; cursor:pointer; transition:opacity 0.3s; }
.lead-form button:hover { opacity:0.9; }

/* Reveal Animations */
.reveal { opacity:0; transform:translateY(30px); transition:opacity 0.7s ease, transform 0.7s ease; }
.reveal.active { opacity:1; transform:translateY(0); }
@keyframes fadeIn { from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);} }

/* About / Contact */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-content h2 { font-size:36px; margin-bottom:24px; }
.about-content p { color:var(--color-text-light); margin-bottom:20px; font-size:16px; line-height:1.9; }
.contact-form { display:flex; flex-direction:column; gap:15px; }
.contact-form input,.contact-form textarea { width:100%; padding:14px 18px; border:1px solid rgba(196,149,106,0.3); background:var(--color-white); font-family:var(--font-body); font-size:14px; color:var(--color-text); outline:none; }
.contact-form textarea { height:140px; resize:vertical; }

/* Elementor full-width support */
.elementor-page .site-content { padding:0 !important; }
body.elementor-page { background:var(--color-bg); }
.elementor-section-wrap + #content { display:none; }

/* WP Product CPT Archive */
.biggenz-product-card { background:var(--color-white); overflow:hidden; transition:var(--transition); position:relative; }
.biggenz-product-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-hover); }
.biggenz-product-card .img-wrap { aspect-ratio:1/1; overflow:hidden; }
.biggenz-product-card .img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease; }
.biggenz-product-card:hover .img-wrap img { transform:scale(1.05); }
.biggenz-product-card .card-body { padding:20px; }
.biggenz-product-card .affiliate-link { display:inline-block; color:var(--color-accent); font-size:13px; font-weight:600; letter-spacing:0.5px; margin-top:12px; }
.biggenz-product-card .affiliate-link:hover { color:var(--color-text); }

/* Responsive */
@media (max-width:1024px) {
  .grid-3,.products-grid,.blog-grid { grid-template-columns:repeat(2,1fr); }
  .grid-6 { grid-template-columns:repeat(3,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; gap:30px; }
  .blog-layout { grid-template-columns:1fr; }
  .sidebar { position:static; }
  .steps-grid { grid-template-columns:1fr; gap:30px; }
  .vip-perks-grid { grid-template-columns:1fr; }
}
@media (max-width:768px) {
  .nav-links { display:none; }
  .hamburger { display:flex; }
  .grid-3,.products-grid,.blog-grid { grid-template-columns:1fr; }
  .grid-6 { grid-template-columns:repeat(2,1fr); }
  .hero-title { font-size:36px; }
  .page-title { font-size:32px; }
  .footer-grid { grid-template-columns:1fr; }
  .about-grid { grid-template-columns:1fr; gap:40px; }
  .quiz-container { padding:30px 20px; }
  .quiz-options { grid-template-columns:1fr; }
  .product-spotlight { flex-direction:column; }
  .newsletter-form { flex-direction:column; }
  .newsletter-input,.newsletter-btn { border-radius:2px; width:100%; }
}
@media (max-width:480px) {
  .grid-6 { grid-template-columns:repeat(2,1fr); }
}
