/* =========================================================================
   SOGNO TOSCANO — Cinematic Hospitality (dark)
   Redesign concept · webtest.sogno-toscano.tech
   Palette sampled from the real Arcadia (Phoenix) store: deep sage-green,
   brass, cream, warm wood, marble. Moody, immersive, animated.
   Cormorant Garamond + Inter.
   ========================================================================= */

@font-face{font-family:"Cormorant";src:url("../fonts/CormorantGaramond-Regular.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Cormorant";src:url("../fonts/CormorantGaramond-Bold.ttf") format("truetype");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Cormorant";src:url("../fonts/CormorantGaramond-Italic.ttf") format("truetype");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/Inter-Regular.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/Inter-Medium.ttf") format("truetype");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("../fonts/Inter-Bold.ttf") format("truetype");font-weight:700;font-style:normal;font-display:swap}

:root{
  --noir:#222C1C;
  --g900:#2D3A27; --g800:#37452F; --g700:#47573C; --sage:#6B7A58; --olive:#3D5234; --g-soft:#A3B289;
  --cream:#F3ECDA; --cream-2:#EAE0C8; --cream-dim:rgba(243,236,218,.62);
  --brass:#C0A35C; --brass-2:#D8C188; --brass-deep:#9C8340;
  --terra:#A1603C; --marble:#EFE9DD; --ink:#211B12;

  --serif:"Cormorant",Georgia,serif;
  --sans:"Inter",system-ui,sans-serif;
  --maxw:1320px; --pad:clamp(22px,5vw,90px);
  --ease:cubic-bezier(.22,.61,.36,1); --eo:cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--sans);color:var(--cream);background:var(--g900);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
::selection{background:var(--brass);color:var(--g900)}

/* ---------- Type ---------- */
.kicker{font-family:var(--sans);font-weight:500;font-size:.7rem;text-transform:uppercase;letter-spacing:.4em;color:var(--brass-2);display:inline-flex;align-items:center;gap:.9em}
.kicker::before{content:"";width:38px;height:1px;background:var(--brass);display:inline-block}
.kicker.center{justify-content:center}
.kicker.center::after{content:"";width:38px;height:1px;background:var(--brass);display:inline-block}
.kicker.ink{color:var(--brass-deep)}
.kicker.ink::before,.kicker.ink.center::after{background:var(--brass-deep)}

h1,h2,h3{font-family:var(--serif);font-weight:400;line-height:1.02;letter-spacing:.005em;color:var(--cream)}
.display{font-size:clamp(3rem,8.5vw,7.4rem);font-weight:300}
.display .it{font-style:italic;color:var(--brass-2)}
h2.title{font-size:clamp(2.3rem,5.2vw,4.6rem)}
h3{font-size:clamp(1.5rem,2.6vw,2.3rem)}
.lede{font-family:var(--serif);font-size:clamp(1.35rem,2.4vw,2rem);font-style:italic;line-height:1.4;color:var(--cream-dim)}
p.body{font-size:1.05rem;color:var(--cream-dim);max-width:58ch;font-weight:400}
.ink-sec p.body{color:#4A4234}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
section{position:relative}
.pad{padding-block:clamp(86px,13vw,190px)}
.sec-dark{background:var(--g900)}
.sec-dark2{background:var(--g800)}
.sec-cream{background:var(--cream);color:var(--ink)}
.sec-cream h1,.sec-cream h2,.sec-cream h3{color:var(--olive)}
.sec-cream .kicker{color:var(--brass-deep)} .sec-cream .kicker::before,.sec-cream .kicker.center::after{background:var(--brass)}
.sec-cream .lede{color:var(--olive)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.8em;font-family:var(--sans);font-weight:500;font-size:.72rem;text-transform:uppercase;letter-spacing:.22em;padding:1.15em 2.3em;border-radius:1px;position:relative;overflow:hidden;transition:color .5s var(--ease),border-color .5s var(--ease)}
.btn .arrow{transition:transform .45s var(--ease)}
.btn:hover .arrow{transform:translateX(6px)}
.btn-brass{background:var(--brass);color:var(--g900)}
.btn-brass::after{content:"";position:absolute;inset:0;background:var(--brass-2);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);z-index:-1}
.btn-brass:hover::after{transform:scaleX(1)}
.btn-out{border:1px solid var(--brass);color:var(--brass-2)}
.btn-out::after{content:"";position:absolute;inset:0;background:var(--brass);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);z-index:-1}
.btn-out:hover{color:var(--g900)} .btn-out:hover::after{transform:scaleX(1)}
.btn-out.ink{border-color:var(--olive);color:var(--olive)} .btn-out.ink::after{background:var(--olive)} .btn-out.ink:hover{color:var(--cream)}

/* ---------- Header ---------- */
.hdr{position:fixed;inset:0 0 auto 0;z-index:100;padding:26px 0;transition:background .6s var(--ease),padding .6s var(--ease),border-color .6s var(--ease);border-bottom:1px solid transparent}
.hdr::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,16,9,.55),transparent);opacity:1;transition:opacity .6s var(--ease);z-index:-1}
.hdr .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px}
.hdr.scrolled{background:rgba(20,26,17,.86);backdrop-filter:blur(14px) saturate(1.1);padding:14px 0;border-color:rgba(192,163,92,.22)}
.hdr.scrolled::before{opacity:0}
.brand img{height:50px;width:auto;transition:height .6s var(--ease);filter:brightness(0) invert(1)}
.scrolled .brand img{height:40px}
.nav{display:flex;align-items:center;gap:clamp(14px,1.9vw,32px)}
.nav a.nl,.nav .drop-t>span{font-family:var(--sans);font-weight:500;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cream);opacity:.92;padding:8px 2px;position:relative;display:inline-flex;align-items:center;gap:.45em;cursor:pointer;transition:opacity .3s}
.nav a.nl::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--brass-2);transition:width .45s var(--ease)}
.nav a.nl:hover{opacity:1} .nav a.nl:hover::after{width:100%}
.nav .cta{color:var(--g900);background:var(--brass);padding:.75em 1.4em;letter-spacing:.18em;border-radius:1px;opacity:1;transition:background .4s}
.nav .cta:hover{background:var(--brass-2)} .nav .cta::after{display:none}
.drop-t{position:relative}
.drop-t>span::after{content:"+";font-size:.85em;opacity:.6;margin-left:.2em}
.drop{position:absolute;top:calc(100% + 16px);left:50%;transform:translateX(-50%) translateY(8px);background:rgba(20,26,17,.97);backdrop-filter:blur(14px);min-width:248px;border:1px solid rgba(192,163,92,.25);border-top:2px solid var(--brass);padding:10px;opacity:0;visibility:hidden;transition:all .35s var(--ease)}
.drop-t:hover .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.drop a{display:block;font-size:.8rem;letter-spacing:.04em;color:var(--cream-dim);padding:11px 14px;transition:all .25s}
.drop a:hover{background:rgba(192,163,92,.12);color:var(--cream);padding-left:20px}
.drop a small{display:block;text-transform:uppercase;letter-spacing:.2em;font-size:.58rem;color:var(--brass);margin-top:3px}
.burger{display:none;flex-direction:column;gap:6px;padding:8px;z-index:120}
.burger span{width:28px;height:1.5px;background:var(--cream);transition:all .35s var(--ease)}

/* ---------- Hero ---------- */
.hero{position:relative;height:100svh;min-height:640px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:-2;background:var(--g900)}
.hero-bg img,.hero-bg video{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-bg img{transform:scale(1.12);animation:heroZoom 14s var(--eo) forwards, heroDrift 30s ease-in-out 14s infinite alternate}
@keyframes heroZoom{from{transform:scale(1.28)}to{transform:scale(1.12)}}
@keyframes heroDrift{from{transform:scale(1.12)}to{transform:scale(1.2) translate(-1.5%,-1%)}}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;background:
  linear-gradient(180deg,rgba(13,16,9,.5),rgba(13,16,9,.22) 34%,rgba(13,16,9,.5) 74%,rgba(13,16,9,.92)),
  radial-gradient(78% 64% at 50% 48%,rgba(13,16,9,.5),rgba(13,16,9,0) 72%)}
.hero-fx{position:absolute;inset:0;z-index:-1;pointer-events:none;mix-blend-mode:soft-light;
  background:radial-gradient(40% 50% at 30% 28%,rgba(216,193,136,.5),transparent 60%),radial-gradient(45% 55% at 75% 70%,rgba(192,163,92,.35),transparent 62%);
  animation:glowDrift 18s ease-in-out infinite alternate;opacity:.9}
@keyframes glowDrift{0%{transform:translate(-3%,-2%) scale(1.05);opacity:.7}100%{transform:translate(4%,3%) scale(1.15);opacity:1}}
.hero-sheen{position:absolute;inset:0;z-index:-1;pointer-events:none;background:linear-gradient(115deg,transparent 30%,rgba(243,236,218,.10) 46%,rgba(243,236,218,.16) 50%,transparent 66%);transform:translateX(-30%);animation:sheen 9s var(--eo) 1.4s infinite}
@keyframes sheen{0%{transform:translateX(-60%)}22%,100%{transform:translateX(70%)}}
.hero-content{padding:0 24px;max-width:1100px;position:relative;z-index:1}
.hero .display,.hero .lede{text-shadow:0 2px 40px rgba(8,9,5,.6)}
.hero-emblem{width:clamp(70px,9vw,104px);margin:0 auto 30px;filter:brightness(0) invert(1);opacity:0;animation:fadeBlur 1.2s var(--eo) .2s forwards}
.hero .kicker{opacity:0;animation:fadeUp 1s var(--eo) .5s forwards;margin-bottom:26px}
.hero .display{opacity:0;animation:fadeBlur 1.4s var(--eo) .8s forwards}
.hero .lede{opacity:0;animation:fadeUp 1.2s var(--eo) 1.3s forwards;margin:26px auto 0;max-width:30ch}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:40px;opacity:0;animation:fadeUp 1.2s var(--eo) 1.7s forwards}
.scroll-cue{position:absolute;left:50%;bottom:34px;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;opacity:0;animation:fadeUp 1s var(--eo) 2.2s forwards}
.scroll-cue .ln{width:1px;height:46px;background:linear-gradient(var(--brass-2),transparent);position:relative;overflow:hidden}
.scroll-cue .ln::after{content:"";position:absolute;top:-46px;left:0;width:1px;height:46px;background:var(--cream);animation:cue 2.2s var(--ease) infinite}
.scroll-cue span{font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;color:var(--cream-dim)}
@keyframes cue{0%{top:-46px}60%,100%{top:46px}}
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@keyframes fadeBlur{from{opacity:0;filter:blur(14px);transform:translateY(16px)}to{opacity:1;filter:blur(0);transform:none}}

.page-hero{height:78svh;min-height:520px}

/* ---------- Full-bleed chapter (image + overlay) ---------- */
.chapter{position:relative;min-height:96svh;display:flex;align-items:flex-end;overflow:hidden}
.chapter.center{align-items:center;text-align:center;justify-content:center}
.chapter-bg{position:absolute;inset:-12% 0;z-index:-2;will-change:transform}
.chapter-bg img{width:100%;height:100%;object-fit:cover}
.chapter::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(13,16,9,.15) 0%,rgba(13,16,9,.05) 35%,rgba(13,16,9,.55) 75%,rgba(13,16,9,.92) 100%)}
.chapter.center::after{background:radial-gradient(120% 90% at 50% 50%,rgba(13,16,9,.3),rgba(13,16,9,.82))}
.chapter-content{position:relative;width:100%;padding-block:clamp(56px,8vw,120px)}
.chapter blockquote{font-family:var(--serif);font-style:italic;font-size:clamp(1.9rem,4vw,3.4rem);line-height:1.28;max-width:24ch;margin:0 auto}
.chapter cite{display:block;font-family:var(--sans);font-style:normal;font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--brass-2);margin-top:30px}

/* ---------- Editorial split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(38px,6vw,100px);align-items:center}
.split.rev .s-media{order:2}
.s-media{position:relative}
.s-media .ph{overflow:hidden}
.s-media .ph img{width:100%;aspect-ratio:4/5;object-fit:cover;transform:scale(1.04);transition:transform 1.4s var(--ease)}
.s-media.wide .ph img{aspect-ratio:3/2}
.s-media:hover .ph img{transform:scale(1.1)}
.s-media .fr{position:absolute;inset:18px -18px -18px 18px;border:1px solid var(--brass);z-index:-1}
.s-media .cap{position:absolute;left:-14px;bottom:26px;background:var(--brass);color:var(--g900);font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;padding:9px 16px;z-index:3}
.s-text .kicker{margin-bottom:26px}
.s-text h2{margin-bottom:26px}
.s-text p+p{margin-top:1.1em}
.s-text .btn,.s-text .grp{margin-top:36px}
.grp{display:flex;gap:14px;flex-wrap:wrap}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:clamp(40px,5vw,76px) 24px;text-align:center;border-right:1px solid rgba(192,163,92,.18)}
.stat:last-child{border-right:none}
.stat .num{font-family:var(--serif);font-size:clamp(3rem,5.5vw,4.8rem);color:var(--brass-2);line-height:1;font-weight:300}
.stat .lab{font-size:.64rem;text-transform:uppercase;letter-spacing:.26em;color:var(--cream-dim);margin-top:14px}

/* ---------- Section head ---------- */
.shead{max-width:62ch;margin:0 auto clamp(48px,7vw,84px)}
.shead.center{text-align:center}
.shead .kicker{margin-bottom:24px}

/* ---------- Cards (pantry / gallery) ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,26px)}
.card{position:relative;overflow:hidden;min-height:clamp(360px,44vw,520px);display:flex;align-items:flex-end}
.card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(13,16,9,.9))}
.card:hover img{transform:scale(1.09)}
.card-b{position:relative;z-index:2;padding:clamp(26px,3vw,38px)}
.card-b .n{font-size:.6rem;letter-spacing:.28em;text-transform:uppercase;color:var(--brass-2)}
.card-b h3{margin:.4em 0 .1em}
.card-b .more{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--brass-2);display:inline-flex;gap:.5em;margin-top:14px;opacity:0;transform:translateY(8px);transition:all .5s var(--ease)}
.card:hover .more{opacity:1;transform:none}

/* ---------- Location rows ---------- */
.loc{display:grid;grid-template-columns:1.08fr 1fr;gap:clamp(30px,4.5vw,72px);align-items:center;margin-bottom:clamp(56px,8vw,110px)}
.loc:last-child{margin-bottom:0}
.loc.rev .l-media{order:2}
.l-media{position:relative;overflow:hidden}
.l-media img{width:100%;aspect-ratio:3/2;object-fit:cover;transition:transform 1.4s var(--ease)}
.loc:hover .l-media img{transform:scale(1.06)}
.l-media .fr{position:absolute;inset:14px -14px -14px 14px;border:1px solid var(--brass);z-index:-1}
.loc .city{font-size:.64rem;text-transform:uppercase;letter-spacing:.26em;color:var(--brass-2);margin-bottom:16px}
.loc h2{margin-bottom:16px}
.lmeta{display:flex;gap:26px;flex-wrap:wrap;margin:22px 0 30px}
.lmeta div{border-left:1px solid var(--brass);padding-left:14px}
.lmeta .k{font-size:.58rem;text-transform:uppercase;letter-spacing:.22em;color:var(--g-soft)}
.lmeta .v{font-family:var(--serif);font-size:1.35rem;color:var(--cream)}
.sec-cream .lmeta .v{color:var(--olive)} .sec-cream .loc .city{color:var(--brass-deep)} .sec-cream .lmeta .k{color:var(--brass-deep)}

/* ---------- Map ---------- */
.map-wrap{background:var(--cream);padding:clamp(22px,3vw,44px);border:1px solid rgba(192,163,92,.4)}
.map-wrap img{width:100%}

/* ---------- Recipes ---------- */
.recipes{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,30px)}
.recipe{background:var(--g800);border:1px solid rgba(192,163,92,.2);transition:transform .5s var(--ease),border-color .5s}
.recipe:hover{transform:translateY(-8px);border-color:var(--brass)}
.recipe .ri{overflow:hidden;aspect-ratio:3/2}
.recipe .ri img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.recipe:hover .ri img{transform:scale(1.09)}
.recipe .rb{padding:24px 26px 30px}
.recipe .rb .date{font-size:.58rem;letter-spacing:.24em;text-transform:uppercase;color:var(--brass-2)}
.recipe .rb h3{font-size:1.4rem;margin:.5em 0}
.recipe .rb .more{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass-2);display:inline-flex;gap:.5em;margin-top:6px}

/* ---------- Forms ---------- */
.form{display:grid;gap:18px;max-width:560px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form .lab{font-size:.6rem;text-transform:uppercase;letter-spacing:.22em;color:var(--brass-2);margin-bottom:8px;display:block}
.form input,.form select,.form textarea{width:100%;font-family:var(--sans);font-size:.95rem;color:var(--cream);background:rgba(243,236,218,.05);border:1px solid rgba(192,163,92,.32);padding:15px 16px;border-radius:1px;transition:border .3s}
.form input::placeholder,.form textarea::placeholder{color:rgba(243,236,218,.35)}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--brass)}
.form select{color:var(--cream)} .form select option{background:var(--g800)}
.form textarea{min-height:130px;resize:vertical}
.sec-cream .form input,.sec-cream .form select,.sec-cream .form textarea{color:var(--ink);background:var(--cream);border-color:rgba(192,163,92,.5)}
.sec-cream .form .lab{color:var(--brass-deep)}

/* ---------- Store pages ---------- */
.infobar{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(192,163,92,.18);border-block:1px solid rgba(192,163,92,.22)}
.infobar > div{background:var(--g900);padding:clamp(22px,3vw,34px) 24px}
.infobar .k{font-size:.58rem;text-transform:uppercase;letter-spacing:.24em;color:var(--brass-2);margin-bottom:9px}
.infobar .v{font-family:var(--serif);font-size:1.18rem;color:var(--cream);line-height:1.3}
.infobar a{color:var(--cream)}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(22px,3vw,46px)}
.pillar{border-top:1px solid var(--brass);padding-top:24px}
.pillar .n{font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:var(--brass-2)}
.pillar h3{margin:.35em 0 .4em}
.pillar p{font-size:.95rem;color:var(--cream-dim)}
.menu{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2vw,26px)}
.mitem{display:flex;gap:18px;align-items:center;background:var(--g800);border:1px solid rgba(192,163,92,.2);padding:16px;transition:border-color .4s var(--ease)}
.mitem:hover{border-color:var(--brass)}
.mitem img{width:104px;height:104px;object-fit:cover;flex:none}
.mitem .mb{flex:1;min-width:0}
.mitem .mt{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.mitem .mt h3{font-size:1.32rem}
.mitem .price{font-family:var(--serif);color:var(--brass-2);font-size:1.25rem;flex:none}
.mitem p{font-size:.85rem;color:var(--cream-dim);margin-top:5px}
.badge{display:inline-flex;align-items:center;gap:10px;border:1px solid var(--brass);padding:11px 20px;border-radius:2px;font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass-2)}
.notice-strip{background:var(--terra);color:var(--cream);text-align:center;font-size:.72rem;letter-spacing:.12em;padding:11px 16px}

/* ---------- Marquee ---------- */
.marq{background:var(--g800);overflow:hidden;border-block:1px solid rgba(192,163,92,.22);padding:0}
.marq .tk{display:flex;white-space:nowrap;animation:marq 34s linear infinite;will-change:transform}
.marq span{font-family:var(--serif);font-style:italic;font-size:clamp(1.4rem,2.5vw,2.1rem);color:var(--brass-2);padding:18px 0}
.marq span::after{content:"\2022";margin:0 .9em;color:var(--terra);font-style:normal}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Footer ---------- */
.ftr{background:var(--noir);color:var(--cream);padding-top:clamp(70px,9vw,110px);position:relative}
.ftr-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:42px;padding-bottom:58px;border-bottom:1px solid rgba(192,163,92,.18)}
.ftr-brand img{height:56px;margin-bottom:24px;filter:brightness(0) invert(1)}
.ftr-brand p{color:rgba(243,236,218,.55);font-size:.92rem;max-width:34ch}
.ftr-col h4{font-family:var(--sans);font-weight:500;font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:var(--brass-2);margin-bottom:20px}
.ftr-col a{display:block;color:rgba(243,236,218,.66);font-size:.9rem;padding:6px 0;transition:color .3s}
.ftr-col a:hover{color:var(--brass-2)}
.ftr-bot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;padding:28px 0}
.ftr-bot small{color:rgba(243,236,218,.4);font-size:.78rem}
.fsoc{display:flex;gap:13px}
.fsoc a{width:40px;height:40px;border:1px solid rgba(192,163,92,.35);border-radius:50%;display:grid;place-items:center;color:var(--brass-2);font-size:.6rem;transition:all .35s}
.fsoc a:hover{background:var(--brass);color:var(--g900);border-color:var(--brass)}
.vv{color:rgba(243,236,218,.3);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase}

/* ---------- Reveal / parallax ---------- */
.has-js .rv{opacity:0;transform:translateY(40px);transition:opacity 1.1s var(--eo),transform 1.1s var(--eo)}
.rv.in{opacity:1;transform:none}
.rv[data-d="1"]{transition-delay:.12s}.rv[data-d="2"]{transition-delay:.24s}.rv[data-d="3"]{transition-delay:.36s}
.has-js .rvimg{clip-path:inset(0 100% 0 0);transition:clip-path 1.3s var(--eo)}
.rvimg.in{clip-path:inset(0 0 0 0)}
.grain::after{content:"";position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.05;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---------- Responsive ---------- */
@media(max-width:1024px){.ftr-top{grid-template-columns:1fr 1fr}.stats{grid-template-columns:1fr 1fr}.stat:nth-child(2){border-right:none}.stat:nth-child(-n+2){border-bottom:1px solid rgba(192,163,92,.18)}}
@media(max-width:860px){
  .nav{position:fixed;inset:0 0 0 auto;width:min(84vw,380px);background:var(--g900);flex-direction:column;align-items:flex-start;justify-content:center;gap:6px;padding:90px 44px;transform:translateX(100%);transition:transform .5s var(--ease);box-shadow:-30px 0 90px rgba(0,0,0,.5);border-left:1px solid rgba(192,163,92,.2)}
  .nav.open{transform:none}
  .nav a.nl,.nav .drop-t>span{font-size:1.05rem;padding:13px 0}
  .drop-t{width:100%}
  .drop{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;background:transparent;border:none;min-width:0;padding:0 0 8px 14px;display:none}
  .drop-t.open .drop{display:block}
  .burger{display:flex}
  .burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
  .split,.split.rev{grid-template-columns:1fr;gap:40px}.split.rev .s-media{order:0}
  .s-media .fr{inset:12px -12px -12px 12px}
  .cards{grid-template-columns:1fr 1fr}.recipes{grid-template-columns:1fr}
  .loc,.loc.rev{grid-template-columns:1fr}.loc.rev .l-media{order:0}
  .form .row{grid-template-columns:1fr}
}
@media(max-width:560px){.cards{grid-template-columns:1fr}.stats{grid-template-columns:1fr 1fr}.ftr-top{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition:none!important}.rv,.rvimg{opacity:1;transform:none;clip-path:none}.hero-bg img{transform:scale(1.08)}}
