/* Page wrapper */
.story-page{
  background: var(--sand);
}

/* Utilities (only if not present globally) */
.section{ padding: 46px 10px; }
.mt-4{ margin-top: 16px; }
.dot{ width:8px; height:8px; border-radius:999px; background: var(--green); display:inline-block; }
.dot--gold{ background: var(--gold); }
.bullet{
  display:inline-flex;
  padding:8px 12px;
  border-radius:999px;
  background: rgba(0,0,0,0.04);
  border: 1px solid rgba(0,0,0,0.06);
  font-size: 12px;
  font-weight: 800;
  color: rgba(0,0,0,0.70);
}

.section-head{
  text-align: center;
  margin-bottom: 18px;
}
.section-head .h2{ margin:0; }
.section-head p{ margin:8px 0 0; }

/* ---------------------------
   1) HERO
--------------------------- */
.story-hero{
  padding: 62px 0 26px;
  background:
    radial-gradient(1200px 560px at 50% -10%, rgba(199,162,75,0.18), transparent 60%),
    radial-gradient(900px 520px at 0% 20%, rgba(47,93,80,0.16), transparent 55%),
    linear-gradient(180deg, #ffffff 0%, var(--sand) 100%);
  border-bottom: 1px solid rgba(0,0,0,0.06);
}

.story-hero__inner{
  display: grid;
  gap: 18px;
  align-items: start;
}

.story-hero__text h1{
  margin: 12px 0 10px;
  font-family: "Playfair Display", Georgia, serif;
  font-size: clamp(30px, 3.4vw, 52px);
  line-height: 1.05;
  /* color: rgba(0,0,0,0.88); */
}
.story-hero__text p{
  margin: 0;
  max-width: 720px;
  font-size: 15px;
  line-height: 1.7;
  color: rgba(0,0,0,0.68);
}

.story-hero__cta{
  margin-top: 14px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.hero-stats{
  margin-top: 18px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 10px;
}
.stat{
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 18px;
  box-shadow: var(--shadow);
  padding: 12px;
}
.stat b{
  display:block;
  font-size: 20px;
  font-weight: 900;
  color: var(--green);
}
.stat span{
  display:block;
  margin-top: 4px;
  font-size: 12px;
  color: rgba(0,0,0,0.62);
}

.story-hero__media{
  display: grid;
  gap: 12px;
}
.hero-media__card{
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 28px;
  box-shadow: var(--shadow-hover);
  overflow: hidden;
}
.hero-media__img{
  height: 260px;
  background:
    radial-gradient(90px 90px at 30% 30%, rgba(47,93,80,0.20), transparent 60%),
    radial-gradient(120px 120px at 70% 55%, rgba(199,162,75,0.22), transparent 65%),
    linear-gradient(135deg, #ffffff 0%, var(--sand) 100%);
}
.hero-media__caption{
  padding: 14px 16px;
  display:flex;
  flex-direction:column;
  gap: 4px;
}
.hero-media__caption b{ font-size: 14px; }
.hero-media__caption span{ font-size: 12px; }

.hero-media__mini{
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.mini-pill{
  display: grid;
  grid-template-columns: 10px 1fr;
  gap: 10px;
  align-items: center;
  padding: 12px 14px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.08);
  background: rgba(255,255,255,0.9);
  box-shadow: var(--shadow);
}
.mini-pill b{ font-size: 13px; }
.mini-pill .muted{ font-size: 12px; grid-column: 2; margin-top:-2px; }

/* ---------------------------
   2) TRUST STRIP
--------------------------- */
.trust-strip{
  padding: 16px 0;
}
.trust-strip__inner{
  display:grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.trust-item{
  padding: 14px 16px;
  border-radius: 22px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: var(--shadow);
}
.trust-item b{ display:block; font-size: 13px;color: var(--green); }
.trust-item span{ display:block; margin-top:4px; font-size: 12px; }

/* ---------------------------
   Shared layout helpers
--------------------------- */
.split{
  display:grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
.card.pad{
  padding: 22px;
  border-radius: 28px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: var(--shadow);
}

.story-quote .quote{
  margin:0;
  font-family: "Playfair Display", Georgia, serif;
  font-size: 22px;
  line-height: 1.35;
  color: rgba(0,0,0,0.82);
}
.quote-by{
  margin-top: 12px;
  display:flex;
  flex-direction:column;
  gap: 2px;
}

.bullets-row{
  margin-top: 14px;
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
}

/* ---------------------------
   4) Promise
--------------------------- */
.promise-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.promise-card{
  border-radius: 24px;
  padding: 16px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: var(--shadow);
  transition: transform .14s ease, box-shadow .14s ease;
}
.promise-card:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow-hover);
}
.promise-card .icon{
  width: 40px;
  height: 40px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  background: rgba(47,93,80,0.10);
  color: var(--green);
  font-weight: 900;
  margin-bottom: 10px;
}
.promise-card b{ display:block; }
.promise-card p{ margin:8px 0 0; font-size: 13px; }

/* ---------------------------
   5) Timeline
--------------------------- */
.timeline-wrap{
  display:grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-top: 14px;
}
.timeline-step{
  width:100%;
  text-align:left;
  border-radius: 18px;
  padding: 14px 14px;
  border: 1px solid rgba(0,0,0,0.08);
  background: rgba(255,255,255,0.92);
  box-shadow: var(--shadow);
}
.timeline-step b{ display:block; font-size: 14px; color: var(--green); }
.timeline-step span{ display:block; margin-top:4px; font-size: 12px; color: rgba(0,0,0,0.64); }
.timeline-step.is-active{
  border-color: rgba(47,93,80,0.35);
  box-shadow: var(--shadow-hover);
}
.timeline-panel{
  margin-top: 14px;
}
.timeline-title{ display:block; font-size: 14px; }
.timeline-text{ margin: 8px 0 0; font-size: 13px; line-height: 1.7; }

/* ---------------------------
   6) Sourcing
--------------------------- */
.checklist{
  margin-top: 14px;
  display:grid;
  gap: 10px;
}
.checkline{
  display:grid;
  grid-template-columns: 22px 1fr;
  gap: 10px;
  align-items: start;
  padding: 12px;
  border-radius: 18px;
  background: var(--sand);
  border: 1px solid rgba(0,0,0,0.06);
}
.tick{
  width: 22px; height: 22px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  background: rgba(47,93,80,0.12);
  color: var(--green);
  font-weight: 900;
}
.checkline b{ font-size: 13px; }
.checkline .muted{ grid-column: 2; margin-top:-2px; font-size: 12px; }

.media-card{
  overflow:hidden;
  padding:0 !important;
}
.media-card__img{
  height: 300px;
  background:
    radial-gradient(140px 140px at 30% 30%, rgba(199,162,75,0.25), transparent 70%),
    radial-gradient(170px 170px at 75% 60%, rgba(47,93,80,0.18), transparent 70%),
    linear-gradient(135deg, #ffffff 0%, var(--sand) 100%);
}
.media-card__bar{
  padding: 14px 16px;
  border-top: 1px solid rgba(0,0,0,0.06);
  display:flex; justify-content:space-between; align-items:center; gap:10px;
}

/* ---------------------------
   7) Packaging
--------------------------- */
.pack-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.pack-card{
  border-radius: 24px;
  padding: 16px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: var(--shadow);
}

/* ---------------------------
   8) Care system
--------------------------- */
.routine{
  margin-top: 14px;
  display:grid;
  gap: 10px;
}
.routine-step{
  padding: 14px;
  border-radius: 20px;
  background: var(--sand);
  border: 1px solid rgba(0,0,0,0.06);
  display:flex;
  justify-content:space-between;
  gap:10px;
}
.routine-step b{ color: rgba(0,0,0,0.82); }

.care-card{
  background: rgba(255,255,255,0.92);
}
.care-card__title{
  display:block;
  margin-bottom: 10px;
}

/* FAQ accordion (reused) */
.faq-mini, .faq-grid{
  display:grid;
  gap: 10px;
}
.faq-q{
  width:100%;
  text-align:left;
  border-radius: 18px;
  padding: 14px 14px;
  border: 1px solid rgba(0,0,0,0.08);
  background: #fff;
  font-weight: 900;
  color: rgba(0,0,0,0.82);
}
.faq-q::after{
  content:"+";
  float:right;
  color: rgba(0,0,0,0.55);
  font-weight: 900;
}
.faq-q.is-open::after{ content:"–"; }
.faq-a{
  display:none;
  padding: 0 12px 12px;
}
.faq-a p{ margin:0; line-height: 1.7; }

/* ---------------------------
   9) UGC
--------------------------- */
.ugc-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
}
.ugc-tile{
  height: 140px;
  border-radius: 24px;
  background:
    radial-gradient(90px 90px at 30% 40%, rgba(47,93,80,0.18), transparent 65%),
    radial-gradient(90px 90px at 70% 60%, rgba(199,162,75,0.18), transparent 65%),
    #fff;
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: var(--shadow);
}

/* ---------------------------
   10) Testimonials
--------------------------- */
.test-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.test-card{
  padding: 16px;
  border-radius: 24px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: var(--shadow);
}
.test-card p{ margin:10px 0 0; }

/* ---------------------------
   11) Team
--------------------------- */
.team-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
}
.team-card{
  padding: 16px;
  border-radius: 24px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: var(--shadow);
  display:flex;
  flex-direction:column;
  gap:6px;
}
.avatar{
  width: 52px; height: 52px;
  border-radius: 18px;
  background: var(--sand);
  border: 1px solid rgba(0,0,0,0.06);
  margin-bottom: 6px;
}

/* ---------------------------
   12) Impact
--------------------------- */
.impact-list{
  margin-top: 14px;
  display:grid;
  gap: 10px;
}
.impact-item{
  padding: 14px;
  border-radius: 20px;
  background: var(--sand);
  border: 1px solid rgba(0,0,0,0.06);
  display:flex;
  justify-content:space-between;
  gap:10px;
}
.impact-badge{
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start;
  gap: 6px;
}
.impact-number{
  font-size: 44px;
  font-weight: 900;
  color: var(--green);
}

/* ---------------------------
   13) Partners
--------------------------- */
.logo-row{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  justify-content:flex-start;
}
.logo-pill{
  padding: 12px 14px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.08);
  background: rgba(255,255,255,0.92);
  box-shadow: var(--shadow);
  font-weight: 900;
  font-size: 12px;
  color: rgba(0,0,0,0.70);
}

/* ---------------------------
   15) CTA
--------------------------- */
.cta-card{
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap: 14px;
  padding: 22px;
  border-radius: 28px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: var(--shadow-hover);
}
.cta-card h2{
  margin:0;
  font-family: "Playfair Display", Georgia, serif;
}
.cta-actions{
  display:flex;
  gap: 10px;
  flex-wrap:wrap;
}

/* ---------------------------
   16) Quick links
--------------------------- */
.quick-links__inner{
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.ql{
  padding: 16px;
  border-radius: 24px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: var(--shadow);
  display:flex;
  justify-content:space-between;
  gap: 14px;
  transition: transform .14s ease, box-shadow .14s ease;
}
.ql:hover{ transform: translateY(-2px); box-shadow: var(--shadow-hover); }
.ql b{ color: rgba(0,0,0,0.85); }
.ql span{ font-size: 12px; }

/* ---------------------------
   MODAL
--------------------------- */
.story-modal{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.45);
  display:none;
  z-index: 90;
}
.story-modal.open{ display:block; }
.modal-card{
  width: min(720px, 92vw);
  margin: 10vh auto 0;
  border-radius: 28px;
  background: #fff;
  box-shadow: var(--shadow-hover);
  overflow:hidden;
}
.modal-head{
  padding: 14px 16px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  border-bottom: 1px solid rgba(0,0,0,0.06);
}
.icon-x{
  width: 40px; height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.08);
  background:#fff;
}
.modal-body{
  padding: 16px;
  display:grid;
  gap: 12px;
}
.value-row{
  padding: 14px;
  border-radius: 22px;
  background: var(--sand);
  border: 1px solid rgba(0,0,0,0.06);
}
.value-row p{ margin: 8px 0 0; }
.modal-foot{
  padding: 14px 16px;
  display:flex;
  gap: 10px;
  justify-content:flex-end;
  flex-wrap:wrap;
  border-top: 1px solid rgba(0,0,0,0.06);
}

/* ---------------------------
   Responsive
--------------------------- */
@media (min-width: 900px){
  .story-hero__inner{
    grid-template-columns: 1.1fr 0.9fr;
    align-items: center;
  }
  .trust-strip__inner{
    grid-template-columns: repeat(4, minmax(0,1fr));
  }
  .split{
    grid-template-columns: 1fr 1fr;
  }
  .promise-grid{
    grid-template-columns: repeat(4, minmax(0,1fr));
  }
  .timeline-wrap{
    grid-template-columns: repeat(4, minmax(0,1fr));
  }
  .pack-grid{
    grid-template-columns: repeat(4, minmax(0,1fr));
  }
  .ugc-grid{
    grid-template-columns: repeat(6, minmax(0,1fr));
  }
  .test-grid{
    grid-template-columns: repeat(3, minmax(0,1fr));
  }
  .team-grid{
    grid-template-columns: repeat(4, minmax(0,1fr));
  }
  .quick-links__inner{
    grid-template-columns: repeat(4, minmax(0,1fr));
  }
}
