:root{
  --terracotta:#c85a3e;
  --terracotta-deep:#9f4028;
  --terracotta-pale:#e8856a;
  --olive-hero:#4d5b43;
  --sun:#e8b96a;
  --sun-dark:#c8963e;
  --wine:#5a2327;
  --wood:#1c0e06;
  --cream:#f9f4ed;
  --cream-2:#fdfaf6;
  --accent:#e8b96a;
  --accent-hover:#c8963e;
  --accent-pressed:#b57f2f;
  --accent-fg:#2c1a0e;
  --accent-2:#c85a3e;
  --accent-2-hover:#9f4028;
  --bg:#f9f4ed;
  --bg-raised:#ffffff;
  --bg-sunk:#fdfaf6;
  --fg:#2c1a0e;
  --fg-2:#5c3a1e;
  --fg-3:#888070;
  --border:rgba(44,26,14,.14);
  --border-strong:rgba(44,26,14,.28);
  --font-heading:'Playfair Display', Georgia, serif;
  --font-body:'Lato', Inter, system-ui, sans-serif;
  --font-script:'Cormorant Garamond', Georgia, serif;
  --header-h:72px;
}

body{
  background:
    radial-gradient(circle at 15% 10%, rgba(200,90,62,.06) 0%, transparent 35%),
    radial-gradient(circle at 85% 20%, rgba(232,217,106,.08) 0%, transparent 40%),
    var(--bg);
}

.site-header{
  padding:14px 0;
  background:linear-gradient(135deg, rgba(44,26,14,.95) 0%, rgba(42,95,127,.9) 100%);
  border-bottom:2px solid rgba(232,217,106,.28);
  box-shadow:0 3px 18px rgba(0,0,0,.14);
}
.site-header.scrolled{
  background:linear-gradient(135deg, rgba(44,26,14,.94) 0%, rgba(42,95,127,.9) 100%);
  box-shadow:0 2px 16px rgba(0,0,0,.16);
  padding:10px 0;
}
.site-header .site-logo,
.site-header .site-nav a,
.site-header .phone-link,
.site-header .site-menu-btn span{color:#fff;}
.site-header .logo-mark{color:var(--sun);}
.site-header .site-nav a::after{background:var(--sun);}

.btn-primary{
  background:linear-gradient(135deg, var(--terracotta) 0%, #ff8c42 100%);
  color:#fff;
  border-color:transparent;
  box-shadow:0 6px 20px -8px rgba(200,90,62,.55);
}
.btn-primary:hover{background:linear-gradient(135deg, var(--terracotta-deep) 0%, #d56e2f 100%);}

.btn-gold{
  background:linear-gradient(135deg, #2a5f7f 0%, #5b9bd5 100%);
  color:#fff;
  box-shadow:0 6px 20px -8px rgba(42,95,127,.6);
}
.btn-gold:hover{background:linear-gradient(135deg, #244f69 0%, #4a84b8 100%);}

.hero{padding:150px 0 108px;}
.hero-veil{
  background:
    linear-gradient(180deg, rgba(28,14,6,0.58) 0%, rgba(28,14,6,0.62) 40%, rgba(28,14,6,0.88) 100%),
    linear-gradient(110deg, rgba(200,90,62,0.36) 0%, rgba(42,95,127,0.28) 60%, rgba(232,217,106,0.18) 100%);
}
.hero-meta{color:var(--sun);}
.hero-line-2{color:#f3c979;}
.hero-pills span{
  border-color:rgba(232,217,106,.4);
  background:rgba(255,255,255,.06);
}

.surface-dark{
  background:linear-gradient(145deg, #2c1a0e 0%, #4d5b43 100%);
  color:#f9f4ed;
  --fg:#f9f4ed;
  --fg-2:#e8ddc9;
  --fg-3:#b9ab94;
  --border:rgba(249,244,237,.16);
  --bg-raised:rgba(255,255,255,.06);
}
.surface-olive{
  background:linear-gradient(145deg, #4d5b43 0%, #2a5f7f 100%);
  color:#fdfaf6;
  --fg:#fdfaf6;
  --fg-2:#ece6d8;
  --fg-3:#cfc5ae;
  --border:rgba(253,250,246,.18);
}

.chip.active,
.menu-tag.tag-sign{background:var(--sun);color:#2c1a0e;}
.menu-price,
.special-price,
.about-stats strong{color:var(--terracotta);}

.res-form{
  background:rgba(255,255,255,.92);
  -webkit-backdrop-filter:blur(6px);
  backdrop-filter:blur(6px);
  border:1px solid rgba(44,26,14,.15);
}

.site-footer{
  background:linear-gradient(135deg, #1c0e06 0%, #2c1a0e 70%, #2a5f7f 100%);
  border-top:2px solid rgba(232,217,106,.2);
}

.res-preview{padding:72px 0;background:linear-gradient(160deg,#f9f4ed 0%,#fdfaf6 100%);border-top:1px solid rgba(44,26,14,.08);border-bottom:1px solid rgba(44,26,14,.08)}
.res-preview .box{max-width:900px;margin:0 auto;background:#fff;border:1px solid rgba(44,26,14,.14);border-radius:12px;padding:24px;box-shadow:0 10px 30px rgba(44,26,14,.08)}
.res-preview h3{font-family:var(--font-heading);font-size:1.6rem;color:#2c1a0e;margin-bottom:8px}
.res-preview p{color:#6f5a49;font-size:.95rem;margin-bottom:14px}
.res-preview .steps{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.res-preview .step{font-size:.78rem;padding:5px 10px;border-radius:999px;background:rgba(232,217,106,.2);color:#5c3a1e;border:1px solid rgba(232,217,106,.4)}
.res-preview .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.res-preview .field{padding:11px 12px;border:1px solid rgba(44,26,14,.18);border-radius:6px;background:#fff;color:#2c1a0e}
.res-preview .cta{margin-top:12px;background:linear-gradient(135deg,#2A5F7F 0%,#5B9BD5 100%);color:#fff;border:none;padding:11px 14px;border-radius:8px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}

.google-reviews{padding:66px 0;background:var(--cream);border-top:1px solid rgba(44,26,14,.08);border-bottom:1px solid rgba(44,26,14,.08)}
.google-reviews .box{max-width:980px;margin:0 auto;background:#fff;border:1px solid rgba(44,26,14,.12);border-radius:12px;padding:22px;box-shadow:0 8px 24px rgba(44,26,14,.06)}
.google-reviews .head{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap;margin-bottom:12px}
.google-reviews .label{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--terracotta);font-family:var(--font-body);margin-bottom:6px}
.google-reviews h3{font-family:var(--font-heading);font-size:1.6rem;color:#2c1a0e}
.google-reviews .score{font-size:.78rem;background:rgba(232,217,106,.22);border:1px solid rgba(232,217,106,.4);color:#5c3a1e;padding:5px 10px;border-radius:20px;font-weight:700}
.google-reviews .grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.google-reviews .card{background:var(--cream);border:1px solid rgba(44,26,14,.1);border-radius:8px;padding:12px}
.google-reviews .stars{color:var(--terracotta);font-size:.9rem;letter-spacing:.08em;margin-bottom:4px}
.google-reviews p{font-size:.88rem;color:#5c3a1e;line-height:1.55;margin-bottom:4px}
.google-reviews small{font-size:.72rem;color:#8a7867}
.google-reviews .cta-wrap{margin-top:14px;display:flex;justify-content:center}
.google-reviews .cta-btn{background:linear-gradient(135deg,#2A5F7F 0%,#5B9BD5 100%);color:#fff;border:none;padding:10px 16px;border-radius:8px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer}

@media (max-width: 960px){
  .site-header{padding:10px 0;}
  .hero{padding:132px 0 90px;}
  .res-preview .grid{grid-template-columns:1fr}
  .google-reviews .grid{grid-template-columns:1fr}
}

/* ── SPEISEKARTE-BEREICH: Intro-Row mit Mittagstisch ── */
.menu-intro-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: start;
  margin-bottom: 40px;
}
.menu-section-head { text-align: left; }
.menu-section-head .section-head { text-align: left; }

/* Mittagstisch-Box */
.mittagstisch-box {
  background: rgba(232,185,106,.08);
  border: 1.5px solid rgba(232,185,106,.35);
  border-radius: 10px;
  padding: 22px 24px;
  min-width: 220px;
  max-width: 260px;
  flex-shrink: 0;
}
.mittagstisch-label {
  font-family: var(--font-label);
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--sun);
  margin-bottom: 6px;
}
.mittagstisch-time {
  font-size: .82rem;
  color: rgba(44,26,14,.65);
  margin-bottom: 14px;
  line-height: 1.4;
}
.mittagstisch-list {
  list-style: none;
  margin: 0 0 10px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.mittagstisch-list li {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 8px;
  font-size: .88rem;
  color: var(--wood);
  padding-bottom: 7px;
  border-bottom: 1px solid rgba(44,26,14,.07);
}
.mittagstisch-list li:last-child { border-bottom: none; }
.mittagstisch-list li strong {
  color: var(--terracotta);
  white-space: nowrap;
  font-size: .84rem;
}
.mittagstisch-note {
  font-size: .75rem;
  color: rgba(44,26,14,.48);
  margin-bottom: 14px;
  font-style: italic;
}
.mittagstisch-cta {
  display: inline-block;
  font-family: var(--font-label);
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--terracotta);
  text-decoration: none;
  border-bottom: 1px solid rgba(200,90,62,.35);
  padding-bottom: 1px;
  transition: color .2s, border-color .2s;
}
.mittagstisch-cta:hover { color: #9f4028; border-color: #9f4028; }

/* Kategorie-Link unter den Gerichten */
.menu-cat-link-row {
  margin-bottom: 16px;
}
.menu-cat-link {
  font-family: var(--font-label);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--sun-dark);
  text-decoration: none;
  border: 1px solid rgba(200,150,62,.3);
  padding: 7px 16px;
  border-radius: 20px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: background .2s, border-color .2s, color .2s;
}
.menu-cat-link:hover {
  background: rgba(200,150,62,.1);
  border-color: var(--sun-dark);
  color: var(--terracotta);
}

.menu-tabs .chip {
  text-decoration: none;
  cursor: pointer;
}

@media (max-width: 860px) {
  .menu-intro-row {
    grid-template-columns: 1fr;
  }
  .mittagstisch-box {
    max-width: 100%;
  }
}
