/*
Theme Name: SG Breitenburg
Description: Individuelles Theme für die SG Breitenburg
Author: SG Breitenburg
Version: 1.0
*/


:root{
  --blau:#00549C; --blau-tief:#04274C; --blau-nacht:#061a33;
  --signal:#2E9BFF; --signal-soft:rgba(46,155,255,.18);
  --tinte:#0E1116; --grau:#5A6472; --linie:#E4EAF2; --schaum:#F4F7FB; --weiss:#fff;
  --display:'Space Grotesk',system-ui,sans-serif;
  --body:'Inter',system-ui,sans-serif;
  --mono:'Space Mono',ui-monospace,monospace;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--tinte);background:var(--weiss);line-height:1.6;-webkit-font-smoothing:antialiased;padding-top:90px;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}
body>footer{margin-top:auto}
body.admin-bar{min-height:calc(100vh - 32px);min-height:calc(100dvh - 32px)}
@media screen and (max-width:782px){body.admin-bar{min-height:calc(100vh - 46px);min-height:calc(100dvh - 46px)}}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
:focus-visible{outline:3px solid var(--signal);outline-offset:2px;border-radius:4px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--blau);display:inline-flex;align-items:center;gap:8px}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--signal)}

/* ===== Mockup-Hinweis ===== */
.note{background:var(--tinte);color:#cfe0f2;font-family:var(--mono);font-size:12px;text-align:center;padding:7px 16px;letter-spacing:.04em}
.note b{color:var(--signal)}

/* ===== Header ===== */
.head{position:fixed;top:0;left:0;width:100%;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--linie)}
.admin-bar .head{top:32px}
@media screen and (max-width:782px){.admin-bar .head{top:46px}}
.head .wrap{display:flex;align-items:center;gap:24px;height:90px}
.custom-logo{height:auto!important;width:auto!important;object-fit:contain;display:block}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--display);font-weight:700;letter-spacing:.01em}
.brand img,.brand .custom-logo{height:60px!important;width:auto!important;max-width:90px;display:block}
.brand .custom-logo-link{display:flex;align-items:center}
.brand small{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--grau);font-weight:400;text-transform:uppercase}
.brand span{font-size:18px;line-height:1.05}
nav.main{margin-left:auto;display:flex;gap:26px;align-items:center}
nav.main a{font-size:15px;font-weight:500;color:#2b3440;position:relative;padding:4px 0}
nav.main a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--signal);transition:width .25s}
nav.main a:hover::after{width:100%}
.btn{font-family:var(--display);font-weight:600;font-size:15px;border-radius:10px;padding:11px 20px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:none;transition:transform .15s,box-shadow .2s}
.btn-primary{background:var(--blau);color:#fff;box-shadow:0 6px 18px rgba(0,84,156,.28)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(0,84,156,.4)}
.btn-ghost{background:transparent;border:1.5px solid rgba(255,255,255,.5);color:#fff}
.btn-ghost:hover{border-color:var(--signal);color:#fff}
.menu-btn{display:none;margin-left:auto;background:none;border:none;font-size:26px;cursor:pointer;color:var(--blau)}
.mobile-nav{display:none;position:fixed;inset:90px 0 0 0;background:#fff;z-index:49;padding:24px;overflow-y:auto}
.mobile-nav.open{display:block}
.mobile-nav a{display:block;font-family:var(--display);font-weight:600;font-size:20px;padding:16px 0;border-bottom:1px solid var(--linie)}
.mobile-nav .btn{margin-top:20px;width:100%;justify-content:center}
.page-jump{position:fixed;bottom:18px;right:18px;z-index:60;background:var(--tinte);color:#fff;font-family:var(--mono);font-size:11px;letter-spacing:.08em;border-radius:10px;padding:10px 14px;display:flex;flex-direction:column;gap:6px;box-shadow:0 10px 30px rgba(0,0,0,.25)}
.page-jump a{color:#cfe0f2;padding:2px 0}
.page-jump a:hover{color:var(--signal)}
.page-jump b{color:var(--signal);font-size:10px;letter-spacing:.14em;text-transform:uppercase}
.pagebreak{background:var(--tinte);text-align:center;padding:14px}
.pagebreak span{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--signal)}

/* ===== Hero ===== */
.hero{position:relative;background:
  radial-gradient(900px 500px at 78% -10%, rgba(46,155,255,.28), transparent 60%),
  linear-gradient(158deg,var(--blau-nacht),var(--blau-tief) 55%,#024079);
  color:#fff;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:46px 46px;mask-image:radial-gradient(700px 420px at 30% 30%,#000,transparent 75%)}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;padding:84px 24px 130px}
.hero .eyebrow{color:#bcd9ff}
.hero .eyebrow::before{background:var(--signal)}
.hero h1{font-family:var(--display);font-weight:700;font-size:clamp(38px,5.4vw,68px);line-height:1.02;letter-spacing:-.02em;margin:18px 0 16px}
.hero h1 em{font-style:normal;color:var(--signal)}
.hero p.lead{font-size:18px;color:#d3e3f5;max-width:34ch;margin-bottom:30px}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap}
.stats{display:flex;gap:30px;margin-top:42px}
.stats div{display:flex;flex-direction:column}
.stats b{font-family:var(--mono);font-size:30px;font-weight:700;color:#fff;line-height:1}
.stats span{font-size:13px;color:#9fc0e3;margin-top:4px}

/* Matchday card */
.matchday{background:rgba(255,255,255,.06);border:1px solid rgba(120,180,255,.28);border-radius:18px;padding:26px;position:relative;backdrop-filter:blur(6px);
  clip-path:polygon(0 0,100% 0,100% 88%,94% 100%,0 100%)}
.matchday::after{content:"";position:absolute;left:0;top:0;width:100%;height:3px;background:linear-gradient(90deg,var(--signal),transparent);border-radius:18px 18px 0 0}
.md-top{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#9fc0e3;margin-bottom:20px}
.md-top .live{color:var(--signal);display:flex;align-items:center;gap:6px}
.md-top .live::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--signal);box-shadow:0 0 10px var(--signal)}
.md-teams{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px;text-align:center}
.md-teams .team{font-family:var(--display);font-weight:600;font-size:15px;color:#fff}
.md-teams .vs{font-family:var(--mono);font-size:13px;color:#7fa8d6}
.md-time{text-align:center;margin:18px 0 14px}
.md-time b{font-family:var(--mono);font-size:40px;font-weight:700;color:#fff;letter-spacing:.02em}
.md-time span{display:block;font-size:13px;color:#9fc0e3;margin-top:2px}
.md-foot{display:flex;justify-content:center;gap:8px;font-size:13px;color:#bcd9ff;border-top:1px solid rgba(255,255,255,.12);padding-top:14px}

/* wave divider */
.wavewrap{position:absolute;bottom:-1px;left:0;width:100%;line-height:0}
.wavewrap svg{width:100%;height:90px;display:block}

/* ===== Section base ===== */
section.block{padding:84px 0}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:40px;flex-wrap:wrap}
.sec-head h2{font-family:var(--display);font-weight:700;font-size:clamp(28px,3.5vw,40px);letter-spacing:-.02em;margin-top:10px}
.link-more{font-family:var(--display);font-weight:600;color:var(--blau);font-size:15px}
.link-more:hover{color:var(--signal)}

/* News */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:var(--weiss);border:1px solid var(--linie);border-radius:16px;overflow:hidden;transition:transform .2s,box-shadow .25s,border-color .2s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(7,40,80,.12);border-color:#bcd4ee}
.card .thumb{height:158px;background:linear-gradient(135deg,var(--blau),#0a3f72);position:relative}
.card .thumb.alt{background:linear-gradient(135deg,#0a3f72,#024079)}
.card .thumb.alt2{background:linear-gradient(135deg,#073a6b,var(--signal))}
.card .thumb .cat{position:absolute;left:14px;top:14px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;background:rgba(0,0,0,.45);color:#fff;padding:5px 10px;border-radius:6px}
.card .body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:9px;flex:1}
.card .date{font-family:var(--mono);font-size:12px;color:var(--grau)}
.card h3{font-family:var(--display);font-weight:600;font-size:19px;line-height:1.25}
.card p{font-size:14.5px;color:var(--grau)}
.card .rd{margin-top:auto;font-family:var(--display);font-weight:600;font-size:14px;color:var(--blau)}

/* Teams */
.teams{background:var(--schaum)}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.tcard{background:#fff;border:1px solid var(--linie);border-radius:14px;padding:20px;transition:transform .18s,box-shadow .22s,border-color .2s;position:relative;overflow:hidden}
.tcard::before{content:"";position:absolute;left:0;top:0;width:4px;height:100%;background:var(--blau);transform:scaleY(0);transform-origin:top;transition:transform .25s}
.tcard:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(7,40,80,.12);border-color:#cdddef}
.tcard:hover::before{transform:scaleY(1)}
.tcard .ag{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--signal)}
.tcard h3{font-family:var(--display);font-weight:700;font-size:21px;margin:6px 0 12px}
.tcard .tr{font-size:13.5px;color:var(--grau);display:flex;align-items:center;gap:7px}
.tcard .tr b{color:var(--tinte);font-weight:500}
.tcard .go{margin-top:16px;font-family:var(--display);font-weight:600;font-size:14px;color:var(--blau);display:inline-flex;gap:6px;align-items:center}

/* Training strip */
.train{background:linear-gradient(160deg,var(--blau-nacht),var(--blau-tief));color:#fff}
.train .grid{display:grid;grid-template-columns:1.1fr 1.4fr;gap:48px;align-items:center}
.train h2{font-family:var(--display);font-weight:700;font-size:clamp(28px,3.4vw,38px);letter-spacing:-.02em;margin:12px 0 14px}
.train p{color:#cfe0f2;max-width:40ch;margin-bottom:24px}
.sched{display:grid;gap:10px}
.srow{display:grid;grid-template-columns:64px 1fr auto;align-items:center;gap:14px;background:rgba(255,255,255,.06);border:1px solid rgba(120,180,255,.22);border-radius:12px;padding:14px 18px}
.srow .day{font-family:var(--mono);font-weight:700;font-size:14px;color:var(--signal)}
.srow .what{font-family:var(--display);font-weight:600;font-size:15px}
.srow .time{font-family:var(--mono);font-size:14px;color:#bcd9ff}

/* CTA band */
.cta-band{background:var(--blau);color:#fff;border-radius:22px;padding:56px;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 80% 120%,rgba(46,155,255,.45),transparent 60%)}
.cta-band h2{position:relative;font-family:var(--display);font-weight:700;font-size:clamp(28px,3.6vw,42px);letter-spacing:-.02em;margin-bottom:12px}
.cta-band p{position:relative;color:#d8e8fa;max-width:48ch;margin:0 auto 26px}
.cta-band .btn-white{position:relative;background:#fff;color:var(--blau)}
.cta-band .btn-white:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,0,0,.25)}

/* Footer */
footer{background:var(--tinte);color:#aeb8c4;padding:64px 0 28px;font-size:14.5px}
.sponsors{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;padding-bottom:46px;border-bottom:1px solid #232a33;margin-bottom:44px}
.sponsors span{font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:#5f6b78;border:1px dashed #333c47;border-radius:8px;padding:14px 30px}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:36px}
.fgrid img.footer-logo{height:72px!important;width:auto!important;margin-bottom:14px}
.fgrid h4{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#fff;margin-bottom:16px}
.fgrid a{display:block;color:#aeb8c4;padding:4px 0}
.fgrid a:hover{color:var(--signal)}
.fgrid p{color:#8893a0;max-width:30ch}
.fbar{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:46px;padding-top:24px;border-top:1px solid #232a33;font-family:var(--mono);font-size:12px;color:#6c7884;letter-spacing:.03em}
.fbar a:hover{color:var(--signal)}

/* ===== Team detail (Muster) ===== */
.divider-label{background:var(--schaum);text-align:center;padding:36px 24px 14px}
.divider-label span{font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--blau);border:1px solid var(--linie);background:#fff;padding:8px 18px;border-radius:30px}
.thero{background:radial-gradient(700px 400px at 85% 0%,rgba(46,155,255,.22),transparent 60%),linear-gradient(150deg,var(--blau-tief),#024079);color:#fff;padding:60px 0}
.thero .ag{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--signal);font-size:13px}
.thero h2{font-family:var(--display);font-weight:700;font-size:clamp(32px,4.4vw,52px);letter-spacing:-.02em;margin:10px 0 14px}
.thero .meta{display:flex;gap:26px;flex-wrap:wrap;color:#cfe0f2;font-size:14.5px}
.thero .meta span{display:flex;align-items:center;gap:8px}
.tbody{display:grid;grid-template-columns:1.6fr 1fr;gap:36px;padding:56px 0}
.panel{border:1px solid var(--linie);border-radius:16px;padding:26px}
.panel h3{font-family:var(--display);font-weight:700;font-size:20px;margin-bottom:18px;display:flex;align-items:center;gap:10px}
.panel h3 .bar{width:20px;height:3px;background:var(--signal);border-radius:2px}
.coach{display:flex;gap:16px;align-items:center;margin-bottom:14px}
.coach .av{width:54px;height:54px;border-radius:12px;background:linear-gradient(135deg,var(--blau),var(--signal));flex:none}
.coach b{font-family:var(--display);display:block;font-size:16px}
.coach small{color:var(--grau);font-family:var(--mono);font-size:12px}
.ttable{width:100%;border-collapse:collapse}
.ttable td{padding:11px 0;border-bottom:1px solid var(--linie);font-size:14.5px}
.ttable td:first-child{font-family:var(--mono);color:var(--blau);font-size:13px;width:90px}
.ttable td:last-child{text-align:right;font-family:var(--mono);color:var(--grau);font-size:13px}
.fussball{background:var(--schaum);border:1px dashed #c4d3e6;border-radius:14px;padding:22px;text-align:center;color:var(--grau);font-size:14px}
.fussball b{display:block;font-family:var(--display);color:var(--tinte);font-size:16px;margin-bottom:4px}
.fussball .badge{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--blau);text-transform:uppercase}

/* Responsive */
@media(max-width:900px){
  nav.main{display:none}
  .menu-btn{display:block}
  .head .btn{display:none}
  .hero .wrap{grid-template-columns:1fr;padding:60px 24px 120px}
  .news-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .train .grid,.tbody{grid-template-columns:1fr;gap:28px}
  .stats{gap:22px}
  .cta-band{padding:40px 26px}
  .fgrid{grid-template-columns:1fr 1fr;gap:28px}
}
@media(max-width:560px){
  .team-grid{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr}
  .stats b{font-size:24px}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto}}
