/*
Theme Name:  FC Niedernhausen-Lichtenberg
Theme URI:   https://www.fc-niedernhausen.de
Author:      1.FC Niedernhausen-Lichtenberg
Description: OnePager mit Unterseiten – 1.FC Niedernhausen-Lichtenberg
Version:     2.0
License:     GNU General Public License v2
Text Domain: fc-niedernhausen
*/

/* ── RESET & VARIABLEN ─────────────────────────────────────── */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --schwarz:#0d0d0d;
  --weiss:#f5f4f0;
  --gruen:#1a8a1a;
  --gruen-hell:#6ec96e;
  --gruen-dunkel:#0f5c0f;
  --grau:#888;
  --rand:#e0ddd8;
  --flaeche:#ffffff;
}
html{scroll-behavior:smooth}
body{font-family:Arial,Helvetica,sans-serif;background:var(--weiss);color:var(--schwarz);font-size:15px;line-height:1.6}
a{color:var(--gruen);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}

/* ── NAVIGATION ────────────────────────────────────────────── */
.site-header{background:var(--schwarz);position:sticky;top:0;z-index:200}
.nav-inner{max-width:1100px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:70px;gap:1rem;flex-wrap:wrap}
.site-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.logo-text{color:white;font-size:15px;font-weight:900;line-height:1.25;letter-spacing:.3px}
.logo-text span{color:var(--gruen-hell)}
#site-navigation{display:flex}
.nav-menu{display:flex;list-style:none;gap:2px;flex-wrap:wrap}
.nav-menu a{display:block;padding:7px 13px;color:#bbb;font-size:12px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;border-radius:4px;transition:color .15s;text-decoration:none}
.nav-menu a:hover,.nav-menu .current-menu-item>a{color:white}
.nav-menu .current-menu-item>a{background:var(--gruen)}
.menu-toggle{display:none;background:none;border:2px solid #555;color:white;padding:6px 12px;cursor:pointer;font-size:13px;font-weight:700;border-radius:4px}

/* ── BUTTONS ───────────────────────────────────────────────── */
.btn{display:inline-block;padding:12px 24px;font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;border-radius:5px;cursor:pointer;border:none;text-decoration:none;transition:opacity .15s}
.btn:hover{opacity:.88;text-decoration:none}
.btn-gruen{background:var(--gruen);color:white}
.btn-weiss{background:white;color:var(--gruen)}
.btn-rand{background:transparent;color:white;border:2px solid #555}
.btn-klein{padding:8px 16px;font-size:12px}

/* ── HERO (OnePager) ───────────────────────────────────────── */
.hero{background:var(--schwarz);color:white;padding:80px 1.5rem 96px;text-align:center;position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:420px;opacity:.03;pointer-events:none}
.hero-label{font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--gruen-hell);font-weight:700;margin-bottom:1rem}
.hero-titel{font-size:76px;font-weight:900;line-height:.92;margin-bottom:.75rem}
.hero-titel .gruen{color:var(--gruen-hell)}
.hero-motto{font-size:14px;color:#888;margin-bottom:2.5rem;letter-spacing:2px;text-transform:uppercase}
.hero-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ── ABSCHNITTE ────────────────────────────────────────────── */
.abschnitt{padding:60px 1.5rem;max-width:1100px;margin:0 auto}
.abschnitt-label{font-size:11px;font-weight:700;letter-spacing:4px;text-transform:uppercase;color:var(--gruen);margin-bottom:6px}
.abschnitt-titel{font-size:42px;font-weight:900;line-height:1;margin-bottom:1.75rem}
.trennlinie{border:none;border-top:1px solid var(--rand)}

/* ── ABTEILUNGS-KARTEN (OnePager) ─────────────────────────── */
.abteilung-raster{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:20px}
.abteilung-karte{border:1px solid var(--rand);border-radius:12px;overflow:hidden;background:var(--flaeche);transition:transform .2s,border-color .2s,box-shadow .2s;cursor:pointer;text-decoration:none;display:block;color:inherit}
.abteilung-karte:hover{transform:translateY(-5px);border-color:var(--gruen);box-shadow:0 8px 24px rgba(26,138,26,.15);text-decoration:none;color:inherit}
.abt-banner{height:100px;display:flex;align-items:center;justify-content:center;font-size:52px}
.abt-banner.fussball{background:linear-gradient(135deg,#0a1f0a,#1a3a1a)}
.abt-banner.tischtennis{background:linear-gradient(135deg,#0a0a1f,#1a1a3a)}
.abt-banner.karneval{background:linear-gradient(135deg,#2a0a0a,#4a1a1a)}
.abt-banner.fischbachtal{background:linear-gradient(135deg,#1a1a0a,#2a2a0a)}
.abt-body{padding:18px 20px}
.abt-name{font-size:19px;font-weight:900;margin-bottom:5px}
.abt-desc{font-size:13px;color:#666;line-height:1.5;margin-bottom:12px}
.abt-link{font-size:12px;font-weight:700;color:var(--gruen);letter-spacing:.5px;text-transform:uppercase}

/* ── SPIELPLAN-SECTION (OnePager) ─────────────────────────── */
.spielplan-section{background:var(--schwarz);padding:60px 1.5rem}
.spielplan-inner{max-width:1100px;margin:0 auto}
.spielplan-inner .abschnitt-titel{color:white}
.spielplan-inner .abschnitt-label{color:var(--gruen-hell)}
.spiel-liste{display:flex;flex-direction:column;gap:10px}
.spiel-zeile{display:grid;grid-template-columns:100px 1fr 110px 1fr 80px;align-items:center;background:#161616;border-radius:8px;padding:14px 20px;gap:10px;border:1px solid #222}
.spiel-datum{font-size:12px;color:#777;font-weight:600;line-height:1.4}
.spiel-team{font-weight:700;font-size:14px;color:white}
.spiel-team.heim{text-align:right}
.spiel-vs{background:#222;border-radius:4px;padding:7px 8px;font-size:11px;font-weight:700;text-align:center}
.spiel-vs.heimspiel{color:var(--gruen-hell)}
.spiel-vs.auswaerts{color:#f0a030}
.spiel-liga{font-size:11px;color:#555;text-align:right;font-weight:600}

/* ── MITGLIED ──────────────────────────────────────────────── */
.mitglied-section{background:var(--gruen);padding:72px 1.5rem;text-align:center}
.mitglied-titel{font-size:50px;font-weight:900;color:white;margin-bottom:10px;line-height:1.05}
.mitglied-sub{font-size:16px;color:rgba(255,255,255,.8);margin-bottom:2rem}

/* ── KONTAKT-KARTEN ────────────────────────────────────────── */
.kontakt-raster{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px}
.kontakt-karte{border:1px solid var(--rand);border-radius:10px;padding:22px;background:var(--flaeche)}
.kontakt-icon{font-size:24px;margin-bottom:10px}
.kontakt-label{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--grau);font-weight:700;margin-bottom:5px}
.kontakt-wert{font-size:14px;font-weight:600;color:var(--schwarz);line-height:1.5;word-break:break-word}

/* ── UNTERSEITEN HERO ──────────────────────────────────────── */
.unterseite-hero{background:var(--schwarz);padding:52px 1.5rem 64px;text-align:center;color:white;position:relative;overflow:hidden}
.unterseite-hero-bg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:380px;opacity:.04;pointer-events:none}
.unterseite-label{font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--gruen-hell);font-weight:700;margin-bottom:8px}
.unterseite-titel{font-size:62px;font-weight:900;line-height:1;margin-bottom:10px}
.unterseite-sub{font-size:14px;color:#888;letter-spacing:1.5px;text-transform:uppercase}
.zurueck-link{display:inline-flex;align-items:center;gap:6px;color:var(--gruen-hell);font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;text-decoration:none;margin-top:18px}
.zurueck-link:hover{text-decoration:none;color:white}

/* ── MANNSCHAFTS-KARTEN (Unterseiten) ─────────────────────── */
.mannschaft-raster{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:22px}
.mannschaft-karte{background:var(--flaeche);border:1px solid var(--rand);border-radius:12px;overflow:hidden;transition:transform .2s,border-color .2s}
.mannschaft-karte:hover{transform:translateY(-4px);border-color:var(--gruen)}
.mannschaft-header{background:var(--schwarz);padding:18px 20px;display:flex;align-items:center;gap:12px}
.mannschaft-icon{font-size:28px}
.mannschaft-header-info{flex:1}
.mannschaft-name{font-size:17px;font-weight:900;color:white;margin-bottom:3px}
.mannschaft-liga-badge{display:inline-block;background:var(--gruen);color:white;font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;padding:3px 8px;border-radius:10px}
.mannschaft-body{padding:18px 20px}
.mannschaft-zeile{display:flex;gap:10px;align-items:flex-start;margin-bottom:10px;font-size:13px;line-height:1.45}
.mannschaft-zeile-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.mannschaft-zeile-label{font-weight:700;color:#555;display:block;font-size:11px;letter-spacing:.5px;text-transform:uppercase;margin-bottom:2px}
.mannschaft-spielplan-btn{display:block;margin-top:14px;text-align:center;background:var(--gruen);color:white;padding:10px;border-radius:6px;font-size:12px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;text-decoration:none}
.mannschaft-spielplan-btn:hover{background:var(--gruen-dunkel);text-decoration:none;color:white}

/* ── LINKS-KARTEN (Fischbachtal) ───────────────────────────── */
.link-raster{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
.link-karte{background:var(--flaeche);border:1px solid var(--rand);border-radius:10px;padding:22px;transition:border-color .2s,transform .2s}
.link-karte:hover{border-color:var(--gruen);transform:translateY(-3px)}
.link-icon{font-size:32px;margin-bottom:12px}
.link-name{font-size:17px;font-weight:900;margin-bottom:6px}
.link-desc{font-size:13px;color:#666;line-height:1.5;margin-bottom:14px}
.link-btn{display:inline-block;background:var(--gruen);color:white;padding:9px 18px;border-radius:5px;font-size:12px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;text-decoration:none}
.link-btn:hover{background:var(--gruen-dunkel);text-decoration:none;color:white}

/* ── TERMINE (Karneval) ────────────────────────────────────── */
.termine-liste{display:flex;flex-direction:column;gap:14px;margin-bottom:2.5rem}
.termin-karte{background:var(--flaeche);border:1px solid var(--rand);border-radius:10px;padding:18px 22px;display:grid;grid-template-columns:90px 1fr;gap:16px;align-items:center}
.termin-datum-block{text-align:center;background:var(--schwarz);color:white;border-radius:8px;padding:10px 8px}
.termin-tag{font-size:30px;font-weight:900;line-height:1;color:var(--gruen-hell)}
.termin-monat{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:#888;margin-top:2px}
.termin-name{font-size:16px;font-weight:700;margin-bottom:4px}
.termin-ort{font-size:13px;color:#666}
.termin-badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;padding:3px 8px;border-radius:10px;margin-top:5px}
.termin-badge.neu{background:#fff3cd;color:#856404}
.termin-badge.bestaetigt{background:#d1e7dd;color:#0a3622}

/* ── ANSPRECHPARTNER ───────────────────────────────────────── */
.ansprechpartner-raster{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin-bottom:2.5rem}
.ap-karte{background:var(--flaeche);border:1px solid var(--rand);border-radius:10px;padding:22px;text-align:center}
.ap-avatar{width:64px;height:64px;border-radius:50%;background:var(--schwarz);display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 12px}
.ap-name{font-size:16px;font-weight:900;margin-bottom:3px}
.ap-rolle{font-size:12px;color:var(--grau);letter-spacing:.5px;text-transform:uppercase;font-weight:700;margin-bottom:10px}
.ap-kontakt{font-size:13px;color:#555;line-height:1.6}
.ap-kontakt a{color:var(--gruen)}

/* ── SETUP-HINWEIS ─────────────────────────────────────────── */
.setup-hinweis{background:#f0f9f0;border:1px dashed #b8ddb8;border-radius:10px;padding:24px 28px;font-size:14px;line-height:1.7;color:#333}
.setup-hinweis ol{margin:12px 0 0 18px}
.setup-hinweis li{margin-bottom:6px}

/* ── FOOTER ────────────────────────────────────────────────── */
.site-footer{background:var(--schwarz);color:#555;padding:30px 1.5rem}
.footer-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-name{font-size:16px;font-weight:900;color:white}
.footer-links{display:flex;gap:18px;flex-wrap:wrap}
.footer-links a{color:#555;font-size:13px;text-decoration:none}
.footer-links a:hover{color:#999}
.footer-copy{font-size:12px}
.admin-bar .site-header{top:32px}

/* ── NEWS ──────────────────────────────────────────────────── */
.news-raster{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
.news-karte{background:var(--flaeche);border:1px solid var(--rand);border-radius:10px;overflow:hidden;transition:transform .2s,border-color .2s}
.news-karte:hover{transform:translateY(-4px);border-color:#bbb}
.news-bild{display:block;height:180px;object-fit:cover;width:100%;background:#222}
.news-bild-placeholder{height:180px;background:#1a3a1a;display:flex;align-items:center;justify-content:center;font-size:48px}
.news-inhalt{padding:18px}
.news-datum{font-size:11px;color:var(--grau);font-weight:700;margin-bottom:6px;letter-spacing:.5px;text-transform:uppercase}
.news-karte-titel{font-size:16px;font-weight:700;line-height:1.3;margin-bottom:8px}
.news-karte-titel a{color:var(--schwarz);text-decoration:none}
.news-karte-titel a:hover{color:var(--gruen)}
.news-auszug{font-size:13px;color:#666;line-height:1.55;margin-bottom:12px}
.news-mehr{font-size:12px;font-weight:700;color:var(--gruen);letter-spacing:.5px;text-transform:uppercase}
.beitrag-wrapper{max-width:780px;margin:0 auto;padding:3rem 1.5rem}
.beitrag-datum{font-size:12px;color:var(--grau);font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:.5rem}
.beitrag-titel{font-size:36px;font-weight:900;margin-bottom:1.5rem;line-height:1.1}
.beitrag-bild{width:100%;height:360px;object-fit:cover;border-radius:10px;margin-bottom:2rem}
.beitrag-inhalt p{margin-bottom:1.2rem;line-height:1.75}
.beitrag-zurueck{display:inline-block;margin-top:2rem;font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--gruen)}
.seite-wrapper{max-width:900px;margin:0 auto;padding:3rem 1.5rem}
.seite-titel{font-size:40px;font-weight:900;margin-bottom:1.5rem}
.seite-inhalt p{margin-bottom:1.2rem;line-height:1.75}

/* ── RESPONSIVE ────────────────────────────────────────────── */
@media(max-width:900px){
  .spiel-zeile{grid-template-columns:80px 1fr 90px 1fr 60px}
}
@media(max-width:680px){
  .hero-titel{font-size:48px}
  .unterseite-titel{font-size:40px}
  .abschnitt-titel{font-size:32px}
  .mitglied-titel{font-size:36px}
  .menu-toggle{display:block}
  #site-navigation{display:none;width:100%}
  #site-navigation.offen{display:block}
  .nav-menu{flex-direction:column;padding:1rem 0;gap:2px}
  .spiel-zeile{grid-template-columns:1fr 1fr;gap:6px}
  .spiel-team.heim{text-align:left}
  .spiel-vs{grid-column:1/-1;text-align:center}
  .termin-karte{grid-template-columns:1fr}
  .termin-datum-block{display:flex;gap:8px;align-items:center;justify-content:center}
}
