/* =====================================================================
   DJK Eintracht Scharnhorst — Redesign-Prototyp
   Modern, animiert, responsiv. Markenfarbe Blau + energetischer Akzent.
   ===================================================================== */

:root{
	--blue:#0088cc;
	--blue-dark:#0a3d5c;
	--blue-deep:#06293d;
	--accent:#ff7a18;
	--accent-dark:#e96a0a;
	--ink:#1f2a37;
	--muted:#5b6b7b;
	--bg:#f5f8fb;
	--card:#ffffff;
	--line:#e6ecf2;
	--radius:16px;
	--radius-sm:10px;
	--shadow:0 10px 30px rgba(10,61,92,.10);
	--shadow-lg:0 24px 60px rgba(10,61,92,.18);
	--maxw:1180px;
	--head:"Poppins",system-ui,sans-serif;
	--body:"Inter",system-ui,-apple-system,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--body);color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:var(--head);line-height:1.15;color:var(--blue-deep);font-weight:700;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.text-accent{color:var(--accent);}
.hide-sm{display:inline;}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
	font-family:var(--head);font-weight:600;font-size:.95rem;padding:.8em 1.5em;border-radius:999px;
	border:2px solid transparent;cursor:pointer;transition:.25s ease;white-space:nowrap;}
.btn--lg{padding:1em 2em;font-size:1.05rem;}
.btn--sm{padding:.55em 1.1em;font-size:.85rem;}
.btn--accent{background:var(--accent);color:#fff;box-shadow:0 8px 20px rgba(255,122,24,.35);}
.btn--accent:hover{background:var(--accent-dark);transform:translateY(-2px);}
.btn--primary{background:var(--blue);color:#fff;}
.btn--primary:hover{background:var(--blue-dark);transform:translateY(-2px);}
.btn--ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.7);backdrop-filter:blur(4px);}
.btn--ghost:hover{background:#fff;color:var(--blue-deep);}
.btn--light{background:#fff;color:var(--blue-deep);}
.btn--light:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);}
.btn--ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.6);}
.btn--ghost-light:hover{background:rgba(255,255,255,.15);}
.btn--outline{background:transparent;color:var(--blue);border-color:var(--blue);}
.btn--outline:hover{background:var(--blue);color:#fff;transform:translateY(-2px);}

/* ---------- Topbar ---------- */
.topbar{background:var(--blue-deep);color:#cfe3ef;font-size:.82rem;}
.topbar__inner{display:flex;justify-content:space-between;align-items:center;height:38px;}
.topbar__info{display:flex;gap:18px;}
.topbar__links a:hover{color:#fff;}
.topbar .dot{margin:0 8px;opacity:.5;}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
	border-bottom:1px solid var(--line);transition:.3s ease;}
.header.shrink{box-shadow:0 6px 24px rgba(10,61,92,.10);}
.header__inner{display:flex;align-items:center;justify-content:space-between;height:78px;transition:.3s;}
.header.shrink .header__inner{height:64px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand__logo{height:46px;width:auto;transition:.3s;}
.header.shrink .brand__logo{height:38px;}
.brand__text{font-family:var(--head);font-size:.95rem;line-height:1.05;color:var(--blue-deep);text-transform:uppercase;letter-spacing:.5px;}
.brand__text strong{color:var(--blue);font-size:1.05rem;}
.nav{display:flex;align-items:center;gap:6px;}
.nav>a{font-family:var(--head);font-weight:600;font-size:.95rem;color:var(--blue-deep);padding:.6em .9em;border-radius:8px;transition:.2s;}
.nav>a:hover{color:var(--blue);background:rgba(0,136,204,.08);}
.nav__cta{color:#fff!important;}
.nav__cta:hover{background:var(--accent-dark)!important;}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;}
.nav-toggle span{width:26px;height:3px;background:var(--blue-deep);border-radius:2px;transition:.3s;}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;overflow:hidden;color:#fff;}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.08);
	animation:heroZoom 14s ease-out forwards;}
@keyframes heroZoom{to{transform:scale(1);}}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(115deg,rgba(6,41,61,.92) 0%,rgba(10,61,92,.78) 45%,rgba(0,136,204,.35) 100%);}
.hero__content{position:relative;max-width:720px;padding-top:40px;padding-bottom:80px;}
.hero__badge{display:inline-block;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.3);
	padding:.5em 1.1em;border-radius:999px;font-size:.85rem;font-weight:600;margin-bottom:22px;backdrop-filter:blur(4px);}
.hero__title{font-family:var(--head);font-weight:800;font-size:clamp(2.6rem,6vw,4.6rem);color:#fff;letter-spacing:-1px;}
.hero__sub{font-size:clamp(1.05rem,2vw,1.3rem);margin:20px 0 32px;color:#e8f1f8;max-width:560px;}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;}
.hero__scroll{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);width:28px;height:46px;
	border:2px solid rgba(255,255,255,.6);border-radius:16px;}
.hero__scroll span{position:absolute;top:8px;left:50%;width:4px;height:8px;background:#fff;border-radius:2px;
	transform:translateX(-50%);animation:scrollDot 1.6s infinite;}
@keyframes scrollDot{0%{opacity:0;top:8px;}40%{opacity:1;}80%{opacity:0;top:24px;}100%{opacity:0;}}

/* ---------- Stats ---------- */
.stats{background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 100%);color:#fff;}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:46px 24px;text-align:center;}
.stat__num{font-family:var(--head);font-weight:800;font-size:clamp(2.2rem,5vw,3.2rem);line-height:1;}
.stat__label{font-size:.95rem;opacity:.9;margin-top:6px;}

/* ---------- Sections ---------- */
.section{padding:90px 0;}
.section--alt{background:#fff;}
.section__head{max-width:680px;margin:0 auto 50px;text-align:center;}
.section__head--left{text-align:left;margin:0;}
.eyebrow{display:inline-block;color:var(--accent);font-family:var(--head);font-weight:700;font-size:.85rem;
	letter-spacing:2px;text-transform:uppercase;margin-bottom:10px;}
.section__head h2{font-size:clamp(1.9rem,4vw,2.7rem);}
.section__head p{color:var(--muted);margin-top:12px;font-size:1.08rem;}

/* ---------- Finder ---------- */
.finder{max-width:640px;margin:0 auto 44px;position:relative;}
.finder__input{width:100%;padding:1.1em 1.4em;border:2px solid var(--line);border-radius:999px;font-size:1.05rem;
	font-family:var(--body);background:#fff;box-shadow:var(--shadow);transition:.2s;}
.finder__input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 4px rgba(0,136,204,.15);}
.finder__results{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:18px;}
.chip{background:#fff;border:1px solid var(--line);padding:.45em 1em;border-radius:999px;font-size:.9rem;
	color:var(--blue-dark);box-shadow:0 2px 6px rgba(10,61,92,.06);animation:pop .3s ease;}
.chip b{color:var(--accent);}
.chip__empty{color:var(--muted);}
a.chip{cursor:pointer;transition:.18s ease;}
a.chip:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-1px);box-shadow:0 4px 12px rgba(10,61,92,.12);}
@keyframes pop{from{opacity:0;transform:scale(.9);}to{opacity:1;transform:scale(1);}}

/* ---------- Cards ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:30px;
	box-shadow:var(--shadow);transition:.3s ease;position:relative;overflow:hidden;}
.card::before{content:"";position:absolute;left:0;top:0;height:4px;width:100%;background:var(--blue);transform:scaleX(0);
	transform-origin:left;transition:.3s;}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);}
.card:hover::before{transform:scaleX(1);}
.card__icon{width:62px;height:62px;border-radius:16px;display:flex;align-items:center;justify-content:center;
	font-size:1.9rem;margin-bottom:18px;}
.icon-blue{background:rgba(0,136,204,.12);}
.icon-teal{background:rgba(13,180,160,.14);}
.icon-amber{background:rgba(245,158,11,.16);}
.icon-violet{background:rgba(124,92,239,.14);}
.icon-rose{background:rgba(244,63,94,.12);}
.icon-green{background:rgba(34,160,90,.14);}
.card h3{font-size:1.3rem;}
.card__count{color:var(--accent);font-weight:700;font-size:.9rem;margin:4px 0 12px;}
.card__list{color:var(--muted);font-size:.95rem;min-height:48px;}
.card__more{display:inline-block;margin-top:16px;color:var(--blue);font-weight:700;font-family:var(--head);font-size:.92rem;}

/* ---------- News ---------- */
.news{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.news__item{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.3s;}
.news__item:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}
.news__img{height:190px;background-size:cover;background-position:center;}
.news__body{padding:24px;}
.news__date{display:inline-block;background:rgba(0,136,204,.1);color:var(--blue);font-weight:700;font-size:.78rem;
	padding:.3em .8em;border-radius:999px;margin-bottom:12px;}
.news__body h3{font-size:1.25rem;margin-bottom:8px;}
.news__body p{color:var(--muted);font-size:.96rem;}
.link-more{display:inline-block;margin-top:14px;color:var(--accent);font-weight:700;font-family:var(--head);font-size:.9rem;}

/* ---------- Termine ---------- */
.termine__wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:center;}
.termine__cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:4px;}
.termine{list-style:none;}
.termine__item{display:flex;gap:20px;align-items:center;background:#fff;border:1px solid var(--line);
	border-radius:var(--radius-sm);padding:18px 22px;margin-bottom:14px;box-shadow:0 4px 14px rgba(10,61,92,.06);transition:.25s;}
.termine__item:hover{transform:translateX(6px);border-color:var(--blue);}
.termine__date{flex:0 0 auto;width:58px;height:58px;border-radius:12px;background:linear-gradient(135deg,var(--blue),var(--blue-dark));
	color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.72rem;text-transform:uppercase;}
.termine__date b{font-family:var(--head);font-size:1.35rem;line-height:1;}
.termine__item h4{font-size:1.1rem;color:var(--blue-deep);}
.termine__item p{color:var(--muted);font-size:.9rem;}
.termine__cat{display:inline-block;background:rgba(0,136,204,.12);color:var(--blue);font-family:var(--head);font-weight:700;font-size:.68rem;text-transform:uppercase;letter-spacing:.5px;padding:.18em .7em;border-radius:999px;margin-bottom:6px;}

/* ---------- Suche / KI ---------- */
.container--narrow{max-width:820px;}
.site-search{display:flex;gap:10px;margin-top:22px;max-width:660px;flex-wrap:wrap;}
.site-search input{flex:1;min-width:220px;padding:.85em 1.1em;border-radius:12px;border:0;font-size:1rem;font-family:var(--body);box-shadow:0 8px 24px rgba(6,41,61,.18);}
.site-search input:focus{outline:3px solid rgba(255,122,24,.45);}
.search-hint{color:#cfe0ec;font-size:.82rem;margin-top:10px;max-width:640px;}
.ai-answer{background:#fff;border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:14px;padding:20px 22px;box-shadow:var(--shadow);margin-bottom:28px;}
.ai-answer__head{font-family:var(--head);font-weight:700;color:var(--blue-deep);margin-bottom:10px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.ai-answer__head span{font-size:.72rem;font-weight:500;color:var(--muted);background:#f0f5f9;padding:.2em .6em;border-radius:999px;}
.ai-answer__body{color:var(--ink);line-height:1.65;}
.ai-answer__sources{margin-top:14px;padding-top:12px;border-top:1px solid var(--line);font-size:.9rem;display:flex;gap:12px;flex-wrap:wrap;align-items:center;}
.ai-answer__sources a{color:var(--blue);font-weight:600;}
.search-results__head{font-size:1.1rem;color:var(--blue-deep);margin:6px 0 14px;}
.search-results{list-style:none;display:flex;flex-direction:column;gap:16px;}
.search-results li{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 18px;box-shadow:0 2px 6px rgba(10,61,92,.05);}
.search-results a{font-family:var(--head);font-weight:700;color:var(--blue);font-size:1.05rem;}
.search-results p{color:var(--muted);font-size:.92rem;margin-top:6px;}

/* ---------- KI-Chat-Widget (Pop-up) ---------- */
#aiWidget{position:fixed;right:20px;bottom:20px;z-index:1200;}
.ai-widget__btn{display:flex;align-items:center;justify-content:center;width:60px;height:60px;padding:0;background:var(--accent);color:#fff;border:0;border-radius:50%;font-size:1.7rem;line-height:1;box-shadow:0 10px 28px rgba(255,122,24,.4);cursor:pointer;transition:.2s ease;}
.ai-widget__btn:hover{background:var(--accent-dark);transform:scale(1.06);}
.ai-widget__panel{position:absolute;right:0;bottom:74px;width:350px;max-width:calc(100vw - 40px);height:470px;max-height:72vh;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;}
.ai-widget__panel[hidden]{display:none;} /* sonst überschreibt display:flex das hidden-Attribut → Panel ließe sich nicht schließen */
.ai-widget__head{background:var(--blue-deep);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;font-family:var(--head);font-weight:700;}
.ai-widget__close{background:transparent;border:0;color:#fff;font-size:1.1rem;cursor:pointer;line-height:1;}
.ai-widget__msgs{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px;background:#f7fafc;}
.ai-msg{max-width:88%;padding:.6em .85em;border-radius:14px;font-size:.92rem;line-height:1.5;}
.ai-msg--bot{background:#fff;border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:4px;color:var(--ink);}
.ai-msg--user{background:var(--blue);color:#fff;align-self:flex-end;border-bottom-right-radius:4px;}
.ai-msg__links{margin-top:8px;display:flex;flex-direction:column;gap:4px;font-size:.85rem;}
.ai-msg__links a{color:var(--blue);font-weight:600;}
.ai-typing{opacity:.7;font-style:italic;}
.ai-widget__form{display:flex;gap:8px;padding:10px;border-top:1px solid var(--line);}
.ai-widget__form input{flex:1;border:1px solid var(--line);border-radius:10px;padding:.6em .8em;font-size:.92rem;}
.ai-widget__form button{background:var(--blue);color:#fff;border:0;border-radius:10px;width:42px;font-size:1.05rem;cursor:pointer;}
.ai-widget__hint{font-size:.7rem;color:var(--muted);padding:0 12px 10px;text-align:center;}

/* ---------- About ---------- */
.about{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.about__media{position:relative;}
.about__media img{border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;height:420px;object-fit:cover;}
.about__badge{position:absolute;bottom:-22px;right:-10px;background:#fff;border-radius:var(--radius-sm);padding:16px 20px;
	box-shadow:var(--shadow-lg);font-family:var(--head);font-weight:700;color:var(--blue-deep);font-size:.95rem;line-height:1.2;}
.about__badge span{color:var(--muted);font-weight:500;font-size:.78rem;font-family:var(--body);}
.checks{list-style:none;margin:22px 0 28px;}
.checks li{position:relative;padding-left:34px;margin-bottom:12px;color:var(--ink);}
.checks li::before{content:"✓";position:absolute;left:0;top:0;width:22px;height:22px;border-radius:50%;
	background:var(--accent);color:#fff;font-size:.8rem;display:flex;align-items:center;justify-content:center;font-weight:700;}

/* ---------- CTA ---------- */
.cta{background:linear-gradient(120deg,var(--blue-deep),var(--blue));color:#fff;padding:70px 0;position:relative;overflow:hidden;}
.cta::after{content:"";position:absolute;right:-80px;top:-80px;width:320px;height:320px;border-radius:50%;
	background:rgba(255,122,24,.25);filter:blur(20px);}
.cta__inner{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;position:relative;}
.cta h2{color:#fff;font-size:clamp(1.7rem,3.5vw,2.4rem);}
.cta p{color:#dceaf3;margin-top:6px;}
.cta__actions{display:flex;gap:14px;flex-wrap:wrap;}

/* ---------- Footer ---------- */
.footer{background:var(--blue-deep);color:#b9cfdd;font-size:.95rem;}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:34px;padding:60px 24px 40px;}
.footer__logo{height:48px;background:#fff;padding:6px 10px;border-radius:8px;margin-bottom:14px;}
.footer__col h4{color:#fff;font-size:1rem;margin-bottom:14px;}
.footer__col a{display:block;color:#b9cfdd;padding:4px 0;transition:.2s;}
.footer__col a:hover{color:#fff;padding-left:5px;}
.footer__col p{margin-bottom:8px;}
.social{display:flex;gap:10px;margin-top:16px;}
.social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;
	justify-content:center;font-weight:700;transition:.2s;}
.social a:hover{background:var(--accent);color:#fff;}
.footer__bar{border-top:1px solid rgba(255,255,255,.12);}
.footer__bar-inner{display:flex;justify-content:space-between;padding:18px 24px;font-size:.85rem;flex-wrap:wrap;gap:8px;}
.footer__bar a:hover{color:#fff;}

/* ---------- Reveal-Animation ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease;}
.reveal.is-visible{opacity:1;transform:none;}

/* ---------- Responsive ---------- */
@media(max-width:980px){
	.cards,.news{grid-template-columns:repeat(2,1fr);}
	.termine__wrap,.about{grid-template-columns:1fr;gap:34px;}
	.footer__grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:760px){
	.hide-sm{display:none;}
	.nav{position:fixed;inset:0 0 0 auto;width:min(80vw,320px);background:#fff;flex-direction:column;align-items:flex-start;
		justify-content:flex-start;padding:90px 28px;gap:6px;box-shadow:var(--shadow-lg);transform:translateX(100%);transition:.35s;z-index:90;}
	.nav.open{transform:translateX(0);}
	.nav>a{width:100%;font-size:1.1rem;padding:.7em 0;}
	.nav__cta{margin-top:10px;}
	.nav-toggle{display:flex;z-index:95;}
	.nav-toggle.open span:nth-child(1){transform:translateY(8px) rotate(45deg);}
	.nav-toggle.open span:nth-child(2){opacity:0;}
	.nav-toggle.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg);}
	.stats__grid{grid-template-columns:repeat(2,1fr);gap:30px;}
	.cards,.news{grid-template-columns:1fr;}
	.footer__grid{grid-template-columns:1fr;}
	.section{padding:64px 0;}
}
@media(prefers-reduced-motion:reduce){
	*{animation:none!important;transition:none!important;}
	.reveal{opacity:1;transform:none;}
}

/* =====================================================================
   ERWEITERUNGEN: Info-Banner, Unterseiten, Formulare
   ===================================================================== */

/* ---- Info-Banner oben ---- */
.banner{color:#fff;font-size:.95rem;font-weight:500;}
.banner--warn{background:linear-gradient(90deg,#e8590c,#ff7a18);}
.banner--info{background:linear-gradient(90deg,var(--blue-dark),var(--blue));}
.banner--ok{background:linear-gradient(90deg,#1b7a43,#28a745);}
.banner__inner{display:flex;align-items:center;gap:14px;padding:10px 24px;}
.banner__text{flex:1;}
.banner__link{color:#fff;font-weight:700;text-decoration:underline;white-space:nowrap;font-family:var(--head);font-size:.9rem;}
.banner__close{background:rgba(255,255,255,.2);border:0;color:#fff;width:26px;height:26px;border-radius:50%;cursor:pointer;font-size:.8rem;flex:0 0 auto;transition:.2s;}
.banner__close:hover{background:rgba(255,255,255,.4);}

/* ---- Aktiver Navi-Link ---- */
.nav>a.is-active{color:var(--blue);background:rgba(0,136,204,.10);}

/* ---- Page-Hero (Unterseiten) ---- */
.page-hero{position:relative;background:linear-gradient(120deg,var(--blue-deep),var(--blue-dark) 60%,var(--blue));color:#fff;padding:70px 0 60px;overflow:hidden;}
.page-hero::after{content:"";position:absolute;right:-60px;top:-60px;width:280px;height:280px;border-radius:50%;background:rgba(255,122,24,.22);filter:blur(10px);}
.page-hero__inner{position:relative;}
.page-hero .eyebrow{color:#ffd2a8;}
.page-hero h1{color:#fff;font-size:clamp(2rem,5vw,3.2rem);}
.page-hero p{color:#dbeaf4;max-width:640px;margin-top:12px;font-size:1.1rem;}
/* Hero-Varianten (Baukasten) */
.page-hero--image{background-size:cover;background-position:center;}
.page-hero--image .page-hero__inner{position:relative;z-index:2;}
.page-hero--centered{text-align:center;}
.page-hero--centered .page-hero__inner{margin-left:auto;margin-right:auto;}
.page-hero--centered p{margin-left:auto;margin-right:auto;}
.page-hero--minimal{background:#fff;color:var(--ink);padding:46px 0 34px;border-bottom:1px solid var(--line);}
.page-hero--minimal::after{display:none;}
.page-hero--minimal h1{color:var(--blue-deep);}
.page-hero--minimal p{color:var(--muted);}
.page-hero--minimal .eyebrow{color:var(--accent);}
.page-hero--minimal .crumbs{color:var(--muted);}
.page-hero--minimal .crumbs a{color:var(--blue);}
/* Hintergrund-Video im Inhaltsbereich (Sportart-Detailseite) */
.section--video{position:relative;overflow:hidden;}
.section--video > .container{position:relative;z-index:2;}
.section__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;border:0;}
.section__video-scrim{position:absolute;inset:0;z-index:1;background:rgba(247,250,252,.86);}
.crumbs{font-size:.85rem;color:#a9c7da;margin-bottom:12px;}
.crumbs a:hover{color:#fff;}

/* ---- Inhalt / Prosa ---- */
.content{max-width:820px;margin:0 auto;}
.content h2{font-size:1.7rem;margin:34px 0 12px;}
.content h3{font-size:1.25rem;margin:24px 0 8px;}
.content p{margin-bottom:14px;color:#37475a;}
.content ul{margin:0 0 16px 1.2em;color:#37475a;}
.content ul li{margin-bottom:6px;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;}

/* ---- Sportarten-Gruppen ---- */
.sportgroup{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin-bottom:24px;box-shadow:var(--shadow);scroll-margin-top:120px;}
.sportgroup__head{display:flex;align-items:center;gap:14px;padding:18px 24px;border-bottom:1px solid var(--line);}
.sportgroup__head .card__icon{margin:0;width:50px;height:50px;font-size:1.5rem;border-radius:12px;}
.sportgroup__head h2{font-size:1.4rem;margin:0;}
.sportgroup__head span{margin-left:auto;color:var(--accent);font-weight:700;font-size:.9rem;font-family:var(--head);}
.sportlist{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:0;padding:8px 24px 20px;}
.sportlist li{padding:10px 6px;border-bottom:1px solid var(--line);color:var(--blue-dark);font-weight:500;display:flex;align-items:center;gap:8px;}
.sportlist li::before{content:"›";color:var(--accent);font-weight:800;}

/* ---- Beitrag-Tabelle ---- */
.beitrag{width:100%;border-collapse:collapse;margin:16px 0;background:#fff;border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow);}
.beitrag th,.beitrag td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--line);}
.beitrag th{background:var(--blue);color:#fff;font-family:var(--head);}
.beitrag td:last-child{font-weight:700;color:var(--blue-deep);}

/* ---- Formulare ---- */
.form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form label{display:block;font-weight:600;font-size:.9rem;margin:12px 0 6px;color:var(--blue-deep);font-family:var(--head);}
.form input,.form select,.form textarea{width:100%;padding:.8em 1em;border:2px solid var(--line);border-radius:10px;font-family:var(--body);font-size:1rem;transition:.2s;}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 4px rgba(0,136,204,.12);}
.form textarea{min-height:120px;resize:vertical;}
.form .btn{margin-top:18px;}
.form-success{text-align:center;padding:30px;color:#1b7a43;font-weight:700;font-family:var(--head);font-size:1.15rem;}
.form-success small{display:block;color:var(--muted);font-weight:500;font-size:.85rem;margin-top:6px;}

/* ---- Info-Karten (Kontakt) ---- */
.infocards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:10px;}
.infocard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;text-align:center;box-shadow:var(--shadow);}
.infocard .ic{font-size:2rem;margin-bottom:10px;}
.infocard h3{font-size:1.1rem;}
.infocard p{color:var(--muted);font-size:.95rem;margin-top:4px;}
.map-box{height:300px;border-radius:var(--radius);background:linear-gradient(135deg,#dce8f1,#eef4f8);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted);font-weight:600;}

@media(max-width:760px){
	.banner__inner{flex-wrap:wrap;font-size:.88rem;padding:10px 16px;}
	.grid-2{grid-template-columns:1fr;gap:24px;}
	.sportlist{grid-template-columns:1fr;}
	.form .row{grid-template-columns:1fr;}
	.infocards{grid-template-columns:1fr;}
}

/* ---- Klickbare Sportliste ---- */
.sportlist li a{color:inherit;text-decoration:none;flex:1;}
.sportlist li:hover{color:var(--accent);}
.sportlist li a:hover{color:var(--accent);}

/* =====================================================================
   DETAILSEITEN: Kurs & Artikel
   ===================================================================== */
.kurs-media img{border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;height:360px;object-fit:cover;}
.tag{display:inline-block;background:rgba(255,122,24,.14);color:var(--accent-dark);font-weight:700;font-size:.8rem;padding:.3em .9em;border-radius:999px;font-family:var(--head);}

.factbox{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;}
.fact{display:flex;align-items:center;gap:14px;padding:15px 20px;border-bottom:1px solid var(--line);}
.fact:last-child{border-bottom:0;}
.fact .ic{width:42px;height:42px;border-radius:10px;background:rgba(0,136,204,.10);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex:0 0 auto;}
.fact b{display:block;font-family:var(--head);color:var(--blue-deep);font-size:.68rem;text-transform:uppercase;letter-spacing:1px;}
.fact span{color:var(--ink);font-weight:500;}

.trainer{display:flex;gap:18px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow);}
.trainer__avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:700;font-size:1.4rem;flex:0 0 auto;}
.trainer h4{margin:0;font-size:1.1rem;}
.trainer p{margin:0;color:var(--muted);font-size:.92rem;}

.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.gallery img{width:100%;height:130px;object-fit:cover;border-radius:12px;transition:.25s;box-shadow:var(--shadow);}
.gallery img:hover{transform:scale(1.04);box-shadow:var(--shadow-lg);}

.article-hero{position:relative;min-height:420px;display:flex;align-items:flex-end;color:#fff;overflow:hidden;}
.article-hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;}
.article-hero__ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(6,41,61,.94),rgba(6,41,61,.3) 60%,rgba(6,41,61,.1));}
.article-hero__inner{position:relative;padding:40px 0 36px;}
.article-hero h1{color:#fff;font-size:clamp(1.9rem,4.5vw,3rem);max-width:820px;margin-top:12px;}
.article-meta{display:flex;gap:18px;color:#dbeaf4;font-size:.9rem;margin-top:14px;flex-wrap:wrap;}
.article__lead{font-size:1.25rem;line-height:1.65;color:var(--blue-deep);font-weight:500;margin:0 0 24px;}
.article figure{margin:28px 0;}
.article figure img{width:100%;border-radius:var(--radius);box-shadow:var(--shadow);}
.article figcaption{color:var(--muted);font-size:.85rem;text-align:center;margin-top:8px;}
.back-link{display:inline-block;margin-top:30px;color:var(--blue);font-weight:700;font-family:var(--head);}
.sharebar{display:flex;gap:10px;align-items:center;margin-top:26px;padding-top:20px;border-top:1px solid var(--line);color:var(--muted);font-size:.9rem;}
.sharebar a{width:36px;height:36px;border-radius:50%;background:var(--bg);display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);font-weight:700;color:var(--blue-dark);}
.sharebar a:hover{background:var(--blue);color:#fff;border-color:var(--blue);}

@media(max-width:760px){
	.gallery{grid-template-columns:repeat(2,1fr);}
	.kurs-media img{height:240px;}
	.article-hero{min-height:300px;}
}

/* ---- Honeypot (Spam-Schutz, für Menschen unsichtbar) ---- */
.hp-field{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden;}

/* ---- Formular-Fehlermeldung ---- */
.form-error{background:#fdecea;border:1px solid #f5c2c0;color:#b3261e;padding:12px 16px;border-radius:10px;font-size:.92rem;margin-bottom:18px;font-weight:500;}

/* ---- Sport-Hero mit Hintergrund-Video ---- */
.page-hero--media{position:relative;}
.page-hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.page-hero__scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(120deg,rgba(6,41,61,.92),rgba(10,61,92,.78) 55%,rgba(0,136,204,.45));}
.page-hero--media .page-hero__inner{position:relative;z-index:2;}

/* ---- Eingebettetes Formular (iframe, z. B. Vereinsportal) ---- */
.embed-frame{position:relative;width:100%;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:#fff;margin-top:16px;}
.embed-frame iframe{width:100%;height:900px;border:0;display:block;}
@media(max-width:760px){.embed-frame iframe{height:1100px;}}

/* =====================================================================
   MARKEN-COVER (Diagonale Energie) — Marken-Grafik statt Foto
   Wiederverwendbar für Sport-Hero und Beiträge ohne eigenes Bild.
   ===================================================================== */
.brand-cover{position:relative;width:100%;min-height:300px;border-radius:var(--radius);overflow:hidden;background:var(--blue-dark);color:#fff;font-family:var(--head);box-shadow:var(--shadow-lg);}
.brand-cover--hero{height:380px;}
.brand-cover__stripes{position:absolute;inset:0;background:repeating-linear-gradient(125deg,rgba(255,255,255,.04) 0 2px,transparent 2px 24px);}
.brand-cover__wedge{position:absolute;top:0;right:0;width:56%;height:100%;background:linear-gradient(155deg,var(--accent),var(--accent-dark));clip-path:polygon(36% 0,100% 0,100% 100%,0 100%);}
.brand-cover__logo{position:absolute;left:28px;top:26px;width:50px;height:50px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;}
.brand-cover__logo img{width:44px;height:44px;display:block;}
.brand-cover__emoji{position:absolute;right:26px;top:22px;font-size:64px;line-height:1;filter:drop-shadow(0 6px 14px rgba(6,41,61,.35));}
.brand-cover__body{position:absolute;left:32px;right:28px;bottom:32px;}
.brand-cover__eyebrow{display:block;font-size:.75rem;font-weight:700;letter-spacing:1.6px;text-transform:uppercase;color:#ffd2a8;}
.brand-cover__title{font-size:clamp(2rem,5.5vw,2.9rem);font-weight:800;line-height:1;letter-spacing:-1px;margin-top:8px;text-shadow:0 2px 12px rgba(6,41,61,.35);white-space:pre-line;}
.brand-cover__sub{display:block;margin-top:12px;font-size:.85rem;font-weight:600;color:#eaf3fa;}
@media(max-width:760px){.brand-cover--hero{height:300px;}.brand-cover__emoji{font-size:50px;}}

.brand-cover--card{height:200px;min-height:0;border-radius:0;box-shadow:none;}
.brand-cover--card .brand-cover__logo{width:36px;height:36px;left:16px;top:14px;}
.brand-cover--card .brand-cover__logo img{width:30px;height:30px;}
.brand-cover--card .brand-cover__emoji{display:none;}
.brand-cover--card .brand-cover__body{left:18px;right:16px;bottom:auto;top:50%;transform:translateY(-50%);}
.brand-cover--card .brand-cover__title{font-size:1.5rem;}
.brand-cover--card .brand-cover__eyebrow{font-size:.62rem;}

/* ---- Initial (Drop-Cap) für die Kurs-Beschreibung ---- */
.content--lead-cap>p:first-of-type::first-letter{float:left;font-family:var(--head);font-weight:800;font-size:62px;line-height:.78;color:var(--accent);margin:7px 14px 0 0;}

/* ---- Beitrags-Karten „Klassik veredelt“ (Aktuelles + Startseite) ---- */
.news__item{display:block;color:inherit;}
.news__media{position:relative;height:200px;}
.news__media img{width:100%;height:100%;object-fit:cover;display:block;}
.news__cat{position:absolute;left:14px;bottom:-13px;z-index:3;background:var(--blue);color:#fff;font-family:var(--head);font-weight:700;font-size:.66rem;letter-spacing:.8px;text-transform:uppercase;padding:.42em .9em;border-radius:999px;box-shadow:0 4px 10px rgba(0,136,204,.35);}
.news__body{padding:26px 18px 20px;}
.news__meta{display:block;font-size:.72rem;font-weight:600;color:var(--muted);margin-bottom:5px;}

/* ---- Kategorie-Filter + Seitenblättern (Aktuelles) ---- */
.filterbar{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:38px;}
.filterbar a{font-family:var(--head);font-weight:600;font-size:.9rem;padding:.5em 1.1em;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--blue-dark);box-shadow:0 2px 6px rgba(10,61,92,.06);transition:.2s;}
.filterbar a:hover{border-color:var(--blue);color:var(--blue);}
.filterbar a.is-active{background:var(--blue);border-color:var(--blue);color:#fff;}
.pager{display:flex;gap:10px;align-items:center;justify-content:center;margin-top:46px;flex-wrap:wrap;}
.pager a,.pager span{font-family:var(--head);font-weight:600;font-size:.92rem;padding:.6em 1.1em;border-radius:10px;border:1px solid var(--line);background:#fff;color:var(--blue-deep);transition:.2s;}
.pager a:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-1px);}
.pager .is-current{background:var(--blue-deep);border-color:var(--blue-deep);color:#fff;}
.pager .is-disabled{color:var(--muted);background:#eef2f6;}

/* ---- Cookie-Hinweis ---- */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:200;background:#fff;border-top:1px solid var(--line);box-shadow:0 -8px 30px rgba(10,61,92,.14);}
.cookie-banner[hidden]{display:none;}
.cookie-banner__inner{display:flex;align-items:center;gap:18px;padding:16px 24px;flex-wrap:wrap;}
.cookie-banner__text{flex:1;min-width:260px;font-size:.9rem;color:var(--muted);margin:0;line-height:1.55;}
.cookie-banner__text a{color:var(--blue);font-weight:600;text-decoration:underline;}
.cookie-banner__actions{display:flex;gap:10px;flex-wrap:wrap;}
.cookie-banner__decline{background:#fff;border-color:var(--line);color:var(--blue-deep);}
.cookie-banner__decline:hover{border-color:var(--blue);color:var(--blue);}

/* ---- Auszeichnungen & Förderer ---- */
.awards{background:#fff;border-top:1px solid var(--line);padding:34px 0;}
.awards__lead{text-align:center;font-family:var(--head);font-weight:700;font-size:.8rem;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:22px;}
.awards__row{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.award{display:flex;align-items:center;gap:12px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 16px;}
.award__ic{font-size:1.9rem;flex:0 0 auto;line-height:1;}
.award__txt{font-size:.82rem;color:var(--muted);line-height:1.35;}
.award__txt b{display:block;font-family:var(--head);color:var(--blue-deep);font-size:.92rem;margin-bottom:2px;}
@media(max-width:980px){.awards__row{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.awards__row{grid-template-columns:1fr;}.cookie-banner__inner{padding:14px 16px;}}
