/* Öffentliche Website Ottersberger Herbstmarkt - Light-Mode, Blau (#004992) Schrift, Gelb (#ffec00) Flächen */

/* Lokal gehostete Schriften (DSGVO: kein Google-CDN zur Laufzeit) */
@font-face{
  font-family:'Roboto';font-style:normal;font-weight:100 900;font-display:swap;
  src:url(/assets/fonts/roboto-latin.woff2) format('woff2');
}
@font-face{
  /* Display-/Logo-Schrift Belgium (Überschriften). */
  font-family:'Belgium';font-style:normal;font-weight:400;font-display:swap;
  src:url(/assets/fonts/belgium.ttf) format('truetype');
}

html{scroll-behavior:smooth}

/* Sticky Footer: Seite füllt mind. die volle Bildschirmhöhe, der Hauptbereich wächst,
   der Footer sitzt immer am unteren Rand (kein weißer Rand bei wenig Inhalt). */
body.pub{background:#fff;color:var(--ink);display:flex;flex-direction:column;min-height:100vh;
  font-family:'Roboto',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  font-size:1.0625rem;line-height:1.6}
/* font-weight:400 explizit, da Belgium nur diesen einen Schnitt mitbringt - ohne das
   erzwingt der Browser-Standard (h1-h3 = bold) einen synthetischen Fett-Schnitt, der
   besonders bei kleineren Größen (Mobil) sichtbar anders/klobig aussieht. Letter-spacing
   in em statt rem, damit es proportional zur (responsiven) Schriftgröße bleibt statt bei
   kleinen Mobil-Größen unverhältnismäßig breit zu wirken. */
body.pub h1,body.pub h2,body.pub h3{font-family:'Belgium','Georgia',serif;font-weight:400}
body.pub h1{letter-spacing:.07em}
body.pub h2,body.pub h3{letter-spacing:.2rem}
.pub-main{flex:1 0 auto}
.pub-footer{flex-shrink:0;position:relative;z-index:3}
.pub-prose{max-width:none}
.pub-prose h2{margin-top:1.6rem}
.pub-prose ul,.pub-prose ol{padding-left:1.2rem}
.pub-prose li{margin:.3rem 0}
.pub-lead{font-size:1.15rem;color:var(--muted);max-width:760px}

/* Header */
.pub-header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30}
.pub-bar{max-width:1180px;margin:0 auto;display:flex;align-items:center;gap:1.2rem;padding:.7rem 1.2rem}
.pub-brand{display:flex;align-items:center;gap:.6rem;color:var(--brand);font-weight:700}
.pub-brand:hover{text-decoration:none}
.pub-brand img{height:52px;max-width:260px;object-fit:contain}
/* Text-Logo: Belgium, kräftig, Jahr/Datum mit gelbem Akzent */
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-title{font-family:'Belgium','Georgia',serif;color:var(--brand);font-size:1.5rem;font-weight:400;letter-spacing:.01em}
.brand-year{color:var(--brand);background:var(--accent);border-radius:5px;padding:0 .28em;margin-left:.12em}
.brand-date{font-family:'Roboto',sans-serif;color:var(--brand-d);font-weight:700;font-size:.82rem;letter-spacing:.06em;margin-top:.15rem}
/* Internes Text-Logo (Topbar) */
.brand-logo-text{font-family:'Belgium','Georgia',serif;color:var(--brand);font-size:1.2rem;font-weight:400}
.pub-nav{display:flex;align-items:center;gap:.2rem}
.pub-nav a{color:var(--ink);padding:.5rem .8rem;border-radius:8px;font-weight:600;font-size:.95rem}
.pub-nav a:hover{background:var(--accent-soft);text-decoration:none}
.pub-nav a.active{color:var(--brand);background:var(--accent-soft)}
.pub-nav .pub-cta{background:var(--brand);color:#fff;margin-left:.4rem}
.pub-nav .pub-cta:hover{background:var(--brand-d)}
.pub-nav .pub-login{color:var(--brand);font-size:1.15rem;margin-left:.3rem;padding:.45rem .6rem;border:1px solid var(--line);border-radius:8px;display:inline-flex;align-items:center}
.pub-nav .pub-login:hover{background:var(--accent-soft);border-color:var(--brand)}
.pub-nav-toggle{display:none;background:none;border:0;font-size:1.5rem;cursor:pointer;color:var(--brand);margin-left:auto}

/* Linke Seitenleiste (Hauptnavigation) + Inhalts-Shell (wie freimarkt.de) */
.sidebar{position:fixed;top:0;left:0;bottom:0;width:232px;background:var(--brand);color:#fff;
  display:flex;flex-direction:column;z-index:50;overflow-y:auto}
.sidebar-brand{display:block;padding:1.5rem 1.1rem 1.2rem;color:#fff;text-align:center}
.sidebar-brand:hover{text-decoration:none}
.sidebar-brand img{max-width:100%;height:auto}
.sidebar-brand .brand-title{font-family:'Belgium','Georgia',serif;font-size:1.5rem;line-height:1.05;color:#fff;display:block}
.sidebar-brand .brand-year{display:inline-block;background:var(--accent);color:var(--brand);border-radius:5px;padding:0 .26em;margin:.7rem 0 0 .3em}
.sidebar-brand .brand-date{display:block;margin-top:.6rem;color:var(--accent);font-weight:700;font-size:.82rem;letter-spacing:.06em}
.sidebar-nav{position:relative;z-index:1;display:flex;flex-direction:column;flex:1;padding:.5rem 0}
.sidebar-nav a{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.28rem;padding:.62rem .5rem;color:#fff;font-weight:600;font-size:.78rem;border-left:4px solid transparent;letter-spacing:.2rem}
.sidebar-nav a i{color:var(--accent);font-size:1.5rem;line-height:1}
.sidebar-nav a:hover{background:rgba(255,255,255,.10);text-decoration:none}
.sidebar-nav a.active{background:rgba(255,236,0,.15);border-left-color:var(--accent)}
/* Otter als dezentes Wasserzeichen unten links im Menü - liegt HINTER dem Text
   (Impressum/Datenschutz/Sponsoring), nicht als eigener Block davor/danach. */
.sidebar-otter{position:absolute;left:0;bottom:0;z-index:0;width:212px;height:221px;opacity:.22;background-color:var(--accent);
  pointer-events:none;
  -webkit-mask:url(/assets/brand/otter-bildelement.svg) no-repeat left bottom/contain;
          mask:url(/assets/brand/otter-bildelement.svg) no-repeat left bottom/contain}
.sidebar-foot{position:relative;z-index:1;padding:1rem 1.2rem;font-size:.8rem;color:rgba(255,255,255,.85)}
.sidebar-foot a{color:rgba(255,255,255,.95)}
.sidebar-foot a:hover{color:var(--accent)}
.sidebar-credit{display:block;margin-top:.6rem;font-size:.74rem;line-height:1.4;color:rgba(255,255,255,.75)}
.sidebar-credit a{color:rgba(255,255,255,.9)}
.sidebar-social{display:none}

.pub-shell{margin-left:232px;display:flex;flex-direction:column;flex:1;min-height:100vh}
.pub-mobilebar{display:none}

@media(max-width:880px){
  .sidebar{transform:translateX(-100%);transition:transform .25s ease;width:250px;box-shadow:0 0 30px rgba(0,0,0,.3)}
  body.pub-nav-open .sidebar{transform:none}
  .pub-shell{margin-left:0}
  .pub-mobilebar{display:flex;align-items:center;justify-content:space-between;gap:1rem;
    background:var(--brand);color:#fff;padding:.6rem 1rem;position:sticky;top:0;z-index:30}
  .pub-mobilebar .brand-title{font-family:'Belgium','Georgia',serif;color:#fff;font-size:1.05rem}
  .pub-mobilebar .brand-year{background:var(--accent);color:var(--brand);border-radius:4px;padding:0 .22em}
  .pub-mobilebar button{background:none;border:0;color:#fff;font-size:1.5rem;cursor:pointer}

  /* Branding steht schon in der Mobil-Leiste oben - im aufgeklappten Menü selbst nicht nochmal. */
  .sidebar-brand{display:none}

  /* Menüpunkte im aufgeklappten Mobil-Menü: Icon links neben dem Text statt darüber. */
  .sidebar-nav a{flex-direction:row;justify-content:flex-start;text-align:left;gap:.8rem;
    letter-spacing:normal;font-size:.95rem;padding:.75rem 1.2rem}
  .sidebar-nav a i{font-size:1.15rem;width:1.3rem;text-align:center}

  /* Social-Icons unten links im Mobil-Menü. */
  .sidebar-social{display:flex;gap:.6rem;margin-top:.9rem}
  .sidebar-social .social-btn{width:36px;height:36px}
}

/* Sections */
.pub-section{padding:3rem 0;position:relative;z-index:1}
.pub-section-alt{background:#fff}
.pub-section-accent{background:var(--accent);padding-top:4.5rem;padding-bottom:4.5rem}
.pub-inner{max-width:1180px;margin:0 auto;padding:0 1.2rem}
.section-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1.2rem}
.section-head h2{margin:0}

/* Hero */
.hero{background:var(--accent);color:var(--brand);padding:7rem 0 6rem;position:relative;overflow:hidden;z-index:1}
.hero-inner{max-width:1180px;margin:0 auto;padding:0 1.2rem;position:relative;z-index:1}
.hero-eyebrow{color:var(--brand);font-weight:700;letter-spacing:.04em;font-size:.9rem;text-transform:uppercase;margin:0 0 .5rem;opacity:.85}
.hero h1{color:var(--brand);font-size:3rem;line-height:1.08;margin:0 0 .9rem;max-width:16ch}
.hero-lead{font-size:1.15rem;color:var(--brand-d);max-width:640px;margin:0 0 2rem}

/* Foto-Hero (Startseite): transparent über dem seitenweiten Foto-Hintergrund (blauer
   Verlauf über dem Foto) - Text daher weiß statt Blau. */
.hero-photo{background:transparent;min-height:100vh;display:flex;align-items:center;text-align:center;position:relative}
.hero-photo .hero-eyebrow{color:#fff}
.hero-markt.hero-photo .hero-title-display{color:#fff}
.hero-photo .hero-date{background:rgba(255,255,255,.12);border-color:#fff;color:#fff}
.hero-markt.hero-photo .hero-lead{color:#fff;opacity:.94}
.hero-markt.hero-photo .btn-pub-primary{background:var(--accent);color:var(--brand)}
.hero-markt.hero-photo .btn-pub-primary:hover{background:#ffd400}
.hero-markt.hero-photo .btn-pub-ghost{background:transparent;color:#fff;border-color:#fff}
.hero-markt.hero-photo .btn-pub-ghost:hover{background:rgba(255,255,255,.15)}
.hero-photo .hero-inner{max-width:1180px;margin:0 auto;padding:0 1.2rem}
@media(max-width:880px){
  .hero-photo{min-height:82vh}
}

/* Seitenweiter Foto-Hintergrund der Startseite + Weichzeichner beim Scrollen */
body.home{background:transparent}
.home-bg{position:fixed;inset:-24px;z-index:0;background:url(/assets/brand/hero.jpg) center/cover no-repeat;
  will-change:filter}
.home-bg-tint{position:fixed;inset:0;z-index:0;
  background:linear-gradient(180deg, color-mix(in srgb, var(--brand) 72%, transparent) 0%, color-mix(in srgb, var(--brand) 55%, transparent) 45%, color-mix(in srgb, var(--brand) 75%, transparent) 100%)}
body.home .pub-shell{position:relative;z-index:1}
body.home .pub-section-alt{background:transparent}

/* Content nach dem Hero: kein weißer Kasten mehr - liegt direkt auf dem
   fest positionierten Foto-Hintergrund (bleibt auch beim Scrollen sichtbar/blurrt mit).
   Lose Texte (nicht in weißen Karten) werden daher hell eingefärbt, s. u. */
.home-content{background:transparent;position:relative;z-index:1;color:#fff}
.home-content h2{color:#fff}
.home-content .section-head a{color:var(--accent)}
.home-content .section-head a:hover{color:#fff}
.home-content .pub-lead{color:rgba(255,255,255,.92)}
.home-content .news-blocks .nb-h{color:#fff}
.home-content .news-blocks .nb-text{color:rgba(255,255,255,.92)}
.home-content .news-blocks .nb-text a{color:var(--accent)}
.home-content .news-blocks .nb-text a:hover{color:#fff}
.home-content .btn-pub-ghost-d{background:transparent;color:#fff;border-color:#fff}
.home-content .btn-pub-ghost-d:hover{background:rgba(255,255,255,.15)}

/* Social-Buttons (blau), oben rechts - immer sichtbar (fixed), bleiben beim Scrollen stehen. */
.social-top{position:fixed;top:1.2rem;right:1.4rem;display:flex;gap:.6rem;z-index:41}
.social-btn{width:42px;height:42px;border-radius:50%;background:var(--brand);color:#fff;display:inline-flex;align-items:center;justify-content:center;border:2px solid #fff}
.social-btn:hover{background:var(--brand-d);text-decoration:none}

/* Scroll-Pfeil unten mittig im Hero */
.hero-scroll{position:absolute;left:50%;bottom:2rem;transform:translateX(-50%);width:54px;height:54px;border-radius:50%;
  border:2px solid var(--brand);color:var(--brand);display:flex;align-items:center;justify-content:center;font-size:1.4rem;
  background:rgba(255,255,255,.4);z-index:4;animation:hero-bounce 2s ease-in-out infinite}
.hero-scroll:hover{background:#fff;text-decoration:none}
@keyframes hero-bounce{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,9px)}}

/* Countdown unten rechts: von Anfang an im "fertigen" Sticky-Look (fixed + dunkles Glas), damit
   beim Loslegen des Scrollens kein Stil-Sprung entsteht. Hebt sich ab dem gelben CTA/Footer mit an
   (--cd-lift, siehe public.js), damit er nie überlappt. Auf Mobil unten wieder statt "static". */
.hero-countdown{position:fixed;right:1.4rem;bottom:calc(1.4rem + var(--cd-lift, 0px));color:#fff;text-align:right;z-index:40;
  background:color-mix(in srgb, var(--brand) 60%, transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  padding:.6rem .9rem;border-radius:12px}
.cd-label{display:block;font-weight:700;font-size:.8rem;letter-spacing:.04em;margin-bottom:.35rem;color:#fff}
.cd-units{display:flex;gap:.5rem;justify-content:flex-end}
.cd-units span{display:flex;flex-direction:column;align-items:center;min-width:50px;background:color-mix(in srgb, var(--brand) 55%, transparent);border-radius:9px;padding:.4rem .3rem;font-size:.68rem;color:#fff;font-weight:600}
.cd-units b{font-family:'Belgium','Georgia',serif;font-size:1.5rem;line-height:1;color:#fff}

/* Gelber Hero auf allen Unterseiten (Standard ohne Hero-Bild) */
.page-hero{position:relative;background:var(--accent);padding:2.8rem 0 2.5rem;display:flex;align-items:center}
.page-hero-inner{width:100%;max-width:1180px;margin:0 auto;padding:0 1.2rem;text-align:center}
.page-hero h1{color:var(--brand);margin:0;font-size:clamp(2.2rem,4.5vw,3.4rem);text-align:center}
.page-hero-sub{color:var(--brand-d);font-size:1.15rem;margin:.6rem auto 0;max-width:780px;text-align:center}

/* Seiten-Hero MIT Bild statt Gelb: großes Foto (~500px Desktop) + blauer Verlauf, weißer Text. */
.page-hero-photo{background-color:var(--brand);background-size:cover;background-position:center;background-repeat:no-repeat;
  min-height:500px;padding:2.8rem 0}
.page-hero-photo::before{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(180deg, color-mix(in srgb, var(--brand) 72%, transparent) 0%, color-mix(in srgb, var(--brand) 55%, transparent) 45%, color-mix(in srgb, var(--brand) 75%, transparent) 100%)}
.page-hero-photo .page-hero-inner{position:relative;z-index:1}
.page-hero-photo h1{color:#fff}
.page-hero-photo .page-hero-sub{color:rgba(255,255,255,.92)}

@media(max-width:880px){
  /* Hero wird zur Spalte; der (jetzt statische) Countdown steht per order ganz oben,
     noch vor dem Eyebrow-Text ("Letztes Septemberwochenende..."). */
  .hero-photo{flex-direction:column}
  .hero-countdown{order:-1;position:static;text-align:center;margin:0 auto 1.8rem;background:none;backdrop-filter:none;-webkit-backdrop-filter:none;padding:0;border-radius:0}
  .cd-units{justify-content:center}
  .hero-scroll{display:none}
  .page-hero-photo{min-height:320px}
  /* Schwebende Social-Buttons nur auf Desktop - auf Mobil gibt es sie schon im aufgeklappten Menü. */
  .social-top{display:none}
}

/* Markt-Hero: großer Belgium-Schriftzug + Datum */
.hero-markt{text-align:center}
.hero-markt .hero-inner{max-width:900px}
.hero-markt .hero-title-display{font-family:'Belgium','Georgia',serif;color:var(--brand);font-size:clamp(2.8rem,7.5vw,5.6rem);line-height:1.02;margin:.2rem auto .4rem;max-width:none;text-align:center}
.hero-date{display:inline-block;font-family:'Belgium','Georgia',serif;font-size:clamp(1.3rem,3.5vw,2.2rem);color:var(--brand);background:#fff;border:2px solid var(--brand);border-radius:10px;padding:.2rem .8rem;margin:20px 0 1.2rem}
.hero-markt .hero-lead{margin-left:auto;margin-right:auto}
.hero-markt .hero-actions{justify-content:center}
.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap}
.hero-actions .btn-pub{padding:.95rem 1.9rem;font-size:1.08rem}
/* Buttons auf gelbem Hero: Primär dunkel, Sekundär mit Brand-Rahmen (sonst auf Gelb unsichtbar) */
.hero .btn-pub-primary{background:var(--brand);color:#fff}
.hero .btn-pub-primary:hover{background:var(--brand-d)}
.hero .btn-pub-ghost{background:transparent;color:var(--brand);border-color:var(--brand)}
.hero .btn-pub-ghost:hover{background:rgba(46,60,94,.08)}

/* Public buttons */
.btn-pub{display:inline-flex;align-items:center;gap:.4rem;padding:.75rem 1.4rem;border-radius:9px;font-weight:700;font-size:1rem;cursor:pointer;border:2px solid transparent}
.btn-pub:hover{text-decoration:none}
.btn-pub-primary{background:var(--accent);color:var(--brand)}
.btn-pub-primary:hover{background:#ffce3d}
.btn-pub-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-pub-ghost:hover{background:rgba(255,255,255,.12)}
.btn-pub-dark{background:var(--brand);color:#fff}
.btn-pub-dark:hover{background:var(--brand-d)}
.btn-pub-ghost-d{background:transparent;color:var(--brand);border-color:var(--brand)}
.btn-pub-ghost-d:hover{background:var(--accent-soft)}
.event-actions{display:flex;flex-wrap:wrap;gap:.7rem;align-items:center}

/* Bereichs-Kacheln (Startseite) */
.tile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.pub-tile{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-top:4px solid var(--accent);
  border-radius:12px;padding:1.4rem;box-shadow:var(--shadow);color:var(--ink)}
.pub-tile:hover{text-decoration:none;border-color:var(--brand);border-top-color:var(--brand);transform:translateY(-2px);transition:.15s}
.pub-tile-ic{font-size:1.8rem;color:var(--brand);margin-bottom:.5rem}
.pub-tile h3{color:var(--brand);margin:.1rem 0 .4rem}
.pub-tile p{color:var(--muted);margin:0 0 .6rem;flex:1}
.pub-tile-more{font-weight:700;color:var(--brand)}
@media(max-width:900px){.tile-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.tile-grid{grid-template-columns:1fr}}

/* USP */
.usp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.usp{text-align:center;padding:1.4rem 1rem}
.usp-ic{font-size:2rem;display:block;margin-bottom:.5rem}
.usp h3{color:var(--brand);margin:.2rem 0 .4rem}
.usp p{color:var(--muted);margin:0}
.usp-ic i{color:var(--brand)}

/* Intro-Abschnitt (Startseite) */
.intro{max-width:840px;margin:0 auto;text-align:center}
.intro h2{font-size:1.8rem;margin-bottom:.6rem}
.intro-lead{font-size:1.15rem;color:var(--ink);margin:.2rem 0 1rem}
.intro p{color:var(--muted)}
.intro a{font-weight:600}

/* Zahlen-Band */
.stats-band{display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem 3rem;text-align:center}
.stat-item{min-width:130px}
.stat-n{display:block;font-size:2.8rem;font-weight:800;color:var(--brand);line-height:1}
.stat-l{display:block;color:var(--muted);margin-top:.3rem;font-size:.95rem}

/* Impressionen (Foto-Raster) */
.impressions{display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem}
.impression{display:block;overflow:hidden;border-radius:10px;cursor:zoom-in}
.impression img{width:100%;aspect-ratio:3/2;object-fit:cover;display:block;transition:transform .2s}
.impression:hover img{transform:scale(1.05)}

/* Impressionen: Jahres-Klickfilter + Jahres-Ueberschriften */
.year-filter{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.6rem}
.year-filter a{padding:.5rem 1.1rem;border-radius:20px;border:2px solid var(--brand);color:var(--brand);font-weight:700}
.year-filter a:hover{background:var(--accent-soft);text-decoration:none}
.year-filter a.active{background:var(--brand);color:#fff}
.year-heading{color:var(--brand);font-size:1.4rem;margin:2rem 0 1rem}
.year-heading:first-of-type{margin-top:0}
@media(max-width:760px){.impressions{grid-template-columns:repeat(2,1fr)}}

/* FAQ-Abschluss */
.faq-cta{margin-top:1.2rem;color:var(--muted)}

/* Kontaktseite + öffentliche Formulare */
.kontakt-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:2rem;align-items:start}
.contact-list{list-style:none;padding:0;margin:1rem 0}
.contact-list li{display:flex;gap:.7rem;align-items:flex-start;margin:.7rem 0}
.contact-list i{color:var(--brand);width:1.3em;text-align:center;margin-top:.25rem}
.pub-form .card{margin-bottom:1rem}
.pub-form h1 i{color:var(--brand)}
.stand-size{display:inline-flex;align-items:center;gap:.45rem;margin-top:.25rem;font-weight:600}
.stand-size input{margin:0;width:110px}
.pay-choice{display:flex;gap:.8rem;flex-wrap:wrap;margin:.5rem 0}
.radio-card{flex:1 1 220px;border:1px solid var(--line);border-radius:10px;padding:.7rem .9rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;font-weight:600;margin:0}
.radio-card:has(input:checked){border-color:var(--brand);background:var(--accent-soft)}
.radio-card input{width:auto;margin:0}
.radio-card i{color:var(--brand)}
@media(max-width:780px){.kontakt-grid{grid-template-columns:1fr}}

/* Cards grid (events/news teasers) */
.card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
@media(max-width:1000px){.card-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.card-grid{grid-template-columns:1fr}}
.pub-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:1.2rem;box-shadow:var(--shadow);display:flex;flex-direction:column}
.pub-card h3{color:var(--brand);margin:.2rem 0 .4rem}
.pub-card h3 a{color:inherit;text-decoration:none}
.pub-card h3 a:hover{text-decoration:underline}
.pub-card-more{margin-top:auto;align-self:flex-start;padding-top:.7rem;font-weight:600;color:var(--brand)}
.pub-card-more:hover{text-decoration:underline}
.pub-card-date{color:var(--warn);font-weight:700;font-size:.85rem;margin:0 0 .3rem}
.pub-card p{margin:.2rem 0;color:var(--muted)}

/* CTA band */
.cta-band{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
.cta-band h2{color:var(--brand);margin:0 0 .3rem;font-size: 1.5rem;}
.cta-band p{margin:0;color:#43506b}
.cta-inline{background:var(--accent-soft);border:1px solid #f3dca0;border-radius:12px;padding:1.4rem 1.6rem;margin-top:1.6rem}

/* FAQ */
.faq details{border:1px solid var(--line);border-radius:10px;padding:.4rem .9rem;margin-bottom:.6rem;background:#fff}
.faq summary{cursor:pointer;font-weight:600;color:var(--brand);padding:.5rem 0;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:"+ ";color:var(--warn)}
.faq details[open] summary::before{content:"– "}
.faq p{margin:.3rem 0 .7rem;color:var(--muted)}

/* Factbox / note */
.pub-factbox{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin:1.4rem 0;background:#f7f8fb;border:1px solid var(--line);border-radius:12px;padding:1.2rem}
.pub-factbox strong{display:block;color:var(--brand);font-size:.85rem;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.2rem}
.pub-factbox span{color:var(--ink)}
.pub-note{background:var(--accent-soft);border:1px solid #f3dca0;border-radius:10px;padding:1rem 1.2rem;margin:1rem 0}
.pub-board{white-space:pre-line;background:#f7f8fb;border-radius:10px;padding:1.2rem;border:1px solid var(--line)}

/* Vorstand-Karten (2 nebeneinander, großes Foto) */
.board-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.6rem;margin-top:1.4rem}
.board-card{display:flex;gap:1.3rem;background:#fff;border:1px solid var(--line);border-radius:12px;padding:1.4rem;box-shadow:var(--shadow)}
.board-photo{flex:0 0 140px}
.board-photo img{width:140px;height:140px;object-fit:cover;border-radius:50%;border:3px solid var(--accent)}
.board-ph{width:140px;height:140px;border-radius:50%;background:var(--accent-soft);color:var(--brand);display:flex;align-items:center;justify-content:center;font-size:3rem}
.board-info{min-width:0}
.board-name{margin:.1rem 0;font-size:1.2rem;color:var(--brand);font-weight:700}
.board-role{color:var(--warn);font-weight:700;font-size:.95rem;margin:0 0 .6rem}
.board-contact{list-style:none;margin:0;padding:0;font-size:.92rem}
.board-contact li{display:flex;gap:.55rem;align-items:flex-start;margin:.3rem 0}
.board-contact i{color:var(--brand);width:1.1em;text-align:center;margin-top:.2rem}
.board-contact a{word-break:break-word}
@media(max-width:760px){.board-grid{grid-template-columns:1fr}}
@media(max-width:480px){.board-card{flex-direction:column}}

/* Satzung: Sprungmarken-Übersicht + fette §-Überschriften */
.satzung-toc{background:#f7f8fb;border:1px solid var(--line);border-radius:12px;
  padding:1rem 1.2rem;margin:1.4rem 0 2rem;display:grid;grid-template-columns:1fr 1fr;gap:.35rem 1.2rem}
.satzung-toc a{color:var(--brand);font-weight:500;font-size:.92rem;padding:.18rem 0;border-bottom:1px solid transparent}
.satzung-toc a:hover{text-decoration:none;border-bottom-color:var(--accent)}
.satzung-toc a strong{color:var(--brand);margin-right:.15rem}
.satzung-h{font-weight:800;color:var(--brand);font-size:1.18rem;margin:1.8rem 0 .5rem;scroll-margin-top:88px}
.satzung-body p{margin:.5rem 0}
@media(max-width:640px){.satzung-toc{grid-template-columns:1fr}}

/* Events list */
.event-list{display:flex;flex-direction:column;gap:1rem}
.event-row{display:flex;gap:1.2rem;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:12px;padding:1.2rem;box-shadow:var(--shadow);scroll-margin-top:88px}
.event-date{flex:0 0 84px;text-align:center;background:var(--accent-soft);border-radius:10px;padding:.7rem .3rem}
.event-day{display:block;font-size:1.8rem;font-weight:800;color:var(--brand);line-height:1}
.event-mon{display:block;font-size:.78rem;color:var(--warn);font-weight:700;margin-top:.2rem}
.event-body h2{margin:.1rem 0 .3rem}
.event-body p{margin:.3rem 0}
.event-row h2 a{color:var(--brand)}
.event-row-more{display:inline-block;margin-top:.4rem;font-weight:600}
.event-hinweis{margin-top:1.6rem;padding-top:1rem;border-top:1px solid var(--line)}
.event-hinweis i{color:var(--brand);margin-right:.3rem}

/* Mitglieder-Steckbrief */
.member-profile{display:flex;gap:1.4rem;align-items:center;flex-wrap:wrap;margin-bottom:1.4rem}
.member-logo{flex:0 0 auto;width:130px;height:130px;border-radius:14px;border:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden}
.member-logo img{max-width:100%;max-height:100%;object-fit:contain}
.member-logo-ph{font-size:2.6rem;color:var(--brand);opacity:.5}
.member-head h1{margin:0 0 .3rem}
.member-cat{color:var(--brand);font-weight:600;margin:.1rem 0}
.member-cat i{opacity:.7}
.member-about .prewrap{line-height:1.65}

/* Detailseite (Veranstaltung) */
.pub-detail-back{margin:0 0 .6rem}
.event-rsvp{margin-top:1.6rem;background:var(--accent-soft);border:1px solid #f3dca0;border-radius:12px;padding:1.2rem 1.4rem;scroll-margin-top:90px}
.event-rsvp h2{color:var(--brand)}
.event-meta{display:flex;flex-wrap:wrap;gap:.4rem 1.4rem;color:var(--muted);font-weight:600;margin:.2rem 0 1.4rem}
.event-meta i{color:var(--brand)}

/* News list */
.news-list{display:flex;flex-direction:column;gap:2rem}
.news-item{border-bottom:1px solid var(--line);padding-bottom:1.6rem;scroll-margin-top:88px}
.news-item h2{margin:.2rem 0 .6rem}
.news-img{max-width:100%;border-radius:10px;margin:.4rem 0}
/* Baukasten-Blöcke (öffentliche Anzeige) - volle Breite, Text bleibt aber gut lesbar */
.news-blocks{max-width:none}
.news-blocks .nb-h{color:var(--brand);font-size:1.3rem;margin:1.5rem 0 .5rem}
.news-blocks .nb-text{margin:.6rem 0;line-height:1.65}
.news-blocks .nb-text p{margin:.5rem 0}
.news-blocks .nb-text ul,.news-blocks .nb-text ol{padding-left:1.4rem;margin:.5rem 0}
.news-blocks .nb-text li{margin:.25rem 0}
.news-blocks .nb-text a{color:var(--brand);text-decoration:underline}
.news-blocks .nb-text a:hover{color:var(--brand-d)}
.news-blocks .nb-btn{margin:1.1rem 0}
.news-blocks .news-gallery{margin:1.2rem 0 .2rem}
.news-blocks .nb-cap{margin:.1rem 0 1rem;font-style:italic}
/* Galerie: nimmt automatisch die volle Breite ein, bricht aber nach 4 Bildern um */
.news-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:.8rem;margin:1.2rem 0 .2rem}
.news-gal-item{display:block;overflow:hidden;border-radius:8px;cursor:zoom-in}
.news-gal-item img{width:100%;aspect-ratio:3/2;object-fit:cover;border:1px solid var(--line);border-radius:8px;display:block;transition:transform .18s}
.news-gal-item:hover img{transform:scale(1.04)}

/* CTA-Block (Aufruf mit eigenem Text + Button) */
.nb-cta{background:var(--accent-soft);border:1px solid #f3dca0;border-radius:12px;padding:1.4rem 1.5rem;margin:1.4rem 0;
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}
.nb-cta .nb-cta-text{margin:0;font-weight:600;color:var(--brand)}
.nb-cta .btn-pub{flex-shrink:0}

/* Foto-Vorschau (Lightbox) */
.lightbox{display:none;position:fixed;inset:0;z-index:100;background:rgba(15,20,35,.93);
  align-items:center;justify-content:center}
.lightbox.open{display:flex}
body.lb-lock{overflow:hidden}
.lb-fig{margin:0;max-width:94vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:.7rem}
.lb-img{max-width:94vw;max-height:82vh;object-fit:contain;border-radius:8px;box-shadow:0 12px 48px rgba(0,0,0,.55)}
.lb-cap{color:#dfe4ee;font-size:.9rem;font-variant-numeric:tabular-nums}
.lb-close,.lb-prev,.lb-next{position:absolute;background:rgba(255,255,255,.14);color:#fff;border:0;
  width:48px;height:48px;border-radius:50%;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.28)}
.lb-close{top:1rem;right:1rem}
.lb-prev{left:1rem;top:50%;transform:translateY(-50%)}
.lb-next{right:1rem;top:50%;transform:translateY(-50%)}
@media(max-width:600px){.lb-prev{left:.3rem}.lb-next{right:.3rem}.lb-close{top:.5rem;right:.5rem}.lb-img{max-height:74vh}}
/* News-Teaser mit Titelbild (Startseite) */
.pub-card-body{padding:0;display:flex;flex-direction:column;flex:1}
.pub-card.has-img{padding:0;overflow:hidden}
.pub-card.has-img .pub-card-img img{width:100%;height:165px;object-fit:cover;display:block}
/* Platzhalter wenn kein Bild: einfarbig gelbe Fläche */
.pub-card-ph{height:165px;background:var(--accent)}
.pub-card.has-img .pub-card-body{padding:1.2rem}

/* Flash on public */
.pub-flash{max-width:1180px;margin:1.2rem auto 0;padding:1rem 1.2rem;border-radius:10px;border:1px solid;
  font-weight:600;font-size:1.02rem;display:flex;align-items:center;gap:.7rem;box-shadow:var(--shadow);scroll-margin-top:90px}
.pub-flash i{font-size:1.25rem;flex:0 0 auto}

/* Footer */
.pub-footer{background:#1565c0;color:#eaf1fb;}
.pub-footer-inner{max-width:1180px;margin:0 auto;padding:2.4rem 1.2rem 1.4rem;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:1.6rem}
.pub-footer strong{color:#fff}
.pub-footer-nav{display:flex;flex-direction:column;gap:.4rem}
.pub-footer-nav a{color:#dfe4ee}
.pub-footer-nav a:hover{color:var(--accent)}
.pub-footer-base{border-top:1px solid rgba(255,255,255,.15);padding:1rem 1.2rem;font-size:.85rem;color:#aeb6c8;
  max-width:1180px;margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.5rem 1.2rem}
.pub-footer-credit{margin-left:auto}
.pub-footer-credit a{color:#dfe4ee}
.pub-footer-credit a:hover{color:var(--accent)}

/* Ansprechpartner-Kontaktkarten */
.am-contact-list{list-style:none;padding:0;margin:1.8rem 0 0;display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.am-contact-list li{background:#fff;border:1px solid var(--line);border-radius:12px;padding:1rem 1.2rem;box-shadow:var(--shadow)}
.am-contact-list strong{color:var(--brand);display:block}
.am-contact-meta{display:flex;flex-wrap:wrap;gap:.3rem 1.2rem;margin-top:.5rem}
.am-contact-meta a{display:inline-flex;align-items:center;gap:.4rem;color:var(--brand);font-weight:600}
.am-contact-meta i{color:var(--brand)}
@media(max-width:680px){.am-contact-list{grid-template-columns:1fr}}

/* Bummelpässe: Vorverkaufsstellen-Kartenskizze + Liste */
.vvk-map-wrap{margin:1.6rem 0 .4rem;text-align:center}
.vvk-map{width:100%;max-width:700px;height:auto}
.vvk-road{stroke:#c3cfdd;stroke-width:3.5;fill:none}
.vvk-road-main{stroke-width:5}
.vvk-roundabout{fill:#c3cfdd}
.vvk-roundabout-island{fill:#fff}

/* Alle Kartentexte bekommen einen weißen Halo (Stroke hinter der Füllung), damit sie auch bei
   knappem Abstand zu Pins/Straßen oder in anderen Render-Umgebungen sicher lesbar bleiben. */
.vvk-road-t,.vvk-label,.vvk-label-sub{paint-order:stroke fill;stroke:#fff;stroke-width:4px;stroke-linejoin:round}
.vvk-road-t{fill:#8a97a8;font-family:'Roboto',sans-serif}

/* Farbige Pins wie im Lageplan-Screenshot: Grün/Pink/Gelb fuer die Verkaufsstellen, großer Blauer fuer den Marktplatz. */
.vvk-pin{stroke:#fff;stroke-width:3}
.vvk-pin-green{fill:#2e9e4f}
.vvk-pin-pink{fill:#e2007a}
.vvk-pin-yellow{fill:#ffcc00}
.vvk-pin-blue{fill:#1a56db}
.vvk-pin-n{fill:#fff;font-family:'Roboto',sans-serif}
.vvk-pin-n-yellow{fill:var(--brand)}
.vvk-label{fill:var(--brand);font-family:'Roboto',sans-serif}
.vvk-label-sub{fill:var(--muted);font-family:'Roboto',sans-serif}
.vvk-map-cap{color:var(--muted);font-size:.85rem;margin:.4rem 0 0}

.vvk-list{list-style:none;padding:0;margin:1.6rem 0 0;display:flex;flex-direction:column;gap:.8rem}
.vvk-list li{display:flex;align-items:center;gap:1rem;background:#fff;border:1px solid var(--line);border-radius:12px;padding:1rem 1.2rem;box-shadow:var(--shadow)}
.vvk-list-n{flex:0 0 auto;width:32px;height:32px;border-radius:50%;color:#fff;font-weight:700;
  display:flex;align-items:center;justify-content:center}
.vvk-list-n-green{background:#2e9e4f}
.vvk-list-n-pink{background:#e2007a}
.vvk-list-n-yellow{background:#ffcc00;color:var(--brand)}
.vvk-list li > div{flex:1;min-width:0}
.vvk-list strong{display:block;color:var(--brand)}
.vvk-list span{color:var(--muted);font-size:.92rem}
.vvk-list .btn-pub{flex:0 0 auto;white-space:nowrap;padding:.55rem .95rem;font-size:.92rem}
@media(max-width:600px){
  .vvk-list li{flex-wrap:wrap}
  .vvk-list .btn-pub{margin-left:calc(32px + 1rem)}
}

@media (max-width:860px){
  .pub-nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);
    flex-direction:column;align-items:stretch;padding:.5rem;gap:.1rem}
  body.pub-nav-open .pub-nav{display:flex}
  .pub-nav-toggle{display:block}
  .pub-nav .pub-cta{margin:.3rem 0 0}
  .hero h1{font-size:2rem}
  .usp-grid{grid-template-columns:1fr}
  .pub-footer-inner{grid-template-columns:1fr;gap:1.2rem}
  .event-row{flex-direction:column;gap:.6rem}
  .event-date{flex-basis:auto;align-self:flex-start;padding:.5rem 1rem}
}
