:root {
  --bv-primary: #3f2d1a;
  --bv-accent: #d99a16;
  --bv-honey: #fff4cf;
  --bv-bg: #fffaf0;
  --bv-text: #2d2117;
  --bv-muted: #6f6254;
  --bv-card: #ffffff;
  --bv-border: rgba(63, 45, 26, .14);
  --bv-shadow: 0 18px 55px rgba(63, 45, 26, .12);
  --bv-radius: 22px;
  --bv-container: 1180px;
  --bv-space: clamp(1rem, 2vw, 2rem);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: linear-gradient(180deg, var(--bv-bg), #fff 46%);
  color: var(--bv-text);
  font: 16px/1.65 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
a { color: var(--bv-primary); text-decoration-thickness: .08em; text-underline-offset: .18em; }
a:hover { color: var(--bv-accent); }
img { max-width: 100%; height: auto; }
.container { width: min(100% - 2rem, var(--bv-container)); margin-inline: auto; }
.skip-link {
  position: absolute;
  left: -999px;
  top: 1rem;
  z-index: 999;
  padding: .75rem 1rem;
  background: #fff;
  border: 2px solid var(--bv-accent);
}
.skip-link:focus { left: 1rem; }

.topbar {
  background: var(--bv-primary);
  color: #fff;
  font-size: .92rem;
}
.topbar a { color: #fff4cf; }
.topbar .container { padding-block: .45rem; }

.site-header {
  background: rgba(255, 250, 240, .92);
  border-bottom: 1px solid var(--bv-border);
  backdrop-filter: blur(12px);
  z-index: 20;
}
.has-sticky-header .site-header { position: sticky; top: 0; }
.header-inner {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .65rem;
  padding-block: 1.2rem .75rem;
}
.brand {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .75rem;
  color: var(--bv-primary);
  text-decoration: none;
  min-width: 0;
  width: 100%;
}
.brand-logo {
  display: block;
  width: min(100%, clamp(520px, 82vw, 1180px));
  max-height: 320px;
  object-fit: contain;
  object-position: center center;
}
.brand-mark {
  display: grid;
  place-items: center;
  width: 2.7rem;
  height: 2.7rem;
  border-radius: 50%;
  background: var(--bv-accent);
  color: #fff;
  font-size: 1.25rem;
  box-shadow: 0 8px 18px rgba(217, 154, 22, .32);
}
.brand strong { display: block; font-size: clamp(1.1rem, 2vw, 1.45rem); line-height: 1.1; }
.brand small { display: block; color: var(--bv-muted); font-size: .85rem; }
.nav-toggle {
  display: none;
  border: 1px solid var(--bv-border);
  border-radius: 999px;
  background: #fff;
  padding: .55rem .85rem;
}
.main-navigation {
  width: 100%;
  display: flex;
  justify-content: center;
  border-top: 1px solid var(--bv-border);
  padding-top: .65rem;
}
.main-navigation ul,
.main-navigation .mod-menu {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .25rem;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
}
.main-navigation a,
.main-navigation span.separator {
  display: block;
  padding: .55rem .8rem;
  border-radius: 999px;
  color: var(--bv-primary);
  text-decoration: none;
  font-weight: 650;
}
.main-navigation a:hover,
.main-navigation .active > a,
.main-navigation .current > a {
  background: var(--bv-honey);
  color: var(--bv-primary);
}

.hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 12% 18%, rgba(217,154,22,.24), transparent 28rem),
    linear-gradient(135deg, var(--bv-honey), #fff 64%);
  border-bottom: 1px solid var(--bv-border);
}
.hero::after {
  content: "";
  position: absolute;
  inset: auto -4rem -8rem auto;
  width: 22rem;
  height: 22rem;
  background: repeating-linear-gradient(60deg, rgba(217,154,22,.16) 0 18px, transparent 18px 36px);
  clip-path: polygon(25% 6%,75% 6%,100% 50%,75% 94%,25% 94%,0 50%);
}
.hero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1rem, 3vw, 2rem);
  align-items: center;
  padding-block: clamp(1.5rem, 4vw, 3rem);
}
.eyebrow {
  margin: 0 0 .7rem;
  color: var(--bv-accent);
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-size: .78rem;
}
h1, h2, h3 { color: var(--bv-primary); line-height: 1.15; }
h1 { margin: 0 0 .65rem; font-size: clamp(1.65rem, 3.2vw, 2.75rem); letter-spacing: -.025em; }
h2 { font-size: clamp(1.45rem, 3vw, 2rem); }
.hero-copy { width: 100%; max-width: none; text-align: center; }
.hero-copy > p:not(.eyebrow) { max-width: none; font-size: clamp(1rem, 1.6vw, 1.15rem); color: var(--bv-muted); }
.hero-card { width: 100%; max-width: none; }
.hero-card,
.moduletable,
.card {
  background: var(--bv-card);
  border: 1px solid var(--bv-border);
  border-radius: var(--bv-radius);
  box-shadow: var(--bv-shadow);
}
.hero-card { padding: clamp(1.25rem, 3vw, 2rem); }
.button,
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .45rem;
  border: 0;
  border-radius: 999px;
  padding: .78rem 1.15rem;
  font-weight: 800;
  text-decoration: none;
  cursor: pointer;
}
.button-primary,
.btn-primary {
  background: var(--bv-primary);
  color: #fff;
}
.button-primary:hover,
.btn-primary:hover { background: var(--bv-accent); color: #1b1208; }

.main-content { padding-block: clamp(2rem, 5vw, 4rem); }
.module-zone { margin-bottom: var(--bv-space); }
.layout-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--bv-space);
}
.has-left .layout-grid { grid-template-columns: 280px minmax(0, 1fr); }
.has-right .layout-grid { grid-template-columns: minmax(0, 1fr) 280px; }
.has-left.has-right .layout-grid { grid-template-columns: 250px minmax(0, 1fr) 250px; }
.has-left.has-right .sidebar-left { grid-column: 1; }
.has-left.has-right .content-area { grid-column: 2; }
.has-left.has-right .sidebar-right { grid-column: 3; }
.content-area,
.sidebar .moduletable,
.module-zone .moduletable {
  background: #fff;
  border: 1px solid var(--bv-border);
  border-radius: var(--bv-radius);
  padding: clamp(1rem, 2vw, 1.6rem);
}
.content-area { min-width: 0; box-shadow: 0 10px 36px rgba(63,45,26,.07); }
.sidebar { min-width: 0; }
.sidebar .moduletable + .moduletable { margin-top: 1rem; }
.honey-section .moduletable,
.events-section .moduletable { background: linear-gradient(180deg, #fff, var(--bv-honey)); }

.com-content-article__body > *:first-child { margin-top: 0; }
.items-leading,
.blog-items { display: grid; gap: 1rem; }
.blog-item,
.item-page,
.newsflash-item {
  border-bottom: 1px solid var(--bv-border);
  padding-bottom: 1rem;
}
.readmore a { font-weight: 800; }
.breadcrumb { background: transparent; padding: 0; }
.pagination { display: flex; gap: .4rem; flex-wrap: wrap; }
.pagination a,
.pagination span { padding: .35rem .65rem; border-radius: .6rem; border: 1px solid var(--bv-border); }
input, textarea, select {
  width: 100%;
  max-width: 100%;
  border: 1px solid var(--bv-border);
  border-radius: .9rem;
  padding: .7rem .85rem;
  font: inherit;
}
label { font-weight: 700; }

.site-footer {
  background: var(--bv-primary);
  color: #fff;
  margin-top: 2rem;
}
.site-footer a { color: var(--bv-honey); }
.footer-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(1.5rem, 4vw, 4rem);
  align-items: start;
  padding-block: 2rem;
}
.footer-two-columns .footer-column-right {
  text-align: right;
}
.footer-module {
  margin-top: 1rem;
}
.site-footer p { color: rgba(255,255,255,.8); }
.error-page { padding-block: 12vh; }

/* Responsive media and Joomla output helpers */
figure, iframe, video, embed, object { max-width: 100%; }
.table-responsive, .content-area table { max-width: 100%; }
.content-area table { display: block; overflow-x: auto; border-collapse: collapse; }
.content-area td, .content-area th { padding: .55rem .7rem; border-bottom: 1px solid var(--bv-border); }

@media (max-width: 1100px) {
  .has-left.has-right .layout-grid { grid-template-columns: minmax(0, 1fr); }
  .has-left.has-right .sidebar-left,
  .has-left.has-right .content-area,
  .has-left.has-right .sidebar-right { grid-column: auto; }
}

@media (max-width: 640px) {
  .container { width: min(100% - 1rem, var(--bv-container)); }
  .header-inner { padding-block: .7rem .6rem; gap: .45rem; }
  .brand-logo { width: min(96vw, 620px); max-height: 180px; }
  .nav-toggle { padding: .48rem .68rem; font-size: .9rem; }
  .hero-grid { padding-block: 1.35rem; }
  h1 { font-size: clamp(1.45rem, 8vw, 2.15rem); }
  .content-area,
  .sidebar .moduletable,
  .module-zone .moduletable { border-radius: 16px; padding: 1rem; }
}

@media (max-width: 900px) {
  .nav-toggle { display: inline-flex; }
  .main-navigation {
    display: none;
    position: static;
    width: 100%;
    background: #fff;
    border: 1px solid var(--bv-border);
    border-radius: var(--bv-radius);
    box-shadow: var(--bv-shadow);
    padding: 1rem;
  }
  .main-navigation.is-open { display: block; }
  .main-navigation ul,
  .main-navigation .mod-menu { display: grid; gap: .25rem; justify-content: stretch; }
  .main-navigation a,
  .main-navigation span.separator { text-align: center; }
  .hero-grid,
  .footer-grid,
  .has-left .layout-grid,
  .has-right .layout-grid,
  .has-left.has-right .layout-grid { grid-template-columns: 1fr; }
  .has-left.has-right .sidebar-left,
  .has-left.has-right .content-area,
  .has-left.has-right .sidebar-right { grid-column: auto; }
}

@media print {
  .topbar, .site-header, .site-footer, .hero, .sidebar, .button { display: none !important; }
  body { background: #fff; color: #000; }
  .content-area { border: 0; box-shadow: none; padding: 0; }
}


/* Version 1.0.7: "Aktuelles aus dem Verein" als rechte Sidebar */
.aktuelles-sidebar h2,
.sidebar-right .moduletable h2,
.sidebar-right .moduletable h3 {
  margin-top: 0;
}
.sidebar-right .moduletable:first-child {
  background: linear-gradient(180deg, #fff, var(--bv-honey));
}
@media (min-width: 901px) {
  .has-right .layout-grid { grid-template-columns: minmax(0, 1fr) minmax(260px, 320px); }
  .has-left.has-right .layout-grid { grid-template-columns: 240px minmax(0, 1fr) minmax(260px, 320px); }
}


/* v1.0.9: Willkommensbereich dauerhaft sichtbar direkt unter dem Menü */
.welcome-band {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  width: 100% !important;
  clear: both;
  position: relative;
  z-index: 2;
  background: linear-gradient(135deg, var(--bv-honey), #ffffff 70%);
  border-top: 1px solid var(--bv-border);
  border-bottom: 1px solid var(--bv-border);
}
.welcome-inner {
  display: block !important;
  width: 100% !important;
  max-width: var(--bv-container) !important;
  text-align: center;
  padding-top: clamp(1.25rem, 3vw, 2.4rem);
  padding-bottom: clamp(1.25rem, 3vw, 2.4rem);
}
.welcome-inner h1 {
  display: block !important;
  margin: 0 0 .6rem;
  font-size: clamp(1.55rem, 3vw, 2.55rem);
  line-height: 1.12;
  color: var(--bv-primary) !important;
}
.welcome-inner > p:not(.eyebrow) {
  margin-left: auto;
  margin-right: auto;
  max-width: 980px;
  font-size: clamp(1rem, 1.45vw, 1.14rem);
  color: var(--bv-muted);
}
.welcome-inner .button { margin-top: .7rem; }


/* v1.1.0: Auf der Startseite den Joomla-Menüseitentitel "Home" ausblenden, Beitragstitel behalten */
.is-homepage .content-area > .page-header:first-child,
.is-homepage .content-area > h1:first-child,
.is-homepage .content-area .blog-featured > .page-header:first-child,
.is-homepage .content-area .blog > .page-header:first-child {
  display: none !important;
}

.is-homepage .content-area .item-page > .page-header,
.is-homepage .content-area .item-page > h1:first-child,
.is-homepage .content-area .item-page > h2:first-child {
  display: block !important;
}


/* v1.1.1: Willkommen kleiner und rechte Sidebar dauerhaft sichtbar */
.welcome-inner {
  padding-top: clamp(.75rem, 1.8vw, 1.35rem) !important;
  padding-bottom: clamp(.75rem, 1.8vw, 1.35rem) !important;
}
.welcome-inner .eyebrow {
  font-size: .68rem !important;
  margin-bottom: .35rem !important;
}
.welcome-inner h1 {
  font-size: clamp(1.15rem, 2.1vw, 1.8rem) !important;
  margin-bottom: .35rem !important;
}
.welcome-inner > p:not(.eyebrow) {
  font-size: clamp(.9rem, 1.15vw, 1rem) !important;
  margin-top: .25rem !important;
  margin-bottom: .35rem !important;
}
.welcome-inner .button {
  margin-top: .35rem !important;
  padding: .55rem .9rem;
  font-size: .92rem;
}
.sidebar-right {
  display: block !important;
}
.aktuelles-sidebar {
  display: block !important;
}


/* v1.1.2: Beitragsbereich breiter, Sidebar weiter nach rechts */
@media (min-width: 901px) {
  .container {
    width: min(100% - 2rem, 1420px);
  }

  .layout-grid {
    gap: clamp(1.1rem, 2.2vw, 2.4rem);
    align-items: start;
  }

  .has-right .layout-grid {
    grid-template-columns: minmax(0, 1fr) 240px !important;
  }

  .has-left.has-right .layout-grid {
    grid-template-columns: 220px minmax(0, 1fr) 240px !important;
  }

  .sidebar-right {
    justify-self: end;
    width: 100%;
    max-width: 240px;
  }

  .content-area {
    width: 100%;
  }
}

@media (min-width: 1200px) {
  .has-right .layout-grid {
    grid-template-columns: minmax(0, 1fr) 250px !important;
  }

  .has-left.has-right .layout-grid {
    grid-template-columns: 230px minmax(0, 1fr) 250px !important;
  }

  .sidebar-right {
    max-width: 250px;
  }
}

.footer-custom-text {
    margin: 0.35rem 0 0;
    line-height: 1.7;
}

@media (max-width: 700px) {
  .footer-grid {
    grid-template-columns: 1fr;
    gap: 1.25rem;
    text-align: left;
  }

  .footer-two-columns .footer-column-right {
    text-align: left;
  }
}


/* v1.1.8: Überschrift der rechten Sidebar separat steuerbar */
.sidebar-heading {
  margin: 0 0 .75rem;
  padding: .85rem 1rem;
  border-radius: var(--bv-radius);
  background: linear-gradient(180deg, #fff, var(--bv-honey));
  border: 1px solid var(--bv-border);
  color: var(--bv-primary);
  font-size: 1.05rem;
  line-height: 1.2;
}
.sidebar-right .sidebar-heading + .moduletable {
  margin-top: 0;
}


/* v1.2.0: Menübuttons im Stil der Sidebar-Überschrift */
.main-navigation {
  border-top: 0;
  padding-top: .75rem;
}

.main-navigation ul,
.main-navigation .mod-menu {
  gap: .55rem;
}

.main-navigation li {
  margin: 0;
}

.main-navigation a,
.main-navigation span.separator,
.nav-toggle {
  display: block;
  margin: 0;
  padding: .85rem 1rem;
  border-radius: var(--bv-radius);
  background: linear-gradient(180deg, #fff, var(--bv-honey));
  border: 1px solid var(--bv-border);
  color: var(--bv-primary);
  font-size: 1.05rem;
  line-height: 1.2;
  font-weight: 800;
  text-decoration: none;
  box-shadow: none;
}

.main-navigation a:hover,
.main-navigation .active > a,
.main-navigation .current > a,
.main-navigation span.separator:hover,
.nav-toggle:hover,
.nav-toggle[aria-expanded="true"] {
  background: linear-gradient(180deg, var(--bv-honey), #fff);
  color: var(--bv-primary);
  border-color: rgba(217, 154, 22, .45);
}

@media (max-width: 900px) {
  .main-navigation {
    border: 0;
    background: transparent;
    box-shadow: none;
    padding: .75rem 0 0;
  }

  .main-navigation ul,
  .main-navigation .mod-menu {
    gap: .5rem;
  }

  .main-navigation a,
  .main-navigation span.separator {
    width: 100%;
  }
}


/* v1.2.1: Menü dauerhaft in einer Reihe, Menü-Button ausblenden */
.nav-toggle {
  display: none !important;
}

.main-navigation {
  display: flex !important;
  justify-content: center;
  align-items: center;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.main-navigation ul,
.main-navigation .mod-menu {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  justify-content: center;
  align-items: center;
  gap: .55rem;
  width: auto;
  max-width: 100%;
  white-space: nowrap;
}

.main-navigation li {
  flex: 0 0 auto;
}

.main-navigation a,
.main-navigation span.separator {
  white-space: nowrap;
}

@media (max-width: 900px) {
  .nav-toggle {
    display: none !important;
  }

  .main-navigation {
    display: flex !important;
    justify-content: flex-start;
    overflow-x: auto;
    padding-bottom: .25rem;
  }

  .main-navigation ul,
  .main-navigation .mod-menu {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    justify-content: flex-start;
    width: auto;
  }

  .main-navigation a,
  .main-navigation span.separator {
    width: auto !important;
    padding: .75rem .9rem;
  }
}


/* v1.2.2: Kopfbereich etwas schmaler */
.header-inner {
  gap: .45rem !important;
  padding-block: .75rem .45rem !important;
}

.brand-logo {
  width: min(100%, clamp(420px, 72vw, 980px)) !important;
  max-height: 240px !important;
}

.main-navigation {
  padding-top: .45rem !important;
}

.main-navigation a,
.main-navigation span.separator {
  padding: .68rem .9rem !important;
  font-size: .98rem !important;
}

@media (max-width: 640px) {
  .header-inner {
    padding-block: .55rem .35rem !important;
  }

  .brand-logo {
    width: min(94vw, 520px) !important;
    max-height: 145px !important;
  }

  .main-navigation a,
  .main-navigation span.separator {
    padding: .62rem .8rem !important;
    font-size: .94rem !important;
  }
}


/* v1.2.3: Startseite - doppeltes Home entfernen, Beitragstitel behalten */
.is-homepage .content-area .item-page > .page-header:first-child {
  display: none !important;
}

.is-homepage .content-area .item-page > .page-header:first-child + .page-header,
.is-homepage .content-area .item-page > .page-header:first-child + .page-header h1,
.is-homepage .content-area .item-page > .page-header:first-child + .page-header h2 {
  display: block !important;
}

.is-homepage .content-area .com-content-article > .page-header:first-child {
  display: none !important;
}

.is-homepage .content-area .com-content-article > .page-header:first-child + .page-header {
  display: block !important;
}


/* v1.2.4: Startseite - Joomla-Menüseitentitel "Home" noch robuster entfernen */
body.is-homepage .content-area > .page-header,
body.is-homepage .content-area > .com-content-article > .page-header:first-of-type,
body.is-homepage .content-area > .item-page > .page-header:first-of-type,
body.is-homepage .content-area .blog > .page-header:first-of-type,
body.is-homepage .content-area .blog-featured > .page-header:first-of-type,
body.is-homepage .content-area .com-content-category-blog > .page-header:first-of-type {
  display: none !important;
}

body.is-homepage .content-area article .page-header,
body.is-homepage .content-area .blog-item .page-header,
body.is-homepage .content-area .com-content-article.item-page .page-header + .page-header,
body.is-homepage .content-area .item-page .page-header + .page-header {
  display: block !important;
}


/* v1.2.6: Willkommensbereich mit Fotomotiven links und rechts */
.welcome-with-images {
  display: grid !important;
  grid-template-columns: minmax(120px, 210px) minmax(0, 1fr) minmax(120px, 210px);
  align-items: center;
  gap: clamp(.75rem, 2.2vw, 2rem);
}

.welcome-copy {
  min-width: 0;
  text-align: center;
}

.welcome-image {
  display: flex;
  align-items: center;
  justify-content: center;
}

.welcome-image img {
  width: min(100%, 210px);
  aspect-ratio: 4 / 3;
  max-height: 160px;
  object-fit: cover;
  border-radius: 18px;
  border: 3px solid rgba(217,154,22,.35);
  box-shadow: 0 12px 26px rgba(63,45,26,.16);
}

.welcome-image-left img {
  transform: rotate(-2deg);
}

.welcome-image-right img {
  transform: rotate(2deg);
}

@media (max-width: 820px) {
  .welcome-with-images {
    grid-template-columns: 1fr;
    gap: .75rem;
  }

  .welcome-image {
    order: 2;
  }

  .welcome-copy {
    order: 1;
  }

  .welcome-image-left,
  .welcome-image-right {
    display: none;
  }
}

@media (min-width: 821px) and (max-width: 1100px) {
  .welcome-with-images {
    grid-template-columns: minmax(90px, 150px) minmax(0, 1fr) minmax(90px, 150px);
  }

  .welcome-image img {
    max-height: 115px;
  }
}


/* v1.3.0: Home-Überschrift bei Beiträgen aus Home-Kontext entfernen */
body.is-default-menu-context .content-area > .page-header:first-child,
body.is-default-menu-context .content-area .com-content-article > .page-header:first-child:has(+ .page-header),
body.is-default-menu-context .content-area .item-page > .page-header:first-child:has(+ .page-header) {
  display: none !important;
}

body.is-default-menu-context .content-area .com-content-article > .page-header:first-child + .page-header,
body.is-default-menu-context .content-area .item-page > .page-header:first-child + .page-header {
  display: block !important;
}


/* v1.3.1: zusätzliche Absicherung gegen Joomla-Home-Seitenüberschrift */
body.is-default-menu-context .content-area .page-header:first-child h1:first-child,
body.is-default-menu-context .content-area .page-header:first-child h2:first-child {
  margin-top: 0;
}

/* v1.3.2: Beitragsschrift etwas größer */
.content-area .item-page,
.content-area .com-content-article,
.content-area .blog-item,
.content-area .com-content-category-blog,
.content-area .blog-featured {
  font-size: 1.08rem;
  line-height: 1.75;
}

.content-area .item-page p,
.content-area .com-content-article p,
.content-area .blog-item p,
.content-area .com-content-category-blog p,
.content-area .blog-featured p,
.content-area .item-page li,
.content-area .com-content-article li {
  font-size: 1.08rem;
  line-height: 1.75;
}

.content-area .item-page .page-header h1,
.content-area .com-content-article .page-header h1,
.content-area .item-page .page-header h2,
.content-area .com-content-article .page-header h2 {
  font-size: clamp(1.55rem, 2.5vw, 2.25rem);
}
