/* ===== Marché Freshco — fresh-market kinetic site ===== */
:root{
  --ink:#16140f;
  --green-900:#11331e;
  --green-700:#1F5C3D;
  --green-500:#3E8E5A;
  --lime:#9FC541;
  --orange:#E8852B;
  --red:#D1422E;
  --cream:#F6F1E7;
  --cream-2:#EFE7D6;
  --font-display:'Anton',sans-serif;
  --font-head:'Archivo',sans-serif;
  --font-body:'Inter',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased}
body{font-family:var(--font-body);background:var(--cream);color:var(--ink);overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
em{font-style:normal}
.ink-green{color:var(--green-700)}
.ink-orange{color:var(--orange)}

/* lenis */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}

/* ===== PRELOADER ===== */
.preloader{position:fixed;inset:0;z-index:1000;background:var(--green-900);display:grid;place-items:center;overflow:hidden}
.preloader__ring{width:120px;height:120px;border-radius:50%;background:var(--orange);
  box-shadow:0 0 0 0 var(--green-700);will-change:transform}
.preloader__word{position:absolute;display:flex;gap:.4ch;font-family:var(--font-display);
  color:var(--cream);font-size:clamp(2rem,7vw,5rem);letter-spacing:.02em;opacity:0}
.preloader__word span{display:inline-block;transform:translateY(120%)}

/* ===== NAV ===== */
.nav{position:fixed;top:0;left:0;width:100%;z-index:100;display:flex;align-items:center;
  justify-content:space-between;padding:18px clamp(18px,4vw,48px);
  transition:padding .4s ease,background .4s ease;mix-blend-mode:normal}
.nav.is-scrolled{padding:12px clamp(18px,4vw,48px);background:rgba(17,51,30,.92);
  backdrop-filter:blur(10px)}
.nav__brand{display:flex;align-items:center;gap:.4ch;font-family:var(--font-head);
  font-weight:800;font-size:1.15rem;color:var(--cream);letter-spacing:-.01em}
.nav__brand em{color:var(--orange)}
.nav__leaf{color:var(--green-500);display:inline-flex}
.nav.is-light .nav__brand{color:var(--cream)}
.nav__links{display:flex;gap:28px;font-weight:500;font-size:.82rem;letter-spacing:.04em;
  text-transform:uppercase;color:var(--cream)}
.nav__links a{position:relative;opacity:.85;transition:opacity .25s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;
  background:var(--orange);transition:width .3s ease}
.nav__links a:hover{opacity:1}
.nav__links a:hover::after{width:100%}
.nav__right{display:flex;align-items:center;gap:16px}
.nav__hours{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--lime);
  font-weight:600}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer}
.nav__burger span{width:24px;height:2px;background:var(--cream);transition:transform .3s ease,opacity .2s ease}
.lang-toggle{font-family:var(--font-head);font-weight:700;font-size:.74rem;letter-spacing:.06em;
  color:var(--cream);background:transparent;border:1.5px solid rgba(246,241,231,.4);
  border-radius:100px;padding:7px 13px;cursor:pointer;line-height:1;
  transition:background .25s,color .25s,border-color .25s}
.lang-toggle:hover{background:var(--cream);color:var(--green-900);border-color:var(--cream)}

.btn{font-family:var(--font-head);font-weight:700;cursor:pointer;display:inline-flex;
  align-items:center;justify-content:center;transition:transform .25s ease,background .25s ease,color .25s}
.btn--pill{background:var(--orange);color:var(--ink);border-radius:100px;padding:10px 22px;
  font-size:.8rem;letter-spacing:.02em}
.btn--pill:hover{transform:translateY(-2px);background:var(--lime)}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;background:var(--green-900);color:var(--cream);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:120px 24px 60px;overflow:hidden}
.hero__bg{position:absolute;inset:0;background:
  radial-gradient(120% 80% at 50% 0%,rgba(232,133,43,.18),transparent 60%),
  radial-gradient(80% 60% at 50% 100%,rgba(63,142,90,.25),transparent 70%)}
.hero__tags{position:relative;z-index:3;display:flex;gap:12px;align-items:center;
  font-family:var(--font-head);font-weight:700;text-transform:uppercase;letter-spacing:.18em;
  font-size:.78rem;color:var(--lime);margin-bottom:18px}
.hero__tags .dot{color:var(--orange)}
.hero__title{position:relative;z-index:3;font-family:var(--font-display);
  font-size:clamp(4.5rem,17vw,16rem);line-height:.82;letter-spacing:-.01em;text-transform:uppercase}
.hero__title .line{display:block;overflow:hidden}
.hero__title .w{display:inline-block;transform:translateY(110%)}
.hero__accent{color:var(--orange)}
.hero__produce{position:absolute;top:50%;left:50%;width:min(46vw,520px);
  transform:translate(-50%,-46%);z-index:2;mix-blend-mode:screen;opacity:.96;
  filter:drop-shadow(0 30px 60px rgba(0,0,0,.5));will-change:transform;pointer-events:none}
.hero__sub{position:relative;z-index:3;max-width:540px;margin:28px auto 0;
  font-size:1.02rem;line-height:1.5;color:rgba(246,241,231,.82)}
.hero__scroll{position:relative;z-index:3;margin-top:40px;font-family:var(--font-head);
  font-weight:600;text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;
  color:var(--cream);opacity:.8}
.hero__scroll span{display:inline-block;animation:bob 1.6s ease-in-out infinite}
@keyframes bob{50%{transform:translateY(6px)}}
.hero__num{position:absolute;right:4vw;bottom:2vw;z-index:3;font-family:var(--font-display);
  font-size:clamp(5rem,16vw,15rem);color:transparent;-webkit-text-stroke:2px rgba(246,241,231,.16);
  line-height:.8}

/* ===== MARQUEE ===== */
.marquee{background:var(--orange);color:var(--ink);overflow:hidden;padding:18px 0;
  border-top:3px solid var(--ink);border-bottom:3px solid var(--ink)}
.marquee__track{display:flex;align-items:center;gap:34px;white-space:nowrap;width:max-content;
  font-family:var(--font-display);font-size:clamp(1.4rem,3vw,2.4rem);text-transform:uppercase;
  letter-spacing:.01em;will-change:transform}
.marquee__track i{color:var(--green-700);font-style:normal}

/* ===== MANIFESTO ===== */
.manifesto{background:var(--cream);padding:clamp(90px,16vh,200px) clamp(24px,6vw,120px)}
.reveal-lines{font-family:var(--font-head);font-weight:800;
  font-size:clamp(1.8rem,5.4vw,4.6rem);line-height:1.04;letter-spacing:-.02em;max-width:1100px}
.reveal-lines span{display:block;overflow:hidden}
.reveal-lines span > em,.reveal-lines em{color:var(--green-700)}
.reveal-lines span{will-change:transform}

/* ===== CATEGORY SECTIONS ===== */
.cat{position:relative;padding:clamp(80px,12vh,160px) clamp(24px,6vw,96px);overflow:hidden}
.cat--light{background:var(--cream)}
.cat--dark{background:var(--green-900);color:var(--cream)}
.cat__num{position:absolute;top:6%;left:50%;transform:translateX(-50%);
  font-family:var(--font-display);font-size:clamp(10rem,32vw,30rem);line-height:.8;
  color:transparent;-webkit-text-stroke:2px rgba(31,92,61,.14);z-index:0;pointer-events:none}
.cat--dark .cat__num{-webkit-text-stroke-color:rgba(232,133,43,.18)}
.cat__inner{position:relative;z-index:2;max-width:1200px;margin:0 auto;display:grid;
  grid-template-columns:1.05fr .95fr;gap:clamp(32px,6vw,90px);align-items:center}
.cat__inner--rev{direction:rtl}
.cat__inner--rev>*{direction:ltr}
.cat__media{border-radius:18px;overflow:hidden;aspect-ratio:4/3;box-shadow:0 30px 60px rgba(0,0,0,.18)}
.cat__media img{width:100%;height:100%;object-fit:cover}
.cat__kicker{font-family:var(--font-head);font-weight:700;text-transform:uppercase;
  letter-spacing:.16em;font-size:.76rem;color:var(--orange)}
.cat__kicker.light{color:var(--lime)}
.cat__copy h2{font-family:var(--font-display);font-size:clamp(2.6rem,6.5vw,5.6rem);
  line-height:.92;text-transform:uppercase;margin:14px 0 18px;letter-spacing:-.005em}
.cat__copy p{font-size:1.05rem;line-height:1.6;max-width:46ch;opacity:.92}
.cat__list{list-style:none;display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.cat__list li{font-family:var(--font-head);font-weight:600;font-size:.8rem;
  text-transform:uppercase;letter-spacing:.06em;padding:8px 16px;border-radius:100px;
  border:1.5px solid currentColor;opacity:.85}

/* ===== STORY ===== */
.story{background:var(--green-700);color:var(--cream);padding:clamp(90px,14vh,180px) clamp(24px,6vw,96px);
  text-align:center}
.story__head h2{font-family:var(--font-display);font-size:clamp(2.4rem,6vw,5rem);
  text-transform:uppercase;line-height:.94;margin-top:14px}
.story__stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  max-width:1000px;margin:64px auto 0}
.stat b{display:block;font-family:var(--font-display);font-size:clamp(2.6rem,6vw,4.4rem);
  color:var(--lime);line-height:1}
.stat span{display:block;margin-top:10px;font-size:.86rem;opacity:.82;letter-spacing:.02em}
.story__quote{max-width:680px;margin:72px auto 0;font-family:var(--font-head);font-weight:600;
  font-size:clamp(1.2rem,2.6vw,1.9rem);line-height:1.4}
.story__quote span{display:block;margin-top:18px;font-size:.82rem;font-weight:500;
  text-transform:uppercase;letter-spacing:.12em;color:var(--orange)}

/* ===== TESTIMONIALS ===== */
.testi{background:var(--green-900);color:var(--cream);
  padding:clamp(80px,12vh,160px) clamp(24px,6vw,96px);text-align:center}
.testi__head h2{font-family:var(--font-display);font-size:clamp(2.4rem,6vw,5rem);
  text-transform:uppercase;line-height:.94;margin-top:14px}
.testi__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,28px);
  max-width:1150px;margin:56px auto 0;text-align:left}
.tcard{background:#13251a;border:1px solid rgba(246,241,231,.1);border-radius:18px;
  padding:30px 30px 26px;display:flex;flex-direction:column;gap:16px;
  box-shadow:0 22px 48px rgba(0,0,0,.3);transition:transform .35s ease}
.tcard:hover{transform:translateY(-6px)}
.tcard__stars{color:var(--orange);font-size:1.05rem;letter-spacing:.18em}
.tcard blockquote{font-family:var(--font-head);font-weight:600;font-size:1.12rem;
  line-height:1.45;flex:1}
.tcard figcaption{display:flex;flex-direction:column;gap:2px;padding-top:8px;
  border-top:1px solid rgba(246,241,231,.12)}
.tcard__name{font-family:var(--font-head);font-weight:800;font-size:1rem}
.tcard__src{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--lime)}
.testi__cta{display:inline-block;margin-top:48px;font-family:var(--font-head);font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;color:var(--cream);
  padding-bottom:4px;border-bottom:2px solid var(--orange);transition:color .25s}
.testi__cta:hover{color:var(--orange)}

/* ===== DEPARTMENTS ===== */
.depts{background:var(--cream);padding:clamp(80px,12vh,160px) clamp(24px,6vw,96px);text-align:center}
.depts__title{font-family:var(--font-display);font-size:clamp(2.2rem,5.5vw,4.6rem);
  text-transform:uppercase;margin-bottom:48px}
.depts__grid{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;max-width:980px;margin:0 auto}
.depts__grid span{font-family:var(--font-head);font-weight:700;font-size:clamp(1rem,2.4vw,1.7rem);
  text-transform:uppercase;letter-spacing:-.01em;padding:14px 26px;border-radius:100px;
  background:var(--cream-2);color:var(--green-700);transition:background .3s,color .3s,transform .3s}
.depts__grid span:hover{background:var(--green-700);color:var(--cream);transform:translateY(-3px)}

/* ===== VISIT / FOOTER ===== */
.visit{background:var(--ink);color:var(--cream);padding:clamp(80px,12vh,160px) clamp(24px,6vw,96px) 48px;
  position:relative;overflow:hidden}
.visit__num{font-family:var(--font-display);font-size:3rem;color:var(--orange);text-align:center;
  animation:bob 1.8s ease-in-out infinite}
.visit__title{font-family:var(--font-display);font-size:clamp(4rem,15vw,13rem);line-height:.84;
  text-transform:uppercase;text-align:center;margin:18px 0 60px}
.visit__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;max-width:900px;
  margin:0 auto 50px;text-align:center}
.visit__cols h4{font-family:var(--font-head);font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;font-size:.78rem;color:var(--orange);margin-bottom:12px}
.visit__cols p{line-height:1.6;opacity:.9}
.btn--big{display:flex;width:fit-content;margin:0 auto;background:var(--orange);color:var(--ink);
  border-radius:100px;padding:18px 40px;font-size:1.05rem}
.btn--big:hover{transform:translateY(-3px);background:var(--lime)}
.visit__base{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
  margin-top:70px;padding-top:24px;border-top:1px solid rgba(246,241,231,.16);
  font-size:.76rem;letter-spacing:.06em;text-transform:uppercase;opacity:.7}

/* ===== reveal defaults ===== */
.reveal-up{opacity:0;transform:translateY(40px)}

/* ===== PRODUCTS PAGE ===== */
.shop-page{background:var(--cream)}
.nav__links a.is-active{opacity:1}
.nav__links a.is-active::after{width:100%}
.shop-hero{background:var(--green-900);color:var(--cream);text-align:center;
  padding:160px clamp(24px,6vw,96px) 90px;position:relative;overflow:hidden}
.shop-hero::after{content:"";position:absolute;inset:0;background:
  radial-gradient(80% 60% at 50% 0%,rgba(232,133,43,.16),transparent 60%);pointer-events:none}
.shop-hero h1{position:relative;font-family:var(--font-display);
  font-size:clamp(3.6rem,12vw,10rem);line-height:.86;text-transform:uppercase}
.shop-hero p{position:relative;max-width:600px;margin:26px auto 0;line-height:1.6;
  color:rgba(246,241,231,.82);font-size:1.05rem}
.shop-hero .hero__scroll{color:var(--cream)}

.shopnav{position:sticky;top:56px;z-index:50;display:flex;gap:8px;flex-wrap:wrap;justify-content:center;
  padding:14px 16px;background:rgba(17,51,30,.96);backdrop-filter:blur(8px)}
.shopnav a{font-family:var(--font-head);font-weight:600;font-size:.74rem;text-transform:uppercase;
  letter-spacing:.06em;color:var(--cream);padding:8px 16px;border-radius:100px;
  border:1.5px solid rgba(246,241,231,.22);transition:background .25s,color .25s,border-color .25s}
.shopnav a:hover,.shopnav a.is-active{background:var(--orange);color:var(--ink);border-color:var(--orange)}

.shop-cat{padding:clamp(64px,10vh,120px) clamp(24px,6vw,96px)}
.shop-cat--dark{background:var(--green-900);color:var(--cream)}
.shop-cat__head{max-width:1200px;margin:0 auto clamp(36px,5vw,56px)}
.shop-cat__head h2{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.8rem);
  text-transform:uppercase;line-height:.96;margin:12px 0 14px}
.shop-cat__head p{max-width:54ch;line-height:1.6;opacity:.9}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,30px);
  max-width:1200px;margin:0 auto}
.pcard{background:var(--cream);border-radius:16px;overflow:hidden;
  box-shadow:0 18px 40px rgba(0,0,0,.12);display:flex;flex-direction:column;
  transition:transform .35s ease,box-shadow .35s ease}
.shop-cat--dark .pcard{background:#13251a;box-shadow:0 18px 40px rgba(0,0,0,.35)}
.pcard:hover{transform:translateY(-6px);box-shadow:0 26px 56px rgba(0,0,0,.2)}
.pcard__img{aspect-ratio:1/1;overflow:hidden}
.pcard__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.pcard:hover .pcard__img img{transform:scale(1.06)}
.pcard__body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:6px;flex:1}
.shop-cat--dark .pcard__body{color:var(--cream)}
.pcard__body h3{font-family:var(--font-head);font-weight:800;font-size:1.3rem;letter-spacing:-.01em}
.pcard__body p{font-size:.92rem;line-height:1.45;opacity:.8;flex:1}
.pcard__tag{align-self:flex-start;margin-top:6px;font-family:var(--font-head);font-weight:700;
  font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;padding:6px 14px;border-radius:100px;
  background:var(--green-700);color:var(--cream)}
.pcard__tag--alt{background:var(--orange);color:var(--ink)}
.pcard--text{background:var(--cream-2);justify-content:center;min-height:220px}
.shop-cat--dark .pcard--text{background:#16291d}
.pcard--text .pcard__body{padding:30px}

.shop-banner{background:var(--orange);color:var(--ink);text-align:center;
  padding:clamp(80px,12vh,150px) clamp(24px,6vw,96px)}
.shop-banner h2{font-family:var(--font-display);font-size:clamp(2.6rem,8vw,6.5rem);
  text-transform:uppercase;line-height:.9}
.shop-banner .ink-orange{color:var(--green-900)}
.shop-banner p{max-width:520px;margin:18px auto 34px;line-height:1.6;font-size:1.05rem}
.shop-banner .btn--big{background:var(--green-900);color:var(--cream)}
.shop-banner .btn--big:hover{background:var(--ink)}
.shop-page .visit{padding-top:clamp(60px,8vh,100px)}

/* ===== REAL SHOP PHOTOS (featured / pop-out) ===== */
.realshop{background:var(--cream);
  padding:clamp(56px,8vh,100px) clamp(24px,6vw,96px) clamp(40px,6vh,70px);
  border-top:1px solid rgba(31,92,61,.08)}
.realshop__head{max-width:1200px;margin:0 auto clamp(30px,4vw,46px);text-align:center}
.realshop__head h2{font-family:var(--font-display);font-size:clamp(2.2rem,5.6vw,4.6rem);
  text-transform:uppercase;line-height:.94;margin:12px 0 14px}
.realshop__head p{max-width:54ch;margin:0 auto;line-height:1.55;opacity:.82}
.realshop__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,32px);
  max-width:1200px;margin:0 auto}
.realcard{position:relative;border-radius:20px;overflow:hidden;
  border:3px solid var(--orange);
  box-shadow:0 20px 46px rgba(0,0,0,.18), 0 0 0 7px rgba(63,142,90,.14);
  transition:transform .45s cubic-bezier(.2,.7,.2,1),box-shadow .45s ease}
.realcard:hover{transform:translateY(-10px) scale(1.02);
  box-shadow:0 34px 68px rgba(0,0,0,.26), 0 0 0 7px rgba(232,133,43,.28)}
.realcard__img{aspect-ratio:4/5;overflow:hidden}
.realcard__img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.realcard:hover .realcard__img img{transform:scale(1.07)}
.realcard__badge{position:absolute;top:14px;left:14px;z-index:3;display:inline-flex;align-items:center;gap:5px;
  font-family:var(--font-head);font-weight:800;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;
  background:var(--orange);color:var(--ink);padding:7px 13px;border-radius:100px;
  box-shadow:0 6px 18px rgba(0,0,0,.3)}
.realcard figcaption{position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:46px 18px 16px;color:var(--cream);
  font-family:var(--font-head);font-weight:700;font-size:1.02rem;letter-spacing:-.01em;
  background:linear-gradient(transparent,rgba(16,28,18,.9))}

/* ===== RESPONSIVE ===== */
@media(max-width:960px){
  .pgrid{grid-template-columns:repeat(2,1fr)}
  .realshop__grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:860px){
  .nav__brand,.nav__right{position:relative;z-index:100}
  .nav__burger{display:flex}
  .nav__hours{display:none}
  .nav .btn--pill{display:none}
  .nav__links{position:fixed;inset:0;height:100dvh;display:flex;flex-direction:column;
    align-items:flex-start;justify-content:center;gap:6px;padding:96px 34px;
    background:var(--green-900);z-index:95;
    transform:translateX(100%);transition:transform .5s cubic-bezier(.76,0,.24,1)}
  .nav__links a{opacity:1;font-family:var(--font-display);font-size:clamp(2.2rem,9vw,3.2rem);
    text-transform:uppercase;line-height:1.1;color:var(--cream)}
  .nav__links a::after{display:none}
  .nav__links a.is-active{color:var(--orange)}
  .nav.is-open .nav__links{transform:translateX(0)}
  .nav.is-open .nav__burger span:first-child{transform:translateY(3.5px) rotate(45deg)}
  .nav.is-open .nav__burger span:last-child{transform:translateY(-3.5px) rotate(-45deg)}
  .testi__grid{grid-template-columns:1fr;max-width:520px}
  .realshop__grid{grid-template-columns:repeat(2,1fr)}
  .cat__inner,.cat__inner--rev{grid-template-columns:1fr;direction:ltr}
  .cat__inner--rev .cat__media{order:-1}
  .story__stats{grid-template-columns:repeat(2,1fr)}
  .visit__cols{grid-template-columns:1fr;gap:34px}
  .hero__produce{width:78vw;transform:translate(-50%,-44%)}
  .visit__base{justify-content:center;text-align:center}
}
@media(max-width:560px){
  .pgrid{grid-template-columns:1fr}
  .realshop__grid{grid-template-columns:1fr;max-width:430px;margin-inline:auto}
  .story__stats{grid-template-columns:1fr}
}
