/* ==========================================================================
   Nu-tura Urbana — website styles
   Based on the Fresh Basil palette system
   ========================================================================== */

:root{
  /* PRIMARY */
  --basil:#4B8A37;
  --terracotta:#B5532E;
  --humus:#2C251B;
  --oat:#F7F2E5;
  --nasturtium:#F2A830;

  /* SECONDARY */
  --basil-deep:#2E5E22;
  --basil-lit:#7FB155;
  --mint-wash:#DCE8C9;
  --clay-wash:#EDDBCC;
  --nasturtium-bud:#D46A12;
  --loam:#403426;
  --oat-warm:#EFE6CE;
  --seed:#1A1A12;

  /* TYPE */
  --grotesk:'Space Grotesk','Helvetica Neue',Arial,sans-serif;
  --serif:'Fraunces',Georgia,serif;
  --mono:'JetBrains Mono','IBM Plex Mono',ui-monospace,monospace;

  /* METRICS */
  --page-max: 1360px;
  --page-pad: clamp(20px, 4vw, 56px);
  --radius-lg: 22px;
  --radius-md: 14px;
  --radius-sm: 8px;
}

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Fraunces:ital,wght@0,400;0,500;0,600;1,300;1,400;1,500&family=JetBrains+Mono:wght@400;500&display=swap');

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--oat);
  color:var(--humus);
  font-family:var(--grotesk);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img,svg{display:block;max-width:100%}
a{color:inherit}

/* grain */
body::before{
  content:"";
  position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.17 0 0 0 0 0.15 0 0 0 0 0.1 0 0 0 0.05 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;opacity:.6;
}

/* ==========================================================================
   Header / nav
   ========================================================================== */
.site-header{
  position:sticky;top:0;z-index:10;
  background:color-mix(in srgb, var(--oat) 88%, transparent);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border-bottom:1px solid #2C251B1A;
}
.site-header .row{
  max-width:var(--page-max);margin:0 auto;
  padding:16px var(--page-pad);
  display:flex;align-items:center;gap:32px;
}
.brandmark{
  font-family:var(--grotesk);font-weight:700;
  font-size:24px;letter-spacing:-0.045em;line-height:1;
  color:var(--humus);text-decoration:none;display:flex;align-items:baseline;gap:0;
}
.brandmark .m{color:var(--basil-deep)}
.brandmark .hy{color:var(--terracotta)}
.brandmark .sub{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:14px;letter-spacing:-0.01em;color:var(--basil-deep);
  margin-left:10px;
}

.nav-main{display:flex;gap:28px;margin-left:auto;align-items:center}
.nav-main a{
  font-family:var(--grotesk);font-weight:500;font-size:14.5px;
  color:var(--humus);text-decoration:none;opacity:.78;
  transition:opacity .15s ease, color .15s ease;
  position:relative;padding:4px 0;
}
.nav-main a:hover{opacity:1;color:var(--basil-deep)}
.nav-main a.active{opacity:1;color:var(--basil-deep)}
.nav-main a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--basil);border-radius:2px;
}

.lang-switch{
  display:flex;gap:2px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;
  padding:5px;border:1px solid #2C251B22;border-radius:999px;
}
.lang-switch button{
  all:unset;cursor:pointer;padding:4px 9px;border-radius:999px;
  text-transform:uppercase;color:var(--humus);opacity:.6;
}
.lang-switch button.active{background:var(--humus);color:var(--oat);opacity:1}
.lang-switch button:hover{opacity:1}

.menu-toggle{
  display:none;background:none;border:none;cursor:pointer;
  padding:8px;margin-left:auto;
  flex-direction:column;justify-content:center;gap:5px;
}
.menu-toggle span{
  display:block;width:24px;height:2px;background:var(--humus);
  transition:transform .2s, opacity .2s;
}
body.menu-open .menu-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.menu-open .menu-toggle span:nth-child(2){opacity:0}
body.menu-open .menu-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 22px;border-radius:999px;
  font-family:var(--grotesk);font-weight:600;font-size:14px;letter-spacing:-0.005em;
  text-decoration:none;border:1px solid transparent;cursor:pointer;
  transition:transform .15s ease, background .15s ease, color .15s ease;
  white-space:nowrap;
}
.btn.primary{background:var(--basil);color:var(--oat)}
.btn.primary:hover{background:var(--basil-deep);transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--humus);border-color:#2C251B33}
.btn.ghost:hover{background:#2C251B0A;border-color:var(--humus)}
.btn.on-dark{background:var(--nasturtium);color:var(--humus)}
.btn.on-dark:hover{background:var(--nasturtium-bud);color:var(--oat)}
.btn .arr{font-family:var(--serif);font-weight:400;font-size:18px;line-height:.8;transform:translateY(-1px)}
.btn.sm{padding:9px 16px;font-size:13px}

/* ==========================================================================
   Sections & typography
   ========================================================================== */
main{position:relative;z-index:2}
section{position:relative}
.wrap{max-width:var(--page-max);margin:0 auto;padding:0 var(--page-pad)}

.eyebrow{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--basil-deep);display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{
  content:"";width:18px;height:1px;background:var(--basil-deep);display:inline-block;
}

h1,h2,h3,h4{margin:0;font-weight:400}
h1.display{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(56px, 9vw, 132px);
  line-height:.9;letter-spacing:-0.025em;
  color:var(--humus);text-wrap:pretty;
}
h1.display em{font-style:italic;color:var(--basil-deep);font-weight:400}
h1.display .ta{font-style:italic;color:var(--terracotta)}
h2.section-title{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(36px, 5vw, 68px);
  line-height:.98;letter-spacing:-0.02em;text-wrap:pretty;
}
h2.section-title em{font-style:italic;color:var(--basil-deep)}
h3.sub{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(22px, 2.4vw, 30px);
  line-height:1.12;letter-spacing:-0.012em;
}
h3.sub em{font-style:italic;color:var(--basil-deep)}

p.lead{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(20px, 2vw, 26px);
  line-height:1.38;max-width:38ch;color:var(--humus);
}
p{max-width:62ch}
p.body{font-size:16.5px;line-height:1.6;color:var(--humus)}
p.body b{color:var(--basil-deep);font-weight:600}

.caption{
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--loam);
}

/* ==========================================================================
   Hero
   ========================================================================== */
.hero{
  padding:clamp(20px,2.5vw,36px) 0 clamp(60px,8vw,120px);
  position:relative;overflow:hidden;
}
.hero.hero-stacked{padding-bottom:0}
.hero.hero-stacked .wrap{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  padding-top:clamp(40px,6vw,80px);padding-bottom:clamp(48px,6vw,80px);
}
.hero-stack{display:flex;flex-direction:column;align-items:center;max-width:1000px}
.hero-stack .eyebrow{margin-bottom:30px}
.hero-stack .eyebrow::before{display:none}
.hero-stack h1.display{margin:0;text-align:center;max-width:14ch}
.hero-stack .lead{
  margin:30px auto 32px;max-width:54ch;text-align:center;
  font-family:var(--serif);font-style:italic;font-weight:400;
  color:var(--loam);
}
.hero-stack .cta-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.hero-band{
  width:100%;padding:0;
}
.hero-band .hero-visual{
  width:100%;aspect-ratio:2/1;border-radius:0;
  min-height:520px;max-height:840px;
  background:#2C251B;
}
.hero-band .hero-visual img{
  width:100%;height:100%;object-fit:cover;object-position:center 45%;display:block;
  position:relative;z-index:2;
}
.hero-band .hero-visual::before,
.hero-band .hero-visual::after{display:none}
.hero-band-secondary{margin-top:0}
.hero-band-secondary .hero-visual{aspect-ratio:2/1;min-height:380px;max-height:680px}
.hero-band .hero-visual .caption{
  position:absolute;bottom:18px;left:24px;z-index:3;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
  color:#F7F2E5;
  background:rgba(44,37,27,0.55);
  padding:8px 14px;border-radius:999px;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  max-width:calc(100% - 48px);
}
@media (max-width:520px){
  .hero-band .hero-visual .caption{font-size:9.5px;bottom:12px;left:14px;padding:6px 12px;letter-spacing:.14em}
}
.hero-band-alt{position:relative;margin-top:0}
.hero-band-alt .hero-visual{
  aspect-ratio:auto;min-height:560px;max-height:760px;
}
.hero-band-alt .hero-visual img{object-position:center 78%}
.hero-band-alt .alt-tag{
  position:absolute;top:14px;left:50%;transform:translateX(-50%);z-index:5;
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--oat);background:rgba(44,37,27,.7);padding:6px 14px;border-radius:999px;
  backdrop-filter:blur(6px);
}
@media (max-width:860px){
  .hero-band .hero-visual{aspect-ratio:5/3;min-height:220px}
}

.hero .wrap{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(40px,5vw,72px);align-items:start}
.hero-text-l{display:flex;flex-direction:column;justify-content:flex-start}
.hero-text-l .eyebrow{margin-bottom:22px}
.hero-text-l h1.display{margin:0 0 28px 0}
.hero-text-l .lead{margin:0 0 28px 0;max-width:46ch}
.hero-text-l .cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-text-l .meta-row{
  margin-top:auto;padding-top:40px;margin-top:48px;display:flex;gap:28px;flex-wrap:wrap;
  border-top:1px solid #2C251B1A;
}
.hero-text-l .meta-row .m{display:flex;flex-direction:column;gap:4px}
.hero-text-l .meta-row .m b{font-family:var(--grotesk);font-size:28px;font-weight:500;letter-spacing:-0.02em;color:var(--basil-deep)}
.hero-text-l .meta-row .m span{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--loam)}

.hero-visual{
  width:100%;aspect-ratio:5/4;
  border-radius:var(--radius-lg);overflow:hidden;
  position:relative;
  background:linear-gradient(160deg,var(--mint-wash),var(--basil-lit) 55%,var(--basil-deep) 110%);
  background-size:cover;background-position:center;
}
.hero-visual::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(45% 60% at 28% 72%, #1E4D15 0%, transparent 55%),
    radial-gradient(50% 55% at 68% 32%, #8FBE5A 0%, transparent 60%),
    radial-gradient(35% 50% at 85% 88%, #F4C97A 0%, transparent 62%),
    linear-gradient(160deg,var(--mint-wash),var(--basil-lit) 55%,var(--basil-deep) 110%);
  background-size:140% 140%;
  background-position:0% 50%;
  animation:heroPan 24s ease-in-out infinite alternate;
  transform-origin:center;
}
.hero-visual::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at center,transparent 55%,rgba(30,24,18,0.35) 100%);
}
@keyframes heroPan{
  0%   { background-position:0% 50%;   transform:scale(1.02); }
  100% { background-position:100% 45%; transform:scale(1.08); }
}
@media (prefers-reduced-motion:reduce){
  .hero-visual::before{animation:none}
}
.hero-visual .ph-tag{
  position:absolute;left:16px;bottom:16px;z-index:2;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;
  color:#F7F2E5CC;
}
@media (max-width:860px){
  .hero .wrap{grid-template-columns:1fr;gap:28px}
  .hero-visual{min-height:320px;aspect-ratio:4/3}
}
  color:var(--oat);opacity:.85;
}

/* ==========================================================================
   Placeholder image blocks
   ========================================================================== */
.ph{
  position:relative;border-radius:var(--radius-md);overflow:hidden;
  display:flex;align-items:flex-end;
  min-height:180px;
}
.ph::after{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,.15), transparent 40%),
    radial-gradient(circle at 80% 70%, rgba(0,0,0,.15), transparent 45%);
  pointer-events:none;
}
.ph > .ph-tag{
  position:relative;z-index:2;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--oat);opacity:.82;padding:14px;
}
.ph.basil{background:linear-gradient(160deg,var(--basil-lit),var(--basil-deep))}
.ph.terra{background:linear-gradient(160deg,#D27F5E,var(--terracotta))}
.ph.humus{background:linear-gradient(160deg,#5a4c38,var(--humus))}
.ph.mint{background:linear-gradient(160deg,#EBF0DB,var(--mint-wash));}
.ph.mint > .ph-tag{color:var(--humus)}
.ph.clay{background:linear-gradient(160deg,#F5E5D6,var(--clay-wash))}
.ph.clay > .ph-tag{color:var(--humus)}
.ph.oat{background:linear-gradient(160deg,var(--oat),var(--oat-warm))}
.ph.oat > .ph-tag{color:var(--humus)}
.ph.nasturtium{background:linear-gradient(160deg,var(--nasturtium),var(--nasturtium-bud))}
.ph.has-img{background:var(--humus);position:relative;overflow:hidden;display:block}
.ph.has-img::after{display:none}
.ph.has-img > img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}

/* ==========================================================================
   Intro band (for sub-pages)
   ========================================================================== */
.intro-band{padding:clamp(56px,8vw,110px) 0 clamp(30px,4vw,48px)}
.intro-band .grid{display:grid;grid-template-columns:1.3fr 1fr;gap:64px;align-items:end}

/* ==========================================================================
   How it works
   ========================================================================== */
.how{padding:clamp(70px,9vw,130px) 0;background:var(--oat-warm);position:relative}
.how .head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:56px}
.how .steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
  counter-reset:stp;
}
.how .step{
  background:var(--oat);border-radius:var(--radius-md);padding:22px;
  display:flex;flex-direction:column;gap:14px;min-height:260px;
  border:1px solid #2C251B10;
}
.how .step .n{
  font-family:var(--grotesk);font-weight:700;
  font-size:40px;line-height:1;letter-spacing:-0.04em;color:var(--basil-deep);
}
.how .step h3{
  font-family:var(--serif);font-weight:400;font-size:24px;line-height:1.1;letter-spacing:-0.012em;
}
.how .step h3 em{font-style:italic;color:var(--terracotta)}
.how .step p{font-size:14.5px;line-height:1.55;color:var(--loam);margin:0}
.how .step .when{
  margin-top:auto;font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--basil-deep);
}

/* ==========================================================================
   Whats included (system)
   ========================================================================== */
.system{padding:clamp(70px,9vw,130px) 0}
.system .head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:56px}
.system .grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.system .card{
  background:var(--oat-warm);border-radius:var(--radius-md);
  padding:28px;display:flex;flex-direction:column;gap:14px;
  position:relative;overflow:hidden;
}
.system .card.wide{grid-column:span 7}
.system .card.med{grid-column:span 5}
.system .card.third{grid-column:span 4}
.system .card.half{grid-column:span 6}
.system .card.full{grid-column:span 12}
.system .card.showcase{display:grid;grid-template-columns:minmax(280px,40%) 1fr;grid-template-rows:auto auto 1fr;column-gap:36px;row-gap:14px;align-items:start;min-height:380px}
.system .card.showcase > .tag{grid-column:1;grid-row:1}
.system .card.showcase > h3{grid-column:1;grid-row:2}
.system .card.showcase > p{grid-column:1;grid-row:3;align-self:end}
.system .card.showcase > .ph{grid-column:2;grid-row:1 / -1;min-height:340px;align-self:stretch;flex:initial}
@media (max-width:900px){
  .system .card.showcase{grid-template-columns:1fr;grid-template-rows:auto auto auto auto}
  .system .card.showcase > .ph{grid-column:1;grid-row:4;min-height:220px}
}
.system .card .ph{flex:none;height:300px;min-height:0;margin-top:auto}
.system .card .tag{font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--terracotta)}
.system .card h3{font-family:var(--serif);font-weight:400;font-size:28px;line-height:1.05;letter-spacing:-0.015em}
.system .card h3 em{font-style:italic;color:var(--basil-deep)}
.system .card p{font-size:15px;line-height:1.55;color:var(--loam);margin:0;max-width:42ch}
.system .card.dark{background:var(--humus);color:var(--oat)}
.system .card.dark h3{color:var(--oat)}
.system .card.dark h3 em{color:var(--nasturtium)}
.system .card.dark p{color:#F7F2E5cc}
.system .card.dark .tag{color:var(--nasturtium)}
.system .card.deep{background:var(--basil-deep);color:var(--oat)}
.system .card.deep h3{color:var(--oat)}
.system .card.deep h3 em{color:var(--nasturtium)}
.system .card.deep p{color:#F7F2E5cc}
.system .card.deep .tag{color:var(--mint-wash)}

/* ==========================================================================
   Regenerative credentials (callout strip)
   ========================================================================== */
.regen{padding:clamp(70px,9vw,130px) 0;background:var(--humus);color:var(--oat);position:relative;overflow:hidden}
.regen .head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:56px}
.regen h2.section-title{color:var(--oat)}
.regen h2.section-title em{color:var(--nasturtium)}
.regen .eyebrow{color:var(--basil-lit)}
.regen .eyebrow::before{background:var(--basil-lit)}
.regen .lead{color:#F7F2E5dd}
.regen .cols{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.regen .c{
  padding:32px;border-left:1px solid #F7F2E522;display:flex;flex-direction:column;gap:12px;
  min-height:320px;
}
.regen .c:first-child{border-left:none;padding-left:0}
.regen .c .n{
  font-family:var(--grotesk);font-weight:700;font-size:48px;line-height:1;letter-spacing:-0.04em;color:var(--nasturtium);
}
.regen .c h3{font-family:var(--serif);font-weight:400;font-size:26px;line-height:1.1;letter-spacing:-0.012em;color:var(--oat)}
.regen .c h3 em{font-style:italic;color:var(--basil-lit)}
.regen .c p{font-size:15px;line-height:1.55;color:#F7F2E5bb;margin:0}

/* Founders — light variant on oat-warm, dark text */
.founders{padding:clamp(70px,9vw,130px) 0;background:var(--oat-warm);color:var(--basil-deep);position:relative;overflow:hidden}
.founders .head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:56px}
.founders .eyebrow{color:var(--loam)}
.founders .eyebrow::before{background:var(--loam)}
.founders h2.section-title{color:var(--basil-deep)}
.founders h2.section-title em{color:var(--nasturtium)}
.founders .body{color:var(--loam);max-width:52ch}
.founders .cols{display:grid;grid-template-columns:repeat(2,1fr);gap:0}
.founders .c{
  padding:32px;border-left:1px solid #2C251B1A;display:flex;flex-direction:column;gap:14px;
}
.founders .c:first-child{border-left:none;padding-left:0}
.founders .c h3{font-family:var(--serif);font-weight:400;font-size:32px;line-height:1.1;letter-spacing:-0.012em;color:var(--basil-deep);margin:0}
.founders .c h3 em{font-style:italic;color:var(--basil)}
.founders .c p{font-size:15px;line-height:1.6;color:var(--loam);margin:0}
@media (max-width:860px){
  .founders .head{grid-template-columns:1fr;gap:24px}
  .founders .cols{grid-template-columns:1fr}
  .founders .c{border-left:none;border-top:1px solid #2C251B1A;padding:24px 0}
  .founders .c:first-child{border-top:none;padding-top:0}
}

/* ==========================================================================
   Plants grid
   ========================================================================== */
.plants{padding:clamp(70px,9vw,130px) 0}
.plants .head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:48px}
.plants .grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}
.plant{
  background:var(--oat-warm);border-radius:12px;padding:16px 14px 14px;
  display:flex;flex-direction:column;gap:10px;min-height:180px;position:relative;
  transition:transform .15s ease, background .15s ease;
  border:1px solid #2C251B10;
}
.plant:hover{transform:translateY(-2px);background:var(--mint-wash)}
.plant .swatch{
  width:100%;height:80px;border-radius:8px;
  background:linear-gradient(160deg, var(--basil-lit), var(--basil-deep));
  position:relative;overflow:hidden;
}
.plant .swatch::after{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.15), transparent 40%);
}
.plant.v2 .swatch{background:linear-gradient(160deg, #D27F5E, var(--terracotta))}
.plant.v3 .swatch{background:linear-gradient(160deg, #F7D385, var(--nasturtium))}
.plant.v4 .swatch{background:linear-gradient(160deg, #EBF0DB, var(--mint-wash))}
.plant.v5 .swatch{background:linear-gradient(160deg, #5a4c38, var(--humus))}
.plant.v6 .swatch{background:linear-gradient(160deg, #F5E5D6, var(--clay-wash))}
.plant .name{font-family:var(--serif);font-weight:400;font-size:17px;line-height:1.1;letter-spacing:-0.008em}
.plant .latin{font-family:var(--serif);font-style:italic;font-size:11.5px;color:var(--loam);opacity:.75;line-height:1.2}
.plant .tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:auto}
.plant .tg{
  font-family:var(--mono);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;
  padding:3px 6px;border-radius:4px;background:#2C251B10;color:var(--loam);
}
.plant .tg.med{background:var(--basil-deep);color:var(--oat)}
.plant .tg.comp{background:var(--nasturtium);color:var(--humus)}

/* ==========================================================================
   Tiers / modular chooser
   ========================================================================== */
.tiers{padding:clamp(70px,9vw,130px) 0;background:var(--mint-wash)}
.tiers .head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:56px}
.tiers .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;align-items:stretch}
.tier{
  background:var(--oat);border-radius:var(--radius-lg);padding:32px;
  display:flex;flex-direction:column;gap:20px;
  border:1px solid #2C251B14;position:relative;overflow:hidden;
}
.tier.featured{background:var(--humus);color:var(--oat);border-color:var(--humus)}
.tier.featured .tier-label{color:var(--nasturtium)}
.tier.featured .price{color:var(--oat)}
.tier.featured .price .mo{color:#F7F2E5bb}
.tier.featured li{color:#F7F2E5cc;border-color:#F7F2E522}
.tier.featured li::before{color:var(--basil-lit)}
.tier.featured .name em{color:var(--basil-lit)}
.tier .tier-label{
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--terracotta);
  display:flex;justify-content:space-between;align-items:center;
}
.tier .tier-label .badge{
  background:var(--nasturtium);color:var(--humus);padding:3px 8px;border-radius:4px;font-size:9px;
}
.tier-dim{
  font-family:var(--serif);font-size:40px;line-height:1;letter-spacing:-0.02em;
  color:var(--humus);display:flex;align-items:baseline;gap:8px;
  padding:10px 0 2px;border-top:1px solid #2C251B18;margin-top:4px;
}
.tier-dim span{
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--loam);align-self:center;
}
.tier-dim.on-dark{color:var(--oat);border-top-color:#F7F2E525}
.tier-dim.on-dark span{color:#F7F2E5aa}
.tier .name{font-family:var(--serif);font-weight:400;font-size:42px;line-height:.95;letter-spacing:-0.02em}
.tier .name em{font-style:italic;color:var(--basil-deep)}
.tier .price{
  font-family:var(--grotesk);font-weight:600;font-size:40px;line-height:1;letter-spacing:-0.03em;color:var(--humus);
  display:flex;align-items:baseline;gap:6px;
}
.tier .price .cur{font-size:22px;font-weight:500;opacity:.75}
.tier .price .mo{font-family:var(--serif);font-style:italic;font-weight:400;font-size:16px;letter-spacing:-0.005em;color:var(--loam);margin-left:6px}
.tier .sub-price{
  font-family:var(--grotesk);font-size:15px;color:var(--loam);
  padding-top:14px;border-top:1px solid #2C251B1A;
}
.tier.featured .sub-price{color:#F7F2E5bb;border-color:#F7F2E522}
.tier ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}
.tier li{
  font-size:14.5px;line-height:1.45;color:var(--humus);
  padding:11px 0;border-bottom:1px solid #2C251B0F;
  display:flex;gap:10px;align-items:flex-start;
}
.tier li::before{content:"●";color:var(--basil);font-size:9px;line-height:1.8;flex-shrink:0}
.tier .cta{margin-top:auto}

/* ==========================================================================
   Artisan band / about
   ========================================================================== */
.artisan{padding:clamp(70px,9vw,130px) 0}
.artisan .grid{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:center}
.artisan .body{display:flex;flex-direction:column;gap:22px;max-width:50ch}
.artisan .body p{font-size:16.5px;line-height:1.6}
.artisan .img-stack{position:relative;aspect-ratio:5/6}
.artisan .img-stack .ph{position:absolute;border-radius:var(--radius-md)}
.artisan .img-stack .ph.a{inset:0 30% 25% 0}
.artisan .img-stack .ph.b{inset:40% 0 0 40%}
.artisan .img-stack .ph.c{inset:15% 10% 55% 50%;border:4px solid var(--oat)}

/* ==========================================================================
   Quote / pull
   ========================================================================== */
.pull{padding:clamp(60px,7vw,100px) 0;background:var(--clay-wash)}
.pull .wrap{max-width:980px;text-align:center}
.pull blockquote{
  font-family:var(--serif);font-weight:400;font-style:italic;
  font-size:clamp(26px,3.6vw,44px);line-height:1.2;letter-spacing:-0.015em;
  margin:0;text-wrap:balance;color:var(--humus);
}
.pull blockquote em{color:var(--terracotta)}
.pull .who{
  margin-top:22px;font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--loam);
}

/* ==========================================================================
   Final CTA
   ========================================================================== */
.cta-block{padding:clamp(70px,9vw,130px) 0 clamp(90px,10vw,140px);background:var(--basil-deep);color:var(--oat);position:relative;overflow:hidden}
.cta-block::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at 85% 20%, var(--basil-lit), transparent 55%);
  opacity:.5;
}
.cta-block .wrap{position:relative;display:grid;grid-template-columns:1.2fr 1fr;gap:56px;align-items:end}
.cta-block h2{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(48px,7vw,96px);line-height:.95;letter-spacing:-0.02em;
  color:var(--oat);margin:0;
}
.cta-block h2 em{font-style:italic;color:var(--nasturtium)}
.cta-block .eyebrow{color:var(--nasturtium)}
.cta-block .eyebrow::before{background:var(--nasturtium)}
.cta-block .side{display:flex;flex-direction:column;gap:22px}
.cta-block .side p{color:#F7F2E5cc;font-size:16px;line-height:1.55;max-width:36ch;margin:0}
.cta-block .side .cta-row{display:flex;gap:12px;flex-wrap:wrap}

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer{background:var(--humus);color:var(--oat);padding:48px 0 24px}
.site-footer .wrap{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;align-items:start;max-width:var(--page-max);margin:0 auto;padding:0 var(--page-pad)}
.site-footer .brandmark{color:var(--oat)}
.site-footer .brandmark .m{color:var(--basil-lit)}
.site-footer .brandmark .hy{color:var(--nasturtium)}
.site-footer h4{
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--basil-lit);margin:0 0 14px;font-weight:500;
}
.site-footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.site-footer li a{
  color:#F7F2E5bb;font-size:14px;text-decoration:none;transition:color .15s ease;
}
.site-footer li a:hover{color:var(--oat)}
.site-footer .tag-col p{
  font-family:var(--serif);font-style:italic;font-size:18px;line-height:1.35;color:#F7F2E5cc;
  margin-top:14px;max-width:28ch;
}
.site-footer .legal{
  max-width:var(--page-max);margin:48px auto 0;padding:22px var(--page-pad) 0;
  border-top:1px solid #F7F2E522;
  display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#F7F2E577;
}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width:1100px){
  .plants .grid{grid-template-columns:repeat(4,1fr)}
  .system .card.wide,.system .card.med,.system .card.third,.system .card.half{grid-column:span 6}
  .how .steps{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .intro-band .grid,.how .head,.system .head,.plants .head,.tiers .head,.regen .head,.chooser .head,.artisan .grid,.cta-block .wrap{grid-template-columns:1fr;gap:32px}
  .chooser .matrix.matrix{grid-template-columns:1fr;padding:18px}
  .chooser .matrix .col,.chooser .matrix .col.featured{border-left:none;border-top:1px solid #2C251B1A;padding:18px 0;margin:0}
  .chooser .matrix .col:first-child{border-top:none;padding-top:0}
  .hero-visual{aspect-ratio:4/3}
  .tiers .grid{grid-template-columns:1fr}
  .regen .cols{grid-template-columns:1fr}
  .regen .c{border-left:none;border-top:1px solid #F7F2E522;padding:24px 0}
  .regen .c:first-child{border-top:none;padding-top:0}
  .site-footer .wrap{grid-template-columns:1fr 1fr}
  .nav-main{display:none}
  .nav-main.compact{display:flex;gap:14px}
  .nav-main.compact a{font-size:13px}
  .plants .grid{grid-template-columns:repeat(3,1fr)}
  .system .grid{grid-template-columns:1fr}
  .system .card.wide,
  .system .card.med,
  .system .card.third,
  .system .card.half,
  .system .card.full{grid-column:1}
  .system .card{min-height:0}
}
@media (max-width:520px){
  .plants .grid{grid-template-columns:repeat(2,1fr)}
  .how .steps{grid-template-columns:1fr}
  .site-footer .wrap{grid-template-columns:1fr}
  h1.display{font-size:38px;letter-spacing:-0.02em;line-height:1}
  .hero-stack{width:100%}
  .hero-stack h1.display{max-width:none;width:100%;align-self:stretch}
  .hero-stack .lead{font-size:16px;max-width:none;width:100%;align-self:stretch}
  /* prevent header from overflowing the viewport */
  body{overflow-x:hidden}
  .site-header .row{gap:10px;padding:12px 16px;flex-wrap:wrap}
  .brandmark{font-size:20px}
  .brandmark .sub{display:none}
  .menu-toggle{display:flex}
  .site-header .btn.primary.sm{display:none}
  /* keep language switcher visible on the top bar, just more compact */
  .lang-switch{padding:3px;gap:1px;margin-left:auto}
  .lang-switch button{padding:3px 7px;font-size:9.5px}
  .menu-toggle{margin-left:0}
  body.menu-open .site-header .row::after{
    content:"";flex-basis:100%;height:0;
  }
  body.menu-open .nav-main{
    display:flex;flex-direction:column;align-items:center;
    flex-basis:100%;gap:14px;padding:18px 0 6px;margin:6px 0 0;
    border-top:1px solid #2C251B1A;
  }
  body.menu-open .site-header .btn.primary.sm{
    display:inline-flex;justify-content:center;
    flex-basis:100%;margin:6px 0 4px;padding:11px 18px;font-size:13px;
  }
}

/* ==========================================================================
   Product page specifics
   ========================================================================== */
.chooser{padding:clamp(40px,6vw,80px) 0 clamp(70px,9vw,130px)}
.chooser .head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:36px}
.chooser .matrix{
  background:var(--oat-warm);border-radius:var(--radius-lg);padding:clamp(22px,3vw,40px);
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:0;
}
.chooser .col{padding:22px;border-left:1px solid #2C251B1A;display:flex;flex-direction:column;gap:14px}
.chooser .col:first-child{border-left:none}
.chooser .col.featured{background:var(--oat);border-radius:var(--radius-md);margin:-12px 0}
.chooser .col h3{font-family:var(--serif);font-weight:400;font-size:32px;line-height:1;letter-spacing:-0.02em}
.chooser .col h3 em{font-style:italic;color:var(--basil-deep)}
.chooser .col .price{font-family:var(--grotesk);font-weight:600;font-size:32px;letter-spacing:-0.02em;color:var(--humus)}
.chooser .col .mo{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--loam)}
.chooser .col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}
.chooser .col li{
  font-size:14px;padding:9px 0;border-bottom:1px solid #2C251B12;color:var(--humus);
}
.chooser .col li:last-child{border:none}
.chooser .col li b{font-weight:600;color:var(--basil-deep)}

/* ==========================================================================
   Timeline (how it works deep)
   ========================================================================== */
.timeline{padding:clamp(50px,6vw,100px) 0}
.timeline .wrap{display:grid;grid-template-columns:220px 1fr;gap:40px;align-items:start}
.timeline .side h2{position:sticky;top:90px}
.timeline .items{display:flex;flex-direction:column;gap:0}
.timeline .item{
  display:grid;grid-template-columns:120px 1fr;gap:32px;
  padding:28px 0;border-top:1px solid #2C251B1A;
}
.timeline .item:last-child{border-bottom:1px solid #2C251B1A}
.timeline .item .when{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--terracotta);padding-top:4px;
}
.timeline .item h3{
  font-family:var(--serif);font-weight:400;font-size:28px;line-height:1.05;letter-spacing:-0.015em;margin-bottom:10px;
}
.timeline .item h3 em{font-style:italic;color:var(--basil-deep)}
.timeline .item p{font-size:15.5px;line-height:1.55;color:var(--loam);margin:0;max-width:62ch}
@media (max-width:860px){
  .timeline .wrap{grid-template-columns:1fr}
  .timeline .item{grid-template-columns:1fr;gap:10px}
}
