/* =========================================================
   MamaBless — design system
   Inspired by mamaearth.in : warm green + sunshine yellow,
   creamy backgrounds, soft rounded cards, friendly type.
   ========================================================= */

:root{
  --green-900:#0e3b1f;
  --green-700:#1f6f3a;
  --green-500:#2f9e44;
  --green-300:#a7e3b5;
  --green-50: #eafff0;
  --yellow-500:#ffc233;
  --yellow-300:#ffe28a;
  --orange-500:#ff7849;
  --pink-300:#ffb8b8;
  --cream:    #fffaf0;
  --bg:       #fffdf8;
  --ink:      #1d2b21;
  --ink-soft: #4a5a4f;
  --line:     #e8e3d6;
  --white:    #ffffff;
  --shadow-sm: 0 2px 6px rgba(20,40,25,.06);
  --shadow-md: 0 8px 24px rgba(20,40,25,.10);
  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 22px;
  --r-pill: 999px;
  --container: 1240px;
}

*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{
  font-family:'Nunito',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink); background:var(--bg);
  font-size:16px; line-height:1.55; -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:var(--green-700); text-decoration:none; }
a:hover{ color:var(--green-500); }
h1,h2,h3,h4{ font-family:'DM Serif Display',Georgia,serif; color:var(--green-900); margin:0 0 .5em; line-height:1.15; font-weight:400; letter-spacing:-.01em; }
h1{ font-size:clamp(2rem,4.2vw,3.4rem); }
h2{ font-size:clamp(1.6rem,3vw,2.4rem); }
h3{ font-size:1.25rem; }
p{ margin:0 0 1em; color:var(--ink-soft); }
.container{ max-width:var(--container); margin:0 auto; padding:0 24px; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  background:var(--green-700); color:#fff; padding:14px 26px;
  border-radius:var(--r-pill); font-weight:700; border:0; cursor:pointer;
  transition:transform .15s ease, background .2s ease, box-shadow .2s ease;
  font-size:.95rem; letter-spacing:.02em;
}
.btn:hover{ background:var(--green-900); color:#fff; transform:translateY(-1px); box-shadow:var(--shadow-md); }
.btn-yellow{ background:var(--yellow-500); color:var(--green-900); }
.btn-yellow:hover{ background:#f5b50f; color:var(--green-900); }
.btn-outline{ background:transparent; color:var(--green-700); border:2px solid var(--green-700); }
.btn-outline:hover{ background:var(--green-700); color:#fff; }
.btn-block{ width:100%; }
.btn-sm{ padding:9px 18px; font-size:.85rem; }

/* ---------- Header ---------- */
.site-header{ background:#fff; box-shadow:0 1px 0 var(--line); position:sticky; top:0; z-index:50; }
.topbar{ background:var(--green-900); color:#fff; font-size:.82rem; }
.topbar-inner{ display:flex; justify-content:space-between; padding:8px 24px; flex-wrap:wrap; gap:8px; }
.topbar a{ color:#cfe9d6; margin-left:18px; }
.topbar a:hover{ color:#fff; }

.header-main{ display:flex; align-items:center; gap:24px; padding:18px 24px; }
.logo{ display:flex; align-items:center; gap:8px; font-family:'DM Serif Display',serif; font-size:1.6rem; color:var(--green-900); }
.logo-leaf{ font-size:1.7rem; }
.logo em{ color:var(--green-500); font-style:normal; }
.logo-light{ color:#fff; }
.logo-light em{ color:var(--yellow-300); }

.search{ flex:1; display:flex; max-width:520px; background:var(--cream); border:2px solid var(--line); border-radius:var(--r-pill); overflow:hidden; transition:border-color .2s ease; }
.search:focus-within{ border-color:var(--green-500); }
.search input{ flex:1; border:0; background:transparent; padding:12px 18px; font:inherit; color:var(--ink); outline:none; }
.search button{ border:0; background:transparent; padding:0 18px; font-size:1.05rem; cursor:pointer; color:var(--green-700); }

.header-actions{ display:flex; gap:18px; align-items:center; margin-left:auto; }
.ha{ display:flex; flex-direction:column; align-items:center; color:var(--ink); font-size:.72rem; line-height:1; gap:4px; position:relative; }
.ha-icon{ font-size:1.35rem; }
.ha:hover{ color:var(--green-700); }
.cart-btn .cart-badge{
  position:absolute; top:-6px; right:-10px; background:var(--orange-500); color:#fff;
  font-size:.65rem; min-width:18px; height:18px; border-radius:9px; display:flex; align-items:center; justify-content:center; padding:0 5px; font-weight:700;
}
.hamburger{ display:none; flex-direction:column; gap:4px; background:transparent; border:0; padding:6px; cursor:pointer; }
.hamburger span{ width:22px; height:2px; background:var(--ink); border-radius:2px; }

/* ---------- Primary nav + mega ---------- */
.primary-nav{ background:var(--green-700); color:#fff; }
.nav-inner ul{ list-style:none; margin:0; padding:0; display:flex; gap:6px; flex-wrap:wrap; }
.nav-inner a{ color:#eafff0; padding:14px 16px; display:inline-block; font-weight:700; font-size:.93rem; border-radius:var(--r-sm); }
.nav-inner a:hover, .nav-inner a.is-active{ background:rgba(255,255,255,.1); color:#fff; }
.nav-cta a{ background:var(--yellow-500); color:var(--green-900) !important; margin:6px 0; }
.nav-cta a:hover{ background:#f5b50f; }

.has-mega{ position:relative; }
.mega{
  position:absolute; top:100%; left:50%; transform:translateX(-50%);
  background:#fff; color:var(--ink); padding:28px 32px; border-radius:var(--r-md);
  box-shadow:var(--shadow-md); display:none; min-width:880px; gap:32px;
  grid-template-columns:repeat(5,1fr); z-index:60;
}
.has-mega:hover .mega, .has-mega:focus-within .mega{ display:grid; }
.mega-col h4{ font-family:'Nunito',sans-serif; font-size:.85rem; text-transform:uppercase; letter-spacing:.08em; color:var(--green-700); margin-bottom:10px; }
.mega-col a{ display:block; padding:6px 0; color:var(--ink); font-weight:600; font-size:.92rem; }
.mega-col a:hover{ color:var(--green-700); }
.mega-promo .promo-card{ background:var(--cream); border-radius:var(--r-md); padding:18px; }

/* ---------- Hero ---------- */
.hero{ background:linear-gradient(135deg,#eafff0 0%,#fff5d6 100%); padding:64px 0; overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns:1.1fr 1fr; gap:48px; align-items:center; }
.hero-eyebrow{ display:inline-block; background:var(--white); color:var(--green-700); padding:6px 14px; border-radius:var(--r-pill); font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; box-shadow:var(--shadow-sm); margin-bottom:18px; }
.hero h1{ margin-bottom:14px; }
.hero h1 .accent{ color:var(--green-500); position:relative; display:inline-block; }
.hero h1 .accent::after{ content:""; position:absolute; left:0; right:0; bottom:6px; height:10px; background:var(--yellow-300); z-index:-1; border-radius:6px; }
.hero p.lead{ font-size:1.1rem; max-width:480px; }
.hero-ctas{ display:flex; gap:14px; flex-wrap:wrap; margin-top:14px; }
.hero-trust{ display:flex; gap:24px; margin-top:30px; flex-wrap:wrap; }
.hero-trust div{ display:flex; align-items:center; gap:10px; font-size:.85rem; color:var(--ink); font-weight:700; }
.hero-trust span.ico{ width:38px; height:38px; background:var(--white); border-radius:50%; display:grid; place-items:center; box-shadow:var(--shadow-sm); font-size:1.1rem; }
.hero-art{ position:relative; }
.hero-art .blob{
  background: radial-gradient(circle at 30% 30%, var(--yellow-300), var(--green-300) 70%);
  aspect-ratio:1/1; border-radius:50%;
  display:grid; place-items:center; font-size:8rem;
  box-shadow:var(--shadow-md); position:relative; color:var(--green-900);
}
.hero-art .floater{ position:absolute; background:#fff; padding:14px 18px; border-radius:var(--r-md); box-shadow:var(--shadow-md); display:flex; gap:10px; align-items:center; font-size:.85rem; font-weight:700; }
.floater.f1{ top:20px; left:-12px; }
.floater.f2{ bottom:30px; right:-10px; }
.floater .emoji{ font-size:1.5rem; }

/* ---------- Section / utility ---------- */
.section{ padding:72px 0; }
.section-tight{ padding:48px 0; }
.section-cream{ background:var(--cream); }
.section-green{ background:var(--green-50); }
.section-head{ text-align:center; max-width:680px; margin:0 auto 40px; }
.section-head .eyebrow{ display:inline-block; color:var(--green-500); font-weight:800; letter-spacing:.1em; text-transform:uppercase; font-size:.78rem; margin-bottom:8px; }

/* ---------- Category pills ---------- */
.cat-grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:18px; }
.cat{ background:#fff; border-radius:var(--r-md); padding:22px 12px; text-align:center; transition:transform .2s, box-shadow .2s; box-shadow:var(--shadow-sm); border:1px solid var(--line); }
.cat:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.cat .ic{ width:64px; height:64px; margin:0 auto 10px; border-radius:50%; display:grid; place-items:center; font-size:1.6rem; background:var(--green-50); color:var(--green-700); }
.cat .ic.y{ background:#fff5d6; }
.cat .ic.p{ background:#ffe6e6; }
.cat .ic.b{ background:#e6f1ff; }
.cat .name{ font-weight:700; color:var(--ink); font-size:.92rem; }

/* ---------- Product cards ---------- */
.prod-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.prod{ background:#fff; border-radius:var(--r-md); overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--line); transition:transform .2s, box-shadow .2s; display:flex; flex-direction:column; }
.prod:hover{ transform:translateY(-3px); box-shadow:var(--shadow-md); }
.prod .thumb{ aspect-ratio:1/1; background:linear-gradient(135deg,var(--green-50),var(--cream)); display:grid; place-items:center; font-size:5rem; position:relative; color:var(--green-700); }
.prod .thumb .prod-ic{ font-size:4.5rem; color:var(--green-700); opacity:.85; }
.prod .badge-tag{ position:absolute; top:12px; left:12px; background:var(--orange-500); color:#fff; font-size:.7rem; padding:5px 10px; border-radius:var(--r-pill); font-weight:800; letter-spacing:.05em; z-index:2; }
.prod .heart{ position:absolute; top:12px; right:12px; width:36px; height:36px; border-radius:50%; background:#fff; border:0; display:grid; place-items:center; box-shadow:var(--shadow-sm); cursor:pointer; color:var(--ink-soft); font-size:1rem; transition:color .2s, transform .2s; z-index:2; }
.prod .heart:hover{ transform:scale(1.1); color:var(--orange-500); }
.prod .heart.is-on{ color:var(--orange-500); }
.prod .heart.is-on i::before{ content:"\f004"; font-weight:900; }
.prod .body{ padding:16px; display:flex; flex-direction:column; gap:8px; flex:1; }
.prod .cat-label{ color:var(--green-500); font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; }
.prod .title{ font-family:'Nunito',sans-serif; font-weight:700; color:var(--ink); font-size:1rem; min-height:2.6em; }
.prod .rating{ font-size:.78rem; color:var(--ink-soft); display:flex; align-items:center; gap:6px; }
.prod .stars{ color:var(--yellow-500); display:inline-flex; gap:1px; font-size:.78rem; }
.pdp-rating .stars, .stars-row{ display:inline-flex; gap:2px; }
.prod .price{ display:flex; align-items:baseline; gap:8px; }
.prod .price .now{ font-weight:800; color:var(--green-900); font-size:1.15rem; }
.prod .price .was{ text-decoration:line-through; color:var(--ink-soft); font-size:.85rem; }
.prod .price .off{ background:var(--green-50); color:var(--green-700); font-size:.7rem; padding:2px 8px; border-radius:var(--r-pill); font-weight:800; }
.prod .add{ margin-top:auto; }

/* ---------- Banner / promo strip ---------- */
.promo-strip{ background:var(--yellow-500); color:var(--green-900); padding:14px 0; text-align:center; font-weight:800; letter-spacing:.02em; }
.promo-strip span{ margin:0 18px; }

/* ---------- USP strip ---------- */
.usp{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.usp .usp-item{ display:flex; gap:14px; align-items:flex-start; }
.usp .usp-ic{ width:48px; height:48px; border-radius:50%; background:var(--green-50); display:grid; place-items:center; font-size:1.2rem; flex-shrink:0; color:var(--green-700); }
.usp h4{ font-family:'Nunito',sans-serif; font-size:.95rem; color:var(--ink); margin:0 0 4px; }
.usp p{ margin:0; font-size:.85rem; }

/* ---------- Ingredient cards ---------- */
.ing-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.ing{ background:#fff; border-radius:var(--r-md); padding:24px; text-align:center; box-shadow:var(--shadow-sm); border:1px solid var(--line); }
.ing .em{ font-size:2.6rem; margin-bottom:10px; color:var(--green-500); }
.ing h4{ font-family:'Nunito',sans-serif; font-size:1rem; color:var(--ink); margin-bottom:6px; }
.ing p{ font-size:.85rem; margin:0; }

/* ---------- Testimonials ---------- */
.test-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.test{ background:#fff; border-radius:var(--r-md); padding:28px; box-shadow:var(--shadow-sm); border:1px solid var(--line); }
.test .stars{ color:var(--yellow-500); margin-bottom:10px; display:inline-flex; gap:2px; font-size:.95rem; }
.test blockquote{ margin:0 0 18px; font-size:1rem; color:var(--ink); font-style:italic; }
.test .who{ display:flex; align-items:center; gap:12px; }
.test .av{ width:40px; height:40px; border-radius:50%; background:var(--green-300); display:grid; place-items:center; font-weight:800; color:var(--green-900); }

/* ---------- Blog cards ---------- */
.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.blog-card{ background:#fff; border-radius:var(--r-md); overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--line); }
.blog-card .img{ aspect-ratio:16/10; background:linear-gradient(135deg,var(--green-300),var(--yellow-300)); display:grid; place-items:center; font-size:3rem; color:#fff; }
.blog-card .body{ padding:20px; }
.blog-card .meta{ font-size:.75rem; color:var(--ink-soft); text-transform:uppercase; letter-spacing:.06em; margin-bottom:6px; }
.blog-card h3{ font-size:1.1rem; }
.blog-card a.read{ color:var(--green-700); font-weight:700; font-size:.85rem; }

/* ---------- Newsletter / footer ---------- */
.newsletter{ background:var(--green-700); color:#fff; padding:48px 0; }
.nl-inner{ display:grid; grid-template-columns:1.2fr 1fr; gap:32px; align-items:center; }
.newsletter h2{ color:#fff; }
.newsletter p{ color:#cfe9d6; margin:0; }
.nl-form{ display:flex; gap:8px; background:#fff; padding:6px; border-radius:var(--r-pill); }
.nl-form input{ flex:1; border:0; padding:14px 18px; font:inherit; outline:none; background:transparent; color:var(--ink); }
.nl-form button{ background:var(--yellow-500); color:var(--green-900); font-weight:800; border:0; padding:12px 24px; border-radius:var(--r-pill); cursor:pointer; }
.nl-form button:hover{ background:#f5b50f; }

.site-footer{ background:var(--green-900); color:#cfe9d6; padding:56px 0 0; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr 1.4fr; gap:32px; }
.f-col h4{ color:#fff; font-family:'Nunito',sans-serif; font-size:.95rem; text-transform:uppercase; letter-spacing:.08em; margin-bottom:14px; }
.f-col a{ display:block; color:#cfe9d6; padding:5px 0; font-size:.92rem; }
.f-col a:hover{ color:#fff; }
.f-brand p{ color:#cfe9d6; max-width:320px; margin-top:12px; }
.f-brand a{ color:var(--yellow-300); display:inline; padding:0; }
.socials{ display:flex; gap:10px; margin-top:14px; }
.socials a{ width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,.08); display:grid; place-items:center; padding:0; color:#fff; font-size:1rem; transition:background .2s, color .2s; }
.socials a:hover{ background:var(--yellow-500); color:var(--green-900); }
.f-contact .badges{ display:flex; gap:8px; margin-top:12px; flex-wrap:wrap; }
.badge{ background:rgba(255,255,255,.08); color:#fff; font-size:.7rem; padding:4px 10px; border-radius:var(--r-pill); font-weight:700; letter-spacing:.04em; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.08); margin-top:40px; padding:18px 0; font-size:.82rem; }
.fb-inner{ display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; align-items:center; }
.pay-icons{ display:inline-flex; gap:14px; align-items:center; font-size:.78rem; color:#cfe9d6; }
.pay-icons i{ font-size:1.6rem; color:#cfe9d6; }
.pay-icons i.fa-cc-visa{ color:#1a1f71; background:#fff; padding:2px 4px; border-radius:3px; font-size:1.4rem; }
.pay-icons i.fa-cc-mastercard{ color:#eb001b; background:#fff; padding:2px 4px; border-radius:3px; font-size:1.4rem; }
.pay-icons i.fa-cc-amex{ color:#2e77bb; background:#fff; padding:2px 4px; border-radius:3px; font-size:1.4rem; }

/* ---------- Generic page header ---------- */
.page-head{ background:var(--green-50); padding:48px 0; }
.page-head h1{ margin-bottom:8px; }
.crumbs{ font-size:.85rem; color:var(--ink-soft); }
.crumbs a{ color:var(--green-700); }

/* ---------- Shop layout ---------- */
.shop-layout{ display:grid; grid-template-columns:260px 1fr; gap:32px; padding:40px 0 80px; }
.filters{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:22px; height:fit-content; position:sticky; top:120px; }
.filters h4{ font-family:'Nunito',sans-serif; font-size:.95rem; text-transform:uppercase; letter-spacing:.06em; color:var(--green-900); margin:18px 0 8px; }
.filters h4:first-child{ margin-top:0; }
.filters label{ display:flex; align-items:center; gap:8px; padding:5px 0; font-size:.9rem; color:var(--ink); cursor:pointer; }
.filters .price-input{ display:flex; gap:6px; }
.filters .price-input input{ width:50%; padding:8px 10px; border:1px solid var(--line); border-radius:var(--r-sm); font:inherit; }
.filters .stars-row{ color:var(--yellow-500); }
.shop-toolbar{ display:flex; justify-content:space-between; align-items:center; margin-bottom:20px; flex-wrap:wrap; gap:12px; }
.shop-toolbar select{ padding:9px 14px; border-radius:var(--r-pill); border:1px solid var(--line); font:inherit; background:#fff; }
.shop-results{ font-size:.9rem; color:var(--ink-soft); }
.pagination{ display:flex; justify-content:center; gap:6px; margin-top:32px; }
.pagination a{ width:38px; height:38px; border-radius:50%; display:grid; place-items:center; background:#fff; border:1px solid var(--line); color:var(--ink); font-weight:700; }
.pagination a.is-active, .pagination a:hover{ background:var(--green-700); color:#fff; border-color:var(--green-700); }

/* ---------- Product detail ---------- */
.pdp{ display:grid; grid-template-columns:1.1fr 1fr; gap:48px; padding:48px 0 64px; }
.pdp-gallery{ position:sticky; top:120px; align-self:start; }
.pdp-main-img{ background:linear-gradient(135deg,var(--green-50),var(--cream)); border-radius:var(--r-md); aspect-ratio:1/1; display:grid; place-items:center; font-size:8rem; border:1px solid var(--line); color:var(--green-700); }
.pdp-thumbs{ display:grid; grid-template-columns:repeat(5,1fr); gap:10px; margin-top:12px; }
.pdp-thumbs .t{ aspect-ratio:1/1; background:var(--cream); border-radius:var(--r-sm); display:grid; place-items:center; font-size:1.4rem; cursor:pointer; border:2px solid transparent; color:var(--green-700); }
.pdp-thumbs .t.is-active, .pdp-thumbs .t:hover{ border-color:var(--green-500); }
.pdp h1{ margin-bottom:6px; }
.pdp .pdp-tag{ color:var(--green-700); font-weight:700; font-size:.85rem; text-transform:uppercase; letter-spacing:.06em; margin-bottom:10px; }
.pdp .pdp-rating{ display:flex; align-items:center; gap:10px; margin-bottom:18px; font-size:.9rem; color:var(--ink-soft); }
.pdp .pdp-rating .stars{ color:var(--yellow-500); }
.pdp-price{ display:flex; align-items:baseline; gap:14px; padding:14px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); margin-bottom:18px; }
.pdp-price .now{ font-size:2rem; font-weight:800; color:var(--green-900); font-family:'DM Serif Display',serif; }
.pdp-price .was{ text-decoration:line-through; color:var(--ink-soft); font-size:1rem; }
.pdp-price .off{ background:var(--green-50); color:var(--green-700); padding:4px 10px; border-radius:var(--r-pill); font-weight:800; font-size:.8rem; }
.pdp-price small{ color:var(--ink-soft); margin-left:auto; }
.pdp-options{ margin-bottom:20px; }
.pdp-options h4{ font-family:'Nunito',sans-serif; font-size:.85rem; text-transform:uppercase; letter-spacing:.08em; color:var(--green-900); margin-bottom:8px; }
.opt-pills{ display:flex; gap:8px; flex-wrap:wrap; }
.opt-pills label{ background:#fff; border:1px solid var(--line); padding:9px 16px; border-radius:var(--r-pill); cursor:pointer; font-weight:700; font-size:.88rem; }
.opt-pills input{ display:none; }
.opt-pills input:checked + span, .opt-pills label:hover{ }
.opt-pills label:has(input:checked){ background:var(--green-700); color:#fff; border-color:var(--green-700); }
.qty{ display:inline-flex; align-items:center; border:1px solid var(--line); border-radius:var(--r-pill); overflow:hidden; }
.qty button{ width:38px; height:38px; background:#fff; border:0; cursor:pointer; font-size:.9rem; color:var(--ink); }
.qty button:hover{ color:var(--green-700); }
.qty input{ width:42px; text-align:center; border:0; font:inherit; font-weight:700; }
.pdp-actions{ display:flex; gap:12px; margin:18px 0 28px; flex-wrap:wrap; }
.pdp-meta{ background:var(--cream); border-radius:var(--r-md); padding:18px; display:grid; grid-template-columns:1fr 1fr; gap:14px; font-size:.85rem; }
.pdp-meta .item{ display:flex; gap:10px; align-items:center; }
.pdp-meta .em{ font-size:1.4rem; color:var(--green-700); }

.pdp-tabs{ border-top:1px solid var(--line); padding-top:32px; margin-top:48px; }
.tab-nav{ display:flex; gap:6px; flex-wrap:wrap; border-bottom:1px solid var(--line); margin-bottom:24px; }
.tab-nav button{ background:transparent; border:0; padding:12px 18px; font:inherit; font-weight:700; color:var(--ink-soft); cursor:pointer; border-bottom:3px solid transparent; }
.tab-nav button.is-active{ color:var(--green-700); border-color:var(--green-700); }
.tab-panel{ display:none; }
.tab-panel.is-active{ display:block; }
.tab-panel ul{ padding-left:20px; }
.tab-panel li{ margin-bottom:6px; }

/* ---------- Cart ---------- */
.cart-layout{ display:grid; grid-template-columns:2fr 1fr; gap:32px; padding:40px 0 80px; }
.cart-list{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); }
.cart-row{ display:grid; grid-template-columns:80px 1fr auto auto auto; gap:18px; align-items:center; padding:20px; border-bottom:1px solid var(--line); }
.cart-row:last-child{ border-bottom:0; }
.cart-row .ci{ width:80px; height:80px; border-radius:var(--r-sm); background:var(--cream); display:grid; place-items:center; font-size:2.2rem; color:var(--green-700); }
.cart-row .ti{ font-weight:700; color:var(--ink); }
.cart-row .v{ color:var(--ink-soft); font-size:.85rem; }
.cart-row .pr{ font-weight:800; color:var(--green-900); }
.cart-row .rm{ background:none; border:0; cursor:pointer; color:var(--ink-soft); font-size:1rem; padding:8px; border-radius:50%; transition:background .2s, color .2s; }
.cart-row .rm:hover{ background:#fdecec; color:#c0392b; }
.summary{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:24px; height:fit-content; position:sticky; top:120px; }
.summary h3{ margin-bottom:18px; }
.sum-row{ display:flex; justify-content:space-between; padding:8px 0; border-bottom:1px dashed var(--line); font-size:.95rem; }
.sum-row.tot{ border-bottom:0; padding-top:14px; font-size:1.15rem; font-weight:800; color:var(--green-900); }
.coupon{ display:flex; gap:6px; margin:14px 0; }
.coupon input{ flex:1; padding:11px 14px; border:1px solid var(--line); border-radius:var(--r-pill); font:inherit; }
.coupon button{ background:var(--green-900); color:#fff; border:0; padding:0 18px; border-radius:var(--r-pill); cursor:pointer; font-weight:700; }

/* ---------- Forms ---------- */
.form{ display:grid; gap:14px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form label{ display:block; font-size:.85rem; font-weight:700; color:var(--ink); margin-bottom:6px; }
.form input, .form select, .form textarea{
  width:100%; padding:12px 14px; border:1px solid var(--line); border-radius:var(--r-sm);
  font:inherit; background:#fff; outline:none; transition:border-color .2s;
}
.form input:focus, .form select:focus, .form textarea:focus{ border-color:var(--green-500); }
.form .check{ display:flex; gap:8px; align-items:flex-start; font-size:.88rem; color:var(--ink-soft); }

.auth-card{ max-width:440px; margin:48px auto 80px; background:#fff; border-radius:var(--r-md); border:1px solid var(--line); padding:36px; box-shadow:var(--shadow-sm); }
.auth-card h1{ font-size:1.8rem; margin-bottom:6px; }
.auth-card .sw{ text-align:center; margin-top:18px; font-size:.9rem; color:var(--ink-soft); }
.auth-divider{ display:flex; align-items:center; gap:10px; color:var(--ink-soft); font-size:.8rem; margin:18px 0; }
.auth-divider::before, .auth-divider::after{ content:""; flex:1; height:1px; background:var(--line); }
.social-buttons{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.social-buttons button{ background:#fff; border:1px solid var(--line); padding:11px; border-radius:var(--r-sm); cursor:pointer; font:inherit; font-weight:700; }

/* ---------- Account dashboard ---------- */
.acct-layout{ display:grid; grid-template-columns:260px 1fr; gap:32px; padding:40px 0 80px; }
.acct-side{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:22px; height:fit-content; }
.acct-side .who{ display:flex; align-items:center; gap:12px; margin-bottom:20px; padding-bottom:18px; border-bottom:1px solid var(--line); }
.acct-side .av{ width:48px; height:48px; border-radius:50%; background:var(--green-300); display:grid; place-items:center; font-weight:800; color:var(--green-900); }
.acct-side a{ display:block; padding:10px 12px; border-radius:var(--r-sm); color:var(--ink); font-weight:700; font-size:.92rem; }
.acct-side a i{ width:18px; color:var(--green-700); }
.acct-side a:hover, .acct-side a.is-active{ background:var(--green-50); color:var(--green-700); }
.acct-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:28px; }
.acct-stat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-bottom:24px; }
.acct-stat{ background:var(--cream); border-radius:var(--r-md); padding:20px; }
.acct-stat .num{ font-size:1.8rem; font-weight:800; color:var(--green-900); font-family:'DM Serif Display',serif; }
.acct-stat .lab{ font-size:.85rem; color:var(--ink-soft); }

/* ---------- Order list ---------- */
.order{ display:grid; grid-template-columns:1fr auto; gap:14px; padding:18px; border:1px solid var(--line); border-radius:var(--r-md); margin-bottom:14px; align-items:center; }
.order .oid{ font-weight:800; color:var(--green-900); }
.order .om{ color:var(--ink-soft); font-size:.85rem; }
.status{ font-size:.78rem; font-weight:800; padding:5px 10px; border-radius:var(--r-pill); }
.status.delivered{ background:var(--green-50); color:var(--green-700); }
.status.shipped{ background:#e6f1ff; color:#1f6feb; }
.status.processing{ background:#fff5d6; color:#a26500; }

/* ---------- Generic article ---------- */
.article{ max-width:760px; margin:0 auto; padding:48px 24px 80px; }
.article h2{ margin-top:1.4em; }
.article p{ font-size:1.02rem; }
.article ul{ padding-left:20px; }

/* ---------- 404 ---------- */
.err{ text-align:center; padding:96px 24px; }
.err h1{ font-size:7rem; margin:0; color:var(--green-700); }

/* ---------- Responsive ---------- */
@media (max-width: 980px){
  .hero-grid, .nl-inner, .pdp, .cart-layout, .shop-layout, .acct-layout{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .prod-grid, .ing-grid, .blog-grid, .test-grid, .usp{ grid-template-columns:repeat(2,1fr); }
  .cat-grid{ grid-template-columns:repeat(3,1fr); }
  .filters, .summary, .pdp-gallery, .acct-side{ position:static; }
  .mega{ display:none !important; }
  .hamburger{ display:flex; }
  .primary-nav{ display:none; }
  .primary-nav.is-open{ display:block; }
  .nav-inner ul{ flex-direction:column; }
  .header-actions .ha-label{ display:none; }
  .search{ order:5; flex-basis:100%; max-width:none; }
  .header-main{ flex-wrap:wrap; }
}
@media (max-width: 560px){
  .footer-grid{ grid-template-columns:1fr; }
  .prod-grid, .ing-grid, .blog-grid, .test-grid, .usp, .cat-grid, .form-row{ grid-template-columns:1fr; }
  .topbar-inner{ font-size:.72rem; }
  .topbar a{ margin-left:10px; }
  h1{ font-size:1.9rem; }
  .pdp-meta{ grid-template-columns:1fr; }
}
