/* ── ÜBER UNS ────────────────────────────────────────────────── */
.about{background:var(--bg2)}
.about-g{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(2.5rem,6vw,8rem);align-items:center;
}
.about-frame{
  position:relative;aspect-ratio:3/4;
  background:var(--purple);border-radius:3px;
  overflow:hidden;border:1px solid var(--line);
}
.about-frame::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(201,168,76,.1),transparent 55%),
             linear-gradient(315deg,rgba(201,168,76,.08),transparent 55%);
}
.about-frame img{width:100%;height:100%;object-fit:cover;opacity:.7;mix-blend-mode:luminosity}
.frame-ph{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-h);font-size:10rem;font-style:italic;color:rgba(201,168,76,.05);
}

/* Badge */
.about-badge{
  position:absolute;bottom:-1.8rem;right:-1.8rem;
  width:104px;height:104px;border-radius:50%;
  background:var(--gold);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;color:var(--bg);
  box-shadow:0 16px 48px rgba(201,168,76,.4);
  font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;
  font-weight:500;
}
.about-badge strong{display:block;font-family:var(--ff-h);font-size:2.6rem;font-weight:300;line-height:1}

.about-txt p{color:var(--muted);font-size:.93rem;margin-bottom:1.1rem}
.chips{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:1.8rem}
.chip{
  display:inline-block;padding:.3rem .9rem;border-radius:100px;
  font-size:.6rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  border:1px solid rgba(201,168,76,.20);color:var(--green);
  background:rgba(201,168,76,.08);
}
@media(max-width:720px){
  .about-g{grid-template-columns:1fr}
  .about-badge{right:.5rem;bottom:-1rem}
}

/* ── DRINKS ──────────────────────────────────────────────────── */
.drinks{background:var(--bg)}
.drinks-head{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:end;margin-bottom:3.5rem}
@media(max-width:640px){.drinks-head{grid-template-columns:1fr}}

.card-g{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));
  gap:1px;border:1px solid var(--line);border-radius:3px;overflow:hidden;
}
.dc{
  background:var(--bg2);padding:2rem 1.8rem;
  border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  position:relative;overflow:hidden;transition:background .28s;
}
.dc::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(to right,var(--gold),var(--gold-light));
  transform:scaleX(0);transform-origin:left;transition:transform .35s;
}
.dc:hover,.dc.active{background:rgba(65,13,41,.6)}
.dc:hover::before,.dc.active::before{transform:scaleX(1)}
.dc .n{/* Nummer */
  position:absolute;right:1.4rem;top:.8rem;
  font-family:var(--ff-h);font-size:4.5rem;font-weight:300;
  color:rgba(201,168,76,.04);line-height:1;pointer-events:none;
}
.dc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.7rem}
.dc-name{font-family:var(--ff-h);font-size:1.4rem;color:#fff}
.dc-price{font-size:.82rem;font-weight:500;color:var(--green);padding-top:.15rem}
.dc-desc{font-size:.85rem;color:var(--muted);line-height:1.7}
.dc-tag{
  display:inline-block;margin-top:.8rem;
  font-size:.57rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--coral);font-weight:500;
}

/* ── SPEISEKARTE MODAL ───────────────────────────────────────── */
.menu-modal{
  position:fixed;inset:0;z-index:9999;
  background:rgba(10,3,5,.95);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  display:none;align-items:flex-start;justify-content:center;
  overflow-y:auto;
}
.menu-modal.open{display:flex}
.menu-modal-inner{
  width:min(780px,92vw);
  padding:3.5rem 2.5rem 4rem;
  margin:3rem auto;
  position:relative;
}
.menu-close{
  position:fixed;top:1.5rem;right:2rem;
  background:none;border:1px solid var(--line2);
  color:var(--txt);font-size:2rem;
  width:48px;height:48px;border-radius:50%;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .2s,border-color .2s;z-index:10;
}
.menu-close:hover{background:var(--wine);border-color:var(--gold)}
.menu-header{text-align:center;margin-bottom:3rem}
.menu-cat{margin-bottom:2.8rem}
.menu-cat-title{
  font-family:var(--ff-h);font-size:1.5rem;font-weight:400;
  color:var(--gold);margin-bottom:1.2rem;
  padding-bottom:.6rem;border-bottom:1px solid var(--line2);
}
.menu-items{display:flex;flex-direction:column;gap:.15rem}
.mi{padding:.65rem 0}
.mi-top{display:flex;align-items:baseline;gap:.4rem}
.mi-name{
  font-family:var(--ff-h);font-size:1.12rem;color:#fff;
  white-space:nowrap;flex-shrink:0;
}
.mi-dots{
  flex:1;border-bottom:1px dotted var(--muted2);
  margin:0 .3rem;min-width:1.5rem;
  position:relative;top:-.25rem;
}
.mi-price{
  font-size:.85rem;font-weight:500;color:var(--gold-light);
  white-space:nowrap;flex-shrink:0;
}
.mi-desc{font-size:.8rem;color:var(--muted);margin-top:.2rem;line-height:1.5}
.menu-footer-note{
  text-align:center;font-size:.72rem;color:var(--muted);
  margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--line);
}
@media(max-width:600px){
  .menu-modal-inner{padding:2.5rem 1.2rem 3rem}
  .menu-cat-title{font-size:1.25rem}
  .mi-name{font-size:1rem}
  .menu-close{top:1rem;right:1rem;width:40px;height:40px;font-size:1.5rem}
}

/* ── EVENTS ──────────────────────────────────────────────────── */
.events{background:var(--bg2)}
.ev-g{display:grid;grid-template-columns:1fr 1.35fr;gap:clamp(2rem,5vw,7rem);align-items:start}
@media(max-width:820px){.ev-g{grid-template-columns:1fr}}

.ev-item{
  display:grid;grid-template-columns:52px 1fr;gap:1.4rem;
  padding:1.6rem 0;border-bottom:1px solid var(--line);
  transition:padding-left .2s,border-color .2s;cursor:pointer;
}
.ev-item:hover,.ev-item.active{padding-left:.6rem;border-color:var(--coral)}
.ev-d .day{font-family:var(--ff-h);font-size:2.2rem;font-weight:300;color:var(--coral);line-height:1}
.ev-d .mon{font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.ev-name{font-family:var(--ff-h);font-size:1.2rem;color:#fff;margin-bottom:.2rem}
.ev-body{font-size:.83rem;color:var(--muted)}
.ev-pill{
  display:inline-block;margin-top:.45rem;padding:.18rem .65rem;border-radius:100px;
  font-size:.57rem;letter-spacing:.1em;text-transform:uppercase;
  border:1px solid rgba(201,168,76,.22);color:var(--green);background:rgba(201,168,76,.08);
}

/* Featured Card */
.feat{
  background:var(--bg3);border-radius:3px;overflow:hidden;
  border:1px solid rgba(201,168,76,.15);position:sticky;top:80px;
}
.feat-top{
  height:220px;
  position:relative;overflow:hidden;
}
.feat-top img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.feat-top::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 50%,rgba(201,168,76,.15),transparent 65%);
}
.feat-glyph{
  font-family:var(--ff-h);font-size:7rem;font-style:italic;
  color:rgba(255,255,255,.05);position:relative;z-index:1;
}
.feat-body{padding:1.8rem}
.feat-tag{font-size:.58rem;letter-spacing:.26em;text-transform:uppercase;color:var(--coral);margin-bottom:.4rem}
.feat-title{font-family:var(--ff-h);font-size:1.55rem;color:#fff;margin-bottom:.6rem}
.feat-desc{font-size:.85rem;color:var(--muted);margin-bottom:1.4rem}

/* ── GALERIE ─────────────────────────────────────────────────── */
.gallery{background:var(--bg)}
.gal-m{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-template-rows:260px 260px;
  gap:3px;
}
.gc1{grid-column:span 5;grid-row:span 2}
.gc2{grid-column:span 4}
.gc3{grid-column:span 3}
.gc4{grid-column:span 4}
.gc5{grid-column:span 3;grid-row:span 2}
/* Zeile 2: gc2 und gc3 füllen gc5's Platz in Zeile 2 */

.gc{overflow:hidden;border-radius:2px;background:var(--bg3);position:relative}
.gc-in{
  width:100%;height:100%;
  filter:brightness(.65) saturate(.75);
  transition:filter .45s,transform .45s cubic-bezier(.4,0,.2,1);
}
.gc:hover .gc-in{filter:brightness(.85) saturate(1);transform:scale(1.06)}
.gc-in img{width:100%;height:100%;object-fit:cover;display:block}
.gc-ph{
  width:100%;height:100%;
  background:linear-gradient(135deg,var(--bg2),var(--bg3));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-h);font-size:5rem;font-style:italic;
  color:rgba(201,168,76,.08);
}
.gc-ov{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(7,5,15,.75),transparent 50%);
  display:flex;align-items:flex-end;padding:1rem;
  opacity:0;transition:opacity .3s;
}
.gc:hover .gc-ov{opacity:1}
.gc-lbl{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--green)}

@media(max-width:700px){
  .gal-m{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .gc1,.gc2,.gc3,.gc4,.gc5{grid-column:span 1;grid-row:span 1;height:180px}
  .gc1{grid-column:span 2;height:220px}
}

/* ── GALERIE OVERLAY ─────────────────────────────────────────── */
.gal-ov{
  position:fixed;inset:0;z-index:9998;
  background:rgba(10,3,5,.96);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  display:none;overflow-y:auto;
}
.gal-ov.open{display:block}
.gal-ov-inner{
  max-width:1100px;margin:0 auto;
  padding:5rem 2rem 4rem;
}
.gal-ov-head{text-align:center;margin-bottom:2.5rem}
.gal-ov-close{
  position:fixed;top:1.2rem;right:1.5rem;
  background:none;border:1px solid var(--line2);
  color:var(--txt);font-size:2rem;
  width:48px;height:48px;border-radius:50%;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .2s;z-index:2;
}
.gal-ov-close:hover{background:var(--wine)}
.gal-ov-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:6px;
}
.gal-ov-item{
  aspect-ratio:4/3;overflow:hidden;border-radius:3px;
  cursor:pointer;position:relative;background:var(--bg3);
}
.gal-ov-item img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.75);transition:filter .3s,transform .35s;
}
.gal-ov-item:hover img{filter:brightness(1);transform:scale(1.04)}
.gal-ov-item .gal-ov-lbl{
  position:absolute;bottom:0;left:0;right:0;
  padding:.6rem .8rem;
  background:linear-gradient(to top,rgba(5,2,3,.8),transparent);
  font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-light);
}
@media(max-width:480px){
  .gal-ov-inner{padding:4rem 1rem 3rem}
  .gal-ov-grid{grid-template-columns:1fr 1fr;gap:4px}
  .gal-ov-close{top:.8rem;right:.8rem;width:36px;height:36px;font-size:1.3rem}
}

/* ── LIGHTBOX ────────────────────────────────────────────────── */
.gc{cursor:pointer}
.lb{
  position:fixed;inset:0;z-index:10000;
  background:rgba(5,2,3,.96);
  display:none;align-items:center;justify-content:center;
  padding:1rem;
}
.lb.open{display:flex}
.lb img{
  max-width:92vw;max-height:88vh;
  object-fit:contain;border-radius:3px;
  box-shadow:0 20px 80px rgba(0,0,0,.7);
}
.lb-close{
  position:absolute;top:1.2rem;right:1.5rem;
  background:none;border:1px solid var(--line2);
  color:var(--txt);font-size:2rem;
  width:48px;height:48px;border-radius:50%;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .2s;z-index:2;
}
.lb-close:hover{background:var(--wine)}
.lb-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  background:none;border:1px solid var(--line2);
  color:var(--txt);font-size:1.4rem;
  width:44px;height:44px;border-radius:50%;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
.lb-nav:hover{background:var(--wine)}
.lb-prev{left:1rem}
.lb-next{right:1rem}
.lb-cap{
  position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);
  font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold-light);opacity:.7;
}
@media(max-width:480px){
  .lb-close{top:.6rem;right:.6rem;width:36px;height:36px;font-size:1.3rem}
  .lb-nav{width:36px;height:36px;font-size:1.1rem}
  .lb-prev{left:.5rem}
  .lb-next{right:.5rem}
}

/* ── KONTAKT ─────────────────────────────────────────────────── */
.contact{background:var(--bg)}
.ct-g{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,7rem)}
.ct-addr{grid-column:1}
.ct-hours{grid-column:1}
.ct-map{grid-column:2;grid-row:1/3}
@media(max-width:720px){
  .ct-g{grid-template-columns:1fr}
  .ct-addr{order:1}
  .ct-map{order:2;grid-column:1;grid-row:auto}
  .ct-hours{order:3}
}

.ct-lbl{
  font-size:.58rem;font-weight:500;letter-spacing:.24em;text-transform:uppercase;
  color:var(--muted);margin-bottom:.3rem;
}
.ct-val{font-size:.97rem;color:var(--txt);margin-bottom:1.8rem}

/* Öffnungszeiten — dezent, kein grelles Farb-Highlight */
.hours{width:100%;border-collapse:collapse;margin-top:.8rem}
.hours td{
  padding:.6rem 0;font-size:.88rem;
  border-bottom:1px solid var(--line);
  color:var(--muted);          /* alles gleich gedämpft */
}
.hours td:last-child{text-align:right}
.hours tr:last-child td{border-bottom:none}
/* Nur Wochenende minimal heller */
.hours tr.we td{color:rgba(221,212,240,.55)}

.map-box{
  aspect-ratio:4/3;background:var(--bg3);border-radius:3px;
  border:1px solid var(--line);
  overflow:hidden;position:relative;
}
.map-box iframe{
  width:100%;height:100%;border:0;
  filter:grayscale(.4) brightness(.7) contrast(1.1) sepia(.15);
  transition:filter .3s;
}
.map-box:hover iframe{filter:grayscale(0) brightness(.85) contrast(1)}

/* ── MOBILE GLOBAL ──────────────────────────────────────────── */
@media(max-width:480px){
  body{font-size:14px}

  /* Hero */
  .hero{min-height:540px}
  .hero-head{height:clamp(160px,32svh,280px)}
  .hero-location{
    font-size:.52rem;letter-spacing:.18em;gap:.5rem;
    padding:0 1rem;text-align:center;flex-wrap:wrap;justify-content:center;
  }
  .hero-location::before,.hero-location::after{width:18px}
  .hero-arrow{bottom:1.2rem}

  /* Sections */
  .s{padding:clamp(2.8rem,6vw,4rem) 1rem}
  .h2{font-size:clamp(1.7rem,6vw,2.4rem)}
  .lead{font-size:.88rem}

  /* Drinks cards */
  .card-g{grid-template-columns:1fr}
  .dc{padding:1.5rem 1.2rem}
  .dc-name{font-size:1.2rem}
  .dc .n{font-size:3.5rem}

  /* Events */
  .feat{position:static}
  .feat-top{height:160px}
  .feat-title{font-size:1.3rem}
  .feat-body{padding:1.3rem}

  /* Gallery */
  .gal-m{grid-template-rows:auto}
  .gc1,.gc2,.gc3,.gc4,.gc5{height:160px}

  /* Reservation */
  .res-form{padding:1.5rem 1rem}

  /* Kontakt */
  .hours td{font-size:.8rem;padding:.5rem 0}
  .map-box{aspect-ratio:16/10}

  /* Footer */
  .ft-g{gap:2rem}
  .ft-desc{font-size:.8rem}

  /* Speisekarte Modal */
  .menu-modal-inner{padding:2rem .8rem 2.5rem;margin:1rem auto}
  .menu-header{margin-bottom:2rem}
  .menu-header .h2{font-size:clamp(1.6rem,6vw,2rem)}
  .menu-cat{margin-bottom:2rem}
  .menu-cat-title{font-size:1.15rem}
  .mi-name{font-size:.95rem;white-space:normal}
  .mi-dots{display:none}
  .mi-top{flex-wrap:wrap;gap:.2rem}
  .mi-price{font-size:.8rem}
  .mi-desc{font-size:.75rem}
  .menu-close{top:.8rem;right:.8rem;width:36px;height:36px;font-size:1.3rem}
}

/* ── MEDIUM SCREENS ─────────────────────────────────────────── */
@media(max-width:820px) and (min-width:481px){
  .feat{position:static}
  .card-g{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
  .menu-modal-inner{padding:2.5rem 1.5rem 3rem}
  .mi-name{font-size:1rem}
}

/* Touch-friendly tap targets */
@media(hover:none){
  .btn{padding:.9rem 2.2rem;font-size:.68rem}
  .nm a{padding:.6rem 1rem}
  .ev-item{padding:1.8rem 0}
  .dc{padding:2rem 1.5rem}
}
