/* ===========================================================================
   MIGA — Homepage sections (loaded after styles.css)
   ===========================================================================*/

/* ---------- hero (real empanada photo) ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;isolation:isolate;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__media img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);transform-origin:60% 40%}
.hero.kb .hero__media img{animation:kenburns 22s ease-in-out infinite alternate}
@keyframes kenburns{from{transform:scale(1.06) translate(0,0)}to{transform:scale(1.16) translate(-1.5%,-2%)}}
.hero__media::after{content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(15,40,22,.34) 0%,rgba(15,40,22,.12) 30%,rgba(15,40,22,.30) 62%,rgba(15,40,22,.86) 100%),
    radial-gradient(80% 60% at 15% 90%,rgba(15,40,22,.5),transparent 70%);
}
.hero__inner{position:relative;padding-bottom:clamp(2.5rem,6vw,5rem);padding-top:calc(var(--header-h) + 2rem);color:#fff;max-width:880px}
.hero .eyebrow{color:#F2D9A8}
.hero .eyebrow::before{background:var(--gold)}
.hero h1{color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.3);margin:.8rem 0}
.hero h1 .gold{color:#F4C97A}
.hero__lead{font-size:clamp(1.05rem,1.7vw,1.32rem);color:#EAF1E3;max-width:54ch;margin-bottom:1.8rem}
.hero__cta{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}
.hero__trust{display:flex;gap:1.4rem 2rem;flex-wrap:wrap;margin-top:2.2rem;padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.18)}
.hero__trust div{color:#EAF1E3}
.hero__trust .k{font-family:var(--display);font-size:1.5rem;color:#F4C97A;line-height:1}
.hero__trust .v{font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:#C7D6BE;margin-top:.3rem}
.hero__scroll{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);color:#EAF1E3;font-size:.74rem;
  letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:.5rem;z-index:2}
.hero__scroll::after{content:"";width:1px;height:34px;background:linear-gradient(#F4C97A,transparent);animation:scrolldown 1.8s ease-in-out infinite}
@keyframes scrolldown{0%{opacity:0;transform:scaleY(.3)}50%{opacity:1}100%{opacity:0;transform:scaleY(1) translateY(8px)}}
@media (prefers-reduced-motion:reduce){.hero.kb .hero__media img{animation:none}.hero__scroll::after{animation:none}}
@media (max-width:680px){.hero__trust .k{font-size:1.25rem}}

/* ---------- intro / story strip ---------- */
.intro{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.intro__media{position:relative}
.intro__media img{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}
.intro__media .badge{position:absolute;bottom:-22px;left:-22px;background:var(--card);border:1px solid var(--line);
  border-radius:18px;padding:1rem 1.3rem;box-shadow:var(--shadow);display:flex;gap:.8rem;align-items:center;max-width:230px}
.intro__media .badge .yr{font-family:var(--display);font-size:2.2rem;color:var(--forest);line-height:.9}
.intro__media .badge small{font-size:.8rem;color:var(--ink-soft);line-height:1.3}
.intro h2 .lime{color:var(--forest)}
@media (max-width:860px){.intro{grid-template-columns:1fr}.intro__media{order:-1}.intro__media .badge{left:1rem;bottom:-18px}}

/* ---------- capability rails ---------- */
.cap-card{display:flex;flex-direction:column;height:100%}
.cap-card .num{font-family:var(--display);font-size:1.1rem;color:var(--gold);margin-bottom:.4rem}
.cap-card ul{display:flex;flex-direction:column;gap:.5rem;margin:1rem 0 1.3rem}
.cap-card li{display:flex;gap:.6rem;align-items:flex-start;font-size:.94rem;color:var(--ink-soft)}
.cap-card li::before{content:"";flex:none;width:18px;height:18px;margin-top:.15rem;border-radius:50%;
  background:rgba(141,198,63,.25) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231B6B3A' stroke-width='3'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/12px no-repeat}
.cap-card .arrow-link{margin-top:auto}

/* ---------- flavor preview ---------- */
.flavor-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
@media (max-width:900px){.flavor-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.flavor-grid{grid-template-columns:1fr}}
.flavor{position:relative;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:1.4rem;
  transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;transform-style:preserve-3d}
.flavor:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--lime-soft)}
.flavor .dot{width:38px;height:38px;border-radius:12px;background:rgba(200,134,43,.14);display:grid;place-items:center;margin-bottom:.9rem}
.flavor .dot svg{width:20px;height:20px;stroke:var(--gold-deep);fill:none;stroke-width:1.75}
.flavor h4{font-family:var(--body);font-weight:700;font-size:1.02rem;color:var(--forest-deep);margin-bottom:.3rem}
.flavor p{font-size:.85rem;color:var(--ink-soft)}
.flavor.plant .dot{background:rgba(141,198,63,.22)}
.flavor.plant .dot svg{stroke:#3c6014}

/* ---------- proof / validation band ---------- */
.proof{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.proof blockquote{font-family:var(--display);font-size:clamp(1.4rem,2.6vw,2rem);line-height:1.3;color:#fff;margin-bottom:1.2rem}
.proof blockquote::before{content:"“";color:var(--lime);font-size:1.2em;line-height:0;vertical-align:-.35em;margin-right:.1em}
.proof cite{font-style:normal;color:#A9BD9E;font-size:.95rem}
.proof .validators{display:flex;flex-direction:column;gap:1rem}
.proof .validators .vrow{display:flex;gap:1rem;align-items:flex-start;padding:1.1rem 1.3rem;background:rgba(255,255,255,.06);border-radius:14px;border:1px solid rgba(255,255,255,.1)}
.proof .validators .vrow svg{flex:none;width:24px;height:24px;stroke:var(--lime);fill:none;stroke-width:1.75;margin-top:.1rem}
.proof .validators h4{color:#fff;font-family:var(--body);font-size:1rem;margin-bottom:.2rem}
.proof .validators p{color:#C7D6BE;font-size:.9rem;margin:0}
@media (max-width:820px){.proof{grid-template-columns:1fr}}

/* ---------- process timeline ---------- */
.timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;counter-reset:step}
@media (max-width:880px){.timeline{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.timeline{grid-template-columns:1fr}}
.tl-step{position:relative;padding-top:2.6rem}
.tl-step::before{counter-increment:step;content:counter(step);position:absolute;top:0;left:0;
  width:44px;height:44px;border-radius:12px;background:var(--forest);color:#fff;font-family:var(--display);
  font-size:1.3rem;display:grid;place-items:center}
.tl-step h4{font-family:var(--body);font-weight:700;color:var(--forest-deep);margin-bottom:.4rem}
.tl-step p{font-size:.92rem;color:var(--ink-soft)}

/* ---------- audience marquee ---------- */
.marquee{overflow:hidden;border-block:1px solid var(--line);padding:1.4rem 0;-webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__track{display:flex;gap:3rem;width:max-content;animation:marquee 32s linear infinite}
.marquee span{font-family:var(--display);font-size:clamp(1.3rem,2.4vw,2rem);color:var(--forest-deep);display:inline-flex;align-items:center;gap:3rem;white-space:nowrap}
.marquee span::after{content:"•";color:var(--gold)}
.marquee .outline{color:transparent;-webkit-text-stroke:1px var(--gold)}
@keyframes marquee{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee__track{animation:none}}
