/* ==========================================================================
   FSV Eisingen 1910 e.V. — styles.css
   Single source of truth for the CI. Tokens 1:1 aus dem Briefing (§3) +
   Marken-Richtlinie. Heller Grün-Weiß-Look als Standard, dunkle Abschnitte
   als gezieltes Stilmittel. Selbst gehostete Schriften, cookiefrei.
   ========================================================================== */

/* --- Self-hosted Fonts (Latin + Latin-Ext, deckt Deutsch inkl. äöüß ab) --- */
/* Variable Fonts: eine Datei deckt den ganzen Weight-Range, font-display:swap */
@font-face{
  font-family:'Archivo';
  font-style:normal;
  font-weight:700 900;
  font-display:swap;
  src:url('../fonts/archivo-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Archivo';
  font-style:normal;
  font-weight:700 900;
  font-display:swap;
  src:url('../fonts/archivo-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:'Hanken Grotesk';
  font-style:normal;
  font-weight:400 700;
  font-display:swap;
  src:url('../fonts/hanken-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:'Hanken Grotesk';
  font-style:normal;
  font-weight:400 700;
  font-display:swap;
  src:url('../fonts/hanken-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}

/* ==========================================================================
   1 · Design-Tokens (CI — verbindlich, §3)
   ========================================================================== */
:root{
  /* Farben */
  --signal:#65B32F;   /* Logo-/Signal-Grün — NUR dekorativ. NIE für Text. */
  --green:#48851E;    /* Tief-Grün — Buttons, Links, Akzente, Text auf Weiß (AA) */
  --ink:#0F1A12;      /* Tinte — Fließtext & Headlines */
  --slate:#4A5550;    /* Sekundärtext */
  --tint:#F1F9EB;     /* sehr helles Grün — Sektions-Hintergründe */
  --line:#E3E8E0;     /* Trennlinien/Rahmen */
  --white:#FFFFFF;    /* Basis-Hintergrund */
  --dark:#0A0A0B;     /* dunkle Abschnitte (Stilmittel) */

  --radius:16px;
  --radius-btn:13px;
  --maxw:1080px;

  /* abgeleitete Helfer */
  --ink-soft:#26302A;            /* etwas weicheres Tinte für lange Fließtexte */
  --shadow-card:0 1px 2px rgba(15,26,18,.04),0 8px 24px rgba(15,26,18,.06);
  --shadow-lift:0 4px 10px rgba(15,26,18,.06),0 18px 44px rgba(15,26,18,.10);

  /* Schrift-Stacks mit System-Fallback (falls woff2 noch fehlt) */
  --font-display:'Archivo','Archivo Black',system-ui,-apple-system,'Segoe UI',sans-serif;
  --font-body:'Hanken Grotesk',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;

  /* Spacing / Sektionen */
  --pad-x:clamp(20px,5vw,40px);
  --section-y:clamp(56px,9vw,96px);

  --header-h:72px;
}

/* ==========================================================================
   2 · Reset & Basis
   ========================================================================== */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  font-family:var(--font-body);
  font-weight:400;
  color:var(--ink);
  background:var(--white);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img,svg{display:block;max-width:100%;height:auto}
a{color:inherit}
button{font:inherit;cursor:pointer}
ul{list-style:none;padding:0}

h1,h2,h3,h4,.dsp{
  font-family:var(--font-display);
  font-weight:800;
  letter-spacing:-.02em;
  line-height:1.05;
  color:var(--ink);
}

/* Sichtbare Fokus-Zustände (Barrierefreiheit) */
:focus-visible{
  outline:3px solid var(--signal);
  outline-offset:2px;
  border-radius:4px;
}

/* Skip-Link für Tastaturnutzer */
.skip-link{
  position:absolute;left:12px;top:-100px;z-index:200;
  background:var(--green);color:#fff;padding:10px 16px;border-radius:10px;
  font-weight:600;transition:top .2s ease;
}
.skip-link:focus{top:12px}

/* ==========================================================================
   3 · Layout-Helfer
   ========================================================================== */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad-x)}
.wrap-wide{max-width:1240px;margin-inline:auto;padding-inline:var(--pad-x)}

section{padding-block:var(--section-y)}
.section--tint{background:var(--tint)}
.section--line{border-top:1px solid var(--line)}
.section--dark{background:var(--dark);color:#E7ECE6}
.section--dark h1,.section--dark h2,.section--dark h3{color:#fff}

.kicker{
  font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--green);margin-bottom:14px;
}
.section--dark .kicker{color:var(--signal)}

.section-head h2{font-size:clamp(26px,4vw,38px);font-weight:800}
.section-head .sub{color:var(--slate);max-width:62ch;margin-top:12px;font-size:16px}
.section--dark .sub{color:#AFBBB1}

/* ==========================================================================
   4 · Buttons, Links, Pills (UI-Bausteine §3)
   ========================================================================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-body);font-weight:600;font-size:15px;line-height:1;
  padding:14px 24px;border-radius:var(--radius-btn);
  border:1px solid transparent;text-decoration:none;
  transition:transform .15s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease;
}
.btn:active{transform:translateY(1px)}

.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:#3d7219;box-shadow:0 8px 20px rgba(72,133,30,.28)}

.btn-ghost{background:#fff;border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--green);color:var(--green)}
.section--dark .btn-ghost{background:transparent;border-color:rgba(255,255,255,.28);color:#fff}
.section--dark .btn-ghost:hover{border-color:var(--signal);color:var(--signal)}

.btn-sm{padding:10px 16px;font-size:14px}

.link{
  color:var(--green);font-weight:600;text-decoration:underline;
  text-underline-offset:3px;text-decoration-thickness:1.5px;
}
.link:hover{color:#3d7219}

/* „Sponsor des Spieltags"-Pill */
.spill{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--tint);color:var(--green);font-weight:700;font-size:13px;
  padding:8px 14px;border-radius:999px;
}
.spill .dot{width:7px;height:7px;border-radius:50%;background:var(--signal);flex:0 0 auto}
.section--dark .spill{background:rgba(101,179,47,.14);color:var(--signal)}

/* Karten */
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-card);overflow:hidden;
  transition:transform .2s ease,box-shadow .2s ease;
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lift)}

/* ==========================================================================
   5 · Header / Navigation (header.php)
   ========================================================================== */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(140%) blur(12px);
  -webkit-backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex;align-items:center;gap:18px;
  min-height:var(--header-h);
  max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad-x);
}
.nav__brand{display:flex;align-items:center;gap:11px;text-decoration:none;flex:0 0 auto}
.nav__brand img{height:42px;width:auto}
.nav__brand .name{
  font-family:var(--font-display);font-weight:900;font-size:16px;
  letter-spacing:-.01em;line-height:1;color:var(--ink);
}
.nav__brand .name span{display:block;font-size:11px;font-weight:600;color:var(--slate);letter-spacing:.06em;margin-top:3px}

.nav__menu{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav__item{position:relative}
.nav__link{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 14px;border-radius:10px;
  font-weight:600;font-size:15px;color:var(--ink);text-decoration:none;
  background:none;border:0;cursor:pointer;font-family:inherit;
  transition:background .15s ease,color .15s ease;white-space:nowrap;
}
.nav__link:hover{background:var(--tint);color:var(--green)}
.nav__link .chev{width:9px;height:9px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-1px);transition:transform .2s ease}

/* aktiver Menüpunkt — grüne Unterstreichung */
.nav__link[aria-current="page"],
.nav__item--active > .nav__link{color:var(--green)}
.nav__link[aria-current="page"]::after,
.nav__item--active > .nav__link::after{
  content:"";position:absolute;left:14px;right:14px;bottom:4px;height:2px;
  background:var(--green);border-radius:2px;
}

/* Dropdowns (Desktop: hover + focus-within) */
.nav__panel{
  position:absolute;top:calc(100% + 6px);left:0;min-width:248px;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow-lift);padding:8px;
  opacity:0;visibility:hidden;transform:translateY(6px);
  transition:opacity .16s ease,transform .16s ease,visibility .16s;
}
.nav__item--has-panel:hover .nav__panel,
.nav__item--has-panel:focus-within .nav__panel,
.nav__item--has-panel .nav__panel.is-open{opacity:1;visibility:visible;transform:translateY(0)}
.nav__item--has-panel:hover .nav__link .chev,
.nav__item--has-panel:focus-within .nav__link .chev{transform:rotate(-135deg) translateY(-1px)}
.nav__panel a{
  display:block;padding:10px 12px;border-radius:9px;
  font-size:14.5px;font-weight:500;color:var(--ink);text-decoration:none;
}
.nav__panel a:hover{background:var(--tint);color:var(--green)}

.nav__cta{margin-left:6px}
.nav__shop::after{content:"↗";font-size:.85em;margin-left:2px;opacity:.7}

/* Hamburger */
.nav__burger{
  display:none;margin-left:auto;width:44px;height:44px;
  background:transparent;border:1px solid var(--line);border-radius:11px;
  position:relative;flex:0 0 auto;
}
.nav__burger span,.nav__burger span::before,.nav__burger span::after{
  content:"";position:absolute;left:50%;top:50%;width:18px;height:2px;
  background:var(--ink);border-radius:2px;transform:translate(-50%,-50%);
  transition:transform .22s ease,opacity .22s ease;
}
.nav__burger span::before{transform:translate(-50%,-7px)}
.nav__burger span::after{transform:translate(-50%,5px)}

/* Mobile-Overlay */
.nav__overlay{
  position:fixed;inset:0;z-index:99;background:#fff;
  padding:calc(var(--header-h) + 8px) var(--pad-x) 40px;
  overflow-y:auto;
  opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:opacity .2s ease,transform .2s ease,visibility .2s;
}
.nav__overlay.is-open{opacity:1;visibility:visible;transform:translateY(0)}
.nav__overlay .group{border-top:1px solid var(--line);padding:18px 0}
.nav__overlay .group:first-child{border-top:0}
.nav__overlay .group > .ttl{
  font-family:var(--font-display);font-weight:800;font-size:13px;
  text-transform:uppercase;letter-spacing:.1em;color:var(--slate);margin-bottom:8px;
}
.nav__overlay a{display:block;padding:11px 4px;font-size:18px;font-weight:600;color:var(--ink);text-decoration:none}
.nav__overlay a:hover{color:var(--green)}
.nav__overlay .btn{margin-top:18px;width:100%}

@media (max-width:920px){
  .nav__menu{display:none}
  .nav__burger{display:inline-flex}
}
/* Body-Scroll-Lock wenn Overlay offen */
body.nav-open{overflow:hidden}

/* ==========================================================================
   6 · Hero (heller Grün-Weiß-Look, §5)
   ========================================================================== */
.hero{
  position:relative;overflow:hidden;
  background:linear-gradient(180deg,#fff 0%,var(--tint) 100%);
  border-bottom:1px solid var(--line);
}
.hero__inner{position:relative;z-index:2;padding-block:clamp(48px,8vw,92px)}
.hero__eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--green);
}
.hero__eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--signal)}
.hero__title{
  font-family:var(--font-display);font-weight:900;
  font-size:clamp(40px,8vw,76px);line-height:.92;letter-spacing:-.03em;
  margin-top:16px;
}
.hero__title .sub{
  display:block;-webkit-text-stroke:1.4px var(--signal);color:transparent;
  font-size:.42em;margin-top:.14em;letter-spacing:-.01em;
}
.hero__claim{color:var(--slate);max-width:42ch;margin-top:20px;font-size:clamp(16px,2.2vw,19px)}
.hero__actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
/* Logo als dezentes Wasserzeichen (heller Hero) */
.hero__wm{
  position:absolute;right:-4%;top:50%;transform:translateY(-50%);
  height:130%;width:auto;opacity:.07;pointer-events:none;z-index:1;user-select:none;
}
@media (max-width:680px){.hero__wm{height:90%;right:-22%;opacity:.05}}

/* Foto-Hero (Stilmittel): Stadionbild, abgedunkelt, weiße Typo (§3) */
.hero--photo{background:var(--dark);border-bottom:0}
.hero--photo .hero__bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero--photo .hero__bg img{width:100%;height:100%;object-fit:cover;display:block}
.hero--photo::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(8,16,10,.42) 0%,rgba(8,16,10,.80) 100%);}
.hero--photo .hero__inner{z-index:2;padding-block:clamp(72px,12vw,132px)}
.hero--photo .hero__eyebrow{color:#fff}
.hero--photo .hero__eyebrow .dot{background:var(--signal)}
.hero--photo .hero__title{color:#fff}
.hero--photo .hero__year{
  display:block;font-family:var(--font-body);font-weight:600;
  font-size:clamp(12px,1.5vw,15px);letter-spacing:.24em;text-transform:uppercase;
  color:rgba(255,255,255,.82);margin-top:16px;
}
.hero--photo .hero__claim{color:rgba(255,255,255,.9)}
.hero--photo .hero__wm{display:none}

/* ==========================================================================
   7 · Matchday-Kachel & Click-to-Load-Widget (§6)
   ========================================================================== */
.matchtile{
  background:var(--dark);color:#E7ECE6;border-radius:var(--radius);
  padding:clamp(22px,4vw,34px);position:relative;overflow:hidden;
}
.matchtile__row{display:flex;flex-wrap:wrap;align-items:center;gap:16px;justify-content:space-between}
.matchtile h3{color:#fff;font-size:clamp(20px,3vw,26px)}
.matchtile .meta{color:#AFBBB1;font-size:13px;letter-spacing:.04em;text-transform:uppercase;margin-top:6px}

/* Click-to-Load Platzhalter — datensparsam, kein Drittanbieter-Request vor Klick */
.ctl{
  border:1px dashed var(--line);border-radius:var(--radius);
  background:var(--tint);padding:clamp(22px,4vw,32px);text-align:center;
}
.ctl__icon{
  width:46px;height:46px;border-radius:12px;margin:0 auto 14px;
  background:#fff;border:1px solid var(--line);display:grid;place-items:center;color:var(--green);
}
.ctl h3{font-size:19px}
.ctl__hint{color:var(--slate);font-size:13.5px;max-width:46ch;margin:8px auto 18px;line-height:1.5}
.ctl__embed{margin-top:6px}
.ctl__embed iframe{width:100%;border:0;border-radius:12px;background:#fff;min-height:520px}
.ctl[data-loaded="true"]{background:#fff;border-style:solid;text-align:left;padding:0}

/* ==========================================================================
   8 · News-Karten / Grids (§5)
   ========================================================================== */
.grid{display:grid;gap:20px}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
@media (max-width:820px){.grid--3{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.grid--2,.grid--3{grid-template-columns:1fr}}

.news{display:flex;flex-direction:column}
.news__media{aspect-ratio:3/2;background:var(--tint);position:relative;overflow:hidden}
.news__media img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
/* Grafiken/Plakate vollständig zeigen statt beschneiden */
.news__media--contain{background:#fff}
.news__media--contain img{object-fit:contain;object-position:center}
.news__media .ph{position:absolute;inset:0;display:grid;place-items:center;color:var(--green);font-weight:700;font-size:13px;letter-spacing:.08em;text-transform:uppercase;opacity:.55}
.news__body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:10px;flex:1}
.news__tag{align-self:flex-start;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--green);background:var(--tint);padding:5px 10px;border-radius:999px}
.news__body h3{font-size:20px;font-weight:800}
.news__body p{color:var(--slate);font-size:15px}
.news__body .link{margin-top:auto}

/* Banner „Save the Date" */
.banner{
  display:flex;flex-wrap:wrap;align-items:center;gap:18px;justify-content:space-between;
  background:var(--tint);border:1px solid var(--line);border-radius:var(--radius);
  padding:clamp(22px,4vw,32px);
}
.banner h3{font-size:clamp(22px,3.4vw,30px)}
.banner .when{color:var(--green);font-weight:700;letter-spacing:.04em}

/* Download-Box */
.downloadbox{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  border:1px solid var(--line);border-radius:var(--radius);background:#fff;
  padding:20px 24px;box-shadow:var(--shadow-card);
}
.downloadbox .ic{width:44px;height:44px;border-radius:11px;background:var(--tint);color:var(--green);display:grid;place-items:center;flex:0 0 auto}
.downloadbox .tx{flex:1;min-width:200px}
.downloadbox .tx b{font-family:var(--font-display);font-size:16px}
.downloadbox .tx span{display:block;color:var(--slate);font-size:13.5px;margin-top:2px}

/* ==========================================================================
   9 · Footer + Sponsorenband + Social (footer.php, §4/§7)
   ========================================================================== */
.sponsorband{background:#fff;border-top:1px solid var(--line);padding-block:clamp(28px,5vw,44px)}
.sponsorband__head{display:flex;align-items:baseline;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.sponsorband__head .ttl{font-family:var(--font-display);font-weight:800;font-size:15px;letter-spacing:.02em}
.sponsorband__head .ttl span{color:var(--slate);font-weight:500}
.sponsorband__logos{display:flex;flex-wrap:wrap;align-items:center;gap:clamp(20px,4vw,40px)}
.sponsorband__logos a{
  display:inline-flex;align-items:center;justify-content:center;
  filter:grayscale(1);opacity:.62;transition:filter .2s ease,opacity .2s ease,transform .2s ease;
}
.sponsorband__logos a:hover{filter:grayscale(0);opacity:1;transform:translateY(-2px)}
.sponsorband__logos img{height:clamp(30px,5vw,46px);width:auto}
.sponsorband__logos .ph{
  height:46px;min-width:120px;border:1px dashed var(--line);border-radius:10px;
  display:grid;place-items:center;color:var(--slate);font-size:12px;filter:none;opacity:1;
}

.site-footer{background:var(--dark);color:#AFBBB1}
.site-footer a{color:#D7DEd8;text-decoration:none}
.site-footer a:hover{color:#fff}
.site-footer__top{
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px;
  padding-block:clamp(44px,7vw,68px);
}
@media (max-width:760px){.site-footer__top{grid-template-columns:1fr;gap:28px}}
.site-footer__brand img{height:54px;margin-bottom:16px}
.site-footer__brand .name{font-family:var(--font-display);font-weight:900;color:#fff;font-size:18px}
.site-footer__brand address{font-style:normal;color:#AFBBB1;margin-top:10px;font-size:14.5px;line-height:1.6}
.site-footer__col h4{color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.12em;margin-bottom:14px;font-family:var(--font-display);font-weight:800}
.site-footer__col li{margin-bottom:10px;font-size:14.5px}
.site-footer__social{display:flex;gap:10px;margin-top:4px}
.site-footer__social a{
  width:42px;height:42px;border-radius:11px;border:1px solid rgba(255,255,255,.14);
  display:grid;place-items:center;color:#fff;
}
.site-footer__social a:hover{border-color:var(--signal);background:rgba(101,179,47,.12)}
.site-footer__social svg{width:19px;height:19px}
.site-footer__bottom{
  border-top:1px solid rgba(255,255,255,.10);
  padding-block:20px;display:flex;flex-wrap:wrap;gap:6px 18px;justify-content:space-between;
  font-size:13px;color:#8A968D;
}

/* ==========================================================================
   10 · Sponsoren-Galerie (sponsoren.php, §7)
   ========================================================================== */
.tier{margin-top:30px}
.tier__head{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.tier__head h3{font-size:20px}
.tier__head .pill{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--green);background:var(--tint);padding:4px 10px;border-radius:999px}
.tier__logos{display:flex;flex-wrap:wrap;gap:16px}
.tier__logos a{
  border:1px solid var(--line);border-radius:12px;background:#fff;padding:18px 24px;
  display:grid;place-items:center;min-width:150px;transition:border-color .2s ease,transform .2s ease;
}
.tier__logos a:hover{border-color:var(--green);transform:translateY(-2px)}
.tier__logos img{height:46px;width:auto}

/* Paket-Tabelle */
.pkg{width:100%;border-collapse:separate;border-spacing:0;margin-top:24px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.pkg th,.pkg td{text-align:left;padding:16px 18px;border-bottom:1px solid var(--line);font-size:14.5px;vertical-align:top}
.pkg thead th{background:var(--tint);font-family:var(--font-display);font-weight:800;color:var(--ink)}
.pkg tbody tr:last-child td{border-bottom:0}
.pkg .pkg__name{font-family:var(--font-display);font-weight:800;color:var(--green)}

/* ==========================================================================
   11 · Entrance-Animation (staggered, respektiert reduced-motion)
   ========================================================================== */
[data-reveal]{opacity:0;transform:translateY(16px);transition:opacity .6s cubic-bezier(.22,.61,.36,1),transform .6s cubic-bezier(.22,.61,.36,1)}
[data-reveal].is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1!important;transform:none!important;transition:none!important}
  .card,.btn{transition:none}
}

/* ==========================================================================
   12 · Utilities
   ========================================================================== */
.stack-sm{display:flex;flex-direction:column;gap:8px}
.lead{font-size:clamp(17px,2.4vw,20px);color:var(--ink-soft);max-width:58ch}
.muted{color:var(--slate)}
.center{text-align:center}
.mt-0{margin-top:0}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.two-col{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(24px,4vw,40px);align-items:start}
@media (max-width:820px){.two-col{grid-template-columns:1fr}}

/* ==========================================================================
   13 · Unterseiten — Page-Head, Ansprechpartner, Prosa, statische Karte
   ========================================================================== */
/* Kompakter Seitenkopf (statt großem Hero) für Unterseiten */
.pagehead{
  background:linear-gradient(180deg,#fff,var(--tint));
  border-bottom:1px solid var(--line);
}
.pagehead__inner{padding-block:clamp(40px,6vw,64px)}
.pagehead h1{font-size:clamp(32px,5.5vw,52px);font-weight:900;letter-spacing:-.03em;margin-top:14px}
.pagehead .lead{margin-top:16px;color:var(--slate);max-width:60ch;font-size:clamp(16px,2.2vw,19px)}

/* Ansprechpartner-Karten */
.person{display:flex;gap:14px;align-items:center;padding:18px 20px}
.person__avatar{
  width:48px;height:48px;border-radius:50%;flex:0 0 auto;
  background:var(--tint);color:var(--green);display:grid;place-items:center;
  font-family:var(--font-display);font-weight:800;font-size:17px;
}
.person__info b{font-family:var(--font-display);font-size:16px;display:block}
.person__info .role{color:var(--slate);font-size:13.5px;margin:2px 0 4px}
.person__info a{color:var(--green);font-weight:600;text-decoration:none;font-size:14.5px}
.person__info a:hover{text-decoration:underline;text-underline-offset:3px}

/* Info-Liste (Trainingszeiten o.ä.) */
.factlist{display:grid;gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}
.factlist__row{display:flex;justify-content:space-between;gap:16px;padding:14px 18px;border-bottom:1px solid var(--line);font-size:15px}
.factlist__row:last-child{border-bottom:0}
.factlist__row .k{color:var(--slate)}
.factlist__row .v{font-weight:600;text-align:right}

/* Prosa (Impressum, Datenschutz, längere Texte) */
.prose{max-width:72ch}
.prose h2{font-size:clamp(20px,3vw,26px);margin-top:40px}
.prose h2:first-child{margin-top:0}
.prose h3{font-size:18px;margin-top:26px}
.prose p,.prose ul{margin-top:12px;color:var(--ink-soft);font-size:16px}
.prose ul{padding-left:20px;list-style:disc}
.prose li{margin-top:6px}
.prose a{color:var(--green);text-decoration:underline;text-underline-offset:3px}
.prose .muted{color:var(--slate);font-size:14px}

/* Statisches Karten-Bild / Maps-Ersatz (kein iframe, §8) */
.mapcard{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}
.mapcard__img{aspect-ratio:16/9;background:var(--tint) center/cover no-repeat;display:grid;place-items:center;color:var(--green)}
.mapcard__bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;flex-wrap:wrap}
.mapcard__bar address{font-style:normal;font-size:14.5px;color:var(--ink)}

/* Namens-/Trainer-Liste als Chips */
.taglist{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;padding:0;list-style:none}
.taglist li{
  background:var(--tint);color:var(--ink);border:1px solid var(--line);
  border-radius:999px;padding:7px 14px;font-size:14.5px;font-weight:500;
}

/* Hinweis-/Platzhalter-Box für noch fehlende Vereins-Inhalte (§10) */
.notice{
  border:1px dashed var(--line);background:var(--tint);border-radius:var(--radius);
  padding:18px 20px;color:var(--slate);font-size:14px;
}
.notice b{color:var(--ink)}
