/* ============ DESIGN TOKENS ============ */
:root{
  --cream: #f3ecd9;
  --cream-2: #ece4cf;
  --cream-deep: #e6dcc1;
  --green: #14281d;
  --green-2: #1c3527;
  --green-soft: #2a4736;
  --green-card: #94ad7a;
  --green-card-2: #aac28e;
  --ink: #1a1a1a;
  --muted: #5d5a4f;
  --line: rgba(20,40,29,.18);
  --accent: #c9a64a;
  --shadow-soft: 0 30px 60px -30px rgba(20,40,29,.35);
  --shadow-hard: 0 40px 80px -20px rgba(20,40,29,.45);
  --shadow-card: 8px 8px 0 #14281d;
  --radius: 14px;
  --radius-lg: 24px;
  --ease: cubic-bezier(.2,.7,.2,1);
}

*{margin:0;padding:0;box-sizing:border-box;-webkit-font-smoothing:antialiased}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{
  font-family:'Inter',sans-serif;
  background:var(--cream);
  color:var(--ink);
  overflow-x:hidden;
  line-height:1.55;
}

body::before{
  content:"";
  position:fixed; inset:0;
  background-image:
    radial-gradient(circle at 8% 12%, rgba(20,40,29,.06) 0 1px, transparent 1.5px),
    radial-gradient(circle at 92% 18%, rgba(20,40,29,.05) 0 1px, transparent 1.5px),
    radial-gradient(circle at 15% 80%, rgba(20,40,29,.05) 0 1px, transparent 1.5px),
    radial-gradient(circle at 85% 70%, rgba(20,40,29,.06) 0 1px, transparent 1.5px);
  background-size:280px 280px, 320px 320px, 360px 360px, 300px 300px;
  pointer-events:none;
  z-index:0;
  opacity:.9;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

.container{max-width:1280px;margin:0 auto;padding:0 32px;position:relative;z-index:1}

/* ============ ANNOUNCEMENT ============ */
.announce{
  background:var(--green);
  color:var(--cream);
  text-align:center;
  font-size:12px;
  letter-spacing:.18em;
  padding:10px 20px;
  font-weight:500;
  position:relative;
  z-index:50;
}
.announce a{text-decoration:underline;text-underline-offset:3px}

/* ============ NAV ============ */
.nav{
  position:sticky; top:0;
  background:rgba(243,236,217,.85);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  z-index:40;
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s var(--ease);
}
.nav.scrolled{box-shadow:0 6px 24px -16px rgba(20,40,29,.3)}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 0;
}
.logo{display:flex;align-items:center;gap:12px;color:var(--green)}
.logo-icon{width:40px;height:40px;display:grid;place-items:center}
.logo-icon svg{width:100%;height:100%}
.logo-text{font-family:'Fraunces',serif;font-size:24px;font-weight:700;letter-spacing:-.01em}

.nav-links{display:flex;gap:42px;align-items:center}
.nav-links a{
  font-size:14px; font-weight:500; color:var(--green);
  position:relative; padding:6px 0;
  transition:color .2s var(--ease);
}
.nav-links a::after{
  content:""; position:absolute; left:50%; bottom:0;
  width:0; height:2px; background:var(--green);
  transition:width .3s var(--ease), left .3s var(--ease);
}
.nav-links a:hover::after, .nav-links a.active::after{width:100%; left:0}
.nav-links a.active{font-weight:600}

.nav-actions{display:flex;align-items:center;gap:18px}
.icon-btn{
  width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;
  color:var(--green);
  transition:background .2s var(--ease), transform .2s var(--ease);
  position:relative;
}
.icon-btn:hover{background:rgba(20,40,29,.08); transform:translateY(-1px)}
.icon-btn svg{width:20px;height:20px}
.cart-count{
  position:absolute; top:4px; right:4px;
  width:18px;height:18px;border-radius:50%;
  background:var(--green); color:var(--cream);
  font-size:10px; font-weight:600;
  display:grid;place-items:center;
  transition:transform .3s var(--ease);
}
.cart-count.pulse{animation:pulse .5s var(--ease)}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.4)}}

.menu-toggle{display:none}

/* ============ HERO ============ */
.hero{
  padding:80px 0 100px;
  position:relative;
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.05fr 1fr;
  gap:60px;
  align-items:center;
}
.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-size:12px; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--green);
  padding:8px 16px;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(255,255,255,.4);
  margin-bottom:28px;
  opacity:0; transform:translateY(20px);
  animation:fadeUp .8s var(--ease) .1s forwards;
}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:#3d8a4f;box-shadow:0 0 0 3px rgba(61,138,79,.2)}

.hero h1{
  font-family:'Fraunces',serif;
  font-size:clamp(64px, 9vw, 132px);
  line-height:.9;
  font-weight:800;
  letter-spacing:-.04em;
  color:var(--ink);
  margin-bottom:32px;
  opacity:0; transform:translateY(30px);
  animation:fadeUp .9s var(--ease) .2s forwards;
}
.hero h1 span{display:block}
.hero h1 .period{color:var(--green)}
.hero-tag{
  font-family:'Fraunces',serif;
  font-size:24px;
  font-weight:500;
  font-style:italic;
  color:var(--green);
  margin-bottom:16px;
  opacity:0; transform:translateY(20px);
  animation:fadeUp .9s var(--ease) .35s forwards;
}
.hero-desc{
  font-size:16px; color:var(--muted); max-width:380px;
  margin-bottom:40px;
  opacity:0; transform:translateY(20px);
  animation:fadeUp .9s var(--ease) .45s forwards;
}

.features-row{
  display:flex; gap:32px;
  margin-bottom:42px;
  opacity:0; transform:translateY(20px);
  animation:fadeUp .9s var(--ease) .55s forwards;
}
.feature-pill{text-align:center;flex:1; max-width:110px}
.feature-icon{
  width:62px;height:62px;border-radius:50%;
  border:1.5px solid var(--green);
  display:grid;place-items:center;
  margin:0 auto 12px;
  color:var(--green);
  background:rgba(255,255,255,.3);
  transition:transform .35s var(--ease), background .3s var(--ease);
}
.feature-pill:hover .feature-icon{
  transform:translateY(-4px) rotate(-4deg);
  background:rgba(255,255,255,.6);
}
.feature-icon svg{width:26px;height:26px}
.feature-pill p{
  font-size:10px; font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--green);
  line-height:1.4;
}

.hero-ctas{
  display:flex; gap:14px;
  opacity:0; transform:translateY(20px);
  animation:fadeUp .9s var(--ease) .65s forwards;
}
.btn{
  padding:16px 32px; border-radius:999px;
  font-size:13px; font-weight:700; letter-spacing:.16em;
  text-transform:uppercase;
  display:inline-flex; align-items:center; gap:10px;
  transition: transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease), box-shadow .25s var(--ease);
  cursor:pointer; border:1.5px solid transparent;
  position:relative; overflow:hidden;
}
.btn-primary{
  background:var(--green); color:var(--cream);
  box-shadow:0 12px 24px -12px rgba(20,40,29,.5);
}
.btn-primary:hover{
  background:var(--green-2);
  transform:translateY(-2px);
  box-shadow:0 16px 32px -10px rgba(20,40,29,.55);
}
.btn-primary:active{transform:translateY(0)}
.btn-ghost{
  background:transparent; color:var(--green);
  border-color:var(--green);
}
.btn-ghost:hover{background:var(--green); color:var(--cream); transform:translateY(-2px)}
.btn-card{
  background:rgba(243,236,217,.85);
  color:var(--green);
  border:1.5px solid var(--green);
}
.btn-card:hover{background:var(--green); color:var(--cream)}

.hero-visual{
  position:relative;
  height:600px;
  opacity:0;
  animation:fadeUp 1.2s var(--ease) .3s forwards;
}
.product-box{
  position:absolute;
  left:5%; top:50%; transform:translateY(-50%);
  width:60%; height:88%;
  background:linear-gradient(170deg, var(--green) 0%, var(--green-2) 60%, #0d1c14 100%);
  border-radius:8px;
  box-shadow: var(--shadow-hard), inset 0 0 0 1px rgba(255,255,255,.04);
  padding:32px 28px;
  display:flex; flex-direction:column;
  justify-content:space-between;
  color:var(--cream);
  overflow:hidden;
  transition: transform .6s var(--ease);
}
.product-box::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(circle at 70% 20%, rgba(255,255,255,.05), transparent 60%);
  pointer-events:none;
}
.product-box:hover{transform:translateY(-50%) rotate(-1deg) scale(1.02)}

.box-top{display:flex; justify-content:space-between; align-items:flex-start; position:relative}
.badge-zero{
  background:var(--cream); color:var(--green);
  border-radius:999px; padding:8px 14px;
  font-family:'Fraunces',serif;
  font-weight:700; font-size:14px;
  display:flex;align-items:center;gap:6px;
}
.badge-zero small{font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;line-height:1}

.box-roll{margin:auto 0; text-align:center; position:relative}
.roll-img{
  width:80%;
  margin:0 auto;
  height:200px;
  background:
    radial-gradient(ellipse at center, var(--cream) 0%, var(--cream) 35%, var(--cream-deep) 45%, var(--cream) 55%, var(--cream-deep) 100%);
  border-radius:50%/40%;
  position:relative;
  box-shadow:0 20px 40px -10px rgba(0,0,0,.4), inset 0 -10px 20px rgba(0,0,0,.1);
}
.roll-img::before{
  content:""; position:absolute; inset:30% 35% 30% 35%;
  background:radial-gradient(circle, var(--green-2), var(--green) 70%);
  border-radius:50%;
  box-shadow:inset 0 2px 6px rgba(0,0,0,.5);
}

.box-text{position:relative;z-index:2}
.box-text h3{
  font-family:'Fraunces',serif;
  font-size:36px; line-height:1;
  font-weight:800;
  letter-spacing:-.02em;
}
.box-text .reusable{font-size:14px;font-weight:600;letter-spacing:.2em;display:block;margin-bottom:6px;color:rgba(243,236,217,.85)}
.box-text .bamboo{font-size:14px;font-weight:600;letter-spacing:.2em;display:block;margin-bottom:14px;color:rgba(243,236,217,.85)}
.box-text .ptowels{font-style:italic; color:var(--cream)}
.box-text .sub{
  font-size:9px; letter-spacing:.2em; font-weight:600;
  color:rgba(243,236,217,.6);
  margin-top:18px;
  border-top:1px solid rgba(243,236,217,.2);
  padding-top:12px;
}

.roll-stack{
  position:absolute;
  right:0; top:50%; transform:translateY(-50%);
  width:38%; height:65%;
  display:flex; align-items:center; justify-content:center;
}
.roll-cyl{
  width:75%; aspect-ratio:1/1.3;
  background:
    linear-gradient(90deg,
      var(--cream-deep) 0%, var(--cream) 8%,
      var(--cream) 50%, var(--cream-2) 75%,
      var(--cream-deep) 100%);
  border-radius:50%/12%;
  box-shadow: var(--shadow-soft), inset 0 -10px 20px rgba(0,0,0,.08);
  position:relative;
}
.roll-cyl::before{
  content:""; position:absolute; left:50%; top:8%; transform:translateX(-50%);
  width:30%; aspect-ratio:1/1;
  background:radial-gradient(circle, var(--green) 30%, var(--green-2) 70%);
  border-radius:50%;
  box-shadow:inset 0 4px 8px rgba(0,0,0,.5);
}

.seal{
  position:absolute;
  top:0; right:-10px;
  width:130px; height:130px;
  border-radius:50%;
  background:var(--cream);
  border:1.5px solid var(--green);
  display:grid;place-items:center;
  font-family:'Fraunces',serif;
  color:var(--green);
  transform:rotate(15deg);
  z-index:5;
  animation: spinSlow 22s linear infinite;
}
.seal-inner{
  text-align:center;
  font-size:11px; line-height:1.3;
  font-weight:700; letter-spacing:.08em;
  text-transform:uppercase;
}
.seal-inner span{display:block}
.seal-inner .star{font-size:8px;margin:4px 0;color:var(--green)}
@keyframes spinSlow{to{transform:rotate(375deg)}}

/* ============ STATS STRIP ============ */
.stats-strip{
  background:var(--green);
  color:var(--cream);
  padding:28px 0;
  margin-top:-1px;
  position:relative;
  z-index:2;
}
.stats-inner{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  align-items:center;
}
.stat{
  display:flex; align-items:center; gap:14px;
  padding-left:20px;
  border-left:1px solid rgba(243,236,217,.18);
}
.stat:first-child{border-left:none; padding-left:0}
.stat-icon{
  width:44px;height:44px;
  border-radius:50%;
  border:1px solid rgba(243,236,217,.35);
  display:grid;place-items:center;
  flex-shrink:0;
}
.stat-icon svg{width:20px;height:20px}
.stat p{
  font-size:11px; font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  line-height:1.4;
}

/* ============ SECTION HEADERS ============ */
section{position:relative;z-index:1}
.section-title{
  font-family:'Fraunces',serif;
  font-size:clamp(40px, 5vw, 72px);
  line-height:.95;
  font-weight:800;
  letter-spacing:-.03em;
  color:var(--ink);
}
.section-title em{font-style:normal;color:var(--green)}
.section-eyebrow{
  font-size:11px; font-weight:700;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--green);
  margin-bottom:18px;
}
.section-lead{
  font-size:17px;
  color:var(--muted);
  max-width:520px;
  margin-top:22px;
  line-height:1.7;
}

/* ============ PAGE HEADER (for subpages) ============ */
.page-head{
  padding:90px 0 60px;
  text-align:center;
}
.page-head .section-title{margin-bottom:14px}
.page-head .section-lead{margin:14px auto 0}

/* ============ WHY BAMBOO (Home) ============ */
.why{padding:100px 0; text-align:center}
.why-head{max-width:760px; margin:0 auto 60px}
.why-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:24px;
}
.why-card{
  background:var(--green-card);
  border:2px solid var(--green);
  border-radius:var(--radius-lg);
  padding:40px 24px;
  text-align:center;
  box-shadow:var(--shadow-card);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.why-card:hover{
  transform:translate(-3px,-3px);
  box-shadow:11px 11px 0 var(--green);
}
.why-card-icon{
  width:72px;height:72px;
  display:grid;place-items:center;
  margin:0 auto 30px;
  color:var(--green);
}
.why-card-icon svg{width:100%;height:100%}
.why-card .pct{
  font-family:'Inter',sans-serif;
  font-size:18px; font-weight:800;
  color:var(--green);
  letter-spacing:.04em;
}
.why-card .label{
  display:block;
  margin-top:8px;
  font-family:'Inter',sans-serif;
  font-size:13px; font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--green);
}

/* ============ STORY / ABOUT ============ */
.story{padding:120px 0 60px}
.story-head{text-align:center; max-width:780px; margin:0 auto 80px}

.story-block{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
  margin-bottom:120px;
}
.story-block.reverse{direction:rtl}
.story-block.reverse > *{direction:ltr}

.story-img{
  aspect-ratio: 4/5;
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-soft);
  background:var(--cream-2);
  position:relative;
}
.story-img img{width:100%;height:100%;object-fit:cover; transition:transform 1s var(--ease)}
.story-img:hover img{transform:scale(1.06)}

.story-content h2{
  font-family:'Fraunces',serif;
  font-size:clamp(36px, 4vw, 56px);
  line-height:1;
  font-weight:800;
  letter-spacing:-.03em;
  margin-bottom:24px;
  color:var(--ink);
}
.story-content h2 em{font-style:normal;color:var(--green)}
.story-content p{
  font-size:17px; color:var(--muted);
  line-height:1.7;
  max-width:480px;
}
.story-content p + p{margin-top:14px}

/* ============ HOW IT WORKS (cream variant for home) ============ */
.how{
  padding:120px 0;
  background:var(--cream-2);
  position:relative;
  overflow:hidden;
}
.how-head{text-align:center; max-width:680px; margin:0 auto 80px}

.steps{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  position:relative;
}
.step{
  background:var(--green-card);
  border:2px solid var(--green);
  border-radius:var(--radius-lg);
  padding:30px 24px 24px;
  box-shadow:var(--shadow-card);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
  display:flex; flex-direction:column;
  text-align:center;
}
.step:hover{
  transform:translate(-3px,-3px);
  box-shadow:11px 11px 0 var(--green);
}
.step-num{
  font-family:'Inter',sans-serif;
  font-size:13px; font-weight:700;
  color:var(--green);
  opacity:.6;
  text-align:left;
  margin-bottom:8px;
}
.step-icon{
  width:100px;height:100px;
  margin:0 auto 16px;
  display:grid;place-items:center;
  color:var(--green);
}
.step-icon svg{width:100%;height:100%}
.step h3{
  font-family:'Fraunces',serif;
  font-size:28px; font-weight:800;
  letter-spacing:.02em;
  text-transform:uppercase;
  margin-bottom:10px;
  color:var(--green);
}
.step p{
  font-size:14px; color:var(--green);
  opacity:.85;
  line-height:1.5;
  margin-bottom:24px;
  flex:1;
}
.step .btn{
  width:100%; justify-content:center;
  padding:12px 20px;
  font-size:11px;
}

/* ============ SHOP ============ */
.shop-section{padding:90px 0 120px}
.shop-head{margin-bottom:60px}
.shop-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:32px;
  max-width:880px;
  margin:0 auto;
}
.shop-card{
  background:var(--cream);
  border:1.5px solid var(--green);
  border-radius:var(--radius-lg);
  padding:30px;
  box-shadow:var(--shadow-card);
  display:flex; flex-direction:column;
  position:relative;
  transition:transform .3s var(--ease);
}
.shop-card:hover{transform:translate(-2px,-2px); box-shadow:10px 10px 0 var(--green)}
.shop-card-img{
  background:var(--cream);
  border-radius:var(--radius);
  aspect-ratio:1/1;
  display:grid; place-items:center;
  margin-bottom:20px;
  position:relative;
}
.shop-card-img img{width:80%; height:80%; object-fit:contain}
.shop-card-badge{
  position:absolute;
  top:14px; right:14px;
  background:#fff;
  color:var(--ink);
  font-size:12px; font-weight:700;
  padding:6px 12px;
  border-radius:6px;
  letter-spacing:.05em;
  display:flex; align-items:center; gap:4px;
}
.shop-card h3{
  font-family:'Fraunces',serif;
  font-size:24px; font-weight:800;
  text-transform:uppercase;
  letter-spacing:.02em;
  color:var(--ink);
  margin-bottom:8px;
  line-height:1.1;
}
.shop-card .meta{
  font-size:11px; font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--green);
  opacity:.7;
  margin-bottom:14px;
}
.shop-card .price{
  font-family:'Inter',sans-serif;
  font-size:24px; font-weight:800;
  color:var(--ink);
  margin-bottom:6px;
}
.shop-card .stars{margin-bottom:18px; font-size:14px}
.shop-card ul{list-style:none; display:flex; flex-direction:column; gap:10px; margin-bottom:22px}
.shop-card li{
  display:flex; align-items:center; gap:10px;
  font-size:14px; color:var(--ink);
}
.shop-card li svg{width:18px;height:18px; color:var(--green); flex-shrink:0}
.shop-card .btn{margin-top:auto; justify-content:center}
.member-line{
  text-align:center;
  margin-top:14px;
  font-size:13px; font-weight:600;
  color:var(--green);
  display:flex; align-items:center; justify-content:center; gap:6px;
}
.member-line a{text-decoration:none}
.member-line a:hover{text-decoration:underline}

/* ============ MEMBERS ============ */
.members-section{padding:60px 0 120px}
.members-head{margin-bottom:50px}
.members-head .section-lead{margin-top:8px; max-width:none}
.members-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:32px;
  max-width:880px;
  margin:0 auto;
}
.member-card{
  background:var(--cream);
  border:1.5px solid var(--green);
  border-radius:var(--radius-lg);
  padding:30px;
  box-shadow:var(--shadow-card);
  display:flex; flex-direction:column;
}
.member-card-img{
  background:var(--cream);
  border-radius:var(--radius);
  aspect-ratio:1/1;
  display:grid; place-items:center;
  margin-bottom:20px;
}
.member-card-img img{width:80%; height:80%; object-fit:contain}
.member-card h3{
  font-family:'Fraunces',serif;
  font-size:24px; font-weight:800;
  text-transform:uppercase;
  letter-spacing:.02em;
  margin-bottom:6px;
}
.member-card .tag{
  font-size:11px; font-weight:700;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--green); opacity:.75;
  margin-bottom:14px;
}
.member-card .price-row{
  display:flex; align-items:baseline; gap:10px;
  margin-bottom:8px;
}
.member-card .price-row strong{
  font-size:32px; font-weight:800; color:var(--ink);
}
.member-card .price-row .strike{
  font-size:18px; text-decoration:line-through;
  color:var(--muted);
}
.member-card .stars{margin-bottom:18px}
.member-card ul{list-style:none; display:flex; flex-direction:column; gap:12px; margin-bottom:24px}
.member-card li{
  display:flex; align-items:center; gap:10px;
  font-size:14px; color:var(--ink);
}
.member-card li svg{width:18px;height:18px; color:var(--green); flex-shrink:0}
.member-card .btn{margin-top:auto; justify-content:center}

/* ============ PRODUCT DETAIL ============ */
.product-section{padding:90px 0 120px}
.product-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:start;
}
.product-display{
  position:relative;
  aspect-ratio:1/1;
  background:var(--cream);
  border:2px solid var(--green);
  border-radius:var(--radius-lg);
  display:grid;place-items:center;
  overflow:hidden;
  box-shadow:var(--shadow-card);
}
.product-display img{
  width:75%; height:75%; object-fit:contain;
  filter:drop-shadow(0 30px 40px rgba(20,40,29,.25));
  transition:transform .6s var(--ease);
}
.product-display:hover img{transform:scale(1.03)}

.product-info h2{
  font-family:'Fraunces',serif;
  font-size:clamp(40px, 5vw, 64px);
  line-height:1;
  font-weight:800;
  letter-spacing:-.03em;
  margin-bottom:14px;
  text-transform:uppercase;
}
.product-info .tagline{
  font-family:'Inter',sans-serif;
  font-size:20px; font-weight:600;
  color:var(--ink);
  margin-bottom:20px;
}
.product-info .price-line{
  display:flex;align-items:center;gap:16px;
  margin:18px 0 20px;
  flex-wrap:wrap;
}
.stars{color:var(--accent); font-size:18px; letter-spacing:2px}
.stars.muted{color:#aac28e}
.reviews{font-size:13px; color:var(--muted); text-decoration:underline}

.size-picker{
  display:inline-block;
  border:1.5px dashed var(--green);
  border-radius:10px;
  padding:14px 28px;
  font-size:15px; color:var(--green);
  margin:6px 0 24px;
  background:rgba(170,194,142,.15);
}
.product-desc{
  font-size:16px; color:var(--muted);
  line-height:1.7;
  margin-bottom:30px;
}
.product-desc b, .product-desc strong{color:var(--ink)}

.feature-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:20px;
  margin:30px 0;
}
.feat{text-align:center}
.feat-icon{
  width:80px; height:80px;
  margin:0 auto 12px;
  background:var(--cream-2);
  border-radius:50%;
  display:grid; place-items:center;
  color:var(--green);
}
.feat-icon svg{width:40px; height:40px}
.feat p{font-size:13px; line-height:1.3}
.feat p strong{display:block; color:var(--ink); font-weight:700}

.price-tag{
  display:inline-flex; align-items:baseline; gap:6px;
  font-family:'Fraunces',serif;
  margin:18px 0;
}
.price-tag .currency{font-size:22px; color:var(--muted)}
.price-tag .amount{font-size:80px; font-weight:800; color:var(--green); line-height:1}
.price-tag .note{font-size:13px; color:var(--muted); margin-left:10px; font-family:'Inter',sans-serif; align-self:end; padding-bottom:8px}

/* ============ REVIEWS ============ */
.reviews-section{
  padding:100px 0;
  background:var(--cream-2);
}
.reviews-head{text-align:center; max-width:720px; margin:0 auto 50px}
.reviews-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.review-card{
  background:var(--cream);
  padding:30px 26px;
  border-radius:var(--radius);
  border:1px solid var(--line);
  transition:transform .35s var(--ease), box-shadow .3s var(--ease);
  display:flex; flex-direction:column;
}
.review-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-soft);
}
.review-head{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.review-avatar{
  width:46px;height:46px;border-radius:50%;
  background:var(--green); color:var(--cream);
  display:grid;place-items:center;
  font-family:'Fraunces',serif;
  font-weight:700; font-size:20px;
}
.review-name{font-weight:600; font-size:15px}
.review-stars{color:var(--accent); letter-spacing:2px; margin-bottom:14px}
.review-card h4{
  font-family:'Fraunces',serif;
  font-size:18px;
  text-transform:uppercase;
  letter-spacing:.04em;
  margin-bottom:12px;
  color:var(--green);
}
.review-card p{font-size:14px; color:var(--muted); line-height:1.65; flex:1}
.review-verified{
  font-size:11px; font-weight:600;
  letter-spacing:.12em; text-transform:uppercase;
  color:#5d8a5d;
  margin-top:18px;
  padding-top:14px;
  border-top:1px dashed var(--line);
}

/* ============ FAQ ============ */
.faq-section{padding:100px 0}
.faq-grid{
  display:grid;
  grid-template-columns: 0.6fr 1fr;
  gap:80px;
  align-items:start;
}
.faq-list{display:flex;flex-direction:column;gap:8px}
.faq-item{border-bottom:1px solid var(--line); padding:22px 0}
.faq-q{
  width:100%; text-align:left;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  font-family:'Fraunces',serif;
  font-size:22px; font-weight:600;
  color:var(--ink);
  cursor:pointer;
  transition:color .2s var(--ease);
}
.faq-q:hover{color:var(--green)}
.faq-q-icon{
  width:36px;height:36px;border-radius:50%;
  border:1.5px solid var(--green); color:var(--green);
  display:grid;place-items:center;
  flex-shrink:0;
  transition:transform .35s var(--ease), background .25s var(--ease), color .25s var(--ease);
}
.faq-item.open .faq-q-icon{
  transform:rotate(45deg);
  background:var(--green); color:var(--cream);
}
.faq-a{
  max-height:0; overflow:hidden;
  transition:max-height .45s var(--ease), padding .35s var(--ease);
  color:var(--muted); font-size:15px; line-height:1.7;
}
.faq-item.open .faq-a{
  max-height:400px;
  padding-top:16px;
}

/* ============ CTA ============ */
.cta{
  padding:100px 0;
  background:var(--green);
  color:var(--cream);
  position:relative; overflow:hidden;
}
.cta::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(circle at 10% 20%, rgba(243,236,217,.05), transparent 50%),
    radial-gradient(circle at 90% 80%, rgba(243,236,217,.06), transparent 50%);
}
.cta-inner{text-align:center; max-width:760px; margin:0 auto; position:relative}
.cta .section-eyebrow{color:var(--cream); opacity:.7}
.cta h2{
  font-family:'Fraunces',serif;
  font-size:clamp(56px, 7vw, 100px);
  line-height:.95; font-weight:800;
  letter-spacing:-.03em;
  margin:16px 0 28px;
  color:var(--cream);
}
.cta h2 em{font-style:italic; color:#a8c8a8}
.cta p{font-size:18px; color:rgba(243,236,217,.75); margin-bottom:40px; line-height:1.6}
.cta-buttons{display:inline-flex;gap:14px;flex-wrap:wrap;justify-content:center}
.cta .btn-primary{background:var(--cream); color:var(--green)}
.cta .btn-primary:hover{background:#fff}
.cta .btn-ghost{color:var(--cream); border-color:var(--cream)}
.cta .btn-ghost:hover{background:var(--cream); color:var(--green)}

/* ============ FOOTER ============ */
footer{
  background:var(--cream-2);
  color:var(--ink);
  padding:80px 0 30px;
}
.foot-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:50px;
  max-width:900px;
  margin:0 auto 50px;
  text-align:center;
}
.foot-col h5{
  font-family:'Inter',sans-serif;
  color:var(--ink);
  font-size:18px;
  margin-bottom:20px;
  font-weight:700;
}
.foot-col ul{list-style:none; display:flex; flex-direction:column; gap:14px}
.foot-col a{
  font-size:15px;
  color:var(--ink);
  transition:color .2s;
  cursor:pointer;
}
.foot-col a:hover{color:var(--green); text-decoration:underline}
.foot-col p{font-size:15px; line-height:1.6; color:var(--ink)}

.foot-brand-center{
  text-align:center;
  margin-bottom:30px;
}
.foot-brand-center .logo{
  display:inline-flex;
  justify-content:center;
}
.foot-brand-center .logo-text{
  font-family:'Inter',sans-serif;
  font-size:18px;
  font-weight:600;
  letter-spacing:.32em;
  color:var(--ink);
}

.foot-bottom-links{
  display:flex; justify-content:center; gap:40px;
  margin-bottom:18px;
  flex-wrap:wrap;
}
.foot-bottom-links a{
  font-size:14px;
  color:var(--ink);
  cursor:pointer;
}
.foot-bottom-links a:hover{color:var(--green); text-decoration:underline}

.foot-copy{
  text-align:center;
  font-size:14px;
  color:var(--ink);
  opacity:.85;
}

.foot-socials{
  display:flex; justify-content:center; gap:14px;
  margin-top:24px;
}
.foot-socials a{
  width:40px;height:40px;border-radius:50%;
  border:1.5px solid var(--green);
  display:grid;place-items:center;
  color:var(--green);
  transition:background .2s, transform .2s;
}
.foot-socials a:hover{background:var(--green); color:var(--cream); transform:translateY(-2px)}
.foot-socials svg{width:18px;height:18px}

/* ============ CART DRAWER ============ */
.cart-overlay{
  position:fixed; inset:0;
  background:rgba(20,40,29,.5);
  backdrop-filter:blur(4px);
  z-index:90;
  opacity:0; pointer-events:none;
  transition:opacity .35s var(--ease);
}
.cart-overlay.open{opacity:1; pointer-events:all}
.cart-drawer{
  position:fixed; top:0; right:0; bottom:0;
  width:min(420px, 100%);
  background:var(--cream);
  z-index:100;
  transform:translateX(100%);
  transition:transform .45s var(--ease);
  display:flex; flex-direction:column;
  box-shadow:-20px 0 60px -20px rgba(20,40,29,.4);
}
.cart-drawer.open{transform:translateX(0)}
.cart-head{
  padding:28px 28px 18px;
  display:flex; justify-content:space-between; align-items:center;
  border-bottom:1px solid var(--line);
}
.cart-head h3{
  font-family:'Fraunces',serif;
  font-size:26px; font-weight:700;
  color:var(--green);
}
.cart-close{
  width:38px;height:38px;border-radius:50%;
  display:grid;place-items:center;
  color:var(--green);
  transition:background .2s var(--ease), transform .2s var(--ease);
}
.cart-close:hover{background:rgba(20,40,29,.08); transform:rotate(90deg)}
.cart-body{flex:1; overflow-y:auto; padding:24px 28px}
.cart-empty{text-align:center; color:var(--muted); padding:50px 0}
.cart-empty p{margin-bottom:20px; font-style:italic; font-family:'Fraunces',serif; font-size:18px}
.cart-item{
  display:flex; gap:14px;
  padding:14px 0;
  border-bottom:1px solid var(--line);
  align-items:center;
}
.cart-item-img{
  width:70px;height:70px;border-radius:10px;
  background:var(--cream-2); flex-shrink:0;
  display:grid;place-items:center;
  color:var(--green);
}
.cart-item-info{flex:1}
.cart-item-info strong{display:block; font-size:14px; font-weight:600; margin-bottom:4px}
.cart-item-info span{font-size:13px; color:var(--muted)}
.cart-item-price{font-family:'Fraunces',serif; font-weight:700; color:var(--green)}
.cart-qty{display:flex; align-items:center; gap:6px; margin-top:6px}
.cart-qty button{
  width:24px;height:24px; border-radius:50%;
  border:1px solid var(--line);
  color:var(--green);
  font-size:14px; font-weight:600;
  display:grid;place-items:center;
  transition:background .15s;
}
.cart-qty button:hover{background:var(--cream-2)}
.cart-foot{padding:24px 28px; border-top:1px solid var(--line); background:var(--cream-2)}
.cart-total{
  display:flex; justify-content:space-between;
  font-family:'Fraunces',serif; font-size:20px;
  font-weight:700; color:var(--green);
  margin-bottom:18px;
}
.cart-foot .btn{width:100%; justify-content:center}

/* ============ TOAST ============ */
.toast{
  position:fixed; bottom:30px; left:50%; transform:translateX(-50%) translateY(20px);
  background:var(--green); color:var(--cream);
  padding:14px 28px; border-radius:999px;
  font-size:13px; font-weight:600; letter-spacing:.12em;
  text-transform:uppercase;
  box-shadow:var(--shadow-hard);
  opacity:0; pointer-events:none;
  transition:opacity .3s, transform .3s var(--ease);
  z-index:200;
}
.toast.show{opacity:1; transform:translateX(-50%) translateY(0)}

/* ============ ANIMATIONS ============ */
@keyframes fadeUp{to{opacity:1; transform:translateY(0)}}
.reveal{opacity:0; transform:translateY(40px); transition:opacity .9s var(--ease), transform .9s var(--ease)}
.reveal.in{opacity:1; transform:translateY(0)}

/* ============================================================
   AG-PREFIX COMPONENTS — used for the redesigned home page
   Inspired by earthy agriculture-template aesthetic.
   ============================================================ */

/* Top utility bar */
.ag-topbar{
  background:#0d1c14;
  color:rgba(243,236,217,.85);
  font-size:13px;
  padding:10px 0;
  letter-spacing:.02em;
}
.ag-topbar-inner{
  display:flex; justify-content:space-between; align-items:center;
  gap:24px; flex-wrap:wrap;
}
.ag-topbar-info{display:flex; gap:28px; flex-wrap:wrap}
.ag-topbar-info span{display:inline-flex; align-items:center; gap:8px}
.ag-topbar-info svg{width:14px;height:14px; opacity:.7}
.ag-topbar-info a{color:inherit; transition:color .2s}
.ag-topbar-info a:hover{color:var(--cream)}
.ag-topbar-social{display:flex; gap:14px; align-items:center}
.ag-topbar-social a{
  width:26px;height:26px; display:grid;place-items:center;
  color:rgba(243,236,217,.7); transition:color .2s, transform .2s;
}
.ag-topbar-social a:hover{color:#a8c8a8; transform:translateY(-1px)}
.ag-topbar-social svg{width:14px;height:14px}

/* Main nav using logo image */
.ag-nav{
  background:var(--cream);
  border-bottom:1px solid var(--line);
  padding:18px 0;
  position:sticky; top:0; z-index:40;
}
.ag-nav.scrolled{box-shadow:0 6px 24px -16px rgba(20,40,29,.3)}
.ag-nav-inner{display:flex; align-items:center; justify-content:space-between; gap:32px}
.ag-logo img{height:42px; width:auto; display:block}
.ag-nav-links{display:flex; gap:36px; align-items:center}
.ag-nav-links a{
  font-size:14px; font-weight:600; color:var(--green);
  letter-spacing:.04em;
  position:relative; padding:6px 0;
  transition:color .2s;
}
.ag-nav-links a::after{
  content:""; position:absolute; left:50%; bottom:-2px;
  width:0; height:2px; background:var(--green-card);
  transition:width .3s var(--ease), left .3s var(--ease);
}
.ag-nav-links a:hover,
.ag-nav-links a.active{color:var(--green-card)}
.ag-nav-links a:hover::after,
.ag-nav-links a.active::after{width:24px; left:calc(50% - 12px)}

.ag-nav-actions{display:flex; align-items:center; gap:14px}
.ag-nav-cta{
  background:var(--green-card);
  color:var(--green);
  padding:12px 24px;
  border-radius:6px;
  font-size:12px; font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  display:inline-flex; align-items:center; gap:8px;
  transition:background .2s, transform .2s, box-shadow .2s;
  border:none;
}
.ag-nav-cta:hover{
  background:var(--green);
  color:var(--cream);
  transform:translateY(-1px);
  box-shadow:0 8px 16px -8px rgba(20,40,29,.4);
}

/* Hero (image background with overlay) */
.ag-hero{
  position:relative;
  padding:100px 0 140px;
  overflow:hidden;
  background:var(--cream-2);
}
.ag-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 18% 88%, rgba(148,170,123,.18) 0, transparent 38%),
    radial-gradient(circle at 88% 12%, rgba(148,170,123,.14) 0, transparent 32%);
  pointer-events:none;
}
.ag-hero-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:60px;
  align-items:center;
  position:relative;
  z-index:1;
}
.ag-hero-label{
  display:inline-flex; align-items:center; gap:10px;
  font-size:12px; font-weight:800;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--green-card);
  margin-bottom:24px;
}
.ag-hero-label::before{
  content:"";
  width:32px; height:2px;
  background:var(--green-card);
}
.ag-hero h1{
  font-family:'Fraunces',serif;
  font-size:clamp(52px, 6.4vw, 96px);
  line-height:1.02;
  font-weight:800;
  letter-spacing:-.03em;
  color:var(--green);
  margin-bottom:24px;
}
.ag-hero h1 em{font-style:normal; color:var(--green-card)}
.ag-hero p{
  font-size:17px;
  color:var(--muted);
  line-height:1.7;
  max-width:500px;
  margin-bottom:36px;
}
.ag-hero-ctas{display:flex; gap:14px; flex-wrap:wrap}
.ag-btn{
  padding:16px 30px;
  border-radius:6px;
  font-size:12px; font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  display:inline-flex; align-items:center; gap:10px;
  border:none; cursor:pointer;
  transition:transform .2s, background .2s, color .2s, box-shadow .2s;
}
.ag-btn-primary{
  background:var(--green);
  color:var(--cream);
}
.ag-btn-primary:hover{
  background:var(--green-card);
  color:var(--green);
  transform:translateY(-2px);
  box-shadow:0 12px 24px -10px rgba(20,40,29,.45);
}
.ag-btn-outline{
  background:transparent;
  color:var(--green);
  border:1.5px solid var(--green);
}
.ag-btn-outline:hover{
  background:var(--green);
  color:var(--cream);
  transform:translateY(-2px);
}

.ag-hero-visual{
  position:relative;
  display:grid;
  place-items:center;
}
.ag-hero-img-main{
  width:100%;
  aspect-ratio:1/1;
  border-radius:50%;
  overflow:hidden;
  background:#fff;
  box-shadow: 0 40px 80px -30px rgba(20,40,29,.35);
  position:relative;
}
.ag-hero-img-main img{
  width:100%; height:100%; object-fit:cover;
  transition:transform 1.2s var(--ease);
}
.ag-hero-img-main:hover img{transform:scale(1.04)}

.ag-hero-leaf{
  position:absolute;
  width:120px; height:120px;
  color:var(--green-card);
  opacity:.7;
}
.ag-hero-leaf-1{top:-10px; right:-10px; transform:rotate(20deg)}
.ag-hero-leaf-2{bottom:-20px; left:-30px; transform:rotate(-30deg)}

.ag-hero-floater{
  position:absolute;
  background:var(--cream);
  border-radius:12px;
  padding:18px 22px;
  box-shadow:0 20px 40px -16px rgba(20,40,29,.3);
  display:flex; gap:14px; align-items:center;
  font-family:'Fraunces',serif;
}
.ag-hero-floater-icon{
  width:48px; height:48px;
  background:var(--green-card);
  color:var(--green);
  border-radius:50%;
  display:grid;place-items:center;
}
.ag-hero-floater-icon svg{width:24px; height:24px}
.ag-hero-floater strong{
  display:block; font-size:22px; color:var(--green); line-height:1;
}
.ag-hero-floater span{
  display:block; font-size:11px; color:var(--muted);
  font-family:'Inter',sans-serif;
  letter-spacing:.16em; text-transform:uppercase;
  margin-top:4px;
}
.ag-hero-floater-1{bottom:8%; left:-8%}
.ag-hero-floater-2{top:6%; right:-6%}

/* Section title pattern */
.ag-sec-head{text-align:center; max-width:740px; margin:0 auto 64px}
.ag-sec-head.left{text-align:left; margin:0 0 48px}
.ag-eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-size:12px; font-weight:800;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--green-card);
  margin-bottom:16px;
}
.ag-eyebrow::before, .ag-eyebrow::after{
  content:""; width:24px; height:2px; background:var(--green-card);
}
.ag-sec-head.left .ag-eyebrow::after{display:none}
.ag-title{
  font-family:'Fraunces',serif;
  font-size:clamp(36px, 4.4vw, 60px);
  line-height:1.05;
  font-weight:800;
  letter-spacing:-.02em;
  color:var(--green);
}
.ag-title em{font-style:normal; color:var(--green-card)}
.ag-lead{
  font-size:16px; color:var(--muted); line-height:1.7;
  margin-top:18px; max-width:560px;
}
.ag-sec-head .ag-lead{margin-left:auto; margin-right:auto}

/* ABOUT SPLIT */
.ag-about{padding:110px 0}
.ag-about-grid{
  display:grid;
  grid-template-columns:1fr 1.05fr;
  gap:80px;
  align-items:center;
}
.ag-about-imgs{
  position:relative;
  aspect-ratio:1/1;
}
.ag-about-img-main{
  width:78%;
  aspect-ratio:4/5;
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 30px 60px -28px rgba(20,40,29,.4);
}
.ag-about-img-main img{width:100%; height:100%; object-fit:cover}
.ag-about-img-sec{
  position:absolute;
  bottom:0; right:0;
  width:55%;
  aspect-ratio:1/1;
  border-radius:16px;
  overflow:hidden;
  border:8px solid var(--cream);
  box-shadow:0 20px 40px -16px rgba(20,40,29,.35);
}
.ag-about-img-sec img{width:100%; height:100%; object-fit:cover}
.ag-about-badge{
  position:absolute;
  top:8%; right:-6%;
  width:120px; height:120px;
  background:var(--green-card);
  color:var(--green);
  border-radius:50%;
  display:grid;place-items:center;
  text-align:center;
  font-family:'Fraunces',serif;
  font-weight:800;
  box-shadow:0 16px 32px -12px rgba(20,40,29,.4);
}
.ag-about-badge strong{display:block; font-size:30px; line-height:1}
.ag-about-badge span{display:block; font-size:9px; letter-spacing:.16em; text-transform:uppercase; margin-top:6px; font-family:'Inter',sans-serif; font-weight:600}
.ag-about-content ul{list-style:none; margin:24px 0 32px}
.ag-about-content li{
  display:flex; align-items:flex-start; gap:14px;
  font-size:15px; color:var(--ink);
  padding:8px 0;
  line-height:1.6;
}
.ag-about-content li svg{
  width:22px; height:22px;
  color:var(--cream);
  background:var(--green-card);
  border-radius:50%;
  padding:4px;
  flex-shrink:0;
  margin-top:2px;
}

/* SERVICES / WHY 4-CARD */
.ag-services{
  padding:110px 0;
  background:var(--cream-2);
  position:relative;
}
.ag-svc-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:24px;
}
.ag-svc-card{
  background:var(--cream);
  border-radius:16px;
  padding:36px 28px;
  text-align:center;
  border:1px solid var(--line);
  transition:transform .35s var(--ease), box-shadow .3s var(--ease), background .3s;
  position:relative;
  overflow:hidden;
}
.ag-svc-card::before{
  content:"";
  position:absolute;
  top:-40px; right:-40px;
  width:120px; height:120px;
  border-radius:50%;
  background:var(--green-card);
  opacity:.08;
  transition:transform .5s var(--ease);
}
.ag-svc-card:hover{
  transform:translateY(-8px);
  box-shadow:0 30px 60px -28px rgba(20,40,29,.35);
  background:var(--green);
  color:var(--cream);
}
.ag-svc-card:hover::before{transform:scale(8)}
.ag-svc-card:hover .ag-svc-title,
.ag-svc-card:hover .ag-svc-desc,
.ag-svc-card:hover .ag-svc-link{color:var(--cream); position:relative; z-index:1}
.ag-svc-card:hover .ag-svc-icon{
  background:var(--cream);
  color:var(--green);
  position:relative; z-index:1;
}

.ag-svc-icon{
  width:80px; height:80px;
  border-radius:50%;
  background:rgba(148,170,123,.18);
  color:var(--green);
  display:grid;place-items:center;
  margin:0 auto 22px;
  transition:background .3s, color .3s;
}
.ag-svc-icon svg{width:40px; height:40px}
.ag-svc-title{
  font-family:'Fraunces',serif;
  font-size:22px;
  font-weight:700;
  color:var(--green);
  margin-bottom:12px;
  transition:color .3s;
}
.ag-svc-desc{
  font-size:14px;
  color:var(--muted);
  line-height:1.65;
  margin-bottom:18px;
  transition:color .3s;
}
.ag-svc-link{
  display:inline-flex; align-items:center; gap:6px;
  font-size:11px; font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--green);
  transition:color .3s, gap .3s;
}
.ag-svc-card:hover .ag-svc-link{gap:12px}

/* COUNTER STRIP */
.ag-counter{
  padding:80px 0;
  background:var(--green);
  color:var(--cream);
  position:relative;
  overflow:hidden;
}
.ag-counter::before{
  content:"";
  position:absolute; inset:0;
  background:radial-gradient(circle at 30% 50%, rgba(148,170,123,.15), transparent 50%);
  pointer-events:none;
}
.ag-counter-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:32px;
  text-align:center;
  position:relative;
}
.ag-counter-item{
  border-right:1px solid rgba(243,236,217,.15);
  padding:0 16px;
}
.ag-counter-item:last-child{border-right:none}
.ag-counter-num{
  font-family:'Fraunces',serif;
  font-size:64px;
  font-weight:800;
  color:var(--green-card);
  line-height:1;
  display:flex; align-items:baseline; justify-content:center; gap:4px;
}
.ag-counter-num span{font-size:32px}
.ag-counter-label{
  font-size:12px; font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(243,236,217,.8);
  margin-top:12px;
}

/* TESTIMONIALS */
.ag-testi{padding:110px 0}
.ag-testi-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:28px;
}
.ag-testi-card{
  background:var(--cream-2);
  border-radius:16px;
  padding:36px 30px;
  position:relative;
  transition:transform .3s, box-shadow .3s;
}
.ag-testi-card::before{
  content:"\201C";
  position:absolute;
  top:14px; right:24px;
  font-family:'Fraunces',serif;
  font-size:80px;
  color:var(--green-card);
  opacity:.4;
  line-height:1;
}
.ag-testi-card:hover{
  transform:translateY(-6px);
  box-shadow:0 30px 60px -28px rgba(20,40,29,.3);
}
.ag-testi-stars{
  color:var(--accent);
  letter-spacing:2px;
  font-size:15px;
  margin-bottom:16px;
}
.ag-testi-text{
  font-size:15px;
  color:var(--ink);
  line-height:1.7;
  margin-bottom:24px;
  font-style:italic;
  position:relative;
  z-index:1;
}
.ag-testi-author{
  display:flex; align-items:center; gap:14px;
  padding-top:18px;
  border-top:1px solid var(--line);
}
.ag-testi-avatar{
  width:48px; height:48px; border-radius:50%;
  background:var(--green);
  color:var(--cream);
  display:grid;place-items:center;
  font-family:'Fraunces',serif;
  font-weight:700;
  font-size:20px;
}
.ag-testi-author strong{display:block; font-size:15px; color:var(--green); font-weight:700}
.ag-testi-author span{display:block; font-size:12px; color:var(--muted); letter-spacing:.08em}

/* PROCESS / HOW IT WORKS */
.ag-process{
  padding:110px 0;
  background:var(--cream-2);
}
.ag-proc-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:24px;
}
.ag-proc-card{
  text-align:center;
  position:relative;
  padding:20px;
}
.ag-proc-icon-wrap{
  position:relative;
  width:120px; height:120px;
  margin:0 auto 22px;
}
.ag-proc-icon{
  width:100%; height:100%;
  border-radius:50%;
  background:var(--green-card);
  color:var(--green);
  display:grid;place-items:center;
  transition:background .3s, color .3s;
}
.ag-proc-icon svg{width:50px; height:50px}
.ag-proc-card:hover .ag-proc-icon{background:var(--green); color:var(--green-card)}
.ag-proc-num{
  position:absolute;
  top:-6px; right:-6px;
  width:36px; height:36px;
  background:var(--green);
  color:var(--cream);
  border-radius:50%;
  display:grid;place-items:center;
  font-family:'Fraunces',serif;
  font-weight:800;
  font-size:14px;
  border:3px solid var(--cream-2);
}
.ag-proc-title{
  font-family:'Fraunces',serif;
  font-size:22px;
  font-weight:700;
  color:var(--green);
  margin-bottom:10px;
}
.ag-proc-desc{
  font-size:14px;
  color:var(--muted);
  line-height:1.6;
  max-width:240px;
  margin:0 auto;
}

/* VALUE SPLIT (sustainability) */
.ag-value{padding:110px 0}
.ag-value-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}
.ag-value-grid.reverse{direction:rtl}
.ag-value-grid.reverse > *{direction:ltr}
.ag-value-img{
  border-radius:16px;
  overflow:hidden;
  aspect-ratio:5/4;
  position:relative;
  box-shadow:0 30px 60px -28px rgba(20,40,29,.35);
}
.ag-value-img img{width:100%; height:100%; object-fit:cover}
.ag-value-list{list-style:none; margin:24px 0 28px}
.ag-value-list li{
  display:flex; gap:14px; align-items:flex-start;
  padding:10px 0;
  font-size:15px; color:var(--ink);
}
.ag-value-list svg{
  width:22px; height:22px;
  color:var(--cream);
  background:var(--green-card);
  border-radius:50%;
  padding:4px;
  flex-shrink:0;
}

/* CTA STRIP (big call-to-action band) */
.ag-cta{
  padding:80px 0;
  background:linear-gradient(135deg, var(--green) 0%, var(--green-2) 100%);
  color:var(--cream);
  position:relative;
  overflow:hidden;
}
.ag-cta-grid{
  display:grid;
  grid-template-columns:1.4fr auto;
  gap:40px;
  align-items:center;
  position:relative;
  z-index:1;
}
.ag-cta h2{
  font-family:'Fraunces',serif;
  font-size:clamp(34px, 4vw, 52px);
  font-weight:800;
  line-height:1.1;
  letter-spacing:-.02em;
}
.ag-cta h2 em{font-style:italic; color:var(--green-card)}
.ag-cta p{margin-top:14px; color:rgba(243,236,217,.8); font-size:16px}

/* PAGE HEAD (subpage banner) */
.ag-page-head{
  padding:70px 0 60px;
  background:var(--cream-2);
  position:relative;
  overflow:hidden;
}
.ag-page-head::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 12% 80%, rgba(148,170,123,.16) 0, transparent 40%),
    radial-gradient(circle at 90% 20%, rgba(148,170,123,.12) 0, transparent 35%);
  pointer-events:none;
}
.ag-page-head-inner{
  position:relative;
  text-align:center;
  max-width:760px;
  margin:0 auto;
}
.ag-page-head h1{margin-bottom:14px}
.ag-page-head p{margin:0 auto}
.ag-crumb{
  display:inline-flex; gap:8px; align-items:center;
  margin-top:22px;
  font-size:13px;
  letter-spacing:.06em;
  color:var(--muted);
}
.ag-crumb a{
  color:var(--muted);
  transition:color .2s;
}
.ag-crumb a:hover{color:var(--green-card)}
.ag-crumb span{color:var(--green); font-weight:700}
.ag-crumb svg{width:12px; height:12px; opacity:.5}

/* SHOP cards (extends services style with image) */
.ag-shop-section{padding:90px 0 110px}
.ag-shop-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:32px;
  max-width:980px;
  margin:0 auto;
}
.ag-shop-card{
  background:var(--cream);
  border-radius:16px;
  border:1px solid var(--line);
  overflow:hidden;
  display:flex; flex-direction:column;
  transition:transform .35s var(--ease), box-shadow .3s;
}
.ag-shop-card:hover{
  transform:translateY(-6px);
  box-shadow:0 30px 60px -28px rgba(20,40,29,.3);
}
.ag-shop-card-img{
  background:var(--cream-2);
  aspect-ratio:1/1;
  display:grid; place-items:center;
  position:relative;
  overflow:hidden;
}
.ag-shop-card-img img{
  width:78%; height:78%; object-fit:contain;
  transition:transform .6s var(--ease);
}
.ag-shop-card:hover .ag-shop-card-img img{transform:scale(1.06)}
.ag-shop-card-badge{
  position:absolute;
  top:18px; right:18px;
  background:#fff;
  color:var(--ink);
  padding:6px 14px;
  border-radius:6px;
  font-size:11px; font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  box-shadow:0 6px 14px -8px rgba(20,40,29,.3);
}
.ag-shop-card-body{
  padding:30px 30px 34px;
  display:flex; flex-direction:column;
  flex:1;
}
.ag-shop-card-body h3{
  font-family:'Fraunces',serif;
  font-size:24px; font-weight:800;
  color:var(--green);
  margin-bottom:6px;
  line-height:1.15;
}
.ag-shop-card-body .meta{
  font-size:11px; font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--green-card);
  margin-bottom:18px;
}
.ag-shop-card-body .price{
  font-family:'Fraunces',serif;
  font-size:28px; font-weight:800;
  color:var(--ink);
  margin-bottom:8px;
}
.ag-shop-card-body .stars{margin-bottom:18px}
.ag-shop-card-body ul{
  list-style:none;
  display:flex; flex-direction:column; gap:8px;
  margin-bottom:24px;
}
.ag-shop-card-body li{
  display:flex; align-items:center; gap:10px;
  font-size:14px; color:var(--ink);
}
.ag-shop-card-body li svg{
  width:18px; height:18px;
  color:var(--cream);
  background:var(--green-card);
  border-radius:50%;
  padding:3px;
  flex-shrink:0;
}
.ag-shop-card-body .ag-btn{
  margin-top:auto;
  justify-content:center;
  width:100%;
}
.ag-shop-card-foot{
  text-align:center;
  margin-top:14px;
  font-size:13px;
  color:var(--green-card);
  font-weight:700;
}
.ag-shop-card-foot a:hover{text-decoration:underline}

/* PRODUCT detail page */
.ag-prod{padding:90px 0 110px}
.ag-prod-grid{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:60px;
  align-items:start;
}
.ag-prod-img{
  background:var(--cream-2);
  border-radius:16px;
  aspect-ratio:1/1;
  display:grid; place-items:center;
  overflow:hidden;
  box-shadow:0 30px 60px -28px rgba(20,40,29,.3);
  position:relative;
}
.ag-prod-img img{
  width:80%; height:80%; object-fit:contain;
  transition:transform .6s var(--ease);
}
.ag-prod-img:hover img{transform:scale(1.04)}
.ag-prod-info h1{
  font-family:'Fraunces',serif;
  font-size:clamp(36px, 4.4vw, 56px);
  line-height:1.05;
  font-weight:800;
  color:var(--green);
  text-transform:uppercase;
  letter-spacing:-.01em;
  margin-bottom:10px;
}
.ag-prod-info .tagline{
  font-size:18px; color:var(--muted);
  margin-bottom:20px;
  font-style:italic;
  font-family:'Fraunces',serif;
}
.ag-prod-rating{
  display:flex; align-items:center; gap:18px;
  padding:18px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  margin-bottom:24px;
  flex-wrap:wrap;
}
.ag-prod-rating .stars{font-size:18px}
.ag-prod-rating a{color:var(--muted); text-decoration:underline; font-size:13px}
.ag-prod-desc{
  font-size:16px; color:var(--muted);
  line-height:1.75;
  margin-bottom:28px;
}
.ag-prod-desc strong{color:var(--ink)}
.ag-prod-size{
  display:inline-block;
  background:rgba(148,170,123,.18);
  border:1.5px dashed var(--green-card);
  border-radius:10px;
  padding:12px 24px;
  font-weight:700;
  color:var(--green);
  margin-bottom:24px;
}
.ag-prod-feats{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:16px;
  margin:24px 0;
}
.ag-prod-feat{
  text-align:center;
  background:var(--cream-2);
  border-radius:12px;
  padding:18px 12px;
}
.ag-prod-feat strong{
  display:block;
  font-family:'Fraunces',serif;
  font-size:22px;
  color:var(--green);
  font-weight:800;
}
.ag-prod-feat span{
  display:block;
  font-size:11px; font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--muted);
  margin-top:4px;
}
.ag-prod-price{
  display:inline-flex; align-items:baseline; gap:6px;
  font-family:'Fraunces',serif;
  margin:18px 0 24px;
}
.ag-prod-price .currency{font-size:22px; color:var(--muted)}
.ag-prod-price .amount{font-size:64px; font-weight:800; color:var(--green); line-height:1}
.ag-prod-price .note{font-size:13px; color:var(--muted); margin-left:10px; font-family:'Inter',sans-serif; align-self:end; padding-bottom:6px}
.ag-prod-ctas{display:flex; gap:14px; flex-wrap:wrap}

/* MEMBERSHIP / pricing cards */
.ag-price-section{padding:80px 0 110px}
.ag-price-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:32px;
  max-width:920px;
  margin:0 auto;
}
.ag-price-card{
  background:var(--cream);
  border-radius:16px;
  border:1px solid var(--line);
  padding:40px 36px;
  display:flex; flex-direction:column;
  transition:transform .35s, box-shadow .3s;
  position:relative;
}
.ag-price-card.featured{
  background:var(--green);
  color:var(--cream);
  border-color:var(--green);
}
.ag-price-card:hover{
  transform:translateY(-6px);
  box-shadow:0 30px 60px -28px rgba(20,40,29,.3);
}
.ag-price-card .tag{
  font-size:11px; font-weight:800;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--green-card);
  margin-bottom:10px;
}
.ag-price-card.featured .tag{color:var(--green-card)}
.ag-price-card h3{
  font-family:'Fraunces',serif;
  font-size:28px; font-weight:800;
  color:var(--green);
  margin-bottom:16px;
  line-height:1.1;
}
.ag-price-card.featured h3{color:var(--cream)}
.ag-price-amount{
  display:flex; align-items:baseline; gap:10px;
  margin-bottom:24px;
}
.ag-price-amount strong{
  font-family:'Fraunces',serif;
  font-size:56px;
  font-weight:800;
  color:var(--green);
  line-height:1;
}
.ag-price-card.featured .ag-price-amount strong{color:var(--green-card)}
.ag-price-amount .strike{
  font-size:22px; text-decoration:line-through; color:var(--muted);
}
.ag-price-amount .per{
  font-size:14px; color:var(--muted);
  letter-spacing:.04em;
}
.ag-price-card.featured .ag-price-amount .per{color:rgba(243,236,217,.7)}
.ag-price-card .stars{margin-bottom:22px; font-size:16px}
.ag-price-card ul{
  list-style:none;
  display:flex; flex-direction:column; gap:14px;
  margin-bottom:30px;
}
.ag-price-card li{
  display:flex; gap:12px; align-items:flex-start;
  font-size:15px; line-height:1.5;
}
.ag-price-card li svg{
  width:22px; height:22px;
  color:var(--cream);
  background:var(--green-card);
  border-radius:50%;
  padding:4px;
  flex-shrink:0;
}
.ag-price-card.featured li svg{
  color:var(--green);
  background:var(--green-card);
}
.ag-price-card .ag-btn{
  margin-top:auto;
  justify-content:center;
  width:100%;
}
.ag-price-card.featured .ag-btn-primary{
  background:var(--green-card);
  color:var(--green);
}
.ag-price-card.featured .ag-btn-primary:hover{
  background:var(--cream);
}

/* LEGAL / POLICY PAGES */
.ag-legal{padding:60px 0 110px}
.ag-legal-grid{
  display:grid;
  grid-template-columns:240px 1fr;
  gap:60px;
  align-items:start;
}
.ag-legal-aside{
  position:sticky;
  top:120px;
}
.ag-legal-aside h4{
  font-family:'Fraunces',serif;
  font-size:14px;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--green);
  margin-bottom:14px;
}
.ag-legal-aside ul{
  list-style:none;
  display:flex; flex-direction:column;
  gap:8px;
}
.ag-legal-aside a{
  display:block;
  padding:10px 14px;
  font-size:14px;
  color:var(--muted);
  border-radius:8px;
  border-left:3px solid transparent;
  transition:background .2s, color .2s, border-color .2s;
}
.ag-legal-aside a:hover{background:var(--cream-2); color:var(--green)}
.ag-legal-aside a.active{
  background:var(--cream-2);
  color:var(--green);
  border-left-color:var(--green-card);
  font-weight:700;
}
.ag-legal-content{
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:16px;
  padding:50px 60px;
}
.ag-legal-content .updated{
  font-size:12px; font-weight:700;
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted);
  margin-bottom:24px;
}
.ag-legal-content h2{
  font-family:'Fraunces',serif;
  font-size:28px; font-weight:800;
  color:var(--green);
  margin:36px 0 14px;
  letter-spacing:-.01em;
}
.ag-legal-content h2:first-of-type{margin-top:0}
.ag-legal-content h3{
  font-family:'Inter',sans-serif;
  font-size:16px;
  font-weight:700;
  color:var(--ink);
  margin:24px 0 10px;
}
.ag-legal-content p{
  font-size:15px; color:var(--muted);
  line-height:1.75;
  margin-bottom:14px;
}
.ag-legal-content ul{
  list-style:none;
  margin:10px 0 18px;
  padding-left:0;
}
.ag-legal-content li{
  font-size:15px; color:var(--muted);
  line-height:1.7;
  padding:6px 0 6px 26px;
  position:relative;
}
.ag-legal-content li::before{
  content:"";
  position:absolute;
  left:0; top:14px;
  width:8px; height:8px;
  border-radius:50%;
  background:var(--green-card);
}
.ag-legal-content a{
  color:var(--green); font-weight:600;
  text-decoration:underline;
  text-underline-offset:3px;
}
.ag-legal-content a:hover{color:var(--green-card)}
.ag-legal-content strong{color:var(--ink)}

/* MOBILE HAMBURGER + DRAWER */
.ag-menu-toggle{
  display:none;
  width:42px; height:42px;
  border-radius:10px;
  background:transparent;
  color:var(--green);
  align-items:center; justify-content:center;
  border:1.5px solid var(--green);
  cursor:pointer;
  transition:background .2s;
}
.ag-menu-toggle:hover{background:rgba(20,40,29,.06)}
.ag-menu-toggle svg{width:22px; height:22px}
.ag-menu-toggle .menu-close{display:none}
.ag-menu-toggle.open .menu-open{display:none}
.ag-menu-toggle.open .menu-close{display:block}

/* FAQ list (agrion-style polished) */
.ag-faq{padding:90px 0 110px}
.ag-faq-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
  max-width:820px;
  margin:0 auto;
}
.ag-faq-item{
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:12px;
  padding:0;
  overflow:hidden;
  transition:border-color .2s, box-shadow .2s;
}
.ag-faq-item.open{
  border-color:var(--green-card);
  box-shadow:0 20px 40px -28px rgba(20,40,29,.3);
}
.ag-faq-item .faq-q{
  padding:22px 28px;
  font-family:'Fraunces',serif;
  font-size:18px;
  font-weight:700;
  color:var(--green);
}
.ag-faq-item .faq-a{
  padding:0 28px;
  font-size:15px;
}
.ag-faq-item.open .faq-a{padding:0 28px 22px}
.ag-faq-item .faq-q-icon{
  background:rgba(148,170,123,.18);
  border-color:transparent;
}
.ag-faq-item.open .faq-q-icon{background:var(--green); color:var(--cream)}

/* FOOTER multi-column */
.ag-foot{
  background:#0d1c14;
  color:rgba(243,236,217,.7);
  padding:80px 0 30px;
}
.ag-foot-grid{
  display:grid;
  grid-template-columns:1.3fr 1fr 1fr 1.2fr;
  gap:50px;
  margin-bottom:50px;
}
.ag-foot-brand img{height:42px; margin-bottom:22px; filter:brightness(0) invert(1)}
.ag-foot-brand p{font-size:14px; line-height:1.7; max-width:280px}
.ag-foot-brand .ag-topbar-social{margin-top:24px; justify-content:flex-start}
.ag-foot-brand .ag-topbar-social a{
  width:36px; height:36px;
  border:1px solid rgba(243,236,217,.2);
  border-radius:50%;
}
.ag-foot-brand .ag-topbar-social a:hover{background:var(--green-card); border-color:var(--green-card); color:var(--green)}
.ag-foot-col h6{
  font-family:'Fraunces',serif;
  font-size:18px; color:var(--cream);
  font-weight:700;
  margin-bottom:22px;
  position:relative;
  padding-bottom:10px;
}
.ag-foot-col h6::after{
  content:"";
  position:absolute;
  left:0; bottom:0;
  width:32px; height:2px;
  background:var(--green-card);
}
.ag-foot-col ul{list-style:none; display:flex; flex-direction:column; gap:12px}
.ag-foot-col a{
  font-size:14px;
  display:inline-flex; align-items:center; gap:8px;
  transition:color .2s, gap .2s;
}
.ag-foot-col a:hover{color:var(--green-card); gap:12px}
.ag-foot-col a::before{
  content:""; width:6px; height:6px;
  border-right:1.5px solid var(--green-card);
  border-bottom:1.5px solid var(--green-card);
  transform:rotate(-45deg);
}
.ag-foot-news{display:flex; flex-direction:column; gap:18px}
.ag-foot-news-item{display:flex; gap:14px; align-items:center}
.ag-foot-news-thumb{
  width:64px; height:64px;
  border-radius:8px;
  background:var(--green-soft);
  flex-shrink:0;
  overflow:hidden;
}
.ag-foot-news-thumb img{width:100%; height:100%; object-fit:cover}
.ag-foot-news-info p{
  font-size:11px; color:var(--green-card);
  letter-spacing:.12em; text-transform:uppercase;
  font-weight:700;
  margin-bottom:4px;
}
.ag-foot-news-info a{
  font-family:'Fraunces',serif;
  font-size:14px; color:var(--cream);
  font-weight:600;
  line-height:1.4;
  transition:color .2s;
}
.ag-foot-news-info a:hover{color:var(--green-card)}

.ag-foot-bottom{
  border-top:1px solid rgba(243,236,217,.1);
  padding-top:28px;
  display:flex; justify-content:space-between;
  flex-wrap:wrap; gap:18px;
  font-size:13px;
}
.ag-foot-bottom-links{display:flex; gap:24px}
.ag-foot-bottom-links a{transition:color .2s}
.ag-foot-bottom-links a:hover{color:var(--green-card)}

/* ============ RESPONSIVE ============ */
@media (max-width: 1024px){
  .hero-grid, .product-grid, .story-block, .faq-grid{grid-template-columns:1fr; gap:50px}
  .story-block.reverse{direction:ltr}
  .hero-visual{height:480px}
  .stats-inner, .steps, .reviews-grid, .why-grid, .feature-grid{grid-template-columns:repeat(2,1fr); gap:24px}
  .shop-grid, .members-grid{grid-template-columns:1fr; max-width:520px}
  .stat{border-left:none; padding-left:0}
  .foot-grid{grid-template-columns:1fr; gap:32px}

  .ag-hero-grid, .ag-about-grid, .ag-value-grid, .ag-cta-grid, .ag-prod-grid{grid-template-columns:1fr; gap:50px}
  .ag-value-grid.reverse{direction:ltr}
  .ag-svc-grid, .ag-counter-grid, .ag-testi-grid, .ag-proc-grid, .ag-shop-grid, .ag-price-grid{grid-template-columns:repeat(2, 1fr); gap:24px}
  .ag-shop-grid, .ag-price-grid{max-width:560px}
  .ag-counter-item{border-right:none; border-bottom:1px solid rgba(243,236,217,.15); padding-bottom:24px}
  .ag-counter-item:nth-child(3), .ag-counter-item:nth-child(4){border-bottom:none; padding-bottom:0}
  .ag-foot-grid{grid-template-columns:1fr 1fr; gap:32px}
  .ag-hero-floater-1, .ag-hero-floater-2{display:none}
  .ag-about-badge{display:none}
}
@media (max-width: 720px){
  .container{padding:0 20px}
  .nav-links{display:none}
  .menu-toggle{display:grid}
  .hero{padding:50px 0 70px}
  .hero h1{font-size:60px}
  .features-row{gap:16px}
  .feature-pill{max-width:none}
  .stats-inner, .steps, .reviews-grid, .why-grid, .feature-grid, .foot-grid{grid-template-columns:1fr}
  .hero-ctas{flex-direction:column; align-items:stretch}
  .btn{justify-content:center}
  .seal{width:100px;height:100px}
  .product-display .seal{top:14px;right:14px}
  .hero-visual{height:440px}
  .product-box{width:65%; left:3%}
  .roll-stack{width:42%}
  .price-tag .amount{font-size:60px}

  .ag-menu-toggle{display:inline-flex}
  .ag-nav-cta span, .ag-nav-cta{display:none}
  .ag-nav-actions .ag-nav-cta{display:none}
  .ag-nav-links{
    display:flex; flex-direction:column;
    position:fixed;
    top:0; right:0; bottom:0;
    width:min(320px, 80vw);
    background:var(--cream);
    padding:80px 32px 32px;
    gap:8px;
    z-index:99;
    transform:translateX(100%);
    transition:transform .35s var(--ease);
    box-shadow:-20px 0 60px -20px rgba(20,40,29,.4);
    overflow-y:auto;
  }
  .ag-nav-links.open{transform:translateX(0)}
  .ag-nav-links a{
    font-size:18px; padding:14px 0;
    border-bottom:1px solid var(--line);
  }
  .ag-nav-links a::after{display:none}
  .ag-nav-overlay{
    position:fixed; inset:0;
    background:rgba(20,40,29,.4);
    backdrop-filter:blur(3px);
    z-index:98;
    opacity:0; pointer-events:none;
    transition:opacity .3s;
  }
  .ag-nav-overlay.open{opacity:1; pointer-events:all}
  .ag-svc-grid, .ag-counter-grid, .ag-testi-grid, .ag-proc-grid, .ag-foot-grid, .ag-shop-grid, .ag-price-grid{grid-template-columns:1fr}
  .ag-prod-feats{grid-template-columns:repeat(2, 1fr)}
  .ag-prod-price .amount{font-size:48px}

  .ag-legal-grid{grid-template-columns:1fr; gap:30px}
  .ag-legal-aside{position:static}
  .ag-legal-aside ul{flex-direction:row; flex-wrap:wrap; gap:6px}
  .ag-legal-aside a{padding:8px 12px; font-size:13px; border-left:none; border:1px solid var(--line); border-radius:999px}
  .ag-legal-aside a.active{border-color:var(--green); background:var(--green); color:var(--cream)}
  .ag-legal-content{padding:30px 24px}
  .ag-legal-content h2{font-size:22px}
  .ag-topbar-info{font-size:11px; gap:14px}
  .ag-topbar-info span{flex-direction:row}
  .ag-counter-item{border-right:none; border-bottom:1px solid rgba(243,236,217,.15); padding-bottom:24px}
  .ag-counter-item:last-child{border-bottom:none; padding-bottom:0}
  .ag-counter-num{font-size:48px}
  .ag-hero{padding:50px 0 70px}
  .ag-hero-ctas{flex-direction:column; align-items:stretch}
  .ag-btn{justify-content:center}
  .ag-topbar-inner{justify-content:center; text-align:center}
}
