/* ============================================================
   MILESTONE VENTURES LIMITED — Design System
   Brief: Warm editorial food-manufacturing brand.
   Palette: espresso + cream, paprika & saffron accents, herb green.
   Type: Fraunces (display serif) + Hanken Grotesk (body).
   ============================================================ */

/* ---------- 1. TOKENS ---------- */
:root{
  --ink:#211A14;        /* espresso black */
  --espresso:#2F241B;
  --cream:#F5EFE3;      /* canvas */
  --paper:#FBF7EF;      /* card paper */
  --paprika:#C24B2C;    /* primary accent */
  --paprika-dk:#A53C20;
  --saffron:#D98A2B;    /* secondary accent */
  --herb:#3C4A2E;       /* deep herb green */
  --clay:#E3D9C6;       /* borders / muted */
  --muted:#7A6F60;      /* secondary text */
  --line:#E3D9C6;

  --ff-display:"Fraunces",Georgia,serif;
  --ff-body:"Hanken Grotesk","Segoe UI",system-ui,sans-serif;

  --maxw:1240px;
  --gut:clamp(20px,5vw,72px);
  --radius:18px;
  --radius-sm:12px;
  --shadow:0 24px 60px -28px rgba(33,26,20,.45);
  --shadow-sm:0 10px 30px -18px rgba(33,26,20,.4);
  --t:cubic-bezier(.2,.7,.2,1);
}

/* ---------- 2. RESET ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff-body);
  background:var(--cream);
  color:var(--ink);
  line-height:1.62;
  font-size:17px;
  font-weight:400;
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer}
:focus-visible{outline:3px solid var(--saffron);outline-offset:3px;border-radius:4px}

/* grain overlay on whole page */
body::after{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- 3. TYPOGRAPHY ---------- */
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:560;line-height:1.04;letter-spacing:-.01em;color:var(--ink)}
h1{font-size:clamp(2.6rem,6.4vw,5.2rem);font-weight:600;letter-spacing:-.02em}
h2{font-size:clamp(2rem,4.2vw,3.3rem)}
h3{font-size:clamp(1.35rem,2.4vw,1.85rem)}
h4{font-size:clamp(1.1rem,1.8vw,1.32rem);font-weight:600}
p{max-width:68ch}
.lede{font-size:clamp(1.12rem,1.9vw,1.4rem);line-height:1.55;color:#4a4036;font-weight:380}
.eyebrow{
  font-family:var(--ff-body);font-weight:700;font-size:.74rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--paprika);display:inline-flex;align-items:center;gap:.6rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--paprika);display:inline-block}
.eyebrow.light{color:var(--saffron)}.eyebrow.light::before{background:var(--saffron)}
.serif-accent{font-family:var(--ff-display);font-style:italic;font-weight:400;color:var(--paprika)}

/* ---------- 4. LAYOUT ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.section{padding-block:clamp(64px,9vw,120px)}
.section--tight{padding-block:clamp(48px,6vw,80px)}
.bg-ink{background:var(--ink);color:var(--cream)}
.bg-ink h1,.bg-ink h2,.bg-ink h3,.bg-ink h4{color:var(--cream)}
.bg-herb{background:var(--herb);color:var(--cream)}
.bg-herb h2,.bg-herb h3,.bg-herb h4{color:var(--cream)}
.bg-paper{background:var(--paper)}
.center{text-align:center}
.center p{margin-inline:auto}
.measure{max-width:62ch}
.grid{display:grid;gap:clamp(20px,3vw,40px)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
@media(min-width:901px)and(max-width:1100px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}}

/* ---------- 5. BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;font-family:var(--ff-body);
  font-weight:650;font-size:.96rem;letter-spacing:.01em;padding:.95rem 1.6rem;border-radius:100px;
  border:1.5px solid transparent;transition:.35s var(--t);position:relative;
}
.btn svg{width:18px;height:18px;transition:transform .35s var(--t)}
.btn:hover svg{transform:translateX(4px)}
.btn--primary{background:var(--paprika);color:#fff}
.btn--primary:hover{background:var(--paprika-dk);transform:translateY(-2px);box-shadow:0 14px 30px -12px rgba(165,60,32,.6)}
.btn--ink{background:var(--ink);color:var(--cream)}
.btn--ink:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.btn--ghost{border-color:currentColor;color:inherit;background:transparent}
.btn--ghost:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.bg-ink .btn--ghost:hover,.bg-herb .btn--ghost:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.btn--cream{background:var(--cream);color:var(--ink)}
.btn--cream:hover{background:#fff;transform:translateY(-2px)}
.link-arrow{font-weight:650;color:var(--paprika);display:inline-flex;align-items:center;gap:.45rem}
.link-arrow svg{width:16px;transition:transform .3s var(--t)}
.link-arrow:hover svg{transform:translateX(4px)}

/* ---------- 6. HEADER ---------- */
.header{position:sticky;top:0;z-index:1000;transition:.4s var(--t)}
.header__bar{
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  padding:1.15rem var(--gut);transition:.4s var(--t);
  background:rgba(245,239,227,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
}
.header.scrolled .header__bar{padding-block:.7rem;border-bottom-color:var(--line);box-shadow:0 8px 30px -22px rgba(33,26,20,.5)}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--ff-display);font-weight:600;font-size:1.32rem;letter-spacing:-.01em}
.brand svg{width:40px;height:40px;border-radius:11px;flex:none}
.brand small{display:block;font-family:var(--ff-body);font-weight:600;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:-2px}
.nav{display:flex;align-items:center;gap:.3rem}
.nav a{padding:.55rem .85rem;border-radius:8px;font-weight:550;font-size:.94rem;color:#4a4036;transition:.25s}
.nav a:hover,.nav a.active{color:var(--ink);background:rgba(194,75,44,.09)}
.nav a.active{color:var(--paprika)}
.header__cta{display:flex;align-items:center;gap:.8rem}
.menu-btn{display:none;width:46px;height:46px;border:1.5px solid var(--ink);border-radius:11px;background:transparent;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.menu-btn span{width:20px;height:2px;background:var(--ink);transition:.3s}
.menu-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-btn.open span:nth-child(2){opacity:0}
.menu-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:1080px){
  .nav,.header__cta .btn{display:none}
  .menu-btn{display:flex}
  .mobile-nav.open .header__cta .btn{display:inline-flex}
}
.mobile-nav{position:fixed;inset:0;z-index:999;background:var(--cream);transform:translateX(100%);transition:.45s var(--t);display:flex;flex-direction:column;padding:6rem var(--gut) 3rem;gap:.4rem}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav a{font-family:var(--ff-display);font-size:1.7rem;padding:.55rem 0;border-bottom:1px solid var(--line)}
.mobile-nav .btn{margin-top:1.4rem;justify-content:center}

/* ---------- 7. HERO (asymmetric editorial) ---------- */
.hero{position:relative;padding-top:clamp(40px,6vw,80px);overflow:hidden}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(24px,4vw,56px);align-items:center}
.hero__title{margin:.5rem 0 1.3rem}
.hero__title .ink-stroke{position:relative;display:inline-block}
.hero__title .ink-stroke::after{content:"";position:absolute;left:-2%;right:-2%;bottom:.08em;height:.34em;background:var(--saffron);opacity:.5;z-index:-1;border-radius:4px;transform:rotate(-1deg)}
.hero__meta{display:flex;flex-wrap:wrap;gap:1.4rem;margin-top:2rem;padding-top:1.6rem;border-top:1px solid var(--line)}
.hero__meta div{min-width:90px}
.hero__meta b{font-family:var(--ff-display);font-size:1.8rem;display:block;line-height:1}
.hero__meta span{font-size:.78rem;color:var(--muted);letter-spacing:.04em}
.hero__media{position:relative}
.hero__media img{width:100%;aspect-ratio:4/4.6;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow)}
.hero__badge{position:absolute;left:-26px;bottom:34px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);padding:1rem 1.2rem;box-shadow:var(--shadow);max-width:230px}
.hero__badge b{font-family:var(--ff-display);font-size:1.05rem;display:block;margin-bottom:.15rem}
.hero__badge span{font-size:.82rem;color:var(--muted);line-height:1.4;display:block}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:.4rem}
@media(max-width:900px){
  .hero__grid{grid-template-columns:1fr}
  .hero__media{order:-1}
  .hero__media img{aspect-ratio:4/3}
  .hero__badge{left:auto;right:16px;bottom:-22px}
}

/* page hero (interior) */
.phero{position:relative;padding:clamp(70px,9vw,130px) 0 clamp(40px,5vw,64px)}
.phero .eyebrow{margin-bottom:1.1rem}
.phero h1{max-width:16ch}
.phero .lede{margin-top:1.4rem;max-width:60ch}
.crumbs{font-size:.82rem;color:var(--muted);margin-bottom:1.4rem;letter-spacing:.02em}
.crumbs a:hover{color:var(--paprika)}

/* ---------- 8. MARQUEE ---------- */
.marquee{background:var(--ink);color:var(--cream);overflow:hidden;border-block:1px solid rgba(245,239,227,.12)}
.marquee__track{display:flex;gap:3.5rem;width:max-content;animation:scrollx 32s linear infinite;padding:1.05rem 0}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__item{display:flex;align-items:center;gap:.7rem;font-family:var(--ff-display);font-size:1.05rem;white-space:nowrap;color:rgba(245,239,227,.92)}
.marquee__item svg{width:18px;height:18px;color:var(--saffron)}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ---------- 9. CARDS ---------- */
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.5rem,2.4vw,2.2rem);transition:.4s var(--t);height:100%}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--clay)}
.card__num{font-family:var(--ff-display);font-size:1rem;color:var(--paprika);font-weight:600}
.card .ico{width:52px;height:52px;border-radius:14px;background:rgba(194,75,44,.1);display:grid;place-items:center;margin-bottom:1.2rem;color:var(--paprika)}
.card .ico svg{width:26px;height:26px}
.card h3{margin-bottom:.6rem}
.card p{color:#544a3f;font-size:.97rem}

/* product/range card with image */
.rangecard{position:relative;border-radius:var(--radius);overflow:hidden;color:#fff;min-height:330px;display:flex;align-items:flex-end;box-shadow:var(--shadow-sm)}
.rangecard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.6s var(--t)}
.rangecard:hover img{transform:scale(1.06)}
.rangecard::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(33,26,20,.88),rgba(33,26,20,.15) 60%,transparent)}
.rangecard__body{position:relative;z-index:2;padding:1.7rem}
.rangecard__body h3{color:#fff;margin-bottom:.4rem}
.rangecard__body p{color:rgba(245,239,227,.9);font-size:.93rem;max-width:40ch}
.rangecard__tag{display:inline-block;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:var(--saffron);margin-bottom:.7rem}

/* ---------- 10. SPLIT / FEATURE ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:center}
.split--reverse .split__media{order:2}
.split__media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;aspect-ratio:7/5;object-fit:cover}
.split__media{position:relative}
@media(max-width:880px){.split{grid-template-columns:1fr}.split--reverse .split__media{order:-1}}
.tick{display:flex;gap:.8rem;align-items:flex-start;margin-top:1rem}
.tick svg{flex:none;width:22px;height:22px;color:var(--paprika);margin-top:3px}
.tick b{font-family:var(--ff-display);font-weight:560;font-size:1.08rem;display:block;margin-bottom:.15rem}
.tick span{color:#544a3f;font-size:.95rem}

/* ---------- 11. STATS COUNTER ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,40px)}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{text-align:center}
.stat b{font-family:var(--ff-display);font-size:clamp(2.6rem,5vw,4rem);font-weight:600;line-height:1;color:var(--saffron);display:block}
.stat span{display:block;margin-top:.6rem;font-size:.9rem;letter-spacing:.05em;color:rgba(245,239,227,.78)}
.bg-paper .stat b,.bg-cream .stat b{color:var(--paprika)}
.bg-paper .stat span{color:var(--muted)}

/* ---------- 12. PROCESS TIMELINE ---------- */
.process{counter-reset:step;display:grid;gap:1.2rem}
.pstep{display:grid;grid-template-columns:auto 1fr;gap:1.4rem;align-items:start;padding:1.5rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper);transition:.35s var(--t)}
.pstep:hover{border-color:var(--paprika);transform:translateX(6px)}
.pstep__n{counter-increment:step;font-family:var(--ff-display);font-size:1.5rem;font-weight:600;color:#fff;width:54px;height:54px;border-radius:14px;background:var(--ink);display:grid;place-items:center}
.pstep__n::before{content:"0" counter(step)}
.pstep h4{margin-bottom:.3rem}
.pstep p{color:#544a3f;font-size:.96rem;margin:0}

/* ---------- 13. DIAGONAL DIVIDER ---------- */
.diag{position:relative}
.diag--top{clip-path:polygon(0 3.5vw,100% 0,100% 100%,0 100%)}
.diag--both{clip-path:polygon(0 3.5vw,100% 0,100% calc(100% - 3.5vw),0 100%)}

/* full-width image band */
.band{position:relative;min-height:clamp(260px,38vw,440px);display:grid;place-items:center;text-align:center;color:#fff;overflow:hidden}
.band img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.band__inner{position:relative;z-index:2;max-width:760px;padding:2rem var(--gut)}
.band__inner h2{color:#fff}
.band__inner p{color:rgba(245,239,227,.9);margin-inline:auto;margin-top:1rem}

/* ---------- 14. ACCORDION (FAQ) ---------- */
.acc{border-top:1px solid var(--line)}
.acc__item{border-bottom:1px solid var(--line)}
.acc__q{width:100%;background:none;border:none;text-align:left;display:flex;justify-content:space-between;gap:1.5rem;align-items:center;padding:1.4rem 0;font-family:var(--ff-display);font-size:clamp(1.1rem,1.8vw,1.3rem);color:var(--ink)}
.acc__q .pm{flex:none;width:30px;height:30px;border:1.5px solid var(--paprika);border-radius:50%;position:relative;transition:.3s}
.acc__q .pm::before,.acc__q .pm::after{content:"";position:absolute;background:var(--paprika);left:50%;top:50%;transition:.3s}
.acc__q .pm::before{width:12px;height:2px;transform:translate(-50%,-50%)}
.acc__q .pm::after{width:2px;height:12px;transform:translate(-50%,-50%)}
.acc__item.open .pm{background:var(--paprika)}
.acc__item.open .pm::before,.acc__item.open .pm::after{background:#fff}
.acc__item.open .pm::after{transform:translate(-50%,-50%) scaleY(0)}
.acc__a{max-height:0;overflow:hidden;transition:max-height .4s var(--t)}
.acc__a p{padding:0 0 1.5rem;color:#544a3f;max-width:80ch}

/* ---------- 15. TABS ---------- */
.tabs__nav{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem;border-bottom:1px solid var(--line)}
.tabs__btn{background:none;border:none;padding:.8rem 1.1rem;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:.25s}
.tabs__btn.active{color:var(--paprika);border-bottom-color:var(--paprika)}
.tabs__panel{display:none;animation:fade .4s var(--t)}
.tabs__panel.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1}}

/* ---------- 16. FORM ---------- */
.form{display:grid;gap:1.1rem}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
@media(max-width:620px){.form .row{grid-template-columns:1fr}}
.field label{display:block;font-size:.82rem;font-weight:650;letter-spacing:.04em;margin-bottom:.4rem;color:var(--ink)}
.field input,.field select,.field textarea{
  width:100%;font-family:inherit;font-size:1rem;padding:.85rem 1rem;border:1.5px solid var(--line);
  border-radius:12px;background:var(--paper);color:var(--ink);transition:.25s}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--paprika);background:#fff;outline:none}
.form__note{font-size:.82rem;color:var(--muted)}
.form__ok{background:rgba(60,74,46,.1);border:1px solid var(--herb);color:var(--herb);padding:1rem 1.2rem;border-radius:12px;font-weight:600;display:none}
.form__ok.show{display:block}

/* contact info list */
.cinfo{display:grid;gap:1.4rem}
.cinfo__item{display:flex;gap:1rem;align-items:flex-start}
.cinfo__item .ico{flex:none;width:46px;height:46px;border-radius:12px;background:rgba(194,75,44,.1);display:grid;place-items:center;color:var(--paprika)}
.cinfo__item .ico svg{width:22px;height:22px}
.cinfo__item b{font-family:var(--ff-display);font-size:1.05rem;display:block;margin-bottom:.15rem}
.cinfo__item a,.cinfo__item span{color:#544a3f;font-size:.96rem}
.cinfo__item a:hover{color:var(--paprika)}
.map-wrap{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.map-wrap iframe{display:block;width:100%;height:100%;min-height:340px;border:0;filter:saturate(.9)}

/* ---------- 17. PILL / TAGS ---------- */
.pills{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.2rem}
.pill{font-size:.83rem;font-weight:600;padding:.45rem .95rem;border-radius:100px;background:var(--paper);border:1px solid var(--line);color:#4a4036}
.bg-ink .pill,.bg-herb .pill{background:rgba(245,239,227,.08);border-color:rgba(245,239,227,.18);color:var(--cream)}

/* ---------- 18. LEGAL PAGES ---------- */
.legal{max-width:820px}
.legal h2{margin:2.4rem 0 .8rem;font-size:1.6rem}
.legal h3{margin:1.6rem 0 .5rem;font-size:1.2rem}
.legal p,.legal li{color:#3f362c;font-size:1rem;margin-bottom:.9rem;max-width:none}
.legal ul{margin:0 0 1rem 1.2rem;list-style:disc}
.legal li{margin-bottom:.5rem}
.legal a{color:var(--paprika);text-decoration:underline}
.legal .updated{color:var(--muted);font-size:.9rem;margin-bottom:2rem}
.legal table{width:100%;border-collapse:collapse;margin:1rem 0 1.6rem;font-size:.92rem}
.legal th,.legal td{border:1px solid var(--line);padding:.7rem .8rem;text-align:left;vertical-align:top}
.legal th{background:var(--paper);font-family:var(--ff-body);font-weight:700}
.toc{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem 1.8rem;margin-bottom:2.4rem}
.toc b{font-family:var(--ff-display);font-size:1.1rem}
.toc ol{margin:.8rem 0 0 1.2rem;columns:2;gap:2rem}
@media(max-width:620px){.toc ol{columns:1}}
.toc a{color:#4a4036}.toc a:hover{color:var(--paprika)}

/* ---------- 19. CTA STRIP ---------- */
.ctastrip{background:var(--paprika);color:#fff;border-radius:var(--radius);padding:clamp(2.2rem,4vw,3.4rem);display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center;justify-content:space-between;position:relative;overflow:hidden}
.ctastrip::before{content:"";position:absolute;right:-60px;top:-60px;width:240px;height:240px;border-radius:50%;background:rgba(255,255,255,.08)}
.ctastrip h2{color:#fff;max-width:18ch}
.ctastrip p{color:rgba(255,255,255,.9);margin-top:.5rem;position:relative}
.ctastrip .btn--cream{position:relative}

/* ---------- 20. FOOTER ---------- */
.footer{background:var(--ink);color:rgba(245,239,227,.7);padding-top:clamp(60px,7vw,90px)}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:clamp(28px,4vw,56px);padding-bottom:3rem;border-bottom:1px solid rgba(245,239,227,.12)}
@media(max-width:900px){.footer__top{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footer__top{grid-template-columns:1fr}}
.footer__brand{display:flex;align-items:center;gap:.7rem;font-family:var(--ff-display);font-size:1.3rem;color:var(--cream);margin-bottom:1.1rem}
.footer__brand svg{width:42px;height:42px;border-radius:11px}
.footer p{font-size:.93rem;line-height:1.7}
.footer h4{color:var(--cream);font-family:var(--ff-body);font-weight:700;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:1.2rem}
.footer ul li{margin-bottom:.6rem}
.footer ul a{font-size:.94rem;transition:.25s}
.footer ul a:hover{color:var(--saffron);padding-left:4px}
.footer__contact a:hover{color:var(--saffron)}
.footer__legal{display:flex;flex-wrap:wrap;gap:1rem 2rem;justify-content:space-between;align-items:center;padding:1.8rem 0;font-size:.85rem}
.footer__legal nav{display:flex;flex-wrap:wrap;gap:1.2rem}
.footer__legal a:hover{color:var(--saffron)}
.footer__fine{font-size:.84rem;line-height:1.7;color:rgba(245,239,227,.55);padding-bottom:2.4rem}
.footer__fine strong{color:rgba(245,239,227,.8);font-weight:600}

/* ---------- 21. FLOATING CTA ---------- */
.fab{position:fixed;right:22px;bottom:22px;z-index:900;display:inline-flex;align-items:center;gap:.6rem;background:var(--ink);color:var(--cream);padding:.85rem 1.3rem;border-radius:100px;box-shadow:0 18px 40px -14px rgba(33,26,20,.6);transform:translateY(120px);transition:.5s var(--t);font-weight:650;font-size:.92rem}
.fab.show{transform:translateY(0)}
.fab:hover{background:var(--paprika)}
.fab svg{width:18px;height:18px}
@media(max-width:560px){.fab span{display:none}.fab{padding:.95rem}}

/* ---------- 22. COOKIE BANNER ---------- */
.cookie{position:fixed;left:18px;right:18px;bottom:18px;z-index:1200;max-width:560px;margin-inline:auto;background:var(--paper);border:1px solid var(--clay);border-radius:var(--radius);padding:1.4rem 1.5rem;box-shadow:var(--shadow);transform:translateY(160px);opacity:0;transition:.5s var(--t)}
.cookie.show{transform:translateY(0);opacity:1}
.cookie p{font-size:.9rem;color:#544a3f;margin-bottom:1rem}
.cookie a{color:var(--paprika);text-decoration:underline}
.cookie__btns{display:flex;flex-wrap:wrap;gap:.6rem}
.cookie .btn{padding:.65rem 1.2rem;font-size:.88rem}

/* ---------- 23. REVEAL ANIM ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:.8s var(--t)}
.reveal.in{opacity:1;transform:none}
.reveal-d1{transition-delay:.08s}.reveal-d2{transition-delay:.16s}.reveal-d3{transition-delay:.24s}.reveal-d4{transition-delay:.32s}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .marquee__track{animation:none}
  *{scroll-behavior:auto}
}

/* ---------- 24. UTILITIES ---------- */
.mt-0{margin-top:0}.mt-1{margin-top:1rem}.mt-2{margin-top:1.8rem}.mt-3{margin-top:2.6rem}
.mb-2{margin-bottom:1.8rem}
.maxw-sm{max-width:640px}
.txt-muted{color:var(--muted)}
.divider{height:1px;background:var(--line);border:0;margin-block:clamp(40px,6vw,72px)}
