/* ============================================================
   OVO Gelato — homepage
   Brand: sage green + cream, vintage apothecary coin.
   Type: Fraunces (display) + Inter (body).
   ============================================================ */

:root{
  --cream:#f7f1de;
  --paper:#fcf8ec;
  --sage:#7c8556;
  --sage-soft:#9aa074;
  --sage-deep:#565d39;
  --olive:#454a30;
  --ink:#2c281f;
  --muted:#6c6a55;
  --blush:#d18b80;
  --line:rgba(69,74,48,.16);
  --line-soft:rgba(69,74,48,.10);
  --shadow:0 18px 50px -28px rgba(48,52,28,.55);
  --r:18px;
  --maxw:1180px;
  --serif:"Fraunces",Georgia,serif;
  --sans:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.08;margin:0;color:var(--olive);
  font-optical-sizing:auto}
p{margin:0}

.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:24px}
.section{padding-block:clamp(64px,8vw,120px)}
.eyebrow{
  font-family:var(--sans);font-size:.78rem;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:var(--sage);margin:0 0 18px;display:flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--sage);display:inline-block}
.lead{font-size:1.18rem;color:var(--muted);line-height:1.62}

/* Brand asterisk mark */
.ast{display:inline-block;color:var(--sage);line-height:0}
.ast svg{display:block}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--sans);font-weight:600;font-size:.98rem;white-space:nowrap;
  padding:15px 28px;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .18s ease,background .18s ease,color .18s ease,border-color .18s ease;
}
.btn--primary{background:var(--sage);color:var(--paper)}
.btn--primary:hover{background:var(--sage-deep);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--olive);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--sage);color:var(--sage);transform:translateY(-2px)}
.btn--cream{background:var(--cream);color:var(--olive)}
.btn--cream:hover{background:#fff;transform:translateY(-2px)}
.btn--outline-cream{background:transparent;color:var(--cream);border-color:rgba(247,241,222,.45)}
.btn--outline-cream:hover{border-color:var(--cream);transform:translateY(-2px)}

.icon-btn{background:none;border:0;color:var(--olive);cursor:pointer;padding:8px;display:grid;place-items:center;border-radius:10px}

/* ---------- Nav ---------- */
.nav{position:sticky;top:0;z-index:60;background:rgba(247,241,222,.82);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line-soft)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;height:76px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:46px;height:46px}
.brand__word{font-family:var(--serif);font-size:1.5rem;font-weight:600;letter-spacing:.16em;color:var(--olive)}
.nav__links{display:flex;gap:30px}
.nav__links a{font-size:.96rem;font-weight:500;color:var(--ink);position:relative;padding-block:4px}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--sage);transition:width .22s ease}
.nav__links a:hover{color:var(--sage)}
.nav__links a:hover::after{width:100%}
.nav__cta{display:flex;align-items:center;gap:18px}
.nav__phone{font-weight:600;font-size:.95rem;color:var(--olive)}
.nav__phone:hover{color:var(--sage)}
.nav__toggle{display:none;min-width:48px;min-height:48px}

/* Mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:80;background:var(--cream);transform:translateX(100%);
  transition:transform .32s cubic-bezier(.4,0,.2,1);padding:24px;display:flex;flex-direction:column;gap:8px}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.mobile-menu nav{display:flex;flex-direction:column}
.mobile-menu nav a{font-family:var(--serif);font-size:1.7rem;color:var(--olive);padding:14px 0;border-bottom:1px solid var(--line-soft)}
.mobile-menu .btn{margin-top:24px}
.mobile-menu__contact{margin-top:auto;color:var(--muted);font-size:.95rem;display:flex;flex-direction:column;gap:6px}

/* ---------- Hero ---------- */
.hero{padding-block:clamp(40px,6vw,76px) clamp(56px,7vw,96px);position:relative;overflow:hidden}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center}
.hero__title{font-size:clamp(2.7rem,6vw,4.4rem);letter-spacing:-.01em}
.hero__title em{font-style:italic;color:var(--sage)}
.hero__lead{margin-top:24px;max-width:30ch}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero__note{margin-top:30px;padding-top:24px;border-top:1px solid var(--line);
  display:flex;align-items:center;gap:14px;color:var(--muted);font-size:1.02rem;max-width:40ch}
.hero__note .ast{flex:0 0 auto;margin-top:2px}

.hero__figure{position:relative}
.hero__figure img{width:100%;border-radius:230px 230px 26px 26px;box-shadow:var(--shadow);
  aspect-ratio:5/6;object-fit:cover}
.hero__seal{position:absolute;right:-18px;bottom:28px;width:128px;height:128px;
  background:var(--paper);border-radius:50%;display:grid;place-items:center;text-align:center;
  box-shadow:var(--shadow);border:1px solid var(--line-soft);transform:rotate(-7deg)}
.hero__seal span{font-family:var(--serif);font-size:.84rem;line-height:1.25;color:var(--sage-deep);
  font-weight:500;letter-spacing:.02em;padding:0 14px}
.hero__seal strong{display:block;font-size:1.18rem;color:var(--sage);font-weight:600}

/* ---------- Allergy / "for everyone" ---------- */
.everyone{background:var(--paper);border-block:1px solid var(--line-soft)}
.everyone__head{max-width:660px;margin-bottom:clamp(36px,4vw,56px)}
.everyone__head h2{font-size:clamp(2rem,3.6vw,2.9rem);margin-top:6px}
.everyone__head p{margin-top:18px}
.diet-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2.4vw,28px)}
.diet{padding:30px 24px;border:1px solid var(--line);border-radius:var(--r);background:var(--cream);
  transition:transform .2s ease,box-shadow .2s ease}
.diet:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.diet__mark{margin-bottom:18px}
.diet h3{font-size:1.4rem;margin-bottom:8px}
.diet p{color:var(--muted);font-size:.97rem;line-height:1.55}
.everyone__foot{margin-top:34px;color:var(--muted);font-size:1.02rem;display:flex;gap:12px;align-items:flex-start}

/* ---------- Flavours ---------- */
.flavours{background:var(--sage);color:var(--cream);position:relative;overflow:hidden}
.flavours h2,.flavours h3{color:var(--cream)}
.flavours .eyebrow{color:#e7e4c6}
.flavours .eyebrow::before{background:#e7e4c6}
.flavours__grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(32px,5vw,68px);align-items:center}
.flavours__media{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.flavours__media img{width:100%;aspect-ratio:4/3.4;object-fit:cover}
.flavours h2{font-size:clamp(2rem,3.6vw,3rem)}
.flavours__intro{margin-top:18px;color:rgba(247,241,222,.84);font-size:1.12rem;max-width:46ch}
.flavour-list{margin-top:30px;display:grid;grid-template-columns:repeat(2,1fr);gap:2px 28px;
  border-top:1px solid rgba(247,241,222,.22)}
.flavour-list li{list-style:none;display:flex;align-items:center;gap:10px;
  padding:13px 2px;border-bottom:1px solid rgba(247,241,222,.16);font-size:1.04rem}
.flavour-list li span{margin-left:auto;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  color:#dfe0bd;border:1px solid rgba(247,241,222,.3);border-radius:999px;padding:3px 9px}
.flavours__note{margin-top:26px;color:rgba(247,241,222,.7);font-size:.98rem;font-style:italic}

/* ---------- Craft / story ---------- */
.craft__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:center}
.craft__head h2{font-size:clamp(2rem,3.8vw,3.1rem);margin-top:6px}
.craft__head .lead{margin-top:20px}
.points{margin-top:8px;display:flex;flex-direction:column;gap:24px}
.point{display:flex;gap:18px}
.point__mark{flex:0 0 auto;margin-top:3px}
.point h3{font-size:1.28rem;margin-bottom:5px}
.point p{color:var(--muted);font-size:1rem;margin:0}

/* ---------- More than gelato ---------- */
.more{background:var(--paper);border-block:1px solid var(--line-soft)}
.more__head{max-width:640px;margin-bottom:clamp(32px,4vw,52px)}
.more__head h2{font-size:clamp(2rem,3.6vw,2.9rem);margin-top:6px}
.more__head p{margin-top:18px}
.more-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.4vw,28px)}
.more-card{padding:32px 28px;border:1px solid var(--line);border-radius:var(--r);background:var(--cream);
  display:flex;flex-direction:column;gap:10px}
.more-card h3{font-size:1.5rem}
.more-card p{color:var(--muted);font-size:1rem}
.more-card--feature{background:var(--sage);color:var(--cream);border-color:var(--sage)}
.more-card--feature h3{color:var(--cream)}
.more-card--feature p{color:rgba(247,241,222,.85)}
.more-card__tag{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
  color:#e7e4c6;margin-bottom:auto}

/* ---------- Locations ---------- */
.locations__head{max-width:640px;margin-bottom:clamp(32px,4vw,52px)}
.locations__head h2{font-size:clamp(2rem,3.8vw,3.1rem);margin-top:6px}
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,3vw,40px)}
.loc{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--paper);
  display:flex;flex-direction:column}
.loc__map{aspect-ratio:16/10;background:var(--line-soft)}
.loc__map iframe{width:100%;height:100%;border:0;display:block}
.loc__body{padding:28px 28px 32px}
.loc__name{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.loc__name h3{font-size:1.6rem}
.loc__badge{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;color:var(--sage-deep);
  background:rgba(124,133,86,.14);border-radius:999px;padding:5px 12px}
.loc__addr{color:var(--muted);font-size:1.04rem;line-height:1.5}
.loc__addr strong{color:var(--ink);font-weight:600}
.loc__meta{margin-top:14px;color:var(--muted);font-size:.97rem}
.loc__actions{margin-top:22px;display:flex;flex-wrap:wrap;gap:12px}

/* ---------- Order CTA ---------- */
.order{background:var(--sage-deep);color:var(--cream);text-align:center}
.order h2{color:var(--cream);font-size:clamp(2.1rem,4vw,3.3rem);max-width:18ch;margin-inline:auto}
.order p{margin-top:18px;color:rgba(247,241,222,.82);font-size:1.14rem;max-width:48ch;margin-inline:auto}
.order__actions{margin-top:34px;display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.order .ast{margin-bottom:8px}

/* ---------- Footer ---------- */
.footer{background:var(--olive);color:rgba(247,241,222,.78);padding-block:64px 32px}
.footer a{color:rgba(247,241,222,.78)}
.footer a:hover{color:var(--cream)}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;
  padding-bottom:40px;border-bottom:1px solid rgba(247,241,222,.16)}
.footer__brand img{width:64px;height:64px;margin-bottom:16px}
.footer__brand p{color:rgba(247,241,222,.7);font-size:.98rem;max-width:30ch}
.footer__col h4{font-family:var(--sans);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--cream);margin:0 0 14px;font-weight:600}
.footer__col a,.footer__col span{display:block;font-size:.98rem;margin-bottom:9px}
.footer__bottom{display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;
  padding-top:24px;color:rgba(247,241,222,.55);font-size:.88rem}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .nav__links,.nav__phone{display:none}
  .nav__toggle{display:grid}
  .hero__grid{grid-template-columns:1fr;gap:40px}
  .hero__figure{max-width:460px;margin-inline:auto}
  .hero__lead,.hero__note{max-width:none}
  .flavours__grid,.craft__grid,.loc-grid{grid-template-columns:1fr}
  .craft__media{order:-1}
  .diet-grid{grid-template-columns:repeat(2,1fr)}
  .more-grid{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width:560px){
  body{font-size:16px}
  .container{padding-inline:18px}
  .nav__inner{gap:12px}
  .nav__cta .btn{padding:11px 17px;font-size:.88rem}
  .hero__actions .btn,.order__actions .btn{flex:1 1 auto}
  .flavour-list{grid-template-columns:1fr}
  .diet-grid{grid-template-columns:1fr}
  .hero__seal{width:104px;height:104px;right:0}
  .footer__top{grid-template-columns:1fr}
  .loc__actions .btn{flex:1 1 auto}
}
