/* =================================================================
   GOURMETSCHLITTEN — Catering für Film & Fernsehen
   Style: grob / street / 90er / Straight Outta Potsdam
   ================================================================= */

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
img,svg{display:block;max-width:100%}
button,input,select,textarea{font:inherit;color:inherit}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ---------- TOKENS ---------- */
:root{
  --ink:#15110d;
  --ink-2:#1d1813;
  --ink-3:#28201a;
  --bone:#f3ebda;
  --bone-2:#e7dcc4;
  --silver:#b8b3a6;
  --muted:#9c9485;
  --accent:#e8531d;
  --accent-2:#f2b21f;
  --line:rgba(243,235,218,.14);
  --line-dark:rgba(21,17,13,.14);

  --f-display:'Anton',Impact,sans-serif;
  --f-chunk:'Bungee',sans-serif;
  --f-scrawl:'Permanent Marker',cursive;
  --f-body:'Inter',system-ui,-apple-system,sans-serif;

  --maxw:1280px;
  --pad:clamp(20px,5vw,80px);
  --r:22px;
  --ease:cubic-bezier(.16,1,.3,1);
}

/* ---------- BASE ---------- */
body{
  font-family:var(--f-body);
  background:var(--ink);
  color:var(--bone);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
}
.section{padding:clamp(70px,10vw,140px) var(--pad);position:relative}
section[id]{scroll-margin-top:78px}
::selection{background:var(--accent);color:#fff}

/* ---------- GRAIN ---------- */
.grain{
  position:fixed;inset:0;z-index:9000;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

/* ---------- TYPOGRAPHY HELPERS ---------- */
.h-xl{
  font-family:var(--f-display);font-weight:400;
  font-size:clamp(2.4rem,6.4vw,6rem);line-height:.92;
  text-transform:uppercase;letter-spacing:.5px;
}
.h-l{
  font-family:var(--f-display);font-weight:400;
  font-size:clamp(2rem,4.6vw,4rem);line-height:.95;
  text-transform:uppercase;letter-spacing:.5px;
}
.h-xl em,.h-l em,.hero__title em{font-style:normal;color:var(--accent)}
.light{color:var(--bone)}
.eyebrow{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--f-chunk);font-size:clamp(.72rem,1.1vw,.86rem);
  letter-spacing:.18em;text-transform:uppercase;color:var(--accent);
  margin-bottom:18px;
}
.eyebrow::before{content:"★";color:var(--accent-2)}
.eyebrow--light{color:var(--accent-2)}
.lead{font-size:clamp(1.02rem,1.5vw,1.22rem);color:var(--silver);max-width:54ch}
.scrawl{font-family:var(--f-scrawl);color:var(--accent-2);transform:rotate(-3deg);display:inline-block}
.scrawl--accent{color:var(--accent)}

/* sticker */
.sticker{
  display:inline-block;font-family:var(--f-chunk);
  font-size:clamp(.66rem,1vw,.8rem);letter-spacing:.12em;text-transform:uppercase;
  background:var(--accent);color:#fff;padding:.55em 1.1em;border-radius:999px;
  transform:rotate(-2.5deg);box-shadow:4px 4px 0 rgba(0,0,0,.4);
}
.sticker--sm{font-size:.62rem;background:var(--ink);color:var(--accent-2);border:2px solid var(--accent-2);box-shadow:none}

/* ---------- BUTTONS ---------- */
.btn{
  --bg:var(--bone);--fg:var(--ink);
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--f-chunk);font-size:.82rem;letter-spacing:.04em;
  text-transform:uppercase;padding:.95em 1.6em;border-radius:999px;
  background:var(--bg);color:var(--fg);border:2px solid var(--bg);
  cursor:pointer;transition:transform .35s var(--ease),background .25s,color .25s,box-shadow .35s;
  will-change:transform;white-space:nowrap;
}
.btn:hover{transform:translateY(-3px) rotate(-1deg);box-shadow:5px 7px 0 rgba(0,0,0,.35)}
.btn--accent{--bg:var(--accent);--fg:#fff}
.btn--dark{--bg:var(--ink);--fg:var(--bone);border-color:var(--ink)}
.btn--ghost{--bg:transparent;--fg:var(--bone);border-color:var(--bone)}
.btn--ghost:hover{background:var(--bone);color:var(--ink)}
.btn--lg{padding:1.1em 2em;font-size:.92rem}
.btn--sm{padding:.6em 1.1em;font-size:.72rem}
.btn--block{width:100%}

/* ---------- INTRO CURTAIN ---------- */
.intro{
  position:fixed;inset:0;z-index:9500;background:var(--ink);
  display:grid;place-items:center;transition:transform .9s var(--ease);
}
.intro__inner{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}
.intro__logo{width:min(58vw,300px)}
.intro__tag{font-family:var(--f-scrawl);font-size:1.6rem;color:var(--accent-2);transform:rotate(-4deg)}
.intro.is-gone{transform:translateY(-100%)}
.no-js .intro{display:none}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;gap:24px;
  padding:14px var(--pad);
  transition:background .4s,backdrop-filter .4s,padding .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.is-stuck{
  background:rgba(21,17,13,.82);backdrop-filter:blur(14px);
  border-bottom-color:var(--line);padding-top:10px;padding-bottom:10px;
}
.nav__brand{flex:0 0 auto}
.nav__logo{height:44px;width:auto;transition:height .4s}
.nav.is-stuck .nav__logo{height:36px}
.nav__links{display:flex;gap:26px;margin-left:auto;font-weight:600;font-size:.92rem}
.nav__links a{position:relative;padding:4px 0;color:var(--bone)}
.nav__links a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--accent);
  transition:width .3s var(--ease);
}
.nav__links a:hover::after{width:100%}
.nav__cta{margin-left:4px}
.nav__burger{display:none;background:none;border:0;width:42px;height:42px;cursor:pointer;flex-direction:column;gap:5px;justify-content:center;align-items:center;margin-left:auto}
.nav__burger span{width:26px;height:3px;background:var(--bone);border-radius:2px;transition:transform .3s,opacity .3s}
.nav__burger[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav__burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:999;background:var(--ink-2);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:30px;
  transform:translateY(-100%);transition:transform .6s var(--ease);
}
.mobile-menu.is-open{transform:translateY(0)}
.mobile-menu__links{display:flex;flex-direction:column;align-items:center;gap:14px}
.mobile-menu__links a{font-family:var(--f-display);font-size:2rem;text-transform:uppercase;color:var(--bone)}
.mobile-menu__links a:hover{color:var(--accent)}
.mobile-menu__foot{font-family:var(--f-scrawl);color:var(--accent-2)}

/* ---------- HERO ---------- */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:flex-end;
  padding:140px var(--pad) clamp(40px,7vw,90px);overflow:hidden;isolation:isolate;
}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__bg{position:absolute;top:-12%;left:0;width:100%;height:124%;object-fit:cover;object-position:center;filter:saturate(1.05) contrast(1.03)}
.hero__scrim{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(21,17,13,.5) 0%,rgba(21,17,13,.25) 30%,rgba(21,17,13,.9) 88%),
    linear-gradient(90deg,rgba(21,17,13,.85) 0%,rgba(21,17,13,.4) 46%,transparent 76%),
    radial-gradient(120% 80% at 18% 100%,rgba(232,83,29,.24),transparent 60%);
}
.hero__inner{max-width:880px;position:relative;z-index:2}
.sticker--top{margin-bottom:22px}
.hero__title{
  font-family:var(--f-display);font-weight:400;text-transform:uppercase;
  font-size:clamp(3rem,10vw,8.8rem);line-height:.86;letter-spacing:.5px;
  text-shadow:3px 4px 0 rgba(0,0,0,.35);margin-bottom:22px;
}
.hero__title .line{display:block;overflow:hidden}
.hero__title .line>span{display:block}
.hero__sub{font-size:clamp(1.05rem,1.8vw,1.4rem);max-width:46ch;color:var(--bone-2);margin-bottom:30px;text-shadow:0 1px 14px rgba(0,0,0,.55)}
.hero__sub strong{color:var(--bone)}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:42px}
.hero__stats{display:flex;flex-wrap:wrap;gap:clamp(24px,5vw,60px)}
.hero__stats li{display:flex;flex-direction:column}
.hero__stats b{font-family:var(--f-display);font-size:clamp(2.2rem,4.5vw,3.4rem);line-height:1;color:var(--accent-2)}
.hero__stats span{font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--silver)}

.hero__dish{
  position:absolute;right:clamp(-40px,2vw,60px);top:clamp(90px,16vh,200px);z-index:1;
  width:clamp(220px,28vw,420px);aspect-ratio:4/5;border-radius:var(--r);overflow:visible;
  transform:rotate(4deg);filter:drop-shadow(0 30px 50px rgba(0,0,0,.6));
}
.hero__dish img{width:100%;height:100%;object-fit:cover;border-radius:var(--r);border:3px solid var(--bone)}
.price-pop{
  position:absolute;left:-22px;bottom:18px;
  font-family:var(--f-chunk);font-size:1.05rem;background:var(--accent-2);color:var(--ink);
  padding:.7em 1em;border-radius:50%;aspect-ratio:1;display:grid;place-items:center;text-align:center;
  transform:rotate(-12deg);box-shadow:4px 5px 0 rgba(0,0,0,.4);line-height:1;
}

.hero__scroll{
  position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  font-family:var(--f-chunk);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--silver);
}
.hero__scroll svg{width:20px;height:20px;fill:none;stroke:var(--accent);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;animation:bob 1.8s var(--ease) infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}

/* scattered stars */
.star{position:absolute;fill:var(--bone);opacity:.9}
.hero .star{opacity:.85}
.star--1{width:60px;top:18%;right:18%;fill:var(--accent-2);transform:rotate(-8deg)}
.star--2{width:34px;top:30%;right:8%;fill:var(--bone)}
.star--3{width:44px;bottom:20%;right:30%;fill:var(--accent);transform:rotate(12deg)}
.star--4{width:90px;top:8%;right:6%;fill:rgba(243,235,218,.08)}

/* ---------- MARQUEE ---------- */
.marquee{overflow:hidden;white-space:nowrap;border-block:3px solid var(--ink);position:relative}
.marquee--accent{background:var(--accent);color:#fff}
.marquee--outline{background:var(--ink-2);color:transparent;border-color:var(--line)}
.marquee__track{display:inline-flex;will-change:transform;animation:scroll 32s linear infinite}
.marquee[data-dir="reverse"] .marquee__track{animation-direction:reverse}
.marquee__track span{
  font-family:var(--f-display);text-transform:uppercase;
  font-size:clamp(1.6rem,3.4vw,2.8rem);line-height:1.5;padding-block:.28em;letter-spacing:1px;
}
.marquee--outline .marquee__track span{
  -webkit-text-stroke:1.5px var(--bone-2);color:transparent;
}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee:hover .marquee__track{animation-play-state:paused}

/* ---------- STORY ---------- */
.story{background:var(--bone);color:var(--ink)}
.story__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,80px);align-items:center}
.story__copy p{font-size:1.08rem;color:#43382c;margin-top:18px;max-width:48ch}
.story__copy .scrawl{color:var(--accent);font-size:1.3em}
.story__copy .btn{margin-top:28px}
.story .eyebrow{color:var(--accent)}

/* flip cards (story) */
.flips{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.flip{
  appearance:none;border:0;background:none;cursor:pointer;
  aspect-ratio:1/1;perspective:1000px;
}
.flip__inner{
  position:relative;display:block;width:100%;height:100%;
  transition:transform .7s var(--ease);transform-style:preserve-3d;
}
.flip:hover .flip__inner,.flip.is-flipped .flip__inner{transform:rotateX(180deg)}
.flip__face{
  position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;
  border-radius:var(--r);display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;padding:20px;
}
.flip__front{background:var(--ink);color:var(--bone);border:3px solid var(--ink)}
.flip__front b{font-family:var(--f-display);font-size:clamp(2.4rem,5vw,3.6rem);line-height:1;color:var(--accent-2)}
.flip__front small{margin-top:6px;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--silver)}
.flip__back{
  background:var(--accent);color:#fff;transform:rotateX(180deg);
  font-weight:600;font-size:.98rem;line-height:1.4;
}
.flip__back em{font-family:var(--f-scrawl);font-style:normal}

/* ---------- SIGNATURE BITES ---------- */
.bites{background:var(--ink)}
.bites__head{max-width:var(--maxw);margin:0 auto 50px}
.bites__head .lead{margin-top:14px}
.bites__grid{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:22px;
}
.dish{perspective:1400px}
.dish__card{
  position:relative;width:100%;aspect-ratio:3/4;transform-style:preserve-3d;
  transition:transform .8s var(--ease);
}
.dish:hover .dish__card,.dish.is-flipped .dish__card{transform:rotateX(180deg)}
.dish__face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--r);overflow:hidden}
.dish__front{background:var(--ink-2);border:1px solid var(--line)}
.dish__img{position:absolute;inset:0;overflow:hidden}
.dish__img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.dish:hover .dish__img img{transform:scale(1.06)}
.dish__bar{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  display:flex;justify-content:space-between;align-items:flex-end;gap:10px;padding:18px;
  background:linear-gradient(180deg,transparent,rgba(21,17,13,.92));
}
.dish__bar h3{font-family:var(--f-display);font-size:clamp(1.1rem,1.6vw,1.5rem);text-transform:uppercase;line-height:.95;letter-spacing:.5px}
.dish__price{
  font-family:var(--f-chunk);font-size:.86rem;background:var(--accent-2);color:var(--ink);
  padding:.45em .7em;border-radius:8px;white-space:nowrap;transform:rotate(-3deg);
  box-shadow:2px 3px 0 rgba(0,0,0,.4);
}
.dish__back{
  background:var(--accent);color:#fff;transform:rotateX(180deg);
  display:flex;flex-direction:column;justify-content:center;gap:14px;padding:26px;text-align:center;
}
.dish__back h3{font-family:var(--f-display);font-size:1.5rem;text-transform:uppercase;letter-spacing:.5px}
.dish__back p{font-size:.96rem;line-height:1.45;color:rgba(255,255,255,.92)}
.dish__price--big{display:inline-block;margin:0 auto;font-size:1.3rem;background:var(--ink);color:var(--accent-2);transform:rotate(-2deg)}
.dish__back .btn{align-self:center}

/* ---------- CATERING ---------- */
.catering{background:var(--ink);overflow:hidden}
.catering__bg{position:absolute;inset:0;z-index:0}
.catering__bg img{width:100%;height:100%;object-fit:cover}
.catering__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(21,17,13,.72) 0%,rgba(21,17,13,.8) 42%,rgba(21,17,13,.94) 100%)}
.catering__head{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto 50px}
.catering__head .lead{margin-top:16px}
.services{
  position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}
.service{
  background:rgba(40,32,26,.66);border:1px solid var(--line);border-radius:var(--r);
  padding:30px;backdrop-filter:blur(4px);transition:transform .4s var(--ease),border-color .3s,background .3s;
}
.service:hover{transform:translateY(-6px);border-color:var(--accent);background:rgba(40,32,26,.92)}
.service__ico{width:46px;height:46px;fill:none;stroke:var(--accent-2);stroke-width:3;stroke-linejoin:round;stroke-linecap:round;margin-bottom:16px}
.service h3{font-family:var(--f-display);font-size:1.35rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.service p{color:var(--silver);font-size:.98rem}

/* ---------- FLEET ---------- */
.fleet{background:var(--bone);color:var(--ink)}
.fleet__head{max-width:var(--maxw);margin:0 auto 40px}
.fleet__head .scrawl{color:var(--accent)}
.fleet .eyebrow{color:var(--accent)}
.fleet__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr;gap:22px}
.fleet__card{background:var(--ink);color:var(--bone);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column}
.fleet__img{overflow:hidden;aspect-ratio:16/10}
.fleet__img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.fleet__card:hover .fleet__img img{transform:scale(1.05)}
.fleet__card figcaption{padding:24px}
.fleet__card h3{font-family:var(--f-display);font-size:1.5rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.fleet__card p{color:var(--silver);font-size:.96rem}

/* ---------- MENÜ ---------- */
.menu{background:var(--ink)}
.menu__head{max-width:var(--maxw);margin:0 auto 46px}
.menu__grid{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:1fr;gap:18px;
}
.cat{position:relative;border-radius:var(--r);overflow:hidden;min-height:280px;border:1px solid var(--line)}
.cat--tall{grid-row:span 2}
.cat__img{position:absolute;inset:0;overflow:hidden}
.cat__img img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.cat:hover .cat__img img{transform:scale(1.07)}
.cat__txt{
  position:absolute;inset:auto 0 0 0;padding:22px;z-index:2;
  background:linear-gradient(180deg,transparent,rgba(21,17,13,.94));
}
.cat__txt h3{font-family:var(--f-display);font-size:1.5rem;text-transform:uppercase;letter-spacing:.5px}
.cat__txt p{color:var(--bone-2);font-size:.92rem;margin-top:6px;max-width:40ch;
  opacity:0;max-height:0;overflow:hidden;transition:opacity .4s,max-height .5s var(--ease)}
.cat:hover .cat__txt p{opacity:1;max-height:120px}
.menu__note{max-width:var(--maxw);margin:36px auto 0;color:var(--silver);font-size:1.05rem}
.menu__note a{color:var(--accent-2);font-weight:700}

/* ---------- TEAM ---------- */
.team{background:var(--bone);color:var(--ink)}
.team .eyebrow{color:var(--accent)}
.team__head{max-width:var(--maxw);margin:0 auto 44px}
.team__head .lead{margin-top:14px;color:#5a4d3e}
.team__grid{max-width:920px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:24px}
.member{background:var(--ink);color:var(--bone);border-radius:var(--r);overflow:hidden}
.member__img{position:relative;aspect-ratio:4/5;overflow:hidden}
.member__img img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .8s var(--ease)}
.member:hover .member__img img{transform:scale(1.05)}
.member__star{position:absolute;top:14px;right:14px;width:42px}
.member__star svg{fill:var(--accent-2);filter:drop-shadow(2px 2px 0 rgba(0,0,0,.4))}
.member__txt{padding:24px}
.member__txt h3{font-family:var(--f-display);font-size:1.7rem;text-transform:uppercase;letter-spacing:.5px}
.member__role{display:inline-block;font-family:var(--f-chunk);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-2);margin:6px 0 12px}
.member__txt p{color:var(--silver);font-size:.98rem}

/* walk of fame */
.fame{max-width:var(--maxw);margin:60px auto 0;text-align:center}
.fame__title{margin-bottom:24px}
.fame__title .scrawl{color:var(--accent);font-size:clamp(1.4rem,3vw,2rem)}
.fame__list{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 26px}
.fame__list li{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--f-display);font-size:clamp(1rem,1.6vw,1.4rem);text-transform:uppercase;
  color:var(--ink);letter-spacing:.5px;
}
.fame__list svg{width:26px;fill:var(--accent-2)}
.fame__list small{font-family:var(--f-body);font-weight:600;font-size:.7rem;color:#7a6e5e;letter-spacing:.04em;text-transform:none}

/* ---------- BOOKING ---------- */
.book{background:var(--ink-2);overflow:hidden}
.book__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(36px,5vw,72px);align-items:start;position:relative;z-index:2}
.book__copy p{margin-top:16px;color:var(--silver);max-width:42ch;font-size:1.06rem}
.book__contact{margin-top:32px;display:flex;flex-direction:column;gap:14px}
.book__contact li{display:flex;flex-direction:column;border-top:1px solid var(--line);padding-top:12px}
.book__contact span{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.book__contact a{font-family:var(--f-display);font-size:clamp(1.3rem,2.4vw,1.9rem);text-transform:uppercase;letter-spacing:.5px;transition:color .25s}
.book__contact a:hover{color:var(--accent-2)}

.book__form{background:var(--bone);color:var(--ink);border-radius:var(--r);padding:clamp(24px,3vw,40px);display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:7px;grid-column:1/-1}
.field--half{grid-column:span 1}
.field label{font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:#6a5d4c}
.field input,.field select,.field textarea{
  background:#fff;border:2px solid #ddd0b8;border-radius:12px;padding:.8em .9em;color:var(--ink);
  transition:border-color .25s,box-shadow .25s;font-size:.98rem;width:100%;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 4px rgba(232,83,29,.14)}
.field textarea{resize:vertical}
.book__form .btn{grid-column:1/-1;margin-top:4px}
.book__hint{grid-column:1/-1;text-align:center;font-weight:600;min-height:1.2em;font-size:.92rem}
.book__hint.is-ok{color:#2e7d32}
.book__hint.is-err{color:var(--accent)}
.book .star--4{z-index:0;opacity:.5}

/* ---------- INSTAGRAM ---------- */
.insta{background:var(--ink);text-align:center}
.insta__head{max-width:var(--maxw);margin:0 auto 36px}
.insta__head a{color:var(--accent)}
.insta__head a:hover{color:var(--accent-2)}
.insta__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(6,1fr);gap:10px}
.insta__tile{position:relative;aspect-ratio:1;border-radius:14px;overflow:hidden;display:block}
.insta__tile img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease),filter .4s}
.insta__tile:hover img{transform:scale(1.1);filter:brightness(.6)}
.insta__ico{position:absolute;inset:0;display:grid;place-items:center;opacity:0;transition:opacity .35s}
.insta__ico svg{width:34px;fill:none;stroke:#fff;stroke-width:1.6}
.insta__tile:hover .insta__ico{opacity:1}

/* ---------- FOOTER ---------- */
.footer{background:var(--ink-2);padding:clamp(50px,7vw,90px) var(--pad) 30px;border-top:3px solid var(--accent)}
.footer__top{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
.footer__logo{height:60px;width:auto;margin-bottom:16px}
.footer__brand p{color:var(--silver);margin-bottom:16px}
.footer h4{font-family:var(--f-chunk);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-2);margin-bottom:16px}
.footer__nav,.footer__contact{display:flex;flex-direction:column;gap:11px}
.footer__nav a,.footer__contact a{color:var(--silver);transition:color .2s;width:fit-content}
.footer__nav a:hover,.footer__contact a:hover{color:var(--bone)}
.footer__contact .btn{margin-top:6px;color:#fff}
.footer__bottom{
  max-width:var(--maxw);margin:50px auto 0;padding-top:20px;border-top:1px solid var(--line);
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;
  font-size:.82rem;color:var(--muted);
}
.footer__tag{font-family:var(--f-scrawl);color:var(--accent-2)}
.footer__tag em{color:var(--accent);font-style:normal}
.footer__bottom a:hover{color:var(--bone)}
.footer__legal{max-width:var(--maxw);margin:34px auto 0;border-top:1px solid var(--line);padding-top:18px}
.footer__legal summary{cursor:pointer;font-family:var(--f-chunk);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-2);list-style:none;width:fit-content}
.footer__legal summary::-webkit-details-marker{display:none}
.footer__legal summary::before{content:"§ ";color:var(--accent)}
.footer__legal summary:hover{color:var(--bone)}
.footer__legal-body{margin-top:14px;color:var(--muted);font-size:.84rem;line-height:1.65;display:grid;gap:10px;max-width:64ch}
.footer__legal-body a{color:var(--silver)}
.footer__legal-body a:hover{color:var(--bone)}
.footer__legal-body strong{color:var(--bone-2)}

/* ---------- WHATSAPP FLOATING WIDGET ---------- */
.wa-fab{position:fixed;right:clamp(16px,3vw,28px);bottom:clamp(16px,3vw,28px);z-index:990;width:60px;height:60px;border-radius:50%;background:#25d366;display:grid;place-items:center;box-shadow:0 10px 26px rgba(0,0,0,.4);transition:transform .3s var(--ease),box-shadow .3s}
.wa-fab svg{width:34px;height:34px;fill:#fff}
.wa-fab::after{content:"";position:absolute;inset:0;border-radius:50%;animation:wa-pulse 2.6s ease-out infinite;pointer-events:none}
@keyframes wa-pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 20px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
.wa-fab:hover{transform:translateY(-3px) scale(1.06);box-shadow:0 16px 34px rgba(0,0,0,.5)}
.wa-fab__label{position:absolute;right:74px;top:50%;transform:translateY(-50%) translateX(10px);background:var(--ink);color:var(--bone);font-family:var(--f-chunk);font-size:.74rem;letter-spacing:.03em;padding:.6em .95em;border-radius:10px;white-space:nowrap;opacity:0;pointer-events:none;box-shadow:0 6px 18px rgba(0,0,0,.35);transition:opacity .25s,transform .3s var(--ease)}
.wa-fab__label::after{content:"";position:absolute;right:-5px;top:50%;transform:translateY(-50%) rotate(45deg);width:10px;height:10px;background:var(--ink)}
.wa-fab:hover .wa-fab__label{opacity:1;transform:translateY(-50%) translateX(0)}
@media (max-width:560px){.wa-fab{width:56px;height:56px}.wa-fab__label{display:none}}

/* =================================================================
   REVEAL ANIMATIONS (only when JS active)
   ================================================================= */
.is-js [data-reveal]{opacity:0;transform:translateY(40px)}
.is-js .hero__title .line>span{transform:translateY(110%)}
.is-js [data-img-reveal]{clip-path:inset(0 0 100% 0);transform:scale(1.15)}
.is-js .hero__dish{opacity:0;transform:rotate(4deg) translateY(60px) scale(.9)}

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media (max-width:1080px){
  .bites__grid{grid-template-columns:repeat(2,1fr)}
  .services{grid-template-columns:repeat(2,1fr)}
  .menu__grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}
  .story__grid,.fleet__grid,.book__grid{grid-template-columns:1fr}
  .hero__dish{display:none}
  .hero{min-height:92svh}
  .footer__top{grid-template-columns:1fr 1fr}
  .footer__brand{grid-column:1/-1}
  .insta__grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:560px){
  .bites__grid,.services,.menu__grid,.team__grid,.flips{grid-template-columns:1fr}
  .cat--tall{grid-row:span 1}
  .footer__top{grid-template-columns:1fr}
  .hero__stats{gap:24px}
  .book__form{grid-template-columns:1fr}
  .field--half{grid-column:1/-1}
  /* on touch, flips toggle via class only */
  .dish:hover .dish__card{transform:none}
  .dish.is-flipped .dish__card{transform:rotateX(180deg)}
  .flip:hover .flip__inner{transform:none}
  .flip.is-flipped .flip__inner{transform:rotateX(180deg)}
}

/* =================================================================
   REDUCED MOTION
   ================================================================= */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .marquee__track{animation:none}
  .is-js [data-reveal]{opacity:1;transform:none}
  .is-js [data-img-reveal]{clip-path:none;transform:none}
  .is-js .hero__title .line>span{transform:none}
  .is-js .hero__dish{opacity:1;transform:rotate(4deg)}
}


/* ---------- EINSATZGEBIETE (SEO/AIO) ---------- */
.areas{background:var(--ink)}
.areas__head{max-width:var(--maxw);margin:0 auto 30px}
.areas__head .lead{margin-top:14px}
.areas__list{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px 28px;list-style:none;padding:0}
.areas__list li{display:flex;align-items:flex-start;gap:10px;color:var(--bone-2);font-size:1rem;border-top:1px solid var(--line);padding-top:14px}
.areas__list svg{width:20px;flex:0 0 20px;fill:var(--accent-2);margin-top:3px}
.areas__kw{max-width:var(--maxw);margin:26px auto 0;color:var(--muted);font-size:.95rem}

/* ---------- FAQ ---------- */
.faq{background:var(--bone);color:var(--ink)}
.faq .eyebrow{color:var(--accent)}
.faq__head{max-width:880px;margin:0 auto 34px}
.faq__list{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq__item{background:#fff;border:1px solid var(--line-dark);border-radius:16px;overflow:hidden}
.faq__item summary{cursor:pointer;list-style:none;padding:20px 24px;font-family:var(--f-display);font-size:clamp(1.02rem,1.7vw,1.3rem);text-transform:uppercase;letter-spacing:.5px;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";font-family:var(--f-body);color:var(--accent);font-size:1.7rem;line-height:1;transition:transform .3s var(--ease)}
.faq__item[open] summary::after{transform:rotate(45deg)}
.faq__item summary:hover{color:var(--accent)}
.faq__a{padding:0 24px 22px;color:#43382c;font-size:1rem;line-height:1.6;max-width:64ch}
