@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Karla:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&display=swap');

:root{
  --terracotta: #c1501f;
  --terracotta-dark: #9c3d15;
  --terracotta-soft: #e8b39a;
  --forest: #1f3d30;
  --forest-light: #2c5643;
  --cream: #faf3e7;
  --cream-2: #f3e8d6;
  --ink: #2a2016;
  --ink-soft: #5c4f42;
  --gold: #c9973f;
  --line: #e3d5c2;
  --white: #ffffff;

  --font-display: 'Bricolage Grotesque', sans-serif;
  --font-body: 'Karla', sans-serif;

  --shadow-sm: 0 2px 10px rgba(42,32,22,.08);
  --shadow-md: 0 10px 30px rgba(42,32,22,.14);
  --shadow-lg: 0 20px 55px rgba(31,61,48,.22);

  --radius: 18px;
  --radius-sm: 10px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--cream);
  color:var(--ink);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:var(--font-display);margin:0 0 .4em;line-height:1.1;font-weight:700;color:var(--forest);}
p{margin:0 0 1em;}
.container{max-width:1180px;margin:0 auto;padding:0 24px;}
section{padding:96px 0;}
@media (max-width:768px){section{padding:64px 0;}}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease;}
.reveal.in{opacity:1;transform:translateY(0);}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  html{scroll-behavior:auto;}
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 30px;border-radius:999px;
  font-family:var(--font-display);font-weight:600;font-size:16px;
  cursor:pointer;border:none;transition:transform .25s ease,box-shadow .25s ease,background .25s ease;
  white-space:nowrap;
}
.btn-primary{background:var(--terracotta);color:var(--white);box-shadow:var(--shadow-sm);}
.btn-primary:hover{background:var(--terracotta-dark);transform:translateY(-2px);box-shadow:var(--shadow-md);}
.btn-outline{background:transparent;color:var(--cream);border:1.5px solid rgba(250,243,231,.55);}
.btn-outline:hover{background:rgba(250,243,231,.12);border-color:var(--cream);transform:translateY(-2px);}
.btn-ghost{background:var(--forest);color:var(--cream);}
.btn-ghost:hover{background:var(--forest-light);transform:translateY(-2px);box-shadow:var(--shadow-md);}

/* ---------- Navbar ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:16px 0;transition:background .35s ease,box-shadow .35s ease,padding .35s ease;
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;}
.nav.solid{background:rgba(250,243,231,.9);backdrop-filter:blur(14px);box-shadow:0 2px 20px rgba(42,32,22,.08);padding:10px 0;}
.nav-logo{display:flex;align-items:center;gap:10px;}
.nav-logo img{height:44px;width:auto;filter:brightness(0) invert(1);transition:filter .35s ease;}
.nav.solid .nav-logo img{filter:none;}
.nav-links{display:flex;align-items:center;gap:34px;}
.nav-links a:not(.btn){
  font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--cream);
  position:relative;padding:4px 0;transition:color .25s ease;
}
.nav.solid .nav-links a:not(.btn){color:var(--forest);}
.nav-links a:not(.btn)::after{
  content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--terracotta);
  transition:width .25s ease;
}
.nav-links a:not(.btn):hover::after{width:100%;}
.nav-burger{display:none;background:none;border:none;cursor:pointer;color:var(--cream);}
.nav.solid .nav-burger{color:var(--forest);}

@media (max-width:900px){
  .nav-links{
    position:fixed;top:0;right:-100%;height:100vh;width:min(320px,80vw);
    background:var(--forest);flex-direction:column;justify-content:center;gap:28px;
    transition:right .4s ease;padding:40px;
  }
  .nav-links.open{right:0;}
  .nav-links a:not(.btn){color:var(--cream)!important;}
  .nav-burger{display:block;z-index:101;}
}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;
  color:var(--cream);
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center 30%;
  transform:scale(1.15);
  will-change:transform;
}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(31,20,12,.55) 0%,rgba(31,20,12,.5) 45%,rgba(24,16,10,.85) 100%);
}
.hero-content{position:relative;z-index:2;padding-top:90px;}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  font-size:13px;color:var(--terracotta-soft);background:rgba(250,243,231,.1);
  padding:8px 18px;border-radius:999px;border:1px solid rgba(250,243,231,.25);margin-bottom:26px;
}
.hero h1{
  color:var(--cream);font-size:clamp(2.6rem,6vw,5rem);max-width:820px;margin-bottom:.3em;
}
.hero h1 em{color:var(--terracotta-soft);font-style:normal;}
.hero p.lead{font-size:clamp(1.05rem,2vw,1.3rem);max-width:560px;color:rgba(250,243,231,.9);margin-bottom:2em;}
.hero-actions{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:56px;}
.hero-scroll{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(250,243,231,.7);
  font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-family:var(--font-display);
}
.hero-scroll .dot{width:1px;height:36px;background:linear-gradient(rgba(250,243,231,.9),transparent);animation:scrolldrop 1.8s infinite;}
@keyframes scrolldrop{0%{opacity:0;transform:translateY(-8px);}50%{opacity:1;}100%{opacity:0;transform:translateY(8px);}}

.hero-awards{display:flex;gap:24px;align-items:center;}
.hero-award-badge{height:74px;width:auto;filter:drop-shadow(0 6px 16px rgba(0,0,0,.35));}
.hero-award-text{font-size:13px;line-height:1.35;color:rgba(250,243,231,.85);}
.hero-award-text strong{display:block;color:var(--cream);font-family:var(--font-display);font-size:14px;}

/* ---------- Section headers ---------- */
.eyebrow{
  font-family:var(--font-display);font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  font-size:13px;color:var(--terracotta);display:inline-flex;align-items:center;gap:10px;margin-bottom:14px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--terracotta);display:inline-block;}
.section-head{max-width:640px;margin-bottom:56px;}
.section-head h2{font-size:clamp(2rem,4vw,2.8rem);}
.section-head p{color:var(--ink-soft);font-size:1.1rem;}
.center{text-align:center;margin-left:auto;margin-right:auto;}
.center .eyebrow::before{display:none;}
.center .eyebrow{gap:0;}

/* ---------- Story / sourcing ---------- */
.story{background:var(--white);}
.story-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:70px;align-items:center;}
@media (max-width:900px){.story-grid{grid-template-columns:1fr;gap:40px;}}
.story-media{position:relative;}
.story-media img{border-radius:var(--radius);box-shadow:var(--shadow-md);}
.story-media .float-card{
  position:absolute;bottom:-28px;right:-28px;background:var(--forest);color:var(--cream);
  padding:22px 26px;border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);max-width:230px;
}
@media (max-width:600px){.story-media .float-card{position:static;margin-top:18px;max-width:none;}}
.story-media .float-card strong{display:block;font-family:var(--font-display);font-size:1.5rem;color:var(--terracotta-soft);}
.story-media .float-card span{font-size:13px;opacity:.85;}

.sourcing-list{list-style:none;margin:28px 0 0;padding:0;display:grid;gap:16px;}
.sourcing-list li{
  display:flex;gap:14px;align-items:flex-start;padding:16px 18px;background:var(--cream);
  border-radius:var(--radius-sm);border:1px solid var(--line);transition:transform .25s ease,box-shadow .25s ease;
}
.sourcing-list li:hover{transform:translateX(4px);box-shadow:var(--shadow-sm);}
.sourcing-list .ic{
  flex:none;width:40px;height:40px;border-radius:50%;background:var(--terracotta);color:#fff;
  display:flex;align-items:center;justify-content:center;
}
.sourcing-list .ic svg{width:20px;height:20px;}
.sourcing-list b{font-family:var(--font-display);display:block;font-size:15px;color:var(--forest);}
.sourcing-list span{font-size:14px;color:var(--ink-soft);}

/* ---------- Awards ---------- */
.awards{background:var(--forest);color:var(--cream);position:relative;overflow:hidden;}
.awards::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 15% 20%,rgba(193,80,31,.18),transparent 45%),
             radial-gradient(circle at 85% 80%,rgba(193,80,31,.14),transparent 45%);
}
.awards .section-head{position:relative;}
.awards .section-head h2{color:var(--cream);}
.awards .section-head p{color:rgba(250,243,231,.75);}
.awards-grid{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
@media (max-width:900px){.awards-grid{grid-template-columns:1fr;}}
.award-card{
  background:rgba(250,243,231,.06);border:1px solid rgba(250,243,231,.15);border-radius:var(--radius);
  padding:38px 32px;text-align:center;backdrop-filter:blur(6px);
  transition:transform .3s ease,background .3s ease,border-color .3s ease;
}
.award-card:hover{transform:translateY(-8px);background:rgba(250,243,231,.1);border-color:rgba(250,243,231,.3);}
.award-card img{height:110px;margin:0 auto 20px;}
.award-card h3{color:var(--cream);font-size:1.2rem;margin-bottom:6px;}
.award-card .score{font-family:var(--font-display);color:var(--terracotta-soft);font-weight:700;font-size:1.1rem;}
.award-card p{color:rgba(250,243,231,.7);font-size:14px;margin-top:10px;}

/* ---------- Signature dishes (3D flip) ---------- */
.signature{background:var(--cream);}
.flip-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;}
@media (max-width:900px){.flip-grid{grid-template-columns:1fr;}}
.flip-card{
  perspective:1400px;height:400px;border-radius:var(--radius);cursor:pointer;
}
.flip-inner{
  position:relative;width:100%;height:100%;transition:transform .7s cubic-bezier(.2,.8,.2,1);
  transform-style:preserve-3d;border-radius:var(--radius);box-shadow:var(--shadow-md);
}
.flip-card:hover .flip-inner,
.flip-card.flipped .flip-inner{transform:rotateY(180deg);}
.flip-front,.flip-back{
  position:absolute;inset:0;backface-visibility:hidden;border-radius:var(--radius);overflow:hidden;
}
.flip-front img{width:100%;height:100%;object-fit:cover;}
.flip-front .tag{
  position:absolute;bottom:0;left:0;right:0;padding:22px;
  background:linear-gradient(0deg,rgba(20,14,9,.88),transparent);color:#fff;
}
.flip-front .tag h3{color:#fff;font-size:1.3rem;margin-bottom:2px;}
.flip-front .tag span{font-size:13px;color:var(--terracotta-soft);font-family:var(--font-display);font-weight:600;}
.flip-back{
  transform:rotateY(180deg);background:var(--forest);color:var(--cream);
  padding:32px;display:flex;flex-direction:column;justify-content:center;
}
.flip-back h3{color:var(--terracotta-soft);font-size:1.25rem;}
.flip-back p{font-size:14.5px;color:rgba(250,243,231,.85);}
.flip-back .price{
  margin-top:auto;font-family:var(--font-display);font-weight:700;font-size:1.4rem;color:var(--cream);
}

/* ---------- Gallery ---------- */
.gallery{background:var(--white);}
.gallery-grid{
  display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:190px;gap:16px;
}
.gallery-grid a{border-radius:var(--radius-sm);overflow:hidden;position:relative;display:block;}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.gallery-grid a:hover img{transform:scale(1.08);}
.gallery-grid a::after{
  content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(31,20,12,.35),transparent 55%);
  opacity:0;transition:opacity .3s ease;
}
.gallery-grid a:hover::after{opacity:1;}
.g-wide{grid-column:span 2;}
.g-tall{grid-row:span 2;}
@media (max-width:900px){
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px;}
  .g-wide{grid-column:span 2;}
  .g-tall{grid-row:span 1;}
}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;background:rgba(20,14,9,.92);z-index:200;display:none;
  align-items:center;justify-content:center;padding:40px;
}
.lightbox.open{display:flex;}
.lightbox img{max-width:100%;max-height:85vh;border-radius:12px;box-shadow:var(--shadow-lg);}
.lightbox-close{
  position:absolute;top:26px;right:32px;background:none;border:none;color:#fff;font-size:32px;cursor:pointer;
  line-height:1;
}

/* ---------- Reviews Marquee ---------- */
.reviews{background:var(--cream-2);overflow:hidden;}
.review-stats{display:flex;gap:50px;flex-wrap:wrap;margin-bottom:50px;}
.review-stat strong{font-family:var(--font-display);font-size:2.4rem;color:var(--forest);display:block;}
.review-stat span{color:var(--ink-soft);font-size:14px;}
.marquee-wrap{position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);}
.marquee{display:flex;gap:24px;width:max-content;animation:marquee 42s linear infinite;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.review-card{
  flex:none;width:340px;background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:26px;box-shadow:var(--shadow-sm);transition:border-color .2s ease,box-shadow .2s ease;
}
.review-card:hover{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold);}
.marquee:has(.review-card:hover){animation-play-state:paused;}
.review-stars{color:var(--gold);letter-spacing:2px;margin-bottom:10px;font-size:15px;}
.review-card p{font-size:14.5px;color:var(--ink-soft);font-style:italic;}
.review-card .src{font-family:var(--font-display);font-weight:600;font-size:13px;color:var(--forest);}

/* ---------- CTA banner ---------- */
.cta-banner{
  background:linear-gradient(120deg,var(--terracotta),var(--terracotta-dark));color:#fff;
  border-radius:var(--radius);padding:64px 50px;text-align:center;position:relative;overflow:hidden;
}
.cta-banner::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 20%,rgba(255,255,255,.18),transparent 40%);
}
.cta-banner h2{color:#fff;position:relative;}
.cta-banner p{color:rgba(255,255,255,.85);position:relative;max-width:520px;margin:0 auto 30px;}
.cta-banner .btn-primary{background:var(--forest);position:relative;}
.cta-banner .btn-primary:hover{background:var(--forest-light);}

/* ---------- Map / Contact ---------- */
.contact{background:var(--forest);color:var(--cream);}
.contact .section-head h2{color:var(--cream);}
.contact .section-head p{color:rgba(250,243,231,.75);}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:50px;}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr;}}
.contact-info{display:grid;gap:22px;}
.info-row{display:flex;gap:16px;align-items:flex-start;}
.info-row .ic{
  flex:none;width:44px;height:44px;border-radius:50%;background:rgba(250,243,231,.1);
  display:flex;align-items:center;justify-content:center;border:1px solid rgba(250,243,231,.2);
}
.info-row .ic svg{width:20px;height:20px;color:var(--terracotta-soft);}
.info-row b{display:block;font-family:var(--font-display);font-size:15px;}
.info-row span,.info-row a{color:rgba(250,243,231,.75);font-size:14.5px;}
.info-row a:hover{color:var(--terracotta-soft);}
.map-card{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);min-height:360px;border:1px solid rgba(250,243,231,.15);}
.map-card iframe{width:100%;height:100%;min-height:360px;border:0;display:block;}

/* ---------- Footer ---------- */
footer{background:#152920;color:rgba(250,243,231,.65);padding:50px 0 30px;font-size:13.5px;}
.footer-grid{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;margin-bottom:26px;}
.footer-logo img{height:38px;filter:brightness(0) invert(1);opacity:.9;}
.footer-links{display:flex;gap:26px;flex-wrap:wrap;}
.footer-links a:hover{color:var(--cream);}
.footer-bottom{border-top:1px solid rgba(250,243,231,.12);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;}

/* ---------- Inner page hero (Speisekarte/Reservierung/Anleitung) ---------- */
.page-hero{
  padding:170px 0 80px;background:var(--forest);color:var(--cream);position:relative;overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 20% 30%,rgba(193,80,31,.22),transparent 45%);
}
.page-hero .container{position:relative;}
.page-hero h1{color:var(--cream);font-size:clamp(2.2rem,5vw,3.4rem);}
.page-hero p{color:rgba(250,243,231,.8);max-width:560px;font-size:1.1rem;}

/* ---------- Menu ---------- */
.menu-tabs{display:flex;gap:14px;margin-bottom:50px;flex-wrap:wrap;}
.menu-tab{
  padding:12px 26px;border-radius:999px;font-family:var(--font-display);font-weight:600;font-size:14.5px;
  background:var(--white);border:1px solid var(--line);cursor:pointer;transition:all .25s ease;color:var(--ink-soft);
}
.menu-tab.active,.menu-tab:hover{background:var(--terracotta);color:#fff;border-color:var(--terracotta);}
.menu-panel{display:none;}
.menu-panel.active{display:block;}
.menu-cat{margin-bottom:54px;}
.menu-cat h3{
  font-size:1.5rem;color:var(--terracotta-dark);border-bottom:2px solid var(--line);padding-bottom:14px;margin-bottom:26px;
  display:flex;align-items:baseline;gap:14px;
}
.menu-cat h3 span{font-size:13px;font-family:var(--font-body);font-weight:400;color:var(--ink-soft);}
.menu-items{display:grid;grid-template-columns:1fr 1fr;gap:10px 40px;}
@media (max-width:750px){.menu-items{grid-template-columns:1fr;}}
.menu-item{
  display:flex;justify-content:space-between;gap:16px;padding:16px 0;border-bottom:1px dashed var(--line);
}
.menu-item .mi-name{font-family:var(--font-display);font-weight:600;color:var(--forest);font-size:15.5px;}
.menu-item .mi-desc{font-size:13.5px;color:var(--ink-soft);margin-top:3px;}
.menu-item .mi-price{
  flex:none;font-family:var(--font-display);font-weight:700;color:var(--terracotta);white-space:nowrap;
}
.menu-note{
  background:var(--cream-2);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:20px 24px;font-size:14px;color:var(--ink-soft);margin-bottom:40px;
}

/* ---------- Reservation form ---------- */
.res-wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;}
@media (max-width:900px){.res-wrap{grid-template-columns:1fr;}}
.res-form{background:var(--white);border-radius:var(--radius);padding:42px;box-shadow:var(--shadow-md);}
.field{margin-bottom:22px;}
.field label{display:block;font-family:var(--font-display);font-weight:600;font-size:14px;color:var(--forest);margin-bottom:8px;}
.field input,.field select,.field textarea{
  width:100%;padding:14px 16px;border-radius:var(--radius-sm);border:1.5px solid var(--line);
  font-family:var(--font-body);font-size:15px;background:var(--cream);color:var(--ink);
  transition:border-color .2s ease,box-shadow .2s ease;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--terracotta);box-shadow:0 0 0 3px rgba(193,80,31,.15);
}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
@media (max-width:520px){.field-row{grid-template-columns:1fr;}}
.res-side{display:grid;gap:24px;align-content:start;}
.res-side-card{background:var(--forest);color:var(--cream);border-radius:var(--radius);padding:30px;}
.res-side-card h3{color:var(--terracotta-soft);font-size:1.1rem;}
.res-side-card p{color:rgba(250,243,231,.8);font-size:14.5px;}
.hours-table{width:100%;border-collapse:collapse;margin-top:10px;}
.hours-table td{padding:8px 0;font-size:14px;border-bottom:1px solid rgba(250,243,231,.12);}
.hours-table td:last-child{text-align:right;font-family:var(--font-display);font-weight:600;}

/* ---------- Anleitung ---------- */
.guide-steps{display:grid;gap:26px;}
.guide-step{
  display:flex;gap:22px;background:var(--white);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm);
  border:1px solid var(--line);
}
.guide-step .num{
  flex:none;width:46px;height:46px;border-radius:50%;background:var(--terracotta);color:#fff;
  display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:18px;
}
.guide-step h3{margin-bottom:6px;}
.guide-step p{color:var(--ink-soft);font-size:15px;margin-bottom:0;}
.guide-highlight{
  background:var(--forest);color:var(--cream);border-radius:var(--radius);padding:40px;margin:50px 0;
  display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:center;
}
@media (max-width:700px){.guide-highlight{grid-template-columns:1fr;text-align:center;}}
.guide-highlight .ic{
  width:64px;height:64px;border-radius:50%;background:rgba(250,243,231,.1);display:flex;align-items:center;justify-content:center;
  margin:0 auto;
}
.guide-highlight .ic svg{width:32px;height:32px;color:var(--terracotta-soft);}
.guide-highlight h3{color:var(--cream);font-size:1.35rem;}
.guide-highlight p{color:rgba(250,243,231,.8);margin:0;}

/* Leaf decoration */
.leaf-deco{position:absolute;opacity:.08;pointer-events:none;}
