/* ============================================================
   K&V Organic Sprouts — design system
   Palette: sprout greens + warm cream + radish plum accent
   Display: "Fraunces" (organic serif)  Body: "Nunito Sans"
   ============================================================ */

:root{
  --cream:        #f7f4ea;
  --cream-deep:   #efe9d8;
  --ink:          #243018;   /* deep leaf-green near-black */
  --ink-soft:     #4a5a39;
  --sprout:       #6fa238;   /* primary green */
  --sprout-deep:  #4f7a26;
  --sprout-light: #9ccc5a;
  --root:         #b07c4a;   /* warm root brown */
  --plum:         #7d4fa0;   /* radish accent */
  --line:         #ddd6c2;
  --white:        #ffffff;

  --maxw: 1180px;
  --radius: 18px;
  --shadow-sm: 0 2px 10px rgba(36,48,24,.06);
  --shadow:    0 14px 40px rgba(36,48,24,.12);

  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-body: "Nunito Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:var(--sprout-deep); text-decoration:none; }
a:hover{ text-decoration:underline; }

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:600;
  line-height:1.1;
  color:var(--ink);
  margin:0 0 .5em;
  letter-spacing:-.01em;
}
h1{ font-size:clamp(2.3rem,5vw,3.7rem); }
h2{ font-size:clamp(1.8rem,3.6vw,2.7rem); }
h3{ font-size:1.35rem; }
p{ margin:0 0 1.1em; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.eyebrow{
  font-family:var(--font-body);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.72rem;
  font-weight:800;
  color:var(--sprout-deep);
  margin:0 0 .9rem;
}
.center{ text-align:center; }
.muted{ color:var(--ink-soft); }

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;
  font-family:var(--font-body);
  font-weight:800;
  font-size:.95rem;
  letter-spacing:.01em;
  padding:.85em 1.7em;
  border-radius:999px;
  border:2px solid var(--sprout-deep);
  background:var(--sprout-deep);
  color:#fff;
  cursor:pointer;
  transition:transform .15s ease, background .2s ease, box-shadow .2s ease;
  text-align:center;
}
.btn:hover{ background:var(--sprout); border-color:var(--sprout); text-decoration:none; transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.btn--ghost{ background:transparent; color:var(--sprout-deep); }
.btn--ghost:hover{ background:var(--sprout-deep); color:#fff; }
.btn--sm{ padding:.6em 1.2em; font-size:.85rem; }
.btn:disabled{ opacity:.5; cursor:default; transform:none; }

/* ============================================================
   Header / nav
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(247,244,234,.9);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  gap:18px; padding:12px 24px; max-width:var(--maxw); margin:0 auto;
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand img{ height:52px; width:52px; border-radius:50%; object-fit:cover; box-shadow:var(--shadow-sm); }
.brand .brand-name{
  font-family:var(--font-display); font-weight:600; font-size:1.15rem; color:var(--ink); line-height:1;
}
.brand .brand-name small{ display:block; font-family:var(--font-body); font-size:.62rem; letter-spacing:.25em; text-transform:uppercase; color:var(--sprout-deep); font-weight:800; margin-top:3px; }

.nav-links{ display:flex; align-items:center; gap:6px; list-style:none; margin:0; padding:0; }
.nav-links a{
  color:var(--ink); font-weight:700; font-size:.95rem; padding:.5em .85em; border-radius:999px;
}
.nav-links a:hover{ background:var(--cream-deep); text-decoration:none; }
.nav-links a.active{ background:var(--sprout-deep); color:#fff; }

.nav-right{ display:flex; align-items:center; gap:14px; }
.cart-btn{
  position:relative; background:none; border:none; cursor:pointer; padding:6px; color:var(--ink);
  display:flex; align-items:center;
}
.cart-btn svg{ width:26px; height:26px; }
.cart-count{
  position:absolute; top:-4px; right:-4px; background:var(--plum); color:#fff;
  font-size:.68rem; font-weight:800; min-width:18px; height:18px; border-radius:9px;
  display:flex; align-items:center; justify-content:center; padding:0 4px;
}
.nav-toggle{ display:none; background:none; border:none; cursor:pointer; padding:6px; }
.nav-toggle span{ display:block; width:24px; height:2px; background:var(--ink); margin:5px 0; transition:.3s; border-radius:2px; }

/* ============================================================
   Hero
   ============================================================ */
.hero{
  position:relative; overflow:hidden;
  background:
    radial-gradient(120% 90% at 80% 10%, rgba(156,204,90,.30), transparent 60%),
    linear-gradient(180deg, var(--cream) 0%, var(--cream-deep) 100%);
}
.hero-inner{
  display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center;
  max-width:var(--maxw); margin:0 auto; padding:72px 24px 84px;
}
.hero h1 .accent{ color:var(--sprout-deep); font-style:italic; }
.hero .lead{ font-size:1.2rem; color:var(--ink-soft); max-width:46ch; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:8px; }
.hero-badges{ display:flex; gap:22px; margin-top:34px; flex-wrap:wrap; }
.hero-badge{ display:flex; flex-direction:column; }
.hero-badge b{ font-family:var(--font-display); font-size:1.6rem; color:var(--sprout-deep); }
.hero-badge span{ font-size:.8rem; text-transform:uppercase; letter-spacing:.12em; color:var(--ink-soft); font-weight:700; }

.hero-art{ position:relative; display:flex; justify-content:center; }
.hero-logo{
  width:min(380px,80%); aspect-ratio:1; border-radius:50%;
  object-fit:cover; box-shadow:var(--shadow); border:8px solid #fff;
}
.hero-leaf{ position:absolute; opacity:.5; pointer-events:none; }

/* ============================================================
   Sections
   ============================================================ */
.section{ padding:72px 0; }
.section--tint{ background:var(--cream-deep); }
.section-head{ max-width:640px; margin:0 auto 44px; text-align:center; }

/* feature strip */
.features{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.feature{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  padding:30px 26px; box-shadow:var(--shadow-sm);
}
.feature .ic{ font-size:1.7rem; margin-bottom:10px; }
.feature h3{ margin-bottom:.35em; }
.feature p{ margin:0; color:var(--ink-soft); font-size:.97rem; }

/* ============================================================
   Product grid (home preview + shop)
   ============================================================ */
.product-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:24px;
}
.product-card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; box-shadow:var(--shadow-sm); display:flex; flex-direction:column;
  transition:transform .18s ease, box-shadow .18s ease;
}
.product-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
.product-card .pimg{ aspect-ratio:1; background:var(--cream-deep); }
.product-card .pimg img{ width:100%; height:100%; object-fit:cover; }
.product-card .pbody{ padding:18px 18px 20px; display:flex; flex-direction:column; gap:6px; flex:1; }
.product-card h3{ font-size:1.15rem; margin:0; }
.product-card .pdesc{ font-size:.88rem; color:var(--ink-soft); margin:0; flex:1; }
.product-card .prow{ display:flex; align-items:center; justify-content:space-between; margin-top:10px; }
.product-card .price{ font-family:var(--font-display); font-weight:600; font-size:1.25rem; color:var(--ink); }
.product-card .price small{ font-family:var(--font-body); font-size:.72rem; color:var(--ink-soft); font-weight:700; }
.tag{
  align-self:flex-start; font-size:.68rem; font-weight:800; text-transform:uppercase; letter-spacing:.1em;
  padding:.3em .7em; border-radius:999px; background:var(--cream-deep); color:var(--sprout-deep);
}
.tag--spicy{ background:#f3e3ec; color:var(--plum); }

/* ============================================================
   Split / story sections
   ============================================================ */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
.split img{ border-radius:var(--radius); box-shadow:var(--shadow); width:100%; object-fit:cover; }
.split--reverse .split-media{ order:2; }

/* CTA band */
.cta-band{
  background:linear-gradient(120deg,var(--sprout-deep),var(--sprout));
  color:#fff; border-radius:var(--radius); padding:54px 40px; text-align:center;
  box-shadow:var(--shadow);
}
.cta-band h2{ color:#fff; }
.cta-band p{ color:rgba(255,255,255,.92); max-width:48ch; margin:0 auto 1.4em; }
.cta-band .btn{ background:#fff; color:var(--sprout-deep); border-color:#fff; }
.cta-band .btn:hover{ background:var(--cream); }

/* ============================================================
   Information page
   ============================================================ */
.info-hero{ background:var(--cream-deep); padding:56px 0; text-align:center; }
.benefit-list{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:8px; }
.benefit{
  background:var(--white); border:1px solid var(--line); border-radius:14px; padding:22px;
  box-shadow:var(--shadow-sm);
}
.benefit .ic{ font-size:1.5rem; }
.benefit h3{ font-size:1.1rem; margin:.4em 0 .3em; }
.benefit p{ margin:0; font-size:.92rem; color:var(--ink-soft); }

.variety{
  display:grid; grid-template-columns:120px 1fr; gap:24px; align-items:center;
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  padding:22px 26px; box-shadow:var(--shadow-sm); margin-bottom:18px;
}
.variety img{ width:120px; height:120px; border-radius:14px; }
.variety h3{ margin:0 0 .3em; }
.variety p{ margin:0; color:var(--ink-soft); }
.variety .nutri{ display:flex; gap:8px; flex-wrap:wrap; margin-top:10px; }
.chip{ font-size:.72rem; font-weight:800; background:var(--cream-deep); color:var(--sprout-deep); padding:.3em .7em; border-radius:999px; }

/* ============================================================
   Forms (contact)
   ============================================================ */
.form-card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  padding:34px; box-shadow:var(--shadow); max-width:620px; margin:0 auto;
}
.field{ margin-bottom:18px; }
.field label{ display:block; font-weight:800; font-size:.9rem; margin-bottom:6px; color:var(--ink); }
.field input, .field textarea{
  width:100%; padding:13px 15px; border:1.5px solid var(--line); border-radius:12px;
  font-family:inherit; font-size:1rem; background:var(--cream); color:var(--ink);
  transition:border .2s ease, box-shadow .2s ease;
}
.field input:focus, .field textarea:focus{
  outline:none; border-color:var(--sprout); box-shadow:0 0 0 3px rgba(111,162,56,.18); background:#fff;
}
.field textarea{ min-height:130px; resize:vertical; }
.form-note{ font-size:.85rem; color:var(--ink-soft); margin-top:4px; }
.form-status{ margin-top:16px; padding:14px 16px; border-radius:12px; font-weight:700; display:none; }
.form-status.ok{ display:block; background:#e6f3da; color:var(--sprout-deep); }
.form-status.err{ display:block; background:#f6e3e3; color:#9a3b3b; }

/* ============================================================
   Cart drawer
   ============================================================ */
.drawer-overlay{
  position:fixed; inset:0; background:rgba(36,48,24,.45); opacity:0; visibility:hidden;
  transition:.25s; z-index:60;
}
.drawer-overlay.open{ opacity:1; visibility:visible; }
.drawer{
  position:fixed; top:0; right:0; height:100%; width:min(420px,92vw); background:var(--cream);
  transform:translateX(100%); transition:transform .3s cubic-bezier(.4,0,.2,1); z-index:70;
  display:flex; flex-direction:column; box-shadow:-10px 0 40px rgba(0,0,0,.2);
}
.drawer.open{ transform:translateX(0); }
.drawer-head{ display:flex; align-items:center; justify-content:space-between; padding:22px 24px; border-bottom:1px solid var(--line); }
.drawer-head h3{ margin:0; }
.drawer-close{ background:none; border:none; font-size:1.6rem; cursor:pointer; color:var(--ink); line-height:1; }
.drawer-items{ flex:1; overflow-y:auto; padding:12px 24px; }
.cart-empty{ text-align:center; color:var(--ink-soft); padding:48px 0; }
.cart-item{ display:grid; grid-template-columns:64px 1fr auto; gap:14px; align-items:center; padding:16px 0; border-bottom:1px solid var(--line); }
.cart-item img{ width:64px; height:64px; border-radius:12px; }
.cart-item .ci-name{ font-weight:800; font-size:.95rem; }
.cart-item .ci-price{ font-size:.85rem; color:var(--ink-soft); }
.qty{ display:flex; align-items:center; gap:8px; margin-top:6px; }
.qty button{ width:26px; height:26px; border-radius:8px; border:1.5px solid var(--line); background:#fff; cursor:pointer; font-weight:800; color:var(--ink); }
.qty span{ min-width:20px; text-align:center; font-weight:800; }
.ci-remove{ background:none; border:none; color:var(--plum); font-size:.8rem; cursor:pointer; font-weight:700; padding:0; margin-top:6px; }
.drawer-foot{ padding:22px 24px; border-top:1px solid var(--line); background:var(--cream-deep); }
.drawer-total{ display:flex; justify-content:space-between; font-weight:800; font-size:1.15rem; margin-bottom:14px; }
.drawer-foot .btn{ width:100%; }
.checkout-note{ font-size:.78rem; color:var(--ink-soft); text-align:center; margin-top:10px; }

/* ============================================================
   Footer
   ============================================================ */
.site-footer{ background:var(--ink); color:#d8e0cc; padding:54px 0 28px; margin-top:0; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; }
.site-footer h4{ color:#fff; font-family:var(--font-body); font-size:.8rem; text-transform:uppercase; letter-spacing:.18em; margin-bottom:16px; }
.site-footer a{ color:#c3d0b2; display:block; margin-bottom:8px; font-size:.95rem; }
.site-footer a:hover{ color:#fff; }
.footer-brand p{ color:#aebb9c; font-size:.92rem; max-width:34ch; }
.footer-brand .brand-name{ color:#fff; font-family:var(--font-display); font-size:1.3rem; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.12); margin-top:38px; padding-top:20px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; font-size:.84rem; color:#9aa888; }

/* ---- Social icons ---- */
.social-row{ display:flex; gap:12px; flex-wrap:wrap; margin-top:4px; }
.social-icon{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 14px; border-radius:999px;
  background:rgba(255,255,255,.08); color:#d8e0cc !important;
  font-size:.9rem; font-weight:700; margin-bottom:0 !important;
  transition:background .2s ease, color .2s ease, transform .15s ease;
}
.social-icon svg{ flex:none; }
.social-icon:hover{ background:var(--sprout); color:#fff !important; text-decoration:none; transform:translateY(-2px); }
/* darker variant for use on light backgrounds (e.g. contact page) */
.social-icon--dark{
  background:var(--cream-deep); color:var(--sprout-deep) !important; border:1px solid var(--line);
}
.social-icon--dark:hover{ background:var(--sprout-deep); color:#fff !important; }

/* ---- Sold-out product styling ---- */
.product-card.is-soldout .pimg img{ filter:grayscale(.7) opacity(.65); }
.soldout-badge{
  position:absolute; top:12px; left:12px; z-index:2;
  background:var(--plum); color:#fff; font-size:.72rem; font-weight:800;
  text-transform:uppercase; letter-spacing:.06em; padding:.35em .8em; border-radius:999px;
  box-shadow:var(--shadow-sm);
}
.product-card .pimg{ position:relative; }
.product-card.is-soldout .price{ color:var(--ink-soft); }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:980px){
  .hero-inner{ grid-template-columns:1fr; gap:32px; text-align:center; }
  .hero .lead{ margin-left:auto; margin-right:auto; }
  .hero-cta, .hero-badges{ justify-content:center; }
  .hero-art{ order:-1; }
  .product-grid{ grid-template-columns:repeat(2,1fr); }
  .features{ grid-template-columns:1fr; }
  .benefit-list{ grid-template-columns:1fr 1fr; }
  .split, .split--reverse{ grid-template-columns:1fr; gap:28px; }
  .split--reverse .split-media{ order:0; }
  .footer-grid{ grid-template-columns:1fr; gap:28px; }
}
@media (max-width:720px){
  .nav{ padding:10px 16px; gap:10px; }
  /* Collapsed menu drops down from directly under the header bar */
  .nav-links{
    position:absolute; top:100%; left:0; right:0;
    background:#f7f4ea;                 /* fully opaque cream, no transparency */
    flex-direction:column; align-items:stretch; gap:2px; padding:8px 14px 16px;
    border-top:1px solid var(--line); border-bottom:1px solid var(--line);
    box-shadow:0 16px 30px rgba(36,48,24,.16);
    transform:translateY(-12px); opacity:0; visibility:hidden;
    transition:transform .25s ease, opacity .25s ease, visibility .25s; z-index:60;
  }
  .nav-links.open{ transform:translateY(0); opacity:1; visibility:visible; }
  .nav-links a{ padding:.9em 1em; border-radius:10px; font-size:1.05rem; display:block; }
  .nav-toggle{ display:block; }
  .brand img{ height:42px; width:42px; }
  .brand .brand-name{ font-size:1rem; }
  .nav-right{ gap:8px; }
  /* Header sits above page content so the dropdown never blends with it */
  .site-header{ z-index:70; }
  .site-header .nav{ position:relative; }
}
/* Very small phones: keep the brand from crowding the controls */
@media (max-width:380px){
  .brand .brand-name small{ display:none; }
  .nav{ padding:10px 12px; }
}
@media (max-width:520px){
  .product-grid{ grid-template-columns:1fr; }
  .benefit-list{ grid-template-columns:1fr; }
  .variety{ grid-template-columns:1fr; text-align:center; }
  .variety img{ margin:0 auto; }
  .variety .nutri{ justify-content:center; }
}
