/* Öffentliche VdSO-Website - Light-Mode, Blau (#2e3c5e) Schrift, Gelb (#ffd962) Flächen */
/* 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}
.pub-main{flex:1 0 auto}
.pub-footer{flex-shrink:0;position:relative;z-index:3}
/* Otter-Bildelement: gespiegelt, fixiert unten rechts - faehrt beim Scrollen mit (Parallax).
   Per JS (public.js) wird er am Footer hochgeschoben, sodass seine Unterkante an der
   Oberkante des Footers endet (komplett sichtbar, nicht dahinter), und ueber dem gelben
   CTA-Abschnitt sanft ausgeblendet. --otter-lift wird vom Skript gesetzt. */
.pub-otter{position:fixed;right:0;bottom:0;width:min(34vw,380px);aspect-ratio:48/50;
  background:url(/assets/brand/otter-bildelement.svg) center bottom/contain no-repeat;
  transform:translateY(calc(var(--otter-lift, 0px) * -1)) scaleX(-1);
  opacity:.1;pointer-events:none;z-index:2;transition:opacity .25s ease}
.pub-otter.otter-hidden{opacity:0}
.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.12rem;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}
.pub-logo{background:var(--brand);color:#fff;border-radius:9px;padding:.35rem .6rem;font-size:1.15rem;letter-spacing:.5px;font-weight:800}
.pub-brand-text{font-size:1.02rem;line-height:1.15}
.pub-brand-text small{font-weight:500;color:var(--muted)}
.pub-nav{display:flex;align-items:center;gap:.2rem;margin-left:auto}
.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}

/* Sections */
.pub-section{padding:3rem 0;position:relative;z-index:1}
.pub-section-alt{background:#fff}
.pub-section-accent{background:url(/assets/brand/wave-lg.svg) repeat, 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:url(/assets/brand/wave-lg.svg) repeat, 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.25rem;color:#43506b;max-width:640px;margin:0 0 2rem}
.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}

/* 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.2rem;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)}
@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-size:1.08rem;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: VdSO-Logo auf gelbem Hintergrund + dezentes blaues Wellenmuster (5%) */
.pub-card-ph{height:165px;
  background:url(/assets/brand/vdso-logo.svg) center/62% no-repeat,
             url(/assets/brand/wave.svg) repeat,
             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:var(--brand);color:#dfe4ee;}
.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)}

@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}
}
