/* ==========================================================================
   Hamburg Events – eigene Styles (he.css)
   Lädt als letztes Stylesheet und überschreibt die geerbten syltevent-/Tailwind-Regeln.
   Enthält: Design-Tokens, Reset, Akzentfarbe (Gold), Buttons, Cards, Hero,
   mobiles Menü, Bottom-Navigation, Kontakt-Layout, Detail-Eckdaten, Responsiveness.
   ========================================================================== */

/* ---------- Design-Tokens ---------- */
:root{
  --gold:#e0b354; --gold-light:#ecc879; --gold-dark:#bd9038; --ink:#1a1407;
  --bg-1:#1a202c;  --bg-2:#141820;     --bg-3:#0e1116;      --line:#2b3340;
  --text:#cfd3d8;  --text-dim:#8b94a3;
  --radius:.6rem;  --radius-pill:999px;
  --header-h:6rem; --bottomnav-h:4.25rem;
  /* Spacing-Skala */
  --space-1:.25rem; --space-2:.5rem; --space-3:.75rem; --space-4:1rem;
  --space-5:1.5rem; --space-6:2rem;   --space-7:3rem;   --space-8:5rem;
}

/* ---------- Reset: kaputte globale body-Regeln aus geerbtem CSS überschreiben ---------- */
html{overflow-x:hidden;overflow-y:auto;font-size:16px;scroll-behavior:smooth}
body{overflow:visible !important;overflow-x:hidden;margin:0 !important;padding:0 !important;
     font-size:16px;word-break:normal;color:var(--text);background:var(--bg-3);
     font-family:'Inter','Helvetica Neue',Arial,sans-serif;line-height:1.5;flex:none}
*{box-sizing:border-box}
img{max-width:100%}

/* ---------- Akzentfarbe vereinheitlichen (Gold statt geerbtem Grau #888) ---------- */
.text-primary{color:var(--gold)}
.bg-primary{background-color:var(--gold)}
.bg-primary-light,.hover\:bg-primary-light:hover,.hover\:bg-primary:hover{background-color:var(--gold-light)}
.hover\:text-primary:hover{color:var(--gold)}
.hover\:text-primary-dark:hover{color:var(--gold-dark)}
.border-primary{border-color:var(--gold)}

/* ---------- Logo ---------- */
.he-logo{font-family:'Fjalla One',sans-serif;text-transform:uppercase;letter-spacing:.03em;
  line-height:1;color:#fff;white-space:nowrap;text-decoration:none}
.he-logo b{color:var(--gold);font-weight:400}

/* ---------- Buttons (ein einheitlicher Stil für alle CTAs) ---------- */
.he-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);
  font-family:'Fjalla One',sans-serif;text-transform:uppercase;letter-spacing:.02em;
  font-size:1rem;line-height:1;padding:.85rem 1.75rem;border-radius:var(--radius-pill);
  background:var(--gold);color:var(--ink);border:2px solid var(--gold);cursor:pointer;
  text-decoration:none;transition:background .2s,color .2s,transform .2s,box-shadow .2s;
  -webkit-appearance:none;appearance:none}
.he-btn:hover{background:var(--gold-light);border-color:var(--gold-light);
  transform:translateY(-1px);box-shadow:0 10px 22px -10px rgba(224,179,84,.7)}
.he-btn:focus-visible{outline:3px solid var(--gold-light);outline-offset:2px}
.he-btn--outline{background:transparent;color:var(--gold)}
.he-btn--outline:hover{background:var(--gold);color:var(--ink)}
.he-btn--lg{font-size:1.125rem;padding:1rem 2.25rem}
.he-btn--block{display:flex;width:100%}

/* ---------- Formularfelder ---------- */
.he-field{width:100%;min-height:48px;padding:.75rem 1rem;border-radius:var(--radius);
  background:var(--bg-2);color:#fff;border:1px solid var(--line);font-size:1rem;font-family:inherit}
.he-field::placeholder{color:var(--text-dim)}
.he-field:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(224,179,84,.25)}
textarea.he-field{min-height:140px;resize:vertical}

/* ---------- Vertikales Rhythmus-/Spacing-System ---------- */
.he-section{padding-block:var(--space-8)}
.he-section--tight{padding-block:var(--space-7)}
.he-stack>*+*{margin-top:var(--space-5)}
.he-heading{font-family:'Fjalla One',sans-serif;text-transform:uppercase;color:var(--gold);
  font-size:clamp(1.5rem,3vw,2.5rem);line-height:1.1;margin:0 0 var(--space-5)}

/* ---------- Kacheln / Listen-Karten (syltevent-Stil, ohne data-v-Scope) ---------- */
.image-wrapper{padding-top:60%;position:relative;overflow:hidden}
.image-wrapper img{position:absolute;top:50%;left:0;width:100%;height:auto;min-height:100%;
  object-fit:cover;transform:translateY(-50%);transition:transform .45s ease,opacity .45s ease}
.hover-box{overflow:hidden}
.hover-box:hover{background-color:var(--bg-3)}
.hover-box:hover img{opacity:.82;transform:translateY(-50%) scale(1.06)}
.hover-box:hover h3{color:#fff}
/* einheitliches Innen-Padding aller Cards */
.he-card-body{padding:var(--space-4)}

.he-frame img{box-shadow:0 18px 40px -18px rgba(0,0,0,.7);border-radius:var(--radius)}

/* ---------- Hero ---------- */
.he-hero-block{background-size:cover;background-position:center;min-height:60vh}
.he-hero-block.is-small{min-height:42vh}
.he-hero-overlay{position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(14,17,22,.93) 0%,rgba(14,17,22,.72) 45%,rgba(14,17,22,.35) 100%)}
.he-hero-content{position:relative;width:100%;max-width:72rem;margin:0 auto;
  padding:var(--space-8) var(--space-4)}
.he-hero-kicker{color:var(--gold);font-family:'Fjalla One',sans-serif;text-transform:uppercase;
  letter-spacing:.18em;font-size:.95rem;display:block;margin-bottom:var(--space-3)}
.he-hero-title{font-family:'Fjalla One',sans-serif;text-transform:uppercase;color:#fff;
  font-size:clamp(2.25rem,6vw,4rem);line-height:1.02;margin:0 0 var(--space-4);max-width:18ch}
.he-hero-sub{color:#e2e6ea;font-size:clamp(1.05rem,2.2vw,1.5rem);max-width:42ch;
  margin:0 0 var(--space-6)}

/* Detail-Hero-Bild */
.he-hero img{width:100%;height:100%;object-fit:cover;display:block;min-height:300px}

/* ---------- Beschreibungstext + Eckdaten ---------- */
.he-content p{margin:0 0 var(--space-4);line-height:1.65;color:var(--text)}
.he-content ul{list-style:disc;margin:0 0 var(--space-4) 1.3rem;color:var(--text);line-height:1.6}
.he-content ol{list-style:decimal;margin:0 0 var(--space-4) 1.3rem;color:var(--text);line-height:1.6}
.he-content li{margin:.2rem 0}
.he-content strong{color:#fff}
.he-content a{color:var(--gold)}
.he-content h3,.he-content h4{color:var(--gold);font-family:'Fjalla One',sans-serif;
  margin:var(--space-5) 0 var(--space-2)}
/* Ort-Angabe auf Detailseiten (keine Überschrift mehr) */
.he-place{display:inline-flex;align-items:center;gap:var(--space-2);color:#e2e6ea;
  font-family:'Fjalla One',sans-serif;text-transform:uppercase;font-size:1.15rem;letter-spacing:.04em;margin:0}
.he-place .he-ico{color:var(--gold);width:1.2em;height:1.2em}
/* Eckdaten-Definitionsliste */
.he-facts{display:grid;grid-template-columns:max-content 1fr;gap:var(--space-2) var(--space-5);
  margin:var(--space-5) 0 0;padding:var(--space-5);background:var(--bg-3);border-radius:var(--radius);
  border-left:3px solid var(--gold)}
.he-facts dt{color:var(--gold);font-family:'Fjalla One',sans-serif;text-transform:uppercase;
  font-size:.9rem;letter-spacing:.03em}
.he-facts dd{margin:0;color:var(--text)}

/* ---------- Event-Checkliste (Zahl mit klarem Abstand zum Text) ---------- */
.he-checklist{list-style:none;margin:0;padding:0}
.he-checklist li{display:flex;align-items:flex-start;gap:var(--space-5);
  padding:var(--space-3) 0;border-bottom:1px solid rgba(255,255,255,.07)}
.he-checklist li:last-child{border-bottom:0}
.he-checklist .num{flex:none;width:2.25rem;color:var(--gold);font-family:'Fjalla One',sans-serif;
  font-size:1.35rem;line-height:1.3}
.he-checklist .txt{padding-top:.2rem}

/* ---------- Cookie-Consent-Banner ---------- */
.he-cookie{position:fixed;left:0;right:0;bottom:0;z-index:60;background:var(--bg-2);
  border-top:1px solid var(--line);padding:var(--space-4);box-shadow:0 -8px 24px rgba(0,0,0,.45);
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:var(--space-4)}
.he-cookie[hidden]{display:none}
.he-cookie__text{margin:0;font-size:.9rem;color:var(--text);max-width:62ch;flex:1 1 320px}
.he-cookie__text a{color:var(--gold)}
.he-cookie__actions{display:flex;gap:var(--space-3);flex:none}
.he-cookie__actions .he-btn{padding:.7rem 1.4rem;font-size:.95rem}
@media (max-width:767px){
  .he-cookie{bottom:calc(var(--bottomnav-h) + env(safe-area-inset-bottom))}
  .he-cookie__actions{flex:1 1 100%;justify-content:stretch}
  .he-cookie__actions .he-btn{flex:1}
}

/* ---------- "Noch Fragen?"-Callout (Detailseiten) ---------- */
.he-callout{display:flex;align-items:center;gap:var(--space-4);background:var(--bg-3);
  border-radius:var(--radius);padding:var(--space-5);margin-top:var(--space-5);
  border-left:3px solid var(--gold)}
.he-callout .he-ico{width:2.5rem;height:2.5rem;color:var(--gold);flex:none}
.he-callout p{margin:.1rem 0}
.he-callout .he-callout-title{font-family:'Fjalla One',sans-serif;text-transform:uppercase;
  color:#fff;font-size:1.1rem}
.he-callout .he-callout-text{font-size:.9rem;color:var(--text-dim)}
.he-callout a{color:#fff;text-decoration:none}
.he-callout a:hover{color:var(--gold)}

/* ---------- Anfrage-Modal (Popup mit Formular) ---------- */
.he-modal{position:fixed;inset:0;z-index:70;display:flex;align-items:center;justify-content:center;
  padding:var(--space-4)}
.he-modal[hidden]{display:none}
.he-modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.72)}
.he-modal__dialog{position:relative;width:100%;max-width:34rem;max-height:90vh;overflow-y:auto;
  background:var(--bg-2);border-radius:var(--radius);padding:var(--space-6);
  border-top:3px solid var(--gold);box-shadow:0 30px 60px -20px rgba(0,0,0,.85);
  animation:he-modal-in .25s ease}
@keyframes he-modal-in{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.he-modal__close{position:absolute;top:.6rem;right:.6rem;background:none;border:0;color:#fff;
  cursor:pointer;padding:.4rem;line-height:0}
.he-modal__close .he-ico{width:1.5rem;height:1.5rem}
.he-modal h2{font-family:'Fjalla One',sans-serif;text-transform:uppercase;color:var(--gold);
  font-size:1.4rem;margin:0 0 var(--space-2)}
.he-modal .he-modal-intro{font-size:.95rem;color:var(--text);margin:0 0 var(--space-5)}

/* ---------- Inline-SVG-Icons (Ersatz für fehlende fontello-Schrift) ---------- */
.he-ico{width:1em;height:1em;display:inline-block;vertical-align:-0.125em;fill:currentColor;flex:none}

/* ======================================================================
   HEADER + MOBILES MENÜ
   ====================================================================== */
.he-header{position:fixed;top:0;left:0;width:100%;height:var(--header-h);z-index:50;
  background:var(--bg-2);box-shadow:0 2px 10px rgba(0,0,0,.4)}
.he-header-inner{max-width:72rem;height:100%;margin:0 auto;padding:0 var(--space-4);
  display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}
.he-nav-list{display:flex;align-items:center;gap:var(--space-2);list-style:none;margin:0;padding:0}
.he-nav-link{display:block;font-family:'Fjalla One',sans-serif;text-transform:uppercase;
  color:#fff;text-decoration:none;padding:.5rem .75rem;font-size:1rem;transition:color .2s}
.he-nav-link:hover{color:var(--gold)}
.he-nav-link.is-active{color:var(--gold)}
.he-burger,.he-nav-close{display:none;background:none;border:0;color:#fff;cursor:pointer;padding:.5rem}
.he-burger .he-ico,.he-nav-close .he-ico{width:1.75rem;height:1.75rem}
.he-backdrop{display:none}

@media (max-width:1023px){
  .he-burger{display:inline-flex;align-items:center}
  /* Slide-in-Panel von rechts, voll deckend */
  .he-nav{position:fixed;top:0;right:0;height:100vh;height:100dvh;width:min(82vw,340px);
    background:var(--bg-2);box-shadow:-12px 0 30px rgba(0,0,0,.5);
    transform:translateX(100%);transition:transform .3s ease;z-index:60;
    display:flex;flex-direction:column;padding:var(--space-6) var(--space-5);overflow-y:auto}
  .he-nav.is-open{transform:translateX(0)}
  .he-nav-close{display:inline-flex;align-self:flex-end;margin-bottom:var(--space-4)}
  .he-nav-list{flex-direction:column;align-items:stretch;gap:0;width:100%}
  .he-nav-link{font-size:1.25rem;padding:var(--space-4) var(--space-2);min-height:44px;
    border-bottom:1px solid var(--line)}
  .he-backdrop{display:block;position:fixed;inset:0;background:rgba(0,0,0,.55);
    opacity:0;visibility:hidden;transition:opacity .3s;z-index:55}
  .he-backdrop.is-open{opacity:1;visibility:visible}
}
body.he-noscroll{overflow:hidden !important}

/* ======================================================================
   MOBILE BOTTOM-NAVIGATION (App-Feeling, nur < 768px)
   ====================================================================== */
.he-bottomnav{display:none}
@media (max-width:767px){
  .he-bottomnav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:45;
    background:var(--bg-2);border-top:1px solid var(--line);
    padding-bottom:env(safe-area-inset-bottom);height:calc(var(--bottomnav-h) + env(safe-area-inset-bottom))}
  .he-bn-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:2px;color:var(--text-dim);text-decoration:none;font-size:.68rem;min-height:44px;padding:.35rem 0}
  .he-bn-item .he-ico{width:1.4rem;height:1.4rem}
  .he-bn-item.is-active{color:var(--gold)}
  .he-bn-item:active{background:rgba(255,255,255,.04)}
  /* zentraler hervorgehobener „Anfragen“-Button */
  .he-bn-cta{position:relative}
  .he-bn-cta .he-bn-circle{width:3.25rem;height:3.25rem;border-radius:50%;background:var(--gold);
    color:var(--ink);display:flex;align-items:center;justify-content:center;margin-top:-1.6rem;
    box-shadow:0 6px 16px -4px rgba(224,179,84,.7)}
  .he-bn-cta .he-bn-circle .he-ico{width:1.7rem;height:1.7rem}
  .he-bn-cta{color:var(--gold)}
  /* Platz schaffen, damit die Bottom-Nav nichts verdeckt */
  .he-shell{padding-bottom:calc(var(--bottomnav-h) + env(safe-area-inset-bottom))}
}

/* ======================================================================
   KONTAKTSEITE – zweispaltiges Layout
   ====================================================================== */
.he-contact-grid{display:grid;grid-template-columns:1fr;gap:var(--space-7);align-items:start}
.he-info-box{background:var(--bg-2);border-radius:var(--radius);padding:var(--space-6);
  border-top:3px solid var(--gold)}
.he-info-box h2{font-family:'Fjalla One',sans-serif;text-transform:uppercase;color:var(--gold);
  font-size:1.3rem;margin:0 0 var(--space-4)}
.he-info-row{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);color:var(--text)}
.he-info-row .he-ico{width:1.4rem;height:1.4rem;color:var(--gold)}
.he-info-row a{color:#fff;text-decoration:none}
.he-info-row a:hover{color:var(--gold)}
@media (min-width:768px){
  .he-contact-grid{grid-template-columns:1.3fr .9fr}
}

/* ======================================================================
   RESPONSIVE-Feinschliff
   ====================================================================== */
@media (max-width:767px){
  :root{--space-8:3rem;--space-7:2.25rem}
  .he-hero-block{min-height:54vh}
  .he-hero-content{padding:var(--space-7) var(--space-4)}
}
