:root{
  --bg: #f4f7f4;
  --card: #ffffff;
  --text: #142016;
  --muted: #5b6b5f;

  --green-900:#0b2a16;
  --green-800:#0f3a1f;
  --green-700:#145029;
  --green-600:#1a6a35;

  --accent:#1a6a35;
  --accent-2:#2f8a4b;

  --border:#e3ebe5;
  --shadow: 0 10px 30px rgba(0,0,0,.08);
  --radius: 18px;
}

*{box-sizing:border-box}
html,body{height:100%}
body {
  margin: 0;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  background:
    linear-gradient(
      rgba(248, 250, 248, 0.63),
      rgba(248, 250, 248, 0.63)
    ),
    url("/assets/bg/verein.jpg");

  background-size: cover;
  background-position: center;
  background-attachment: fixed;
}


a{color:var(--accent); text-decoration:none}
a:hover{text-decoration:underline}

.container{
  width:min(1100px, 92vw);
  margin:0 auto;
  padding:24px 0 56px;
}

.topbar{
  position:sticky; top:0;
  backdrop-filter:saturate(140%) blur(10px);
  background: rgba(244,247,244,.85);
  border-bottom:1px solid var(--border);
  z-index:10;
}

.header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:14px 0;
}

.brand{
  display:flex; align-items:center; gap:12px;
}
.logo{
  width:38px; height:38px;
  border-radius:12px;
  background: linear-gradient(135deg, var(--green-700), var(--green-900));
  box-shadow: 0 10px 20px rgba(11,42,22,.18);
}
.brand h1{
  font-size:16px; margin:0;
  letter-spacing:.2px;
}
.brand .sub{
  font-size:12px; color:var(--muted);
  margin-top:2px;
}

.nav{
  display:flex; gap:10px; flex-wrap:wrap;
}
.pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:999px;
  background: rgba(255,255,255,.7);
  color:var(--text);
  font-weight:600;
}
.pill:hover{ text-decoration:none; border-color:#cfe0d3; box-shadow: 0 6px 18px rgba(0,0,0,.06); }
.pill.primary{
  background: linear-gradient(135deg, var(--green-700), var(--green-900));
  color:#fff;
  border-color: transparent;
}
.pill.primary:hover{ box-shadow: 0 12px 24px rgba(11,42,22,.22); }

.hero{
  padding:22px 0 8px;
}
.hero h2{
  margin:0;
  font-size:28px;
  letter-spacing:.2px;
}
.hero p{
  margin:8px 0 0;
  color:var(--muted);
  max-width:70ch;
}

.grid{
  display:grid;
  grid-template-columns: 1.4fr .9fr;
  gap:16px;
  margin-top:18px;
}
@media (max-width: 900px){
  .grid{grid-template-columns:1fr}
}

.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow: var(--shadow);
  padding:18px;
}
.card h3{
  margin:0 0 10px;
  font-size:16px;
}
.meta{color:var(--muted); font-size:12px}
hr.sep{
  border:0; border-top:1px solid var(--border);
  margin:14px 0;
}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  background:#fff;
  font-weight:700;
  color:var(--text);
  cursor:pointer;
}
.btn:hover{ box-shadow: 0 8px 18px rgba(0,0,0,.07); text-decoration:none; }
.btn.primary{
  background: linear-gradient(135deg, var(--accent), var(--green-900));
  color:#fff;
  border-color: transparent;
}

.table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  overflow:hidden;
  border-radius:14px;
  border:1px solid var(--border);
}
.table th, .table td{
  padding:10px 12px;
  border-bottom:1px solid var(--border);
  text-align:left;
}
.table th{ background: rgba(26,106,53,.06); font-size:12px; color:var(--muted); letter-spacing:.3px; text-transform:uppercase; }
.table tr:last-child td{ border-bottom:0; }

.footer{
  margin-top:26px;
  color:var(--muted);
  font-size:12px;
}

/* Bereichs-Menü als Card-Leiste */
.subnavwrap{
  margin-top: 10px;
}

.subnavcard{
  background: rgba(255,255,255,.7);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 10px 30px rgba(0,0,0,.06);
  padding: 10px;
}

.subnav{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.subpill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 12px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: #fff;
  color: var(--text);
  font-weight: 700;
  white-space: nowrap;
}

.subpill:hover{
  text-decoration:none;
  box-shadow: 0 6px 18px rgba(0,0,0,.08);
}

.subpill.active{
  background: linear-gradient(135deg, var(--green-700), var(--green-900));
  color:#fff;
  border-color: transparent;
}
/* ---- Subnav als Card-Sammlung (Override ganz unten!) ---- */

.subnavwrap{
  margin-top: 12px;
}

.subnavcard{
  background: rgba(255,255,255,.75);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 10px 30px rgba(0,0,0,.06);
  padding: 10px;
}

/* Container für die "Cards" */
.subnav{
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}

/* Jeder Menüpunkt ist eine Mini-Card */
.subpill{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  padding: 10px 14px !important;
  border-radius: 16px !important;

  background: #fff !important;
  border: 1px solid var(--border) !important;

  font-weight: 750 !important;
  color: var(--text) !important;

  box-shadow: 0 6px 18px rgba(0,0,0,.06) !important;
  text-decoration: none !important;
}

/* Hover: mehr "Card" */
.subpill:hover{
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(0,0,0,.10) !important;
}

/* Aktiv: wie dein grüner Bereichsbutton */
.subpill.active{
  background: linear-gradient(135deg, var(--green-700), var(--green-900)) !important;
  border-color: transparent !important;
  color: #fff !important;
}


/*Artikel Kategorieblock*/
.mitteilungen-layout{
  display:grid;
  grid-template-columns: 280px 1fr;
  gap:16px;
  margin-top:18px;
}
@media (max-width: 900px){
  .mitteilungen-layout{ grid-template-columns: 1fr; }
}

.catbox{
  padding:0;
  overflow:hidden;
}
.catbox .head{
  padding:14px 16px;
  border-bottom:1px solid var(--border);
  font-weight:800;
}
.catlist{ list-style:none; margin:0; padding:8px; }
.catlist li{ margin:0; }

.catlink{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 12px;
  border-radius:12px;
  color:var(--text);
  text-decoration:none;
  font-weight:700;
}
.catlink:hover{ background: rgba(26,106,53,.07); text-decoration:none; }

.catlink.active{
  background: linear-gradient(135deg, var(--green-700), var(--green-900));
  color:#fff;
}

.subcat{
  margin:6px 0 10px 12px;
  padding-left:8px;
  border-left:2px solid rgba(26,106,53,.18);
}
.subcat a{
  display:block;
  padding:8px 10px;
  border-radius:10px;
  color:var(--text);
  font-weight:650;
  text-decoration:none;
}
.subcat a:hover{ background: rgba(26,106,53,.07); }
.subcat a.active{
  background: rgba(26,106,53,.12);
  border:1px solid #cfe0d3;
}

/* Mitteilungen: Layout wie alte Seite */
.mitteilungen-layout{
  display:grid;
  grid-template-columns: 260px 1fr;
  gap:18px;
  margin-top:18px;
}
@media (max-width: 900px){
  .mitteilungen-layout{ grid-template-columns: 1fr; }
}

/* Linke Kategorie-Card */
.catcard{
  padding:0;
  overflow:hidden;
}
.catcard .cathead{
  padding:12px 14px;
  border-bottom:1px solid var(--border);
  font-weight:800;
}

/* Kategorienliste als "Card Rows" */
.catmenu{ padding:10px; display:flex; flex-direction:column; gap:8px; }
.catitem{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:11px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  font-weight:800;
  color:var(--text);
  text-decoration:none;
}
.catitem:hover{ text-decoration:none; box-shadow: 0 8px 18px rgba(0,0,0,.08); }
.catitem.active{
  background: linear-gradient(135deg, var(--green-700), var(--green-900));
  border-color: transparent;
  color:#fff;
}

/* Unterkategorien eingerückt, kleinere "Pills" */
.subcatwrap{
  margin:2px 0 10px 18px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.subcatlink{
  display:flex;
  padding:9px 10px;
  border-radius:12px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.8);
  color:var(--text);
  font-weight:700;
  text-decoration:none;
}
.subcatlink:hover{ text-decoration:none; box-shadow: 0 8px 18px rgba(0,0,0,.06); }
.subcatlink.active{
  background: rgba(26,106,53,.12);
  border-color:#cfe0d3;
}

/* Rechte Seite: Post-Liste wie alt (Trennlinien) */
.postlist{
  margin-top:6px;
}
.postrow{
  padding:14px 0;
  border-top:1px solid var(--border);
}
.postrow:first-child{ border-top:0; padding-top:0; }
.postmeta{
  color:var(--muted);
  font-size:12px;
  margin-bottom:3px;
}
.posttitle a{
  font-size:16px;
  font-weight:900;
  text-decoration:none;
}
.posttitle a:hover{ text-decoration:underline; }

/* === Lehrgang-Anmeldung: größere Texte & Blöcke === */
.signup-page h2 { font-size: 32px; line-height: 1.15; margin-bottom: 8px; }
.signup-page h3 { font-size: 20px; line-height: 1.2; margin-top: 16px; }

.signup-page .meta { font-size: 15px; line-height: 1.5; }

.signup-page .card {
  padding: 18px 18px;
}

.signup-page label.meta {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 6px;
  display: block;
}

.signup-page .input,
.signup-page select.input,
.signup-page textarea.input {
  font-size: 16px;
  padding: 12px 12px;
}

.signup-page .btn {
  font-size: 16px;
  padding: 12px 14px;
}

.signup-page .pill {
  font-size: 14px;
  padding: 8px 10px;
}

.signup-page .sep { margin: 14px 0; }

/* Optional: Formular “breiter”/luftiger */
.signup-page .card form { margin-top: 10px; }

/* Hero Text lesbar auf Foto */
.hero-copy{
  display:inline-block;
  max-width: 76ch;
  padding: 14px 18px;
  border-radius: 18px;
  background: rgba(248,250,248,.82);
  border: 1px solid rgba(227,235,229,.9);
  box-shadow: 0 12px 28px rgba(0,0,0,.10);
  backdrop-filter: blur(10px) saturate(140%);
}

.hero h2{
  margin:0;
  text-shadow: 0 2px 14px rgba(0,0,0,.18);
}

.hero p{
  margin:8px 0 0;
  text-shadow: 0 2px 14px rgba(0,0,0,.14);
}

/* Footer als dezente Badge-Leiste */
.footer{
  margin-top:26px;
  font-size:12px;
  color: var(--muted);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;

  padding: 10px 14px;
  border-radius: 14px;
  background: rgba(248,250,248,.80);
  border: 1px solid rgba(227,235,229,.9);
  box-shadow: 0 10px 24px rgba(0,0,0,.10);
  backdrop-filter: blur(10px) saturate(140%);
}

/* Links im Footer besser sichtbar */
.footer a{
  color: var(--green-800);
  font-weight: 700;
}

