/* ===== BengelBatz Global Styles ===== */
:root{
  --bg:#182230; --surface:#202C3B; --text:#F1F5F9; --muted:#A9B4C2;
  --a1:#FFD166; --a2:#FF6B9A; --a3:#2EC4B6;
  --border:rgba(255,255,255,.12); --radius:16px;
  --header-h: 72px; /* Header-Höhe als Variable */
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; color:var(--text); background:var(--bg);
  font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  background-image:
    radial-gradient(1200px 800px at 110% -10%, rgba(255,107,154,.10) 0%, transparent 60%),
    radial-gradient(900px 700px at -10% 110%, rgba(46,196,182,.10) 0%, transparent 60%),
    linear-gradient(180deg, #1a2534 0%, #16202d 60%, #141d28 100%);
}
a{color:inherit; text-decoration:none}
.wrap{max-width:1100px; margin:0 auto; padding:0 20px}

/* ===== Header (STICKY) ===== */
header{
  position:sticky; top:0; z-index:50; backdrop-filter:saturate(1.1) blur(8px);
  background:linear-gradient(180deg, rgba(24,34,48,.75), rgba(24,34,48,.45));
  border-bottom:1px solid var(--border);
  height: var(--header-h);
}
.nav{height:100%; display:flex; align-items:center; justify-content:space-between}
.brand{display:flex; gap:12px; align-items:center}
.brand img{height:40px; width:auto; border-radius:10px; box-shadow:0 10px 30px -10px rgba(255,209,102,.35)}
.title{font-family:Outfit, system-ui; font-weight:700; letter-spacing:.2px}

/* Desktop-Menü wird in theme.css gestylt */
.menu{display:flex; gap:10px; align-items:center}


/* ===== Hamburger + Drawer ===== */
.hamburger{
  display:none; /* Standardmäßig aus, wird per Media-Query aktiv */
  flex-direction:column; gap:5px; width:44px; height:44px; padding:10px;
  align-items:center; justify-content:center; cursor:pointer;
  border:1px solid var(--border); border-radius:12px;
  background:linear-gradient(180deg,#243248,#1b2738);
  box-shadow:0 10px 24px -18px rgba(0,0,0,.6);
}
.hamburger span{
  display:block; width:22px; height:2px; background:var(--text); border-radius:2px;
  transition:transform .25s ease, opacity .2s ease;
}
.hamburger.open span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2){ opacity:0; }
.hamburger.open span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

@media (max-width:980px){ 
  .menu{display:none} 
  .hamburger{display:inline-flex;}
}

.mobile-menu{
  position:fixed; inset:0; background:rgba(0,0,0,.45);
  opacity:0; pointer-events:none; transition:opacity .2s ease; z-index:999;
}
.mobile-menu.open{opacity:1; pointer-events:auto}
.mobile-nav{
  position:absolute; top:0; right:0; height:100%; width:min(82vw,360px);
  background:linear-gradient(180deg,#1e2b3e,#172337);
  border-left:1px solid var(--border); box-shadow:-10px 0 40px rgba(0,0,0,.4);
  padding:18px; display:flex; flex-direction:column; gap:10px;
  transform:translateX(100%); transition:transform .25s ease;
}
.mobile-menu.open .mobile-nav{transform:translateX(0)}
.mobile-nav-header{display:flex; justify-content:space-between; align-items:center; margin-bottom:6px}
.mobile-title{font-family:Outfit,system-ui; font-weight:700}
.close-btn{background:none; border:1px solid var(--border); color:var(--text);
  border-radius:10px; padding:.35rem .6rem; cursor:pointer}
.mobile-nav a{
  display:block; padding:.95rem 1rem; border-radius:12px;
  border:1px solid var(--border);
  background:linear-gradient(180deg,#243248,#1b2738);
  color:var(--text)
}
.mobile-nav a.primary{
  background:linear-gradient(135deg, var(--a1), var(--a2));
  color:#0B1016; border-color:transparent;
}

/* ===== Hero ===== */
.hero{display:grid; place-items:center; text-align:center; padding:8vh 20px 4vh}
.hero-logo-wrap{filter:drop-shadow(0 24px 60px rgba(0,0,0,.45))}
.hero-logo{
  width:clamp(220px,36vw,440px); height:auto; border-radius:22px;
  box-shadow:0 0 0 6px rgba(255,255,255,.05) inset,
             0 40px 120px -40px rgba(255,107,154,.45),
             0 30px 80px -30px rgba(255,209,102,.35);
}

/* ===== Bildkacheln ===== */
.impressions{max-width:1100px; margin:0 auto; padding:0 20px}
.imgrid{display:grid; gap:14px; grid-template-columns:repeat(2,1fr)}
@media(min-width:1024px){.imgrid{grid-template-columns:repeat(3,1fr)}}
.img-tile{
  border-radius:22px; overflow:hidden;
  background:linear-gradient(180deg,#25344C,#1E2B3E);
  border:1px solid var(--border);
  box-shadow:0 0 0 6px rgba(255,255,255,.03) inset,
             0 40px 120px -40px rgba(255,107,154,.45),
             0 30px 80px -30px rgba(255,209,102,.35);
  aspect-ratio:16/9; display:grid; place-items:center;
}
.img-link{display:block; width:100%; height:100%}
.img-tile img{
  max-width:100%; max-height:100%;
  width:auto; height:auto; display:block;
  transition:transform .35s ease;
}
.img-tile:hover img{transform:scale(1.03)}

/* ===== Öffnungszeiten ===== */
.hours{max-width:900px; margin:5vh auto 2vh; padding:0 20px}
.hours-card{
  background:linear-gradient(180deg,#23344C,#1B2A3F);
  border:1px solid var(--border); border-radius:14px; padding:24px;
  display:grid; place-items:center; text-align:center
}
.hours-list{display:grid; grid-template-columns:1fr 1fr; gap:8px 18px; margin:0 auto 12px}
@media(max-width:640px){.hours-list{grid-template-columns:1fr}}
.hours-list dt{color:#E7EEF6; font-weight:700}
.hours-list dd{margin:0; color:#B8C3CF}
.menu-bullets{list-style:disc; text-align:left; margin:10px 0 0; padding-left:1.2rem; color:#DDE7F1}
.menu-bullets li{margin:.15rem 0}
.slogan{margin-top:12px; font-weight:700; letter-spacing:.2px;
  background:linear-gradient(135deg, var(--a1), var(--a2));
  -webkit-background-clip:text; background-clip:text; color:transparent}

/* ===== Standort & Kontakt ===== */
.loccontact{max-width:1100px; margin:5vh auto 6vh; padding:0 20px}
.locgrid{display:grid; gap:16px; grid-template-columns:1.2fr .8fr}
@media(max-width:900px){.locgrid{grid-template-columns:1fr}}
.card-like{background:linear-gradient(180deg,#1e2b3e,#172337); border:1px solid var(--border); border-radius:14px; padding:16px}
.mapinner{aspect-ratio:16/9; display:grid; place-items:center}

/* ===== Footer ===== */
.site-footer{border-top:1px solid var(--border); margin-top:30px; padding:28px 20px 60px; color:#A9B6C6}
.footgrid{max-width:1100px; margin:0 auto; display:grid; gap:18px; grid-template-columns:1.2fr 1fr 1fr 1fr}
@media(max-width:1000px){.footgrid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footgrid{grid-template-columns:1fr}}
.footcol h4{font-family:Outfit,system-ui; margin:.2rem 0 .5rem; color:#E7EEF6}
.footlink{color:inherit; text-decoration:underline dotted}
.small{font-size:.95rem}

/* ===== Modal ===== */
.modal{position:fixed; inset:0; background:rgba(0,0,0,.5); display:none; align-items:center; justify-content:center; padding:24px; z-index:1000}
.modal.open{display:flex}
.modal__dialog{width:min(900px,96vw); height:min(80vh,900px);
  background:linear-gradient(180deg,#1e2b3e,#172337);
  border:1px solid var(--border); border-radius:14px; overflow:hidden; position:relative;
  box-shadow:0 30px 80px rgba(0,0,0,.6)}
.modal__header{display:flex; justify-content:space-between; padding:10px 14px; border-bottom:1px solid var(--border); background:rgba(36,50,72,.5)}
.modal__title{font-family:Outfit,system-ui; font-weight:700}
.modal__close{background:none; border:1px solid var(--border); color:var(--text); border-radius:8px; padding:.35rem .6rem; cursor:pointer}
.modal__body{height:100%; display:grid; grid-template-rows:auto 1fr}
.modal__content{width:100%; height:100%; border:0}


/* ===== NEU: Event-Modal (Silvester) ===== */
.event-modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.75); /* Dunklerer Hintergrund für Fokus */
  display: none; /* Standardmäßig versteckt */
  align-items: center;
  justify-content: center;
  padding: 16px;
  z-index: 1001; /* Über dem Legal-Modal, falls das mal offen sein sollte */
  backdrop-filter: blur(5px);
}
.event-modal.open {
  display: flex; /* Wird per JS angeschaltet */
}

/* Der Container für das Bild/Video */
.event-modal__dialog {
  position: relative;
  background: transparent;
  /* Mobil: 90% der Breite */
  width: 90%; 
  max-width: 600px; /* Desktop: Maximale Breite */
  max-height: 90vh; /* Höhe ist begrenzt, damit es auf den Schirm passt */
  border-radius: 12px;
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
}

/* Das Bild/Video selbst (responsiv) */
.event-modal__dialog img,
.event-modal__dialog video { /* <-- Hier wurde "video" hinzugefügt */
  display: block;
  width: 100%;
  height: auto;
  max-height: 90vh; /* Stellt sicher, dass das Element nicht höher als der Viewport ist */
  object-fit: contain; /* Stellt sicher, dass das Seitenverhältnis stimmt */
  border-radius: 12px;
}

/* Der Schließen-Knopf (mobil-freundlich) */
.event-modal__close {
  position: absolute;
  /* Platziert oben rechts, leicht außerhalb/überlappend für gute Sichtbarkeit */
  top: -10px;
  right: -10px;
  
  /* Styling */
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(0,0,0,.8);
  border: 2px solid #FFFFFF;
  color: #FFFFFF;
  
  /* Zentrierung des 'X' */
  font-size: 24px;
  font-weight: 700;
  line-height: 32px; /* Höhe - 2*Border */
  text-align: center;
  padding: 0;
  
  cursor: pointer;
  z-index: 10;
  transition: transform 0.2s ease;
}
.event-modal__close:hover {
  transform: scale(1.1);
}