:root {
  --forest: #1a3a2a;
  --forest-mid: #2d5a3d;
  --forest-light: #3d7a52;
  --gold: #c8960c;
  --gold-light: #e8b422;
  --gold-pale: #f5d87a;
  --cream: #faf6ed;
  --cream-dark: #f0e8d5;
  --earth: #8b5e3c;
  --text-dark: #1a1a1a;
  --text-mid: #3d3d3d;
  --text-light: #666;
  --white: #ffffff;
  --red: #e53e3e;
  --green-ok: #2d5a3d;
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'DM Sans',sans-serif; background:var(--cream); color:var(--text-dark); overflow-x:hidden; }
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:var(--cream-dark); }
::-webkit-scrollbar-thumb { background:var(--forest-mid); border-radius:3px; }
body::before { content:''; position:fixed; inset:0; background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E"); pointer-events:none; z-index:0; opacity:.4; }
.cursor { width:10px; height:10px; background:var(--gold); border-radius:50%; position:fixed; top:0; left:0; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); transition:transform .1s ease; mix-blend-mode:multiply; }

/* NAV */
nav { position:fixed; top:0; left:0; right:0; z-index:1000; padding:0 5%; display:flex; align-items:center; justify-content:space-between; height:72px; background:rgba(250,246,237,0.92); backdrop-filter:blur(16px); border-bottom:1px solid rgba(200,150,12,0.2); transition:box-shadow .3s; }
nav.scrolled { box-shadow:0 4px 40px rgba(26,58,42,0.12); }
.nav-logo { font-family:'Playfair Display',serif; font-size:1.6rem; font-weight:700; color:var(--forest); text-decoration:none; }
.nav-logo span { color:var(--gold); }
.nav-links { display:flex; gap:2rem; list-style:none; align-items:center; }
.nav-links a { font-size:.85rem; font-weight:500; color:var(--text-mid); text-decoration:none; letter-spacing:.06em; text-transform:uppercase; position:relative; padding-bottom:4px; transition:color .3s; }
.nav-links a::after { content:''; position:absolute; bottom:0; left:0; width:0; height:1.5px; background:var(--gold); transition:width .3s; }
.nav-links a:hover { color:var(--forest); }
.nav-links a:hover::after { width:100%; }
.nav-cart { font-size:1.1rem !important; text-transform:none !important; letter-spacing:0 !important; background:rgba(200,150,12,0.1); padding:6px 14px !important; border-radius:20px !important; }
.nav-cart::after { display:none !important; }
.nav-cart span { background:var(--forest); color:var(--gold-pale); border-radius:50%; width:18px; height:18px; display:inline-flex; align-items:center; justify-content:center; font-size:.7rem; font-weight:700; margin-left:2px; }
.nav-cta { background:var(--forest) !important; color:var(--gold-pale) !important; padding:10px 22px !important; border-radius:30px !important; font-weight:600 !important; }
.nav-cta:hover { background:var(--forest-mid) !important; }
.nav-cta::after { display:none !important; }
.nav-cart-mobile { display:none; font-size:1.3rem; text-decoration:none; }
.nav-cart-mobile span { background:var(--forest); color:var(--gold-pale); border-radius:50%; width:18px; height:18px; display:inline-flex; align-items:center; justify-content:center; font-size:.7rem; font-weight:700; margin-left:2px; }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; }
.hamburger span { width:24px; height:2px; background:var(--forest); border-radius:2px; transition:.3s; }

/* HERO */
.hero { min-height:100vh; display:grid; grid-template-columns:1fr 1fr; align-items:center; padding:100px 5% 60px; position:relative; overflow:hidden; }
.hero-bg-circle { position:absolute; border-radius:50%; pointer-events:none; }
.hero-bg-circle.c1 { width:700px; height:700px; background:radial-gradient(circle,rgba(61,122,82,.12) 0%,transparent 70%); top:-200px; right:-100px; animation:float1 8s ease-in-out infinite; }
.hero-bg-circle.c2 { width:400px; height:400px; background:radial-gradient(circle,rgba(200,150,12,.1) 0%,transparent 70%); bottom:50px; left:-100px; animation:float2 10s ease-in-out infinite; }
@keyframes float1 { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-30px)} }
@keyframes float2 { 0%,100%{transform:translateY(0)} 50%{transform:translateY(20px)} }
.hero-content { position:relative; z-index:1; }
.hero-badge { display:inline-flex; align-items:center; gap:8px; background:rgba(200,150,12,.12); border:1px solid rgba(200,150,12,.3); border-radius:30px; padding:6px 16px; font-size:.75rem; font-weight:600; color:var(--earth); letter-spacing:.1em; text-transform:uppercase; margin-bottom:24px; animation:fadeUp .8s ease both; }
.hero-badge .dot { width:6px; height:6px; background:var(--gold); border-radius:50%; }
.hero h1 { font-family:'Playfair Display',serif; font-size:clamp(2.8rem,5vw,4.5rem); font-weight:900; line-height:1.1; color:var(--forest); margin-bottom:24px; animation:fadeUp .8s ease .15s both; }
.hero h1 em { color:var(--gold); font-style:italic; }
.hero p { font-size:1.05rem; color:var(--text-light); line-height:1.8; max-width:480px; margin-bottom:40px; animation:fadeUp .8s ease .3s both; }
.hero-actions { display:flex; gap:16px; flex-wrap:wrap; animation:fadeUp .8s ease .45s both; }
.hero-stats { display:flex; gap:40px; margin-top:56px; animation:fadeUp .8s ease .6s both; }
.stat-num { font-family:'Playfair Display',serif; font-size:2rem; font-weight:700; color:var(--forest); }
.stat-num span { color:var(--gold); }
.stat-label { font-size:.8rem; color:var(--text-light); margin-top:4px; text-transform:uppercase; letter-spacing:.08em; }
.hero-visual { display:flex; align-items:center; justify-content:center; position:relative; z-index:1; animation:fadeIn 1.2s ease .3s both; }
.hero-card-stack { position:relative; width:420px; height:480px; }
.product-card-hero { position:absolute; background:var(--white); border-radius:24px; padding:28px; box-shadow:0 20px 60px rgba(26,58,42,.15); border:1px solid rgba(200,150,12,.1); }
.product-card-hero.main { width:280px; top:50%; left:50%; transform:translate(-50%,-50%); z-index:3; }
.product-card-hero.side1 { width:200px; top:20px; left:10px; transform:rotate(-8deg); z-index:2; opacity:.85; animation:cardFloat1 6s ease-in-out infinite; }
.product-card-hero.side2 { width:200px; bottom:20px; right:10px; transform:rotate(6deg); z-index:2; opacity:.85; animation:cardFloat2 7s ease-in-out infinite; }
@keyframes cardFloat1 { 0%,100%{transform:rotate(-8deg) translateY(0)} 50%{transform:rotate(-8deg) translateY(-12px)} }
@keyframes cardFloat2 { 0%,100%{transform:rotate(6deg) translateY(0)} 50%{transform:rotate(6deg) translateY(10px)} }
.card-icon { width:60px; height:60px; border-radius:16px; display:flex; align-items:center; justify-content:center; font-size:1.8rem; margin-bottom:14px; }
.card-icon.green { background:rgba(61,122,82,.12); }
.card-icon.gold { background:rgba(200,150,12,.12); }
.card-icon.earth { background:rgba(139,94,60,.12); }
.card-name { font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:700; color:var(--forest); margin-bottom:6px; }
.card-tag { font-size:.75rem; color:var(--text-light); text-transform:uppercase; letter-spacing:.08em; }
.card-price { font-family:'Playfair Display',serif; font-size:1.4rem; font-weight:700; color:var(--gold); margin-top:12px; }
.card-rating { display:flex; gap:2px; margin-top:8px; }
.star { color:var(--gold-light); font-size:.8rem; }

/* MARQUEE */
.marquee-section { background:var(--forest); padding:18px 0; overflow:hidden; }
.marquee-track { display:flex; white-space:nowrap; animation:marquee 20s linear infinite; }
.marquee-item { display:inline-flex; align-items:center; gap:10px; font-size:.82rem; font-weight:600; color:var(--gold-pale); letter-spacing:.1em; text-transform:uppercase; padding:0 48px; }
.marquee-dot { width:5px; height:5px; background:var(--gold); border-radius:50%; }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* SECTION COMMONS */
section { position:relative; z-index:1; }
.section-header { text-align:center; margin-bottom:56px; }
.section-tag { display:inline-block; font-size:.75rem; font-weight:600; color:var(--gold); letter-spacing:.15em; text-transform:uppercase; margin-bottom:12px; }
.section-title { font-family:'Playfair Display',serif; font-size:clamp(2rem,3.5vw,2.8rem); font-weight:700; color:var(--forest); line-height:1.2; }
.section-title em { color:var(--gold); font-style:italic; }
.section-sub { font-size:1rem; color:var(--text-light); margin-top:12px; max-width:500px; margin-left:auto; margin-right:auto; line-height:1.7; }

/* BUTTONS */
.btn-primary { background:var(--forest); color:var(--gold-pale); padding:16px 36px; border-radius:50px; font-size:.95rem; font-weight:600; text-decoration:none; display:inline-flex; align-items:center; gap:10px; transition:transform .3s,box-shadow .3s,background .3s; box-shadow:0 8px 30px rgba(26,58,42,.25); }
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 16px 40px rgba(26,58,42,.35); background:var(--forest-mid); }
.btn-secondary { border:2px solid var(--forest-light); color:var(--forest); padding:14px 32px; border-radius:50px; font-size:.95rem; font-weight:600; text-decoration:none; transition:background .3s,color .3s; }
.btn-secondary:hover { background:var(--forest); color:var(--cream); }

/* CATEGORIES */
.categories { padding:90px 5%; }
.cat-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:24px; }
.cat-card { background:var(--white); border-radius:24px; padding:36px 28px; text-align:center; border:1px solid rgba(200,150,12,.1); transition:transform .4s cubic-bezier(.34,1.56,.64,1),box-shadow .4s; cursor:pointer; position:relative; overflow:hidden; text-decoration:none; display:block; }
.cat-card:hover { transform:translateY(-8px); box-shadow:0 24px 60px rgba(26,58,42,.15); }
.cat-emoji { font-size:3rem; margin-bottom:16px; display:block; }
.cat-name { font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:700; color:var(--forest); margin-bottom:8px; }
.cat-count { font-size:.8rem; color:var(--text-light); }
.cat-arrow { display:inline-flex; width:36px; height:36px; background:var(--forest); border-radius:50%; align-items:center; justify-content:center; color:var(--gold-pale); font-size:1rem; margin-top:16px; transition:transform .3s,background .3s; }
.cat-card:hover .cat-arrow { transform:translateX(4px); background:var(--gold); color:var(--forest); }

/* PRODUCTS */
.products { padding:90px 5%; background:var(--forest); }
.products-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.prod-card { background:rgba(250,246,237,.05); border:1px solid rgba(200,150,12,.2); border-radius:20px; overflow:hidden; transition:transform .4s,border-color .3s; }
.prod-card:hover { transform:translateY(-6px); border-color:rgba(200,150,12,.5); }
.prod-img { height:160px; display:flex; align-items:center; justify-content:center; font-size:4rem; background:linear-gradient(135deg,rgba(61,122,82,.15),rgba(200,150,12,.1)); position:relative; }
.prod-badge { position:absolute; top:12px; left:12px; background:var(--gold); color:var(--forest); font-size:.7rem; font-weight:700; padding:4px 12px; border-radius:20px; text-transform:uppercase; }
.prod-body { padding:20px; }
.prod-category { font-size:.72rem; color:rgba(200,150,12,.8); text-transform:uppercase; letter-spacing:.1em; margin-bottom:6px; }
.prod-name { font-family:'Playfair Display',serif; font-size:1.05rem; font-weight:700; color:var(--cream); margin-bottom:6px; line-height:1.3; }
.prod-desc { font-size:.82rem; color:rgba(250,246,237,.5); line-height:1.6; margin-bottom:14px; }
.prod-footer { display:flex; align-items:center; justify-content:space-between; }
.prod-price { font-family:'Playfair Display',serif; font-size:1.3rem; font-weight:700; color:var(--gold-light); }
.prod-price small { font-size:.78rem; color:rgba(250,246,237,.4); text-decoration:line-through; font-family:'DM Sans',sans-serif; }
.btn-add { background:var(--gold); color:var(--forest); border:none; padding:8px 16px; border-radius:24px; font-size:.82rem; font-weight:700; cursor:pointer; transition:transform .2s; font-family:'DM Sans',sans-serif; }
.btn-add:hover { transform:scale(1.05); }
.btn-view { background:transparent; color:var(--gold-pale); border:1px solid rgba(200,150,12,.4); padding:8px 16px; border-radius:24px; font-size:.82rem; font-weight:600; cursor:pointer; text-decoration:none; transition:background .2s; font-family:'DM Sans',sans-serif; display:inline-flex; align-items:center; }
.btn-view:hover { background:rgba(200,150,12,.15); }

/* WHY US */
.why-us { padding:90px 5%; }
.why-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.why-features { display:flex; flex-direction:column; gap:20px; }
.why-item { display:flex; gap:20px; align-items:flex-start; padding:20px; border-radius:16px; border:1px solid transparent; transition:border-color .3s,background .3s,transform .3s; }
.why-item:hover { border-color:rgba(200,150,12,.2); background:var(--white); transform:translateX(8px); }
.why-icon { width:52px; height:52px; flex-shrink:0; border-radius:14px; background:linear-gradient(135deg,var(--forest),var(--forest-mid)); display:flex; align-items:center; justify-content:center; font-size:1.5rem; }
.why-text h3 { font-family:'Playfair Display',serif; font-size:1.05rem; font-weight:700; color:var(--forest); margin-bottom:6px; }
.why-text p { font-size:.88rem; color:var(--text-light); line-height:1.7; }
.why-visual { background:linear-gradient(135deg,var(--forest) 0%,var(--forest-mid) 100%); border-radius:32px; padding:50px 40px; color:var(--cream); position:relative; overflow:hidden; }
.why-visual::before { content:''; position:absolute; width:300px; height:300px; border-radius:50%; background:rgba(200,150,12,.1); top:-100px; right:-80px; }
.why-visual h2 { font-family:'Playfair Display',serif; font-size:2.2rem; font-weight:700; margin-bottom:16px; position:relative; }
.why-visual h2 span { color:var(--gold-light); }
.why-visual p { opacity:.7; line-height:1.8; margin-bottom:32px; position:relative; }
.trust-badges { display:grid; grid-template-columns:1fr 1fr; gap:14px; position:relative; }
.trust-badge { background:rgba(255,255,255,.06); border:1px solid rgba(200,150,12,.2); border-radius:14px; padding:16px; text-align:center; }
.trust-badge .icon { font-size:1.8rem; margin-bottom:6px; }
.trust-badge .label { font-size:.78rem; opacity:.7; }

/* TESTIMONIALS */
.testimonials { padding:90px 5%; background:var(--cream-dark); }
.test-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.test-card { background:var(--white); border-radius:20px; padding:32px 28px; border:1px solid rgba(200,150,12,.1); transition:transform .3s,box-shadow .3s; }
.test-card:hover { transform:translateY(-6px); box-shadow:0 20px 50px rgba(26,58,42,.1); }
.test-stars { display:flex; gap:3px; margin-bottom:16px; }
.test-stars span { color:var(--gold); font-size:1rem; }
.test-quote { font-family:'Cormorant Garamond',serif; font-size:1.05rem; color:var(--text-mid); line-height:1.8; margin-bottom:24px; font-style:italic; }
.test-author { display:flex; align-items:center; gap:14px; }
.test-avatar { width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg,var(--forest),var(--gold)); display:flex; align-items:center; justify-content:center; color:var(--cream); font-weight:700; font-size:1rem; flex-shrink:0; }
.test-name { font-weight:600; font-size:.9rem; color:var(--forest); }
.test-location { font-size:.78rem; color:var(--text-light); }

/* CONTACT */
.contact { padding:90px 5%; }
.contact-grid { display:grid; grid-template-columns:1fr 1.3fr; gap:60px; align-items:start; }
.contact-info h2 { font-family:'Playfair Display',serif; font-size:2.2rem; font-weight:700; color:var(--forest); margin-bottom:16px; }
.contact-info h2 em { color:var(--gold); font-style:italic; }
.contact-info p { color:var(--text-light); line-height:1.8; margin-bottom:36px; }
.contact-details { display:flex; flex-direction:column; gap:16px; }
.contact-item { display:flex; gap:16px; align-items:flex-start; padding:18px; background:var(--white); border-radius:14px; border:1px solid rgba(200,150,12,.1); transition:border-color .3s,transform .3s; }
.contact-item:hover { border-color:rgba(200,150,12,.3); transform:translateX(6px); }
.contact-item-icon { width:44px; height:44px; flex-shrink:0; background:linear-gradient(135deg,var(--forest),var(--forest-mid)); border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.1rem; }
.contact-item-text strong { display:block; font-size:.82rem; color:var(--text-light); text-transform:uppercase; letter-spacing:.08em; margin-bottom:3px; }
.contact-item-text a,.contact-item-text span { font-size:.95rem; color:var(--text-dark); text-decoration:none; font-weight:500; }
.contact-item-text a:hover { color:var(--forest); }
.contact-form { background:var(--white); border-radius:24px; padding:36px; border:1px solid rgba(200,150,12,.15); box-shadow:0 20px 60px rgba(26,58,42,.08); }
.contact-form h3 { font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:700; color:var(--forest); margin-bottom:24px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { margin-bottom:18px; }
.form-group label { display:block; font-size:.82rem; font-weight:600; color:var(--forest); margin-bottom:8px; }
.form-group input,.form-group select,.form-group textarea { width:100%; padding:12px 16px; border:1.5px solid rgba(200,150,12,.2); border-radius:10px; font-family:'DM Sans',sans-serif; font-size:.9rem; color:var(--text-dark); background:var(--cream); outline:none; transition:border-color .3s; }
.form-group input:focus,.form-group select:focus,.form-group textarea:focus { border-color:var(--forest-mid); background:var(--white); }
.form-group textarea { resize:vertical; min-height:100px; }
.btn-submit { width:100%; background:linear-gradient(135deg,var(--forest),var(--forest-mid)); color:var(--gold-pale); border:none; padding:16px; border-radius:12px; font-size:1rem; font-weight:700; cursor:pointer; font-family:'DM Sans',sans-serif; transition:transform .3s,box-shadow .3s; }
.btn-submit:hover { transform:translateY(-2px); box-shadow:0 14px 36px rgba(26,58,42,.3); }

/* FOOTER */
footer { background:var(--forest); color:var(--cream); padding:60px 5% 28px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.footer-brand .logo { font-family:'Playfair Display',serif; font-size:1.8rem; font-weight:700; color:var(--cream); margin-bottom:14px; }
.footer-brand .logo span { color:var(--gold); }
.footer-brand p { opacity:.55; line-height:1.8; font-size:.9rem; max-width:280px; }
.footer-social { display:flex; gap:12px; margin-top:22px; }
.social-btn { width:38px; height:38px; background:rgba(255,255,255,.08); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1rem; transition:background .3s,transform .3s; cursor:pointer; }
.social-btn:hover { background:var(--gold); transform:translateY(-3px); }
.footer-col h4 { font-family:'Playfair Display',serif; font-size:1rem; font-weight:600; color:var(--gold-pale); margin-bottom:18px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col ul li a { color:rgba(250,246,237,.55); text-decoration:none; font-size:.88rem; transition:color .3s,padding-left .3s; display:block; }
.footer-col ul li a:hover { color:var(--gold-pale); padding-left:6px; }
.footer-divider { border:none; border-top:1px solid rgba(255,255,255,.08); margin-bottom:24px; }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; font-size:.82rem; opacity:.45; }

/* PAGE HEADER */
.page-header { background:linear-gradient(135deg,var(--forest),var(--forest-mid)); padding:120px 5% 60px; color:var(--cream); }
.page-header h1 { font-family:'Playfair Display',serif; font-size:clamp(2rem,4vw,3rem); font-weight:800; margin-bottom:12px; }
.page-header h1 em { color:var(--gold-light); font-style:italic; }
.page-header p { opacity:.7; font-size:1rem; }
.breadcrumb { display:flex; gap:8px; align-items:center; font-size:.82rem; opacity:.6; margin-bottom:16px; }
.breadcrumb a { color:var(--cream); text-decoration:none; }
.breadcrumb a:hover { opacity:1; }

/* PRODUCT PAGE */
.products-page { padding:60px 5%; }
.filter-bar { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:40px; align-items:center; }
.filter-btn { padding:8px 20px; border-radius:24px; border:1.5px solid rgba(200,150,12,.2); background:var(--white); color:var(--text-mid); font-size:.82rem; font-weight:600; cursor:pointer; transition:all .25s; font-family:'DM Sans',sans-serif; }
.filter-btn.active,.filter-btn:hover { background:var(--forest); color:var(--gold-pale); border-color:var(--forest); }
.all-products-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.aprod-card { background:var(--white); border-radius:20px; overflow:hidden; border:1px solid rgba(200,150,12,.1); transition:transform .35s,box-shadow .35s; }
.aprod-card:hover { transform:translateY(-6px); box-shadow:0 20px 50px rgba(26,58,42,.12); }
.aprod-img { height:160px; display:flex; align-items:center; justify-content:center; font-size:4rem; background:linear-gradient(135deg,rgba(61,122,82,.08),rgba(200,150,12,.07)); position:relative; }
.aprod-badge { position:absolute; top:12px; left:12px; background:var(--gold); color:var(--forest); font-size:.68rem; font-weight:700; padding:4px 12px; border-radius:20px; text-transform:uppercase; }
.aprod-body { padding:20px; }
.aprod-category { font-size:.72rem; color:var(--gold); text-transform:uppercase; letter-spacing:.1em; margin-bottom:6px; }
.aprod-name { font-family:'Playfair Display',serif; font-size:1.05rem; font-weight:700; color:var(--forest); margin-bottom:6px; }
.aprod-desc { font-size:.82rem; color:var(--text-light); line-height:1.6; margin-bottom:14px; }
.aprod-footer { display:flex; align-items:center; justify-content:space-between; gap:8px; }
.aprod-price { font-family:'Playfair Display',serif; font-size:1.2rem; font-weight:700; color:var(--forest); }
.aprod-price small { font-size:.78rem; color:var(--text-light); text-decoration:line-through; font-family:'DM Sans',sans-serif; }
.aprod-actions { display:flex; gap:8px; }
.btn-aprod-view { background:var(--cream-dark); color:var(--forest); border:none; padding:8px 14px; border-radius:24px; font-size:.8rem; font-weight:600; cursor:pointer; text-decoration:none; font-family:'DM Sans',sans-serif; transition:background .2s; }
.btn-aprod-view:hover { background:var(--cream); }
.btn-aprod-add { background:var(--forest); color:var(--gold-pale); border:none; padding:8px 14px; border-radius:24px; font-size:.8rem; font-weight:700; cursor:pointer; font-family:'DM Sans',sans-serif; transition:background .2s,transform .2s; }
.btn-aprod-add:hover { background:var(--forest-mid); transform:scale(1.04); }

/* PRODUCT DETAIL PAGE */
.product-detail { padding:60px 5%; }
.pd-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; }
.pd-visual { background:linear-gradient(135deg,rgba(61,122,82,.08),rgba(200,150,12,.07)); border-radius:28px; height:400px; display:flex; align-items:center; justify-content:center; font-size:8rem; position:sticky; top:100px; border:1px solid rgba(200,150,12,.1); }
.pd-info { }
.pd-cat { font-size:.78rem; color:var(--gold); text-transform:uppercase; letter-spacing:.1em; margin-bottom:10px; }
.pd-name { font-family:'Playfair Display',serif; font-size:clamp(1.8rem,3vw,2.4rem); font-weight:800; color:var(--forest); margin-bottom:14px; line-height:1.2; }
.pd-rating { display:flex; align-items:center; gap:8px; margin-bottom:18px; }
.pd-stars { color:var(--gold); font-size:1.1rem; }
.pd-review-count { font-size:.85rem; color:var(--text-light); }
.pd-price-row { display:flex; align-items:baseline; gap:14px; margin-bottom:24px; }
.pd-price { font-family:'Playfair Display',serif; font-size:2.2rem; font-weight:800; color:var(--forest); }
.pd-mrp { font-size:1.1rem; color:var(--text-light); text-decoration:line-through; }
.pd-savings { background:rgba(200,150,12,.15); color:var(--earth); font-size:.82rem; font-weight:700; padding:4px 12px; border-radius:20px; }
.pd-desc { font-size:.95rem; color:var(--text-light); line-height:1.8; margin-bottom:24px; }
.pd-tags { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:28px; }
.pd-tag { background:rgba(61,122,82,.08); color:var(--forest-mid); font-size:.78rem; font-weight:600; padding:6px 14px; border-radius:20px; }
.pd-qty-row { display:flex; align-items:center; gap:16px; margin-bottom:24px; }
.pd-qty-label { font-size:.88rem; font-weight:600; color:var(--forest); }
.qty-ctrl { display:flex; align-items:center; gap:0; border:1.5px solid rgba(200,150,12,.3); border-radius:30px; overflow:hidden; }
.qty-btn { width:38px; height:38px; background:none; border:none; cursor:pointer; font-size:1.2rem; color:var(--forest); transition:background .2s; }
.qty-btn:hover { background:var(--cream-dark); }
.qty-val { width:40px; text-align:center; font-size:1rem; font-weight:700; color:var(--forest); }
.pd-actions { display:flex; gap:14px; margin-bottom:30px; flex-wrap:wrap; }
.btn-buy-now { background:linear-gradient(135deg,var(--forest),var(--forest-mid)); color:var(--gold-pale); padding:16px 36px; border-radius:50px; font-size:1rem; font-weight:700; border:none; cursor:pointer; font-family:'DM Sans',sans-serif; transition:transform .3s,box-shadow .3s; box-shadow:0 8px 30px rgba(26,58,42,.25); flex:1; }
.btn-buy-now:hover { transform:translateY(-2px); box-shadow:0 14px 36px rgba(26,58,42,.35); }
.btn-cart-full { background:transparent; color:var(--forest); padding:14px 28px; border-radius:50px; font-size:1rem; font-weight:700; border:2px solid var(--forest); cursor:pointer; font-family:'DM Sans',sans-serif; transition:background .3s,color .3s; flex:1; }
.btn-cart-full:hover { background:var(--forest); color:var(--cream); }
.pd-benefits { background:var(--white); border-radius:20px; padding:24px; border:1px solid rgba(200,150,12,.1); margin-bottom:20px; }
.pd-benefits h4 { font-family:'Playfair Display',serif; font-size:1.1rem; color:var(--forest); margin-bottom:14px; }
.pd-benefits ul { list-style:none; display:flex; flex-direction:column; gap:8px; }
.pd-benefits ul li { font-size:.88rem; color:var(--text-mid); display:flex; align-items:center; gap:8px; }
.pd-benefits ul li::before { content:'✓'; color:var(--forest-light); font-weight:700; }
.pd-trust { display:flex; gap:16px; flex-wrap:wrap; }
.pd-trust-item { display:flex; align-items:center; gap:6px; font-size:.78rem; color:var(--text-light); }

/* CART PAGE */
.cart-page { padding:60px 5%; }
.cart-layout { display:grid; grid-template-columns:1.5fr 1fr; gap:48px; align-items:start; }
.cart-items { }
.cart-item { background:var(--white); border-radius:18px; padding:22px; display:flex; gap:18px; align-items:center; border:1px solid rgba(200,150,12,.1); margin-bottom:16px; transition:box-shadow .3s; }
.cart-item:hover { box-shadow:0 8px 30px rgba(26,58,42,.1); }
.cart-item-img { width:80px; height:80px; flex-shrink:0; background:linear-gradient(135deg,rgba(61,122,82,.1),rgba(200,150,12,.08)); border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:2.2rem; }
.cart-item-info { flex:1; }
.cart-item-name { font-family:'Playfair Display',serif; font-size:1rem; font-weight:700; color:var(--forest); margin-bottom:4px; }
.cart-item-cat { font-size:.75rem; color:var(--text-light); text-transform:uppercase; letter-spacing:.06em; }
.cart-item-price { font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:700; color:var(--gold); margin-top:8px; }
.cart-item-right { display:flex; flex-direction:column; align-items:flex-end; gap:12px; }
.cart-remove { background:none; border:none; color:var(--text-light); cursor:pointer; font-size:1.2rem; transition:color .2s; }
.cart-remove:hover { color:var(--red); }
.cart-empty { text-align:center; padding:80px 20px; }
.cart-empty .icon { font-size:5rem; margin-bottom:20px; }
.cart-empty h3 { font-family:'Playfair Display',serif; font-size:1.8rem; color:var(--forest); margin-bottom:10px; }
.cart-empty p { color:var(--text-light); margin-bottom:28px; }
.order-summary { background:var(--white); border-radius:24px; padding:32px; border:1px solid rgba(200,150,12,.15); box-shadow:0 10px 40px rgba(26,58,42,.08); position:sticky; top:100px; }
.order-summary h3 { font-family:'Playfair Display',serif; font-size:1.4rem; font-weight:700; color:var(--forest); margin-bottom:24px; }
.summary-row { display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; font-size:.92rem; }
.summary-row .label { color:var(--text-light); }
.summary-row .value { font-weight:600; color:var(--text-dark); }
.summary-divider { border:none; border-top:1px solid rgba(200,150,12,.15); margin:18px 0; }
.summary-total { display:flex; justify-content:space-between; font-family:'Playfair Display',serif; font-size:1.3rem; font-weight:700; color:var(--forest); }
.summary-saving { background:rgba(200,150,12,.1); color:var(--earth); font-size:.82rem; font-weight:600; padding:8px 14px; border-radius:10px; text-align:center; margin:14px 0; }
.btn-checkout { width:100%; background:linear-gradient(135deg,var(--forest),var(--forest-mid)); color:var(--gold-pale); border:none; padding:18px; border-radius:14px; font-size:1rem; font-weight:700; cursor:pointer; font-family:'DM Sans',sans-serif; transition:transform .3s,box-shadow .3s; box-shadow:0 8px 24px rgba(26,58,42,.2); margin-top:6px; }
.btn-checkout:hover { transform:translateY(-2px); box-shadow:0 14px 36px rgba(26,58,42,.3); }
.secure-note { display:flex; align-items:center; justify-content:center; gap:6px; font-size:.78rem; color:var(--text-light); margin-top:14px; }

/* CHECKOUT PAGE */
.checkout-page { padding:60px 5%; }
.checkout-layout { display:grid; grid-template-columns:1.4fr 1fr; gap:48px; align-items:start; }
.checkout-steps { display:flex; gap:0; margin-bottom:40px; }
.step { display:flex; align-items:center; gap:10px; flex:1; }
.step-num { width:34px; height:34px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.85rem; font-weight:700; border:2px solid rgba(200,150,12,.3); color:var(--text-light); transition:all .3s; flex-shrink:0; }
.step.active .step-num { background:var(--forest); border-color:var(--forest); color:var(--gold-pale); }
.step.done .step-num { background:var(--gold); border-color:var(--gold); color:var(--forest); }
.step-label { font-size:.82rem; font-weight:600; color:var(--text-light); }
.step.active .step-label { color:var(--forest); }
.step.done .step-label { color:var(--gold); }
.step-line { flex:1; height:2px; background:rgba(200,150,12,.2); margin:0 6px; }
.step-line.done { background:var(--gold); }
.checkout-section { background:var(--white); border-radius:20px; padding:30px; border:1px solid rgba(200,150,12,.1); margin-bottom:24px; }
.checkout-section h3 { font-family:'Playfair Display',serif; font-size:1.2rem; font-weight:700; color:var(--forest); margin-bottom:22px; display:flex; align-items:center; gap:10px; }
.checkout-section h3 span { width:28px; height:28px; background:var(--forest); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--gold-pale); font-size:.8rem; }

/* PAYMENT PAGE */
.payment-methods { display:flex; flex-direction:column; gap:14px; margin-bottom:24px; }
.payment-option { display:flex; align-items:center; gap:16px; padding:18px 20px; border:2px solid rgba(200,150,12,.15); border-radius:14px; cursor:pointer; transition:border-color .3s,background .3s; }
.payment-option.selected { border-color:var(--forest); background:rgba(26,58,42,.03); }
.payment-option input[type=radio] { accent-color:var(--forest); width:18px; height:18px; flex-shrink:0; cursor:pointer; }
.payment-option-icon { font-size:1.8rem; }
.payment-option-info { flex:1; }
.payment-option-name { font-weight:700; font-size:.95rem; color:var(--forest); }
.payment-option-sub { font-size:.78rem; color:var(--text-light); margin-top:2px; }
.phonepay-badge { background:linear-gradient(135deg,#5f259f,#7b2fbf); color:white; font-size:.68rem; font-weight:700; padding:2px 8px; border-radius:10px; margin-left:8px; }
.phonepay-panel { background:linear-gradient(135deg,#5f259f,#7b2fbf); border-radius:18px; padding:28px; color:white; margin:16px 0 24px; }
.phonepay-panel .pp-logo { font-size:2rem; font-weight:900; letter-spacing:-1px; margin-bottom:6px; }
.phonepay-panel .pp-sub { opacity:.8; font-size:.85rem; margin-bottom:24px; }
.phonepay-upi-input { width:100%; background:rgba(255,255,255,.15); border:1.5px solid rgba(255,255,255,.3); border-radius:10px; padding:14px 16px; font-size:1rem; color:white; outline:none; font-family:'DM Sans',sans-serif; }
.phonepay-upi-input::placeholder { color:rgba(255,255,255,.5); }
.phonepay-upi-input:focus { border-color:rgba(255,255,255,.7); background:rgba(255,255,255,.2); }
.pp-options { display:flex; gap:10px; margin-top:14px; flex-wrap:wrap; }
.pp-option-btn { background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.3); border-radius:8px; padding:8px 14px; font-size:.78rem; font-weight:600; color:white; cursor:pointer; transition:background .2s; font-family:'DM Sans',sans-serif; }
.pp-option-btn:hover { background:rgba(255,255,255,.25); }
.upi-apps { display:flex; gap:12px; margin-top:16px; flex-wrap:wrap; }
.upi-app { background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.25); border-radius:12px; padding:10px 16px; font-size:.82rem; font-weight:600; color:white; cursor:pointer; transition:background .3s; display:flex; align-items:center; gap:6px; }
.upi-app:hover { background:rgba(255,255,255,.22); }

/* ORDER CONFIRM */
.confirm-page { padding:80px 5%; text-align:center; }
.confirm-icon { font-size:5rem; margin-bottom:24px; animation:popIn .6s cubic-bezier(.34,1.56,.64,1) both; }
@keyframes popIn { from{transform:scale(0);opacity:0} to{transform:scale(1);opacity:1} }
.confirm-page h1 { font-family:'Playfair Display',serif; font-size:clamp(1.8rem,4vw,2.8rem); font-weight:800; color:var(--forest); margin-bottom:14px; }
.confirm-page h1 em { color:var(--gold); font-style:italic; }
.confirm-page p { color:var(--text-light); font-size:1.05rem; line-height:1.8; max-width:520px; margin:0 auto 40px; }
.order-id-box { display:inline-block; background:var(--white); border:1.5px solid rgba(200,150,12,.25); border-radius:14px; padding:16px 32px; font-family:'Playfair Display',serif; font-size:1.2rem; font-weight:700; color:var(--forest); margin-bottom:40px; }
.order-id-box span { color:var(--gold); }
.confirm-details { display:flex; gap:20px; justify-content:center; flex-wrap:wrap; margin-bottom:48px; }
.confirm-detail-item { background:var(--white); border-radius:16px; padding:22px 28px; border:1px solid rgba(200,150,12,.1); min-width:180px; }
.confirm-detail-item .icon { font-size:2rem; margin-bottom:8px; }
.confirm-detail-item .label { font-size:.78rem; color:var(--text-light); text-transform:uppercase; letter-spacing:.08em; }
.confirm-detail-item .val { font-weight:700; color:var(--forest); font-size:.95rem; margin-top:4px; }

/* ANIMATIONS */
@keyframes fadeUp { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
.reveal { opacity:0; transform:translateY(28px); transition:opacity .7s ease,transform .7s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }

/* TOAST */
.toast { position:fixed; bottom:32px; right:32px; background:var(--forest); color:var(--gold-pale); padding:14px 24px; border-radius:14px; font-size:.9rem; font-weight:600; z-index:9999; transform:translateY(100px); opacity:0; transition:transform .4s,opacity .4s; box-shadow:0 10px 40px rgba(26,58,42,.3); }
.toast.show { transform:translateY(0); opacity:1; }

/* RESPONSIVE */
@media(max-width:900px){
  .nav-links{display:none;}
  .hamburger{display:flex;}
  .nav-cart-mobile{display:flex;align-items:center;font-size:1.2rem;text-decoration:none;color:var(--text-dark);}
  .nav-links.open{display:flex;flex-direction:column;position:fixed;top:72px;left:0;right:0;background:var(--cream);padding:24px 5%;gap:20px;border-bottom:1px solid rgba(200,150,12,.2);z-index:999;}
  .hero{grid-template-columns:1fr;padding:110px 5% 60px;text-align:center;}
  .hero-visual{display:none;}
  .hero p,.hero-stats,.hero-actions{max-width:100%;}
  .hero-actions,.hero-stats{justify-content:center;}
  .cat-grid{grid-template-columns:repeat(2,1fr);}
  .products-grid{grid-template-columns:1fr;}
  .why-grid{grid-template-columns:1fr;}
  .test-grid{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px;}
  .form-row{grid-template-columns:1fr;}
  .all-products-grid{grid-template-columns:repeat(2,1fr);}
  .pd-grid{grid-template-columns:1fr;}
  .pd-visual{position:relative;top:0;height:240px;font-size:6rem;}
  .cart-layout{grid-template-columns:1fr;}
  .checkout-layout{grid-template-columns:1fr;}
}
@media(max-width:540px){
  .all-products-grid{grid-template-columns:1fr;}
  .cat-grid{grid-template-columns:1fr 1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;gap:6px;text-align:center;}
  .confirm-details{flex-direction:column;align-items:center;}
}
