/* =====================================================
   SEITENLINIE BAR - Sportbar Website
   Dark Theme + Croatian Accents (CLEAN / FINAL)
   ===================================================== */

/* Prevent iOS auto-darkening while still using our dark theme */
:root { color-scheme: only light !important; }

/* =====================================================
   Variables
   ===================================================== */
:root{
  --color-red:#C41E3A;
  --color-red-light:#E63946;
  --color-red-dark:#9B1B2F;
  --color-blue:#171F52;
  --color-blue-light:#1E3A5F;
  --color-white:#FFFFFF;

  --color-bg-primary:#0A0A0B;
  --color-bg-secondary:#121214;
  --color-bg-tertiary:#1A1A1D;
  --color-bg-card:#16161A;

  --color-text-primary:#FFFFFF;
  --color-text-secondary:#A0A0A5;
  --color-text-muted:#6B6B70;

  --color-gold:#B8860B;

  --gradient-red:linear-gradient(135deg,var(--color-red) 0%,var(--color-red-dark) 100%);
  --gradient-card:linear-gradient(145deg,var(--color-bg-card) 0%,var(--color-bg-primary) 100%);

  --font-heading:'Playfair Display',Georgia,serif;
  --font-body:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;

  --space-xs:.25rem;
  --space-sm:.5rem;
  --space-md:1rem;
  --space-lg:1.5rem;
  --space-xl:2rem;
  --space-2xl:3rem;
  --space-3xl:4rem;
  --space-4xl:6rem;

  --radius-sm:4px;
  --radius-md:8px;
  --radius-lg:12px;
  --radius-full:9999px;

  --shadow-sm:0 2px 4px rgba(0,0,0,.30);
  --shadow-md:0 4px 12px rgba(0,0,0,.40);
  --shadow-lg:0 8px 24px rgba(0,0,0,.50);
  --shadow-glow-red:0 0 30px rgba(196,30,58,.30);

  --transition-fast:150ms ease;
  --transition-base:250ms ease;

  --container-max:1200px;
  --container-padding:1.5rem;
}

/* =====================================================
   Reset
   ===================================================== */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

html{
  font-size:16px;
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}

body{
  font-family:var(--font-body);
  background-color:var(--color-bg-primary);
  color:var(--color-text-primary);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;

  /* super leichter Kroatien-Verlauf (dezent) */
  background-image:linear-gradient(135deg,
    rgba(196,30,58,.05) 0%,
    rgba(255,255,255,.02) 45%,
    rgba(23,31,82,.05) 100%
  );
  background-attachment:fixed;
}

img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; transition:color var(--transition-fast); }
ul,ol{ list-style:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }

.container{
  max-width:var(--container-max);
  margin:0 auto;
  padding:0 var(--container-padding);
}

h1,h2,h3,h4,h5,h6{
  font-family:var(--font-heading);
  font-weight:600;
  line-height:1.2;
}

/* =====================================================
   NAV
   ===================================================== */
.navbar{
  position:fixed;
  top:0;
  left:0; right:0;
  z-index:1000;
  padding:var(--space-sm) 0;
  background:transparent;
  transition:all var(--transition-base);
}

.navbar.scrolled{
  background:rgba(10,10,11,.95);
  backdrop-filter:blur(20px);
  box-shadow:0 2px 20px rgba(0,0,0,.30);
}

.nav-container{
  max-width:var(--container-max);
  margin:0 auto;
  padding:0 var(--container-padding);
  display:flex;
  align-items:center;
  justify-content:center;          /* Desktop Menü zentriert */
}

/* Logo oben links deaktiviert */
.nav-logo{ display:none; }

.nav-menu{
  display:flex;
  align-items:center;
  gap:var(--space-xl);
}

.nav-link{
  font-size:.9rem;
  font-weight:500;
  letter-spacing:.5px;
  color:var(--color-text-secondary);
  position:relative;
  padding:var(--space-sm) 0;
}

.nav-link::after{
  content:'';
  position:absolute;
  left:0; bottom:0;
  width:0;
  height:2px;
  background:var(--gradient-red);
  transition:width var(--transition-base);
}

.nav-link:hover,
.nav-link.active{ color:var(--color-text-primary); }

.nav-link:hover::after,
.nav-link.active::after{ width:100%; }

.nav-toggle{
  display:none;
  flex-direction:column;
  gap:5px;
  padding:var(--space-sm);
}

.nav-toggle span{
  display:block;
  width:25px;
  height:2px;
  background:var(--color-text-primary);
  transition:all var(--transition-base);
}

/* =====================================================
   HERO
   ===================================================== */
.hero{
  position:relative;
  min-height:85vh;
  display:flex;
  align-items:center;
  justify-content:center;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(196,30,58,.15) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 20%, rgba(23,31,82,.20) 0%, transparent 40%),
    var(--color-bg-primary);
  overflow:hidden;
}

.hero::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 0L60 30L30 60L0 30L30 0z' fill='none' stroke='%23ffffff' stroke-width='0.5' opacity='0.03'/%3E%3C/svg%3E");
  opacity:.5;
  pointer-events:none;
}

.hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,
    rgba(10,10,11,.30) 0%,
    rgba(10,10,11,.60) 50%,
    rgba(10,10,11,.90) 100%
  );
  pointer-events:none;
}

.hero-content{
  position:relative;
  z-index:2;
  text-align:center;
  width:100%;
  max-width:900px;
  padding:var(--space-xl) var(--space-2xl) var(--space-2xl);
}

/* Logo full-bleed über die komplette Seitenbreite */
.hero-logo{
  width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  margin-bottom:var(--space-lg);
  padding:0;
}
.hero-logo-img{
  width:100%;
  max-width:none;
  height:auto;
  display:block;
}

.hero-badge{
  display:inline-block;
  padding:var(--space-sm) var(--space-lg);
  background:rgba(196,30,58,.15);
  border:1px solid rgba(196,30,58,.30);
  border-radius:var(--radius-full);
  font-size:.75rem;
  font-weight:600;
  letter-spacing:2px;
  color:var(--color-red-light);
  margin-bottom:var(--space-xl);
}

.hero-title{ margin-bottom:var(--space-lg); }

.title-line{
  display:block;
  font-size:clamp(3rem,10vw,7rem);
  font-weight:700;
  letter-spacing:8px;
  background:linear-gradient(135deg,var(--color-text-primary) 0%,var(--color-gold) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.title-sub{
  display:block;
  font-size:clamp(1rem,3vw,1.5rem);
  font-weight:400;
  letter-spacing:15px;
  color:var(--color-gold);
  margin-top:var(--space-sm);
}

.hero-description{
  font-size:1.1rem;
  color:var(--color-text-secondary);
  max-width:600px;
  margin:0 auto var(--space-2xl);
}

.hero-cta{
  display:flex;
  gap:var(--space-md);
  justify-content:center;
  flex-wrap:wrap;
  margin-bottom:var(--space-3xl);
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  gap:var(--space-sm);
  padding:var(--space-md) var(--space-xl);
  font-size:.9rem;
  font-weight:600;
  letter-spacing:1px;
  border-radius:var(--radius-md);
  transition:all var(--transition-base);
}

.btn-primary{
  background:var(--gradient-red);
  color:var(--color-white);
  box-shadow:var(--shadow-md),var(--shadow-glow-red);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-lg),0 0 40px rgba(196,30,58,.40);
}

.btn-secondary{
  background:transparent;
  color:var(--color-text-primary);
  border:1px solid rgba(255,255,255,.20);
}
.btn-secondary:hover{
  background:rgba(255,255,255,.05);
  border-color:rgba(255,255,255,.30);
}

.hero-features{
  display:flex;
  gap:var(--space-xl);
  justify-content:center;
  flex-wrap:wrap;
}
.feature{
  display:flex;
  align-items:center;
  gap:var(--space-sm);
  font-size:.9rem;
  color:var(--color-text-secondary);
}
.feature-icon{ font-size:1.25rem; }

/* =====================================================
   SECTIONS
   ===================================================== */
section{ padding:var(--space-4xl) 0; }

.section-header{
  text-align:center;
  margin-bottom:var(--space-3xl);
}

.section-header.light .section-title{ color:var(--color-text-primary); }

.section-tag{
  display:inline-block;
  font-size:.75rem;
  font-weight:600;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--color-red-light);
  margin-bottom:var(--space-md);
}

.section-title{
  font-size:clamp(2rem,5vw,3rem);
  margin-bottom:var(--space-md);
}

.section-subtitle{
  font-size:1rem;
  color:var(--color-text-secondary);
  max-width:600px;
  margin:0 auto;
}

/* =====================================================
   ABOUT
   ===================================================== */
.about{ background:var(--color-bg-secondary); }

.about-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--space-4xl);
  align-items:center;
}

.about-lead{
  font-size:1.25rem;
  color:var(--color-text-primary);
  margin-bottom:var(--space-lg);
}

.about-content p{
  color:var(--color-text-secondary);
  margin-bottom:var(--space-md);
}

.about-stats{
  display:flex;
  gap:var(--space-2xl);
  margin-top:var(--space-2xl);
  padding-top:var(--space-2xl);
  border-top:1px solid rgba(255,255,255,.10);
}

.stat{ text-align:center; }
.stat-number{
  display:block;
  font-family:var(--font-heading);
  font-size:2.5rem;
  font-weight:700;
  color:var(--color-red-light);
}
.stat-label{ font-size:.85rem; color:var(--color-text-muted); }

.placeholder-image{
  aspect-ratio:4/3;
  background:var(--gradient-card);
  border-radius:var(--radius-lg);
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(255,255,255,.05);
}
.placeholder-content{ text-align:center; color:var(--color-text-muted); }
.placeholder-icon{ display:block; font-size:3rem; margin-bottom:var(--space-sm); opacity:.5; }
.placeholder-text{ font-size:.85rem; opacity:.5; }

/* =====================================================
   EVENTS
   ===================================================== */
.events{ background:var(--color-bg-primary); }

.events-filter{
  display:flex;
  justify-content:center;
  gap:var(--space-sm);
  margin-bottom:var(--space-2xl);
  flex-wrap:wrap;              /* niemals abschneiden */
}

.filter-btn{
  padding:var(--space-sm) var(--space-lg);
  font-size:.85rem;
  font-weight:500;
  color:var(--color-text-secondary);
  background:var(--color-bg-card);
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--radius-full);
  transition:all var(--transition-base);
  white-space:nowrap;
}

.filter-btn:hover,
.filter-btn.active{
  color:var(--color-text-primary);
  background:rgba(196,30,58,.20);
  border-color:var(--color-red);
}

.events-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(350px,1fr));
  gap:var(--space-lg);
}

.event-card{
  display:flex;
  align-items:flex-start;
  gap:var(--space-lg);
  padding:var(--space-lg);
  background:var(--color-bg-card);
  border:1px solid rgba(255,255,255,.05);
  border-radius:var(--radius-lg);
  transition:all var(--transition-base);
  position:relative;
  overflow:hidden;
}

.event-card::before{
  content:'';
  position:absolute;
  top:0; left:0;
  width:3px; height:100%;
  background:var(--gradient-red);
  opacity:0;
  transition:opacity var(--transition-base);
}

.event-card:hover{
  transform:translateY(-4px);
  border-color:rgba(196,30,58,.30);
  box-shadow:var(--shadow-lg);
}
.event-card:hover::before{ opacity:1; }

.event-card.featured{
  border-color:var(--color-red);
  background:linear-gradient(135deg, rgba(196,30,58,.10) 0%, var(--color-bg-card) 100%);
}
.event-card.featured::before{ opacity:1; }

.event-date{
  flex-shrink:0;
  text-align:center;
  padding:var(--space-md);
  background:var(--color-bg-tertiary);
  border-radius:var(--radius-md);
  min-width:60px;
}

.event-day{
  display:block;
  font-family:var(--font-heading);
  font-size:1.75rem;
  font-weight:700;
  color:var(--color-red-light);
}

.event-month{
  display:block;
  font-size:.75rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:1px;
  color:var(--color-text-muted);
}

.event-content{ flex:1; }

.event-league{
  display:flex;
  align-items:center;
  gap:var(--space-md);
  margin-bottom:var(--space-sm);
  flex-wrap:wrap;
}

.league-badge{
  font-size:.7rem;
  font-weight:600;
  letter-spacing:.5px;
  padding:var(--space-xs) var(--space-sm);
  border-radius:var(--radius-sm);
  text-transform:uppercase;
}

.league-badge.bundesliga{ background:rgba(220,53,69,.20); color:#DC3545; }
.league-badge.champions{ background:rgba(0,86,179,.20); color:#3F9FFF; }
.league-badge.nba{ background:rgba(200,16,46,.20); color:#F97316; }
.league-badge.nfl{ background:rgba(1,51,105,.30); color:#6CA0DC; }
.league-badge.tennis{ background:rgba(207,255,4,.15); color:#9ACD32; }
.league-badge.darts{ background:rgba(255,69,0,.20); color:#FF6347; }
.league-badge.other{ background:rgba(184,134,11,.20); color:var(--color-gold); }

.event-time{ font-size:.8rem; color:var(--color-text-muted); }

.event-title{
  font-size:1.1rem;
  font-weight:600;
  margin-bottom:var(--space-xs);
}

.event-info{ font-size:.85rem; color:var(--color-text-secondary); }

.event-icon{
  position:absolute;
  top:var(--space-md);
  right:var(--space-md);
  font-size:1.5rem;
  opacity:.3;
}

.events-cta{
  text-align:center;
  margin-top:var(--space-3xl);
}

.events-cta p{
  font-size:1.1rem;
  color:var(--color-text-secondary);
  margin-bottom:var(--space-lg);
}

/* =====================================================
   MENU
   ===================================================== */
.menu{
  position:relative;
  background:
    radial-gradient(ellipse at 80% 80%, rgba(196,30,58,.08) 0%, transparent 50%),
    var(--color-bg-secondary);
}

/* Ensure tabs are always clickable (above any overlay) */
.menu-tabs{
  position:relative;
  z-index:50;
  display:flex;
  justify-content:center;
  gap:var(--space-sm);
  margin-bottom:var(--space-2xl);
  flex-wrap:wrap;               /* all visible by default */
}

.menu-tab{
  position:relative;
  z-index:51;
  display:flex;
  align-items:center;
  gap:var(--space-sm);
  padding:var(--space-md) var(--space-lg);
  font-size:.9rem;
  font-weight:500;
  color:var(--color-text-secondary);
  background:var(--color-bg-card);
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--radius-md);
  transition:all var(--transition-base);
  justify-content:center;
  text-align:center;
}

.menu-tab:hover{
  color:var(--color-text-primary);
  border-color:rgba(255,255,255,.20);
}

.menu-tab.active{
  color:var(--color-text-primary);
  background:rgba(196,30,58,.20);
  border-color:var(--color-red);
}

.tab-icon{ font-size:1.25rem; }

.menu-content{ display:none; }
.menu-content.active{ display:block; animation:fadeIn .3s ease; }

@keyframes fadeIn{
  from{ opacity:0; transform:translateY(10px); }
  to{ opacity:1; transform:translateY(0); }
}

.menu-category-header{
  text-align:center;
  margin-bottom:var(--space-2xl);
}

.menu-category-header h3{ font-size:1.5rem; margin-bottom:var(--space-sm); }
.menu-category-header p{ color:var(--color-text-muted); }

.menu-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:var(--space-lg);
}

.menu-item{
  padding:var(--space-lg);
  background:var(--color-bg-card);
  border:1px solid rgba(255,255,255,.05);
  border-radius:var(--radius-lg);
  transition:all var(--transition-base);
}

.menu-item:hover{
  border-color:rgba(255,255,255,.10);
  transform:translateY(-2px);
}

.item-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:var(--space-md);
  margin-bottom:var(--space-sm);
}

.item-name{ font-size:1.1rem; font-weight:600; }
.item-price{
  font-family:var(--font-heading);
  font-size:.95rem;
  color:var(--color-gold);
  white-space:nowrap;
}
.item-description{ font-size:.85rem; color:var(--color-text-secondary); margin-bottom:var(--space-sm); }

/* =====================================================
   GALLERY
   ===================================================== */
.gallery{ background:var(--color-bg-primary); }

.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-template-rows:repeat(2,200px);
  gap:var(--space-md);
}

.gallery-item{
  border-radius:var(--radius-lg);
  overflow:hidden;
  position:relative;
}

.gallery-item .placeholder-image{
  width:100%;
  height:100%;
  aspect-ratio:auto;
  transition:transform var(--transition-base);
}

.gallery-item:hover .placeholder-image{ transform:scale(1.05); }

/* =====================================================
   CONTACT
   ===================================================== */
.contact{
  background:
    radial-gradient(ellipse at 20% 20%, rgba(196,30,58,.10) 0%, transparent 50%),
    var(--color-bg-secondary);
}

.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--space-4xl);
}

.info-cards{
  display:flex;
  flex-direction:column;
  gap:var(--space-lg);
  margin-top:var(--space-xl);
}

.info-card{
  display:flex;
  gap:var(--space-lg);
  padding:var(--space-lg);
  background:var(--color-bg-card);
  border:1px solid rgba(255,255,255,.05);
  border-radius:var(--radius-lg);
  transition:all var(--transition-base);
}

.info-card:hover{
  border-color:rgba(196,30,58,.30);
  transform:translateX(5px);
}

.info-icon{
  font-size:1.5rem;
  width:50px;
  height:50px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--color-bg-tertiary);
  border-radius:var(--radius-md);
  flex-shrink:0;
}

.info-content h4{ font-size:1rem; margin-bottom:var(--space-xs); }
.info-content p{ font-size:.9rem; color:var(--color-text-secondary); }

.map-container{
  height:100%;
  min-height:400px;
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
}
.map-container iframe{ filter:grayscale(80%) invert(92%) contrast(85%); }

/* =====================================================
   FOOTER
   ===================================================== */
.footer{
  background:var(--color-bg-primary);
  border-top:1px solid rgba(255,255,255,.05);
  padding:var(--space-4xl) 0 var(--space-xl);
}

.footer-content{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:var(--space-2xl);
  margin-bottom:var(--space-2xl);
}

.footer-bottom{
  padding-top:var(--space-xl);
  border-top:1px solid rgba(255,255,255,.05);
  text-align:center;
}

.footer-bottom p{ font-size:.85rem; color:var(--color-text-muted); }

/* =====================================================
   RESPONSIVE
   ===================================================== */
@media (max-width:1024px){
  .about-grid{ grid-template-columns:1fr; gap:var(--space-2xl); }
  .contact-grid{ grid-template-columns:1fr; gap:var(--space-2xl); }
  .footer-content{ grid-template-columns:1fr 1fr; gap:var(--space-xl); }
  .gallery-grid{ grid-template-rows:repeat(2,160px); }
}

@media (max-width:768px){
  :root{ --container-padding:1rem; }

  /* Burger rechts (alles andere bleibt zentriert) */
  .nav-container{ justify-content:flex-end; }
  .nav-toggle{ display:flex; z-index:1001; margin-left:auto; }

  .nav-menu{
    position:fixed;
    top:0;
    right:-100%;
    width:80%;
    max-width:320px;
    height:100vh;
    background:var(--color-bg-secondary);
    flex-direction:column;
    justify-content:center;
    align-items:center;
    gap:var(--space-xl);
    transition:right var(--transition-base);
    box-shadow:-10px 0 30px rgba(0,0,0,.50);
  }
  .nav-menu.active{ right:0; }

  .nav-toggle.active span:nth-child(1){ transform:rotate(45deg) translate(5px,5px); }
  .nav-toggle.active span:nth-child(2){ opacity:0; }
  .nav-toggle.active span:nth-child(3){ transform:rotate(-45deg) translate(7px,-6px); }

  /* Mobile: alles zentral */
  .section-header,.section-title,.section-subtitle,.hero-description,.about-content,.about-content p{ text-align:center; }

  .hero{ min-height:78vh; }
  .hero-content{ padding:var(--space-lg) var(--space-md) var(--space-xl); max-width:680px; margin:0 auto; }
  .hero-logo{ padding:0 10px; }
  .hero-cta{ flex-direction:column-reverse; align-items:center; gap:var(--space-sm); margin-bottom:var(--space-xl); }
  .btn{ width:100%; max-width:280px; justify-content:center; }
  .hero-features{ flex-direction:column; gap:var(--space-sm); }

  /* Events: keine abgeschnittenen Inhalte */
  .events-grid{ grid-template-columns:1fr; }
  .event-card{ flex-direction:column; align-items:center; text-align:center; }
  .event-date{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    min-width:auto;
    margin-bottom:10px;
  }
  .event-league{ justify-content:center; }
  .event-icon{ position:static; margin-top:10px; opacity:.35; }

  /* Filter Buttons: kompakter + wrap */
  .events-filter{ gap:8px; }
  .filter-btn{ padding:6px 10px; font-size:.8rem; line-height:1.1; }

  /* Menu Tabs: wrap (immer alle sichtbar) */
  .menu-tabs{ gap:8px; }
  .menu-tab{ padding:10px 12px; font-size:.85rem; min-width:140px; }

  .menu-grid{ grid-template-columns:1fr; }
  .menu-item{ text-align:center; }
  .item-header{ flex-direction:column; align-items:center; text-align:center; }
  .item-price{ margin-top:4px; }

  /* Gallery */
  .gallery-grid{
    grid-template-columns:repeat(2,1fr);
    grid-template-rows:repeat(4,140px);
  }

  /* About stats */
  .about-stats{ flex-direction:column; gap:var(--space-lg); }

  /* Footer */
  .footer-content{ grid-template-columns:1fr; text-align:center; }
}

@media (max-width:480px){
  .title-line{ letter-spacing:4px; }
  .section-title{ font-size:1.75rem; }

  .filter-btn{ padding:6px 9px; font-size:.75rem; }
  .menu-tab{ min-width:0; padding:10px 10px; font-size:.82rem; }

  /* Mobile menu full width on tiny devices */
  .nav-menu{ width:100%; max-width:none; }
}

/* Notch safe areas */
@supports (padding: max(0px)){
  .navbar{
    padding-top:max(var(--space-sm), env(safe-area-inset-top));
    padding-left:max(var(--container-padding), env(safe-area-inset-left));
    padding-right:max(var(--container-padding), env(safe-area-inset-right));
  }
  .footer{ padding-bottom:max(var(--space-xl), env(safe-area-inset-bottom)); }
  .nav-menu{
    padding-top:env(safe-area-inset-top);
    padding-bottom:env(safe-area-inset-bottom);
  }
}

/* Instagram Link Styling - Croatian Flag Colors */
.instagram-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:var(--space-md);
  padding:var(--space-lg) var(--space-2xl);
  font-size:1.1rem;
  font-weight:600;
  letter-spacing:0.5px;
  color:#000000;
  background:linear-gradient(135deg, #C41E3A 0%, #FFFFFF 50%, #171F52 100%);
  border-radius:var(--radius-lg);
  transition:all var(--transition-base);
  box-shadow:var(--shadow-lg);
}

.instagram-link:hover{
  transform:translateY(-3px) scale(1.02);
  box-shadow:0 12px 32px rgba(196,30,58,.50);
}

.instagram-link svg{
  flex-shrink:0;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,0.2));
}

/* Touch targets */
@media (hover:none) and (pointer:coarse){
  .nav-link{ padding:var(--space-md) var(--space-sm); }
  .filter-btn,.menu-tab{ min-height:44px; }
  .btn{ min-height:48px; }

  .event-card:hover{ transform:none; }
  .menu-item:hover{ transform:none; }
  .info-card:hover{ transform:none; }
}

/* Print */
@media print{
  .navbar,.events-filter,.menu-tabs,.footer{ display:none; }
  body{ background:#fff; color:#000; }
  section{ padding:1rem 0; break-inside:avoid; }
}


/* ===============================
   FIX: Mobile Klicks (Burger + Menu Tabs)
   =============================== */

/* Overlays dürfen keine Touchs blocken */
.hero::before,
.hero-overlay{
  pointer-events: none;
}

/* Navbar / Burger immer über allem */
.navbar{
  z-index: 5000;
}

.nav-toggle{
  position: relative;      /* wichtig: sonst wirkt z-index nicht */
  z-index: 6000;
  pointer-events: auto;
}

/* Mobile Slide-Menu über Content */
.nav-menu{
  z-index: 5500;
}

/* Getränkekarte Tabs immer klickbar */
.menu,
.menu-tabs,
.menu-tab{
  position: relative;
  z-index: 10;
  pointer-events: auto;
}

/* iOS Tap-Optimierung */
.menu-tab,
.nav-toggle,
.filter-btn,
.btn{
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}
