/* =====================================================================
   fleisch.restaurant — Design System
   Editorial · Smoky · Ember
   ===================================================================== */
:root{
  --bg:#14100E; --bg-2:#1C1714; --bg-3:#261E18;
  --paper:#F4EBDD; --muted:#A8917C; --faint:#6E5D50;
  --ember:#D9542B; --ember-2:#B8431F; --brass:#C8A45A;
  --line:rgba(244,235,221,.12); --line-2:rgba(244,235,221,.06);
  --serif:"Fraunces",Georgia,serif;
  --sans:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
  --wrap:1200px; --pad:clamp(1.2rem,5vw,3rem);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--paper);font-family:var(--sans);
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
em{font-style:italic;color:var(--ember)}

.wrap{max-width:var(--wrap);margin:0 auto;padding-inline:var(--pad)}
.narrow{max-width:760px}
.section{padding-block:clamp(3.5rem,8vw,7rem)}
.section-dark{background:var(--bg-2);border-block:1px solid var(--line-2)}

.kicker{font-family:var(--mono);font-size:.72rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--ember);margin-bottom:1rem}
.section-title{font-family:var(--serif);font-weight:600;line-height:1.04;
  font-size:clamp(2rem,5vw,3.4rem);letter-spacing:-.02em;margin-bottom:2.5rem}
.page-title{font-family:var(--serif);font-weight:600;line-height:1.02;
  font-size:clamp(2.4rem,6.5vw,5rem);letter-spacing:-.025em}
.lede{font-size:1.15rem;color:var(--muted);max-width:60ch;margin-top:1.2rem}
.lede a{color:var(--ember)}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--mono);
  font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;
  padding:.95rem 1.6rem;border-radius:2px;transition:.25s;border:1px solid transparent}
.btn-ember{background:var(--ember);color:#fff}
.btn-ember:hover{background:var(--ember-2);transform:translateY(-2px)}
.btn-ghost{border-color:var(--line);color:var(--paper)}
.btn-ghost:hover{border-color:var(--paper);background:rgba(244,235,221,.05)}
.btn-block{display:flex;justify-content:center;width:100%;margin-top:1rem}

/* ---- Header ---- */
.site-head{position:sticky;top:0;z-index:50;backdrop-filter:blur(12px);
  background:rgba(20,16,14,.7);border-bottom:1px solid var(--line-2)}
.head-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:700}
.brand-mark{display:grid;place-items:center;width:34px;height:34px;border-radius:3px;
  background:var(--ember);color:#fff;font-family:var(--serif);font-weight:900;font-size:1.2rem}
.brand-name{font-family:var(--serif);font-size:1.25rem;letter-spacing:-.01em}
.dot{color:var(--ember)}
.nav{display:flex;align-items:center;gap:2rem}
.nav a{font-size:.92rem;color:var(--muted);transition:.2s}
.nav a:hover{color:var(--paper)}
.nav-cta{font-family:var(--mono);font-size:.74rem!important;letter-spacing:.08em;
  text-transform:uppercase;padding:.6rem 1rem;border:1px solid var(--line);border-radius:2px;color:var(--paper)!important}
.nav-cta:hover{border-color:var(--ember)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--paper);transition:.3s}

/* ---- Hero ---- */
.hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;
  padding-bottom:clamp(3rem,8vw,6rem);overflow:hidden}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-veil{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(20,16,14,.55) 0%,rgba(20,16,14,.35) 40%,rgba(20,16,14,.95) 100%)}
.hero-inner{position:relative;z-index:2}
.hero-title{font-family:var(--serif);font-weight:600;line-height:.98;
  font-size:clamp(2.8rem,9vw,7rem);letter-spacing:-.03em;margin:.5rem 0 1.3rem;text-wrap:balance}
.hero-lede{font-size:clamp(1.05rem,2vw,1.35rem);color:var(--paper);max-width:46ch;opacity:.92}
.hero-actions{display:flex;gap:1rem;margin-top:2.2rem;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);z-index:2;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--muted);animation:bob 2.4s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ---- Stats bar ---- */
.bar-stats{padding-block:2.2rem;background:var(--bg-2);border-bottom:1px solid var(--line-2)}
.stats-row{display:flex;gap:clamp(2rem,8vw,6rem);flex-wrap:wrap}
.stat{display:flex;flex-direction:column}
.stat-num{font-family:var(--serif);font-size:clamp(2rem,5vw,3rem);font-weight:600;color:var(--brass);line-height:1}
.stat-label{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:.4rem}

/* ---- City grid ---- */
.city-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.2rem}
.city-card{position:relative;display:flex;align-items:flex-end;min-height:240px;
  border-radius:4px;overflow:hidden;border:1px solid var(--line-2);isolation:isolate}
.city-card-img{position:absolute;inset:0;z-index:-2;background-size:cover;background-position:center;
  transition:transform .6s ease;filter:saturate(.9)}
.city-card::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(20,16,14,.1),rgba(20,16,14,.9))}
.city-card:hover .city-card-img{transform:scale(1.06)}
.city-card-body{padding:1.4rem 1.5rem;display:flex;flex-direction:column}
.city-name{font-family:var(--serif);font-size:1.7rem;font-weight:600;line-height:1}
.city-meta{font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;color:var(--muted);margin-top:.4rem;text-transform:uppercase}
.city-arrow{position:absolute;top:1.3rem;right:1.4rem;font-size:1.3rem;color:var(--ember);
  opacity:0;transform:translateX(-6px);transition:.3s}
.city-card:hover .city-arrow{opacity:1;transform:translateX(0)}

/* ---- Value section ---- */
.value-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:2.5rem}
.value-no{font-family:var(--mono);color:var(--ember);font-size:.8rem;letter-spacing:.2em}
.value h3{font-family:var(--serif);font-size:1.5rem;font-weight:600;margin:.8rem 0 .6rem}
.value p{color:var(--muted)}

/* ---- City hub ---- */
.city-hero{padding-block:clamp(3rem,8vw,6rem) clamp(1.5rem,4vw,3rem);
  background:radial-gradient(ellipse at top left,rgba(217,84,43,.12),transparent 60%)}
.crumbs{font-family:var(--mono);font-size:.74rem;letter-spacing:.08em;color:var(--muted);
  margin-bottom:1.6rem;text-transform:uppercase}
.crumbs a:hover{color:var(--ember)}
.crumbs span{margin-inline:.5rem;color:var(--faint)}
.city-map,.side-map{width:100%;border-radius:4px;border:1px solid var(--line);margin-bottom:2.5rem;background:var(--bg-2)}
.city-map{height:380px}
.side-map{height:220px;margin-bottom:0}

.resto-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.4rem}
.resto-card{display:flex;flex-direction:column;background:var(--bg-2);border:1px solid var(--line-2);
  border-radius:4px;overflow:hidden;transition:.3s}
.resto-card:hover{border-color:var(--line);transform:translateY(-4px)}
.resto-img{position:relative;aspect-ratio:16/10;background-size:cover;background-position:center}
.badge{position:absolute;top:.8rem;left:.8rem;font-family:var(--mono);font-size:.66rem;
  letter-spacing:.1em;text-transform:uppercase;background:var(--ember);color:#fff;padding:.3rem .6rem;border-radius:2px}
.resto-body{padding:1.2rem 1.3rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.resto-name{font-family:var(--serif);font-size:1.35rem;font-weight:600;line-height:1.1}
.resto-desc{color:var(--muted);font-size:.95rem;flex:1}
.resto-meta{display:flex;gap:1rem;align-items:center;font-family:var(--mono);font-size:.78rem;margin-top:.3rem}
.m-rating{color:var(--brass)}
.m-price{color:var(--muted)}

/* ---- Detail ---- */
.detail-hero{min-height:50vh;display:flex;align-items:flex-end;background-size:cover;background-position:center;
  padding-block:clamp(2rem,6vw,4rem)}
.detail-badges{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1.2rem}
.b{font-family:var(--mono);font-size:.78rem;letter-spacing:.06em;padding:.4rem .8rem;
  border:1px solid var(--line);border-radius:2px;background:rgba(20,16,14,.5)}
.b-rating{color:var(--brass);border-color:rgba(200,164,90,.4)}
.b-city{color:var(--ember)}
.detail-body{display:grid;grid-template-columns:1fr 340px;gap:3rem;padding-block:clamp(2.5rem,6vw,4.5rem);align-items:start}
.tldr{background:var(--bg-2);border-left:3px solid var(--ember);padding:1.1rem 1.4rem;
  border-radius:2px;color:var(--paper);margin-bottom:2rem}
.tldr strong{color:var(--ember)}
.prose{color:#E7DBC9;font-size:1.08rem}
.prose p{margin-bottom:1.1rem}
.prose h2,.prose h3{font-family:var(--serif);font-weight:600;margin:2rem 0 .8rem}
.facts{display:grid;gap:1px;background:var(--line-2);border:1px solid var(--line-2);border-radius:4px;margin:2.5rem 0;overflow:hidden}
.fact{display:grid;grid-template-columns:160px 1fr;gap:1rem;background:var(--bg-2);padding:1rem 1.3rem}
.fact-k{font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.fact-v{color:var(--paper)}
.faq{margin-top:3rem}
.faq-item{border-bottom:1px solid var(--line-2);padding:1rem 0}
.faq-item summary{font-family:var(--serif);font-size:1.15rem;cursor:pointer;list-style:none;
  display:flex;justify-content:space-between;align-items:center}
.faq-item summary::after{content:"+";color:var(--ember);font-size:1.4rem}
.faq-item[open] summary::after{content:"–"}
.faq-item p{color:var(--muted);margin-top:.7rem}

.detail-side{display:flex;flex-direction:column;gap:1.4rem;position:sticky;top:96px}
.card-info{background:var(--bg-2);border:1px solid var(--line-2);border-radius:4px;padding:1.4rem 1.5rem}
.card-info h3{font-family:var(--serif);font-size:1.2rem;font-weight:600;margin-bottom:.9rem}
.card-info p{margin-bottom:.4rem}
.card-info a{color:var(--ember)}
.addr{color:var(--muted)}
.hours{list-style:none;font-family:var(--mono);font-size:.82rem;color:var(--muted);line-height:1.9}

/* ---- Legal ---- */
.legal .prose{color:var(--muted)}
.legal .prose h3{color:var(--paper)}
.legal .prose a{color:var(--ember)}

/* ---- Footer ---- */
.site-foot{background:var(--bg-2);border-top:1px solid var(--line-2);padding-block:4rem 2rem;margin-top:4rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:3rem}
.foot-tag{color:var(--muted);margin-top:.6rem;max-width:36ch}
.foot-cols{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.foot-cols h4{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ember);margin-bottom:1rem}
.foot-cols a{display:block;color:var(--muted);padding:.25rem 0;transition:.2s}
.foot-cols a:hover{color:var(--paper)}
.foot-bottom{display:flex;justify-content:space-between;margin-top:3rem;padding-top:1.5rem;
  border-top:1px solid var(--line-2);font-family:var(--mono);font-size:.74rem;color:var(--faint);flex-wrap:wrap;gap:.5rem}
.foot-bottom a{color:var(--muted)}

/* ---- Reveal ---- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---- Responsive ---- */
@media(max-width:860px){
  .detail-body{grid-template-columns:1fr}
  .detail-side{position:static}
  .fact{grid-template-columns:1fr}
}
@media(max-width:720px){
  .nav{position:fixed;inset:72px 0 auto 0;flex-direction:column;gap:0;background:var(--bg-2);
    border-bottom:1px solid var(--line);padding:1rem var(--pad);transform:translateY(-130%);transition:.35s;z-index:40}
  .nav.open{transform:none}
  .nav a{padding:.9rem 0;width:100%;border-bottom:1px solid var(--line-2)}
  .burger{display:flex}
  .foot-grid{grid-template-columns:1fr}
  .foot-cols{grid-template-columns:1fr 1fr}
}

/* ---- Affiliate-Blöcke ---- */
.aff{margin:2.5rem 0;padding:1.6rem;background:var(--bg-2);border:1px solid var(--line-2);border-radius:4px}
.aff h3{font-family:var(--serif);font-size:1.3rem;font-weight:600;margin-bottom:1.1rem}
.aff-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.8rem}
.aff-card{display:flex;flex-direction:column;gap:.25rem;padding:1rem 1.1rem;background:var(--bg-3);
  border:1px solid var(--line-2);border-radius:3px;transition:.25s}
.aff-card:hover{border-color:var(--ember);transform:translateY(-3px)}
.aff-partner{font-family:var(--serif);font-size:1.05rem;font-weight:600}
.aff-label{color:var(--muted);font-size:.85rem}
.aff-go{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;color:var(--ember);margin-top:.4rem}
.aff-note{font-size:.78rem;color:var(--faint);margin-top:1rem}

/* ---- Custom Map-Pins ---- */
.fr-pin{transition:transform .2s ease}
.fr-pin svg{filter:drop-shadow(0 3px 5px rgba(0,0,0,.55)) drop-shadow(0 0 7px rgba(217,84,43,.45))}
.fr-pin:hover{transform:scale(1.18)}
.leaflet-popup-content-wrapper{background:var(--bg-3);color:var(--paper);border:1px solid var(--line);border-radius:4px}
.leaflet-popup-content a{color:var(--ember);font-family:var(--sans);font-weight:600}
.leaflet-popup-tip{background:var(--bg-3)}
