/* =========================================================
   Brigittenauer Stadl — shared stylesheet
   Palette: Logo-Grün #1A6737 · warmes Holz · Creme · Stiegl-Rot · Bier-Gold
   Fonts: Playfair Display (Headings) + Karla (Body)
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Karla:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,500;0,600;0,700;1,500&display=swap');

:root{
  --green:#1a6737;
  --green-2:#20813f;
  --green-deep:#0e3a20;
  --green-deepest:#0a2c18;
  --cream:#faf5ea;
  --cream-2:#f4ecdb;
  --card:#fffdf8;
  --sand:#efe3cd;
  --ink:#2b2419;
  --ink-soft:#5f5546;
  --wood:#6e4a2a;
  --gold:#c5912b;
  --gold-soft:#e4c074;
  --red:#c43a2b;
  --red-dark:#a02b1f;
  --line:#e7dbc2;
  --line-soft:#f0e7d4;
  --shadow:0 14px 40px -18px rgba(43,36,25,.45);
  --shadow-lg:0 30px 70px -28px rgba(43,36,25,.55);
  --r:16px;
  --r-lg:26px;
  --maxw:1180px;
  --nav-h:74px;
  --font-head:'Playfair Display',Georgia,serif;
  --font-body:'Karla',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font-body);color:var(--ink);
  background:var(--cream);line-height:1.65;font-size:17px;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:600;line-height:1.12;margin:0;color:var(--ink)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.eyebrow{
  font-family:var(--font-body);font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  font-size:.74rem;color:var(--green);display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--gold);display:inline-block}
.eyebrow.center{justify-content:center}
.eyebrow.center::after{content:"";width:26px;height:2px;background:var(--gold);display:inline-block}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--green);--fg:#fff;
  display:inline-flex;align-items:center;gap:.55em;cursor:pointer;border:none;
  background:var(--bg);color:var(--fg);font-family:var(--font-body);font-weight:700;
  font-size:1rem;padding:.85em 1.5em;border-radius:999px;transition:.22s ease;
  box-shadow:0 10px 24px -12px rgba(26,103,55,.7);letter-spacing:.01em;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(26,103,55,.8)}
.btn svg{width:1.05em;height:1.05em}
.btn.gold{--bg:var(--gold);--fg:#3a2c08;box-shadow:0 10px 24px -12px rgba(197,145,43,.7)}
.btn.gold:hover{box-shadow:0 16px 30px -12px rgba(197,145,43,.85)}
.btn.outline{--bg:transparent;--fg:var(--ink);border:1.5px solid var(--ink);box-shadow:none}
.btn.outline:hover{background:var(--ink);color:var(--cream)}
.btn.ghost-light{--bg:rgba(255,255,255,.14);--fg:#fff;border:1.5px solid rgba(255,255,255,.5);box-shadow:none;backdrop-filter:blur(4px)}
.btn.ghost-light:hover{background:#fff;color:var(--green-deep);border-color:#fff}
.btn.lg{padding:1em 1.8em;font-size:1.05rem}

/* ---------- navbar ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:100;
  display:flex;align-items:center;transition:.3s ease;
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;width:100%}
.nav-brand{display:flex;align-items:center;gap:.7em;font-family:var(--font-head);font-weight:700;font-size:1.18rem}
.nav-brand img{width:42px;height:42px;border-radius:50%;background:#fff;padding:2px;box-shadow:0 4px 12px -4px rgba(0,0,0,.3)}
.nav-brand .bn-sub{display:block;font-family:var(--font-body);font-weight:600;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;opacity:.7;margin-top:1px}
.nav-links{display:flex;align-items:center;gap:.35em}
.nav-links a:not(.btn){
  padding:.5em .85em;border-radius:999px;font-weight:600;font-size:.96rem;transition:.18s;position:relative;
}
.nav-links a:not(.btn):hover{color:var(--green)}
.nav-links a.active:not(.btn){color:var(--green)}
.nav-links a.active:not(.btn)::after{content:"";position:absolute;left:.85em;right:.85em;bottom:.28em;height:2px;background:var(--gold);border-radius:2px}

/* nav over dark hero (top of page) */
.nav.over-hero{color:#fff}
.nav.over-hero .nav-brand .bn-sub{opacity:.85}
.nav.over-hero .nav-links a:not(.btn):hover,.nav.over-hero .nav-links a.active:not(.btn){color:#fff}
.nav.over-hero .nav-links a.active:not(.btn)::after{background:var(--gold-soft)}
/* scrolled / solid */
.nav.solid{background:rgba(250,245,234,.86);backdrop-filter:blur(14px) saturate(1.3);color:var(--ink);box-shadow:0 1px 0 var(--line),0 10px 30px -24px rgba(43,36,25,.6)}
.nav.solid .nav-brand .bn-sub{opacity:.65}

.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;color:inherit}
.nav-toggle svg{width:28px;height:28px}

/* mobile drawer */
.drawer{
  position:fixed;inset:0;z-index:120;background:rgba(14,58,32,.97);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4em;
  opacity:0;visibility:hidden;transition:.3s;backdrop-filter:blur(6px);
}
.drawer.open{opacity:1;visibility:visible}
.drawer a{color:#fdf6e9;font-family:var(--font-head);font-size:1.7rem;padding:.35em 1em;font-weight:600}
.drawer a:hover{color:var(--gold-soft)}
.drawer .btn{margin-top:.6em;font-family:var(--font-body);font-size:1.05rem}
.drawer-close{position:absolute;top:22px;right:24px;background:none;border:none;color:#fff;cursor:pointer}
.drawer-close svg{width:32px;height:32px}

/* ---------- hero ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;overflow:hidden;color:#fff}
.hero-bg{position:absolute;inset:-8% 0 0 0;z-index:0;will-change:transform}
.hero-bg img{width:100%;height:116%;object-fit:cover;object-position:center 60%}
.hero::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(10,32,18,.42) 0%,rgba(10,32,18,.15) 38%,rgba(10,32,18,.62) 78%,rgba(8,28,16,.9) 100%)}
.hero-inner{position:relative;z-index:2;padding-bottom:clamp(48px,7vw,92px);padding-top:120px;max-width:760px}
.hero .badge-row{display:flex;gap:.6em;flex-wrap:wrap;margin-bottom:1.3em}
.hero .pill{
  display:inline-flex;align-items:center;gap:.5em;background:rgba(255,255,255,.13);
  border:1px solid rgba(255,255,255,.32);backdrop-filter:blur(6px);
  padding:.42em 1em;border-radius:999px;font-size:.82rem;font-weight:600;letter-spacing:.02em;
}
.hero .pill svg{width:1em;height:1em;color:var(--gold-soft)}
.hero h1{font-size:clamp(2.7rem,6.4vw,5rem);font-weight:700;color:#fff;letter-spacing:-.01em;text-shadow:0 4px 30px rgba(0,0,0,.35)}
.hero h1 em{font-style:italic;color:var(--gold-soft)}
.hero .lead{font-size:clamp(1.05rem,1.7vw,1.32rem);max-width:540px;margin:1.1em 0 1.7em;color:rgba(255,255,255,.94);font-weight:400}
.hero .cta-row{display:flex;gap:.8em;flex-wrap:wrap;align-items:center}
.hero .stars{color:var(--gold-soft);letter-spacing:.08em}
.scroll-cue{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:3;color:rgba(255,255,255,.8);animation:bob 2.2s ease-in-out infinite}
.scroll-cue svg{width:26px;height:26px}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ---------- interior page header ---------- */
.page-head{position:relative;padding:calc(var(--nav-h) + 56px) 0 60px;color:#fff;overflow:hidden;background:var(--green-deep)}
.page-head.has-img::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(10,46,25,.92),rgba(10,46,25,.62))}
.page-head .ph-bg{position:absolute;inset:0;z-index:0}
.page-head .ph-bg img{width:100%;height:100%;object-fit:cover}
.page-head .wrap{position:relative;z-index:2}
.page-head .crumb{font-size:.84rem;opacity:.8;margin-bottom:.7em;font-weight:600;letter-spacing:.03em}
.page-head .crumb a{color:var(--gold-soft)}
.page-head h1{font-size:clamp(2.3rem,5vw,3.7rem);color:#fff;max-width:760px}
.page-head p{color:rgba(255,255,255,.9);font-size:1.12rem;max-width:580px;margin:.8em 0 0}
.page-head .eyebrow{color:var(--gold-soft)}
.page-head .eyebrow::before{background:var(--gold-soft)}

/* ---------- sections ---------- */
section{position:relative}
.sec{padding:clamp(64px,8vw,118px) 0}
.sec-head{max-width:680px;margin-bottom:clamp(34px,4vw,56px)}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(2rem,3.7vw,3.1rem);margin:.32em 0 .35em}
.sec-head p{color:var(--ink-soft);font-size:1.08rem;margin:0}
.bg-cream2{background:var(--cream-2)}
.bg-green{background:var(--green-deep);color:#f4ead6}
.bg-green h2,.bg-green h3{color:#fff}
.bg-green .sec-head p{color:rgba(244,234,214,.85)}

/* ---------- USP strip ---------- */
.usps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow)}
.usp{background:var(--card);padding:30px 24px;text-align:center}
.usp .ico{width:46px;height:46px;margin:0 auto 12px;color:var(--green);display:grid;place-items:center}
.usp .ico svg{width:38px;height:38px}
.usp .num{font-family:var(--font-head);font-size:2rem;font-weight:700;color:var(--green);line-height:1}
.usp .lbl{font-weight:700;margin-top:6px;font-size:1.02rem}
.usp .sub{font-size:.88rem;color:var(--ink-soft);margin-top:3px}

/* ---------- story / split ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,5vw,72px);align-items:center}
.split.rev{grid-template-columns:.95fr 1.05fr}
.split .media{position:relative}
.split .media img{border-radius:var(--r-lg);box-shadow:var(--shadow-lg);width:100%;aspect-ratio:4/3.1;object-fit:cover}
.split .media .tag{
  position:absolute;bottom:-22px;left:-18px;background:var(--card);border-radius:var(--r);
  padding:16px 20px;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px;max-width:74%;
}
.split .media .tag .k{font-family:var(--font-head);font-size:1.5rem;color:var(--green);font-weight:700;line-height:1}
.split .media .tag .t{font-size:.86rem;color:var(--ink-soft);line-height:1.3}
.split .body h2{font-size:clamp(1.9rem,3.4vw,2.8rem);margin-bottom:.5em}
.split .body p{color:var(--ink-soft);margin:0 0 1.1em}
.split .body p strong{color:var(--ink)}
.feature-list{list-style:none;padding:0;margin:1.4em 0 1.8em;display:grid;gap:.7em}
.feature-list li{display:flex;gap:.7em;align-items:flex-start;font-weight:500}
.feature-list li svg{width:1.3em;height:1.3em;color:var(--green);flex:0 0 auto;margin-top:.18em}

/* ---------- dish cards ---------- */
.dish-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.dish{
  background:var(--card);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);
  border:1px solid var(--line-soft);transition:.3s ease;display:flex;flex-direction:column;
}
.dish:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.dish .ph{aspect-ratio:4/3;overflow:hidden;position:relative}
.dish .ph img{width:100%;height:100%;object-fit:cover;transition:.6s ease}
.dish:hover .ph img{transform:scale(1.07)}
.dish .ph .price{position:absolute;top:12px;right:12px;background:var(--gold);color:#3a2c08;font-weight:700;padding:.3em .75em;border-radius:999px;font-size:.95rem;box-shadow:0 6px 16px -6px rgba(0,0,0,.4)}
.dish .tx{padding:20px 22px 24px;flex:1;display:flex;flex-direction:column}
.dish .tx h3{font-size:1.28rem;margin-bottom:.3em}
.dish .tx p{color:var(--ink-soft);font-size:.95rem;margin:0}
.dish .tx .cat{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--green);font-weight:700;margin-bottom:.5em}

/* ---------- menu (speisekarte) ---------- */
.tabs{display:flex;gap:.5em;flex-wrap:wrap;justify-content:center;margin-bottom:42px}
.tab{
  border:1.5px solid var(--line);background:var(--card);color:var(--ink-soft);cursor:pointer;
  font-family:var(--font-body);font-weight:700;font-size:.96rem;padding:.6em 1.3em;border-radius:999px;transition:.2s;
}
.tab:hover{border-color:var(--green);color:var(--green)}
.tab.active{background:var(--green);border-color:var(--green);color:#fff;box-shadow:0 10px 22px -12px rgba(26,103,55,.7)}
.menu-panel{display:none}
.menu-panel.show{display:block;animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.menu-cat{margin-bottom:46px}
.menu-cat h3{font-size:1.7rem;color:var(--green);display:flex;align-items:center;gap:.55em;margin-bottom:.7em;padding-bottom:.4em;border-bottom:2px solid var(--line)}
.menu-cat h3 .dot{width:9px;height:9px;border-radius:50%;background:var(--gold);flex:0 0 auto}
.m-items{display:grid;gap:.2em}
.m-row{display:flex;gap:14px;align-items:baseline;padding:13px 4px;border-bottom:1px dashed var(--line)}
.m-row:last-child{border-bottom:none}
.m-row .m-main{flex:1;min-width:0}
.m-row .m-name{font-weight:700;font-size:1.06rem}
.m-row .m-desc{color:var(--ink-soft);font-size:.92rem;margin-top:1px}
.m-row .m-dots{flex:1;border-bottom:1px dotted var(--line);transform:translateY(-4px);min-width:18px}
.m-row .m-price{font-weight:700;color:var(--green);white-space:nowrap;font-variant-numeric:tabular-nums;font-size:1.04rem}
.m-note{background:var(--cream-2);border-left:3px solid var(--gold);padding:12px 18px;border-radius:0 10px 10px 0;font-size:.92rem;color:var(--ink-soft);margin-top:14px}

/* schnitzel family cards */
.fam-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.fam{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:22px 22px 24px;transition:.25s;position:relative;overflow:hidden}
.fam::before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--green),var(--gold))}
.fam:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--gold-soft)}
.fam h4{font-size:1.32rem;color:var(--green);margin-bottom:.3em}
.fam p{font-size:.92rem;color:var(--ink-soft);margin:0 0 1em}
.fam .pr{font-weight:700;color:var(--ink);font-size:1.08rem}

/* ---------- reviews marquee ---------- */
.rev-wrap{overflow:hidden;position:relative;padding:8px 0;-webkit-mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.marquee{display:flex;gap:22px;width:max-content;animation:marquee 46s linear infinite}
.marquee:has(.review-card:hover){animation-play-state:paused}
@keyframes marquee{to{transform:translateX(-50%)}}
.review-card{
  width:360px;flex:0 0 auto;background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:24px 26px;box-shadow:var(--shadow);transition:border-color .2s,box-shadow .2s;
}
.review-card:hover{border-color:var(--gold-soft);box-shadow:0 0 0 2px var(--gold-soft),var(--shadow)}
.review-card .stars{color:var(--gold);letter-spacing:.1em;font-size:1.02rem}
.review-card p{font-size:1rem;margin:.6em 0 1em;color:var(--ink);line-height:1.55}
.review-card .who{display:flex;align-items:center;gap:11px}
.review-card .av{width:40px;height:40px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center;font-weight:700;font-family:var(--font-head);flex:0 0 auto}
.review-card .who b{font-size:.96rem}
.review-card .who span{display:block;font-size:.8rem;color:var(--ink-soft)}

/* ---------- gallery ---------- */
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.gal a{display:block;overflow:hidden;border-radius:14px;position:relative;cursor:zoom-in;box-shadow:var(--shadow)}
.gal a img{width:100%;height:100%;object-fit:cover;transition:.6s ease}
.gal a:hover img{transform:scale(1.08)}
.gal a::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(10,32,18,.35));opacity:0;transition:.3s}
.gal a:hover::after{opacity:1}
.gal .tall{grid-row:span 2}
.gal .wide{grid-column:span 2}

/* lightbox */
.lb{position:fixed;inset:0;z-index:200;background:rgba(8,20,12,.93);display:none;align-items:center;justify-content:center;padding:30px}
.lb.open{display:flex;animation:fade .25s}
.lb img{max-width:92vw;max-height:86vh;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb button{position:absolute;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.35);color:#fff;cursor:pointer;width:52px;height:52px;border-radius:50%;display:grid;place-items:center;transition:.2s}
.lb button:hover{background:rgba(255,255,255,.25)}
.lb .lb-close{top:24px;right:24px}
.lb .lb-prev{left:20px;top:50%;transform:translateY(-50%)}
.lb .lb-next{right:20px;top:50%;transform:translateY(-50%)}
.lb button svg{width:24px;height:24px}

/* ---------- packages (feiern) ---------- */
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pkg{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:32px 28px;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:.25s;position:relative}
.pkg.feature{border:2px solid var(--gold);box-shadow:var(--shadow-lg)}
.pkg.feature .ribbon{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--gold);color:#3a2c08;font-weight:700;font-size:.76rem;letter-spacing:.06em;padding:.35em 1.1em;border-radius:999px;text-transform:uppercase}
.pkg h3{font-size:1.5rem;color:var(--green)}
.pkg .price{font-family:var(--font-head);font-size:2.4rem;font-weight:700;color:var(--ink);margin:.2em 0 .05em}
.pkg .price small{font-size:.95rem;font-family:var(--font-body);color:var(--ink-soft);font-weight:600}
.pkg ul{list-style:none;padding:0;margin:1.2em 0 1.6em;display:grid;gap:.6em;flex:1}
.pkg ul li{display:flex;gap:.6em;font-size:.96rem;color:var(--ink-soft)}
.pkg ul li svg{width:1.15em;height:1.15em;color:var(--green);flex:0 0 auto;margin-top:.2em}

/* hours/contact + forms */
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:start}
.info-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 32px;box-shadow:var(--shadow)}
.info-card h3{font-size:1.4rem;margin-bottom:.7em;color:var(--green)}
.info-row{display:flex;gap:14px;padding:11px 0;border-bottom:1px dashed var(--line);align-items:flex-start}
.info-row:last-child{border-bottom:none}
.info-row svg{width:1.4em;height:1.4em;color:var(--green);flex:0 0 auto;margin-top:.15em}
.info-row b{display:block}
.info-row span{color:var(--ink-soft);font-size:.95rem}
.hours-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed var(--line)}
.hours-row:last-child{border-bottom:none}
.hours-row.closed{color:var(--red)}
.hours-row b{font-weight:700}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:.35em}
.field.full{grid-column:1/-1}
.field label{font-weight:700;font-size:.9rem}
.field label .req{color:var(--red)}
.field input,.field select,.field textarea{
  font-family:var(--font-body);font-size:1rem;padding:.75em .9em;border:1.5px solid var(--line);
  border-radius:11px;background:var(--cream);color:var(--ink);transition:.18s;min-height:46px;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(26,103,55,.13);background:#fff}
.field textarea{resize:vertical;min-height:96px}

.map-card{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);height:100%;min-height:360px}
.map-card iframe{width:100%;height:100%;min-height:360px;border:0;display:block}

/* CTA band */
.cta-band{background:linear-gradient(120deg,var(--green-deep),var(--green));color:#fff;border-radius:var(--r-lg);padding:clamp(40px,5vw,64px);text-align:center;position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% -10%,rgba(228,192,116,.25),transparent 55%)}
.cta-band>*{position:relative}
.cta-band h2{color:#fff;font-size:clamp(1.9rem,3.4vw,2.8rem)}
.cta-band p{color:rgba(255,255,255,.9);max-width:540px;margin:.7em auto 1.5em}
.cta-band .cta-row{display:flex;gap:.8em;justify-content:center;flex-wrap:wrap}

/* ---------- footer ---------- */
.footer{background:var(--green-deepest);color:#cdd9cf;padding:64px 0 26px;font-size:.94rem}
.footer .cols{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:38px;margin-bottom:40px}
.footer h4{color:#fff;font-family:var(--font-body);font-weight:700;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1.1em}
.footer a{color:#cdd9cf;transition:.16s}
.footer a:hover{color:var(--gold-soft)}
.footer .fbrand{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.footer .fbrand img{width:54px;height:54px;border-radius:50%;background:#fff;padding:3px}
.footer .fbrand b{font-family:var(--font-head);font-size:1.3rem;color:#fff;display:block}
.footer .fbrand span{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;opacity:.7}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:.55em}
.footer .legal{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:.83rem;opacity:.82}
.footer .legal a{text-decoration:underline}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.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{animation:none}
  .hero-bg{transform:none!important}
  .scroll-cue{animation:none}
  html{scroll-behavior:auto}
}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .usps{grid-template-columns:repeat(2,1fr)}
  .dish-grid,.fam-grid,.pkg-grid{grid-template-columns:repeat(2,1fr)}
  .split,.split.rev{grid-template-columns:1fr;gap:40px}
  .split .media{order:-1}
  .info-grid{grid-template-columns:1fr}
  .gal{grid-template-columns:repeat(2,1fr)}
  .footer .cols{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  body{font-size:16px}
  .nav-links{display:none}
  .nav-toggle{display:block}
  .nav .nav-cta{display:none}
  .hero{min-height:90vh}
  .hero-inner{padding-top:100px}
  .dish-grid,.fam-grid,.pkg-grid,.form-grid{grid-template-columns:1fr}
  .form-grid .field{min-width:0}
  .split .media .tag{position:static;margin-top:16px;max-width:100%}
  .footer .cols{grid-template-columns:1fr 1fr;gap:26px}
  .footer .legal{flex-direction:column;gap:8px}
}
@media (max-width:440px){
  .footer .cols{grid-template-columns:1fr}
  .gal{grid-template-columns:1fr}
  .gal .wide{grid-column:auto}
}
