/* VfR Umkirch Lions — Basketball
   Helles Design ohne dunkle Overlays
*/

*, *::before, *::after { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  scroll-padding-top: 80px;
  background: #ffffff;
}

body {
  margin: 0;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 17px;
  line-height: 1.6;
  color: #1a1a23;
  background: #ffffff;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }

a { color: #0033A0; text-decoration: none; }
a:hover { text-decoration: underline; }

h1, h2, h3, h4 {
  font-family: 'Oswald', sans-serif;
  font-weight: 700;
  line-height: 1.2;
  margin: 0 0 .4em;
  color: #1a1a23;
}
h1 { font-size: clamp(2.4rem, 5vw, 3.8rem); }
h2 { font-size: clamp(1.8rem, 3.5vw, 2.4rem); }
h3 { font-size: 1.25rem; }

p { margin: 0 0 1em; }

.wrap { max-width: 1180px; margin: 0 auto; padding: 0 24px; }

/* --- BUTTONS --- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 11px 22px;
  border-radius: 999px;
  font: 600 .95rem/1 'Inter', sans-serif;
  text-decoration: none !important;
  border: 2px solid transparent;
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
}
.btn-blue { background: #0033A0; color: #ffffff; }
.btn-blue:hover { background: #00237a; }
.btn-orange { background: #ee6c1a; color: #ffffff; }
.btn-orange:hover { background: #c4540d; }
.btn-outline { background: #ffffff; color: #0033A0; border-color: #0033A0; }
.btn-outline:hover { background: #0033A0; color: #ffffff; }
.btn-blue-lg, .btn-orange-lg { padding: 14px 28px; font-size: 1rem; }
.btn-blue-lg { background: #0033A0; color: #ffffff; }
.btn-blue-lg:hover { background: #00237a; }
.btn-orange-lg { background: #ee6c1a; color: #ffffff; }
.btn-orange-lg:hover { background: #c4540d; }
.btn.full { width: 100%; }

/* --- HEADER --- */
.header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: #ffffff;
  border-bottom: 1px solid #e5e5ea;
  height: 72px;
}
.header .wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  gap: 16px;
}
.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  color: #1a1a23 !important;
  text-decoration: none !important;
}
.brand img { width: 44px; height: 44px; object-fit: contain; }
.brand strong {
  display: block;
  font-family: 'Oswald', sans-serif;
  font-size: 1.05rem;
}
.brand small { color: #6b6b73; font-size: .8rem; }

.header nav {
  display: flex;
  align-items: center;
  gap: 4px;
}
.header nav a {
  padding: 9px 14px;
  border-radius: 8px;
  color: #1a1a23;
  font-weight: 500;
  font-size: .95rem;
  text-decoration: none !important;
}
.header nav a:hover { background: #f4f4f7; }
.header nav a.btn-blue {
  background: #0033A0;
  color: #ffffff;
}
.header nav a.btn-blue:hover { background: #00237a; }
.header nav a.btn-orange {
  background: #ee6c1a;
  color: #ffffff;
}
.header nav a.btn-orange:hover { background: #c4540d; }

.burger {
  display: none;
  background: none;
  border: 0;
  font-size: 28px;
  cursor: pointer;
  padding: 4px 10px;
  color: #1a1a23;
}

/* --- HERO --- */
.hero {
  padding: 64px 0 72px;
  background: linear-gradient(180deg, #f4f7ff 0%, #ffffff 100%);
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 48px;
  align-items: center;
}
.eyebrow {
  display: inline-block;
  font-family: 'Oswald', sans-serif;
  letter-spacing: .15em;
  text-transform: uppercase;
  font-size: .82rem;
  color: #0033A0;
  margin-bottom: 14px;
  font-weight: 500;
}
.eyebrow-orange { color: #ee6c1a; }
.hero h1 .accent { color: #ee6c1a; }
.lead {
  font-size: 1.12rem;
  color: #444;
  margin: 18px 0 28px;
}
.hero-cta {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.motto {
  margin: 22px 0 0;
  font-size: .92rem;
  color: #6b6b73;
  letter-spacing: .04em;
}
.motto span {
  display: inline-block;
  background: #ee6c1a;
  color: #ffffff;
  font-family: 'Oswald', sans-serif;
  font-weight: 700;
  letter-spacing: .12em;
  padding: 3px 10px;
  border-radius: 6px;
  margin-right: 8px;
}
.hero-img {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 20px 50px rgba(0,51,160,.18);
}
.hero-img > img:first-child {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}
.hero-badge {
  position: absolute;
  bottom: -16px;
  right: -16px;
  width: 110px;
  height: 110px;
  background: #ffffff;
  border-radius: 50%;
  padding: 10px;
  box-shadow: 0 10px 30px rgba(0,0,0,.15);
}

/* --- SECTIONS --- */
.section { padding: 80px 0; background: #ffffff; }
.section-soft { background: #f7f8fb; }
.section-blue { background: #0033A0; color: #ffffff; }
.section-orange-light { background: #fff7ef; }
.sec-head {
  text-align: center;
  max-width: 760px;
  margin: 0 auto 48px;
}
.sec-head .sub { color: #6b6b73; font-size: 1.05rem; }
.sec-head.light h2 { color: #ffffff; }
.sec-head.light .sub { color: rgba(255,255,255,.85); }
.sec-head.light .eyebrow { color: #ffc83a; }

.two-col {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 56px;
  align-items: center;
}
.ball-list {
  list-style: none;
  padding: 0;
  margin: 0 0 18px;
}
.ball-list li {
  position: relative;
  padding: 6px 0 6px 32px;
}
.ball-list li::before {
  content: "🏀";
  position: absolute;
  left: 0;
  top: 6px;
}
.cta-row {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 24px;
}
.wappen-box {
  text-align: center;
  padding: 24px;
}
.wappen-box img { max-width: 280px; margin: 0 auto 14px; }
.wappen-box p { color: #6b6b73; font-style: italic; }

/* --- TEAMS --- */
.team-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.team-card {
  background: #ffffff;
  border: 1px solid #e5e5ea;
  border-radius: 14px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 2px 10px rgba(0,0,0,.04);
  transition: transform .15s, box-shadow .15s;
  position: relative;
}
.team-card:hover { transform: translateY(-4px); box-shadow: 0 12px 30px rgba(0,0,0,.1); }
.team-photo {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
}
.team-body {
  padding: 24px 26px 26px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.team-pill {
  display: inline-block;
  background: #0033A0;
  color: #ffffff;
  padding: 4px 14px;
  border-radius: 999px;
  font-family: 'Oswald', sans-serif;
  font-size: .85rem;
  letter-spacing: .08em;
  margin-bottom: 14px;
  align-self: flex-start;
}
.team-pill-orange { background: #ee6c1a; }
.team-flag {
  position: absolute;
  top: 18px;
  right: 18px;
  background: #ffc83a;
  color: #1a1a23;
  padding: 5px 14px;
  border-radius: 999px;
  font-family: 'Oswald', sans-serif;
  font-size: .82rem;
  letter-spacing: .03em;
  box-shadow: 0 4px 12px rgba(0,0,0,.15);
}
.team-card h3 { font-size: 1.6rem; margin-bottom: 6px; color: #0033A0; }
.team-u14 h3 { color: #ee6c1a; }
.team-age { color: #6b6b73; font-size: .95rem; margin-bottom: 14px; }
.team-card ul {
  list-style: none;
  padding: 0;
  margin: 0 0 16px;
  font-size: .95rem;
}
.team-card ul li { padding: 5px 0; border-bottom: 1px solid #f0f0f5; }
.team-card ul li:last-child { border-bottom: 0; }
.recruit {
  background: #fff7ef;
  border-left: 4px solid #ee6c1a;
  padding: 12px 14px;
  border-radius: 6px;
  font-size: .9rem;
  margin: 10px 0 16px;
}
.card-cta {
  margin-top: auto;
  color: #0033A0;
  font-weight: 600;
  font-size: .95rem;
}
.card-cta-orange { color: #ee6c1a; }
.trainer-line {
  text-align: center;
  color: #6b6b73;
  margin-top: 40px;
  font-size: .98rem;
}

/* --- SCHEDULE --- */
.schedule {
  display: grid;
  grid-template-columns: 1fr 1fr 1.2fr;
  gap: 20px;
  margin-bottom: 40px;
}
.day {
  background: #ffffff;
  border: 1px solid #e5e5ea;
  border-radius: 14px;
  padding: 24px;
}
.day h3 {
  font-size: 1.2rem;
  color: #0033A0;
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 2px solid #e7ecff;
}
.slot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid #f0f0f5;
  font-size: .98rem;
}
.slot:last-child { border-bottom: 0; }
.slot span:first-child {
  font-family: 'Oswald', sans-serif;
  color: #1a1a23;
}
.badge {
  background: #0033A0;
  color: #ffffff;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: .78rem;
  font-family: 'Oswald', sans-serif;
}
.day.info h3 { color: #ee6c1a; }
.day.info p { font-size: .92rem; margin: 0 0 8px; }

/* --- GALLERY --- */
.gallery {
  display: grid;
  gap: 12px;
}
.gallery.g3 { grid-template-columns: repeat(3, 1fr); }
.gallery.g4 { grid-template-columns: repeat(4, 1fr); }
.gallery img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 10px;
  cursor: zoom-in;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
  transition: transform .15s;
}
.gallery img:hover { transform: scale(1.02); }

/* --- TRAINER (Lead = Abteilungsleitung mit Foto, Extra = nur Text-Kasten) --- */
.trainer-lead-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  max-width: 920px;
  margin: 0 auto 28px;
}
.trainer-lead {
  background: #ffffff;
  border: 1px solid #e5e5ea;
  border-radius: 14px;
  overflow: hidden;
  display: grid;
  grid-template-columns: 180px 1fr;
  align-items: stretch;
  box-shadow: 0 2px 10px rgba(0,0,0,.05);
}
.trainer-lead > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}
.trainer-lead > div { padding: 22px 24px; }
.trainer-lead h3 { font-size: 1.2rem; margin-bottom: 4px; }
.trainer-lead .role {
  color: #ee6c1a;
  font-weight: 600;
  font-size: .9rem;
  margin: 0 0 12px;
}
.trainer-lead p {
  font-size: .92rem;
  margin: 0 0 6px;
  line-height: 1.5;
}
.trainer-lead small { color: #6b6b73; }

.trainer-extra-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  max-width: 920px;
  margin: 0 auto;
}
.trainer-extra {
  background: #f7f8fb;
  border: 1px solid #e5e5ea;
  border-radius: 12px;
  padding: 20px 24px;
}
.trainer-extra h3 { font-size: 1.1rem; margin-bottom: 4px; }
.trainer-extra .role {
  color: #ee6c1a;
  font-weight: 600;
  font-size: .88rem;
  margin: 0 0 8px;
}
.trainer-extra p { margin: 0; font-size: .9rem; }

/* --- EVENTS / SPIELBETRIEB --- */
.events-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 56px;
}
.event-card {
  background: #ffffff;
  border: 1px solid #e5e5ea;
  border-radius: 14px;
  padding: 28px;
  box-shadow: 0 2px 10px rgba(0,0,0,.04);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.event-card-highlight {
  border-color: #ee6c1a;
  background: linear-gradient(180deg, #fff7ef 0%, #ffffff 60%);
}
.event-pill {
  align-self: flex-start;
  background: #0033A0;
  color: #ffffff;
  padding: 4px 14px;
  border-radius: 999px;
  font-family: 'Oswald', sans-serif;
  font-size: .82rem;
  letter-spacing: .08em;
  margin-bottom: 6px;
}
.event-pill-orange { background: #ee6c1a; }
.event-card h3 { font-size: 1.25rem; color: #0033A0; margin-bottom: 2px; }
.event-card-highlight h3 { color: #ee6c1a; }
.event-meta {
  font-size: .85rem;
  color: #6b6b73;
  text-transform: uppercase;
  letter-spacing: .05em;
  font-weight: 600;
  margin: 0 0 8px;
}
.event-card p { font-size: .95rem; margin: 0 0 6px; }
.event-note {
  font-size: .85rem;
  color: #6b6b73;
  font-style: italic;
  margin-top: auto;
  padding-top: 8px;
}

/* --- U-Gallery --- */
.u-gallery { display: flex; flex-direction: column; gap: 32px; }
.u-gallery-block h4 {
  font-family: 'Oswald', sans-serif;
  font-size: 1.1rem;
  color: #0033A0;
  margin: 0 0 14px;
  padding-bottom: 8px;
  border-bottom: 2px solid #e7ecff;
}

/* --- SPONSOREN --- */
.section-sponsor {
  background: linear-gradient(180deg, #f4f7ff 0%, #ffffff 100%);
}
.sponsor-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-bottom: 48px;
}
.sponsor-block {
  background: #ffffff;
  border: 1px solid #e5e5ea;
  border-radius: 14px;
  padding: 32px;
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
}
.sponsor-block h3 {
  color: #0033A0;
  font-size: 1.35rem;
  margin-bottom: 16px;
}
.sponsor-list {
  list-style: none;
  padding: 0;
  margin: 0 0 16px;
}
.sponsor-list li {
  position: relative;
  padding: 8px 0 8px 26px;
  font-size: .98rem;
  border-bottom: 1px solid #f0f0f5;
}
.sponsor-list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 7px;
  color: #ee6c1a;
  font-weight: 700;
}
.sponsor-list li:last-child { border-bottom: 0; }
.sponsor-note {
  font-size: .9rem;
  font-style: italic;
  color: #6b6b73;
  margin: 0;
}
.form-card-sponsor { background: #ffffff; }

.sponsor-example {
  margin: 0 0 48px;
  background: #ffffff;
  border: 1px solid #e5e5ea;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
}
.sponsor-example img {
  width: 100%;
  height: auto;
  display: block;
}
.sponsor-example figcaption {
  padding: 28px 36px 32px;
}
.sponsor-example figcaption h3 {
  color: #0033A0;
  font-size: 1.35rem;
  margin-bottom: 10px;
}
.sponsor-example figcaption p {
  margin: 0;
  font-size: 1rem;
  color: #444;
}
.check-group {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 14px;
  margin-top: 4px;
}
.check-inline {
  flex-direction: row !important;
  align-items: center !important;
  gap: 8px !important;
  font-weight: 400 !important;
  font-size: .92rem;
  margin: 0 !important;
}
.check-inline input { margin: 0 !important; }

/* --- Flutlicht-Hint im Day-Head --- */
.hint-light {
  margin-top: 14px !important;
  font-size: .9rem !important;
  background: rgba(255,255,255,.18);
  padding: 10px 14px;
  border-radius: 8px;
  display: inline-block;
}

/* --- Ferien-Hinweis --- */
.ferien-note {
  background: #fff7ef;
  border-left: 4px solid #ee6c1a;
  padding: 16px 22px;
  border-radius: 8px;
  margin: 0;
  font-size: .96rem;
  color: #4a3624;
}

/* --- FORMS --- */
.form-card {
  background: #ffffff;
  color: #1a1a23;
  border-radius: 14px;
  padding: 36px;
  max-width: 820px;
  margin: 0 auto;
  box-shadow: 0 20px 50px rgba(0,0,0,.08);
}
.section-orange-light .form-card { margin-top: 32px; }
.section-orange-light .form-card + .form-card { margin-top: 24px; }
.form-day-head {
  margin: -36px -36px 28px;
  padding: 28px 36px;
  border-radius: 14px 14px 0 0;
  color: #ffffff;
}
.form-day-orange { background: linear-gradient(135deg, #ee6c1a, #c4540d); }
.form-day-blue { background: linear-gradient(135deg, #0033A0, #00237a); }
.form-day-head h3 { color: #ffffff; margin: 8px 0 4px; font-size: 1.5rem; }
.form-day-head p { color: rgba(255,255,255,.95); margin: 0; font-size: .95rem; }
.day-tag {
  display: inline-block;
  background: rgba(255,255,255,.2);
  padding: 4px 12px;
  border-radius: 999px;
  font-family: 'Oswald', sans-serif;
  font-size: .82rem;
  letter-spacing: .08em;
}
.muted { color: #6b6b73; font-size: .9rem; }
.nowrap { white-space: nowrap; }
.form-heading { margin-bottom: 6px; }
.form-sub { color: #6b6b73; margin-bottom: 22px; font-size: .95rem; }
.form-card form { display: flex; flex-direction: column; gap: 16px; }
.form-card .row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-card label {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: .88rem;
  font-weight: 500;
  color: #444;
}
.form-card input,
.form-card select,
.form-card textarea {
  font: inherit;
  padding: 11px 14px;
  border: 1.5px solid #d4d4dc;
  border-radius: 8px;
  background: #ffffff;
  color: #1a1a23;
}
.form-card input:focus,
.form-card select:focus,
.form-card textarea:focus {
  outline: none;
  border-color: #0033A0;
  box-shadow: 0 0 0 3px rgba(0,51,160,.12);
}
.form-card textarea { resize: vertical; min-height: 80px; }
.check {
  flex-direction: row !important;
  align-items: flex-start;
  gap: 10px !important;
  font-size: .86rem;
  font-weight: 400 !important;
  color: #444;
}
.check input { margin-top: 3px; }
.success { text-align: center; padding: 16px 0; }
.success h3 { color: #0033A0; font-size: 1.4rem; margin-bottom: 12px; }
.success ul { text-align: left; max-width: 560px; margin: 12px auto; padding-left: 20px; }

/* --- TURNIER --- */
.turnier-grid {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 40px;
  align-items: start;
  margin-bottom: 48px;
}
.flyer-box { text-align: center; }
.flyer-box img {
  max-width: 100%;
  border-radius: 12px;
  box-shadow: 0 14px 30px rgba(0,0,0,.15);
  margin-bottom: 16px;
}
.facts {
  list-style: none;
  padding: 0;
  margin: 0;
}
.facts li {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 16px;
  padding: 12px 0;
  border-bottom: 1px solid #e7d8c4;
  font-size: .98rem;
}
.facts li:last-child { border-bottom: 0; }
.facts strong {
  font-family: 'Oswald', sans-serif;
  letter-spacing: .05em;
  color: #ee6c1a;
  text-transform: uppercase;
  font-size: .82rem;
}
.kids-note {
  background: #ffffff;
  border-left: 4px solid #ee6c1a;
  padding: 16px 20px;
  border-radius: 8px;
  margin-top: 16px;
}
.kids-note h3 { color: #ee6c1a; margin-bottom: 6px; }
.kids-note p { margin: 0; font-size: .95rem; }
.subhead {
  font-size: 1.4rem;
  margin: 40px 0 20px;
  text-align: center;
}

/* --- KONTAKT --- */
.kontakt-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.kontakt-grid > div {
  background: #f7f8fb;
  padding: 28px;
  border-radius: 14px;
  text-align: center;
}
.kontakt-grid h3 { color: #0033A0; margin-bottom: 10px; }
.big { font-size: 1.1rem; font-weight: 600; word-break: break-word; }

/* --- FOOTER --- */
.footer {
  background: #1a1a23;
  color: rgba(255,255,255,.7);
  padding: 40px 0 28px;
}
.footer .wrap {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 28px;
}
.foot-brand { display: flex; align-items: center; gap: 14px; }
.foot-brand img { width: 44px; }
.foot-brand strong { display: block; color: #ffffff; font-family: 'Oswald', sans-serif; }
.foot-brand small { font-size: .82rem; }
.footer nav { display: flex; gap: 16px; flex-wrap: wrap; }
.footer nav a { color: rgba(255,255,255,.75); font-size: .9rem; }
.footer nav a:hover { color: #ffc83a; }
.footer .meta { font-size: .82rem; margin: 0; }
.footer .meta a { color: rgba(255,255,255,.75); }

/* --- RESPONSIVE --- */
@media (max-width: 960px) {
  .hero-grid, .two-col, .team-grid, .schedule,
  .turnier-grid, .kontakt-grid, .events-grid,
  .trainer-lead-grid, .trainer-extra-grid,
  .sponsor-grid, .check-group {
    grid-template-columns: 1fr;
  }
  .trainer-lead { grid-template-columns: 130px 1fr; }
  .gallery.g3 { grid-template-columns: repeat(2, 1fr); }
  .gallery.g4 { grid-template-columns: repeat(2, 1fr); }
  .section { padding: 64px 0; }
  .hero { padding: 48px 0 56px; }
  .footer .wrap { grid-template-columns: 1fr; text-align: center; }
  .foot-brand { justify-content: center; }
  .footer nav { justify-content: center; }
}
@media (max-width: 720px) {
  .burger { display: block; }
  .header nav {
    position: absolute;
    top: 72px;
    left: 0;
    right: 0;
    background: #ffffff;
    flex-direction: column;
    padding: 12px;
    gap: 4px;
    border-bottom: 1px solid #e5e5ea;
    box-shadow: 0 10px 30px rgba(0,0,0,.08);
    display: none;
  }
  .header nav.open { display: flex; }
  .header nav a { padding: 12px 16px; text-align: left; }
  .form-card .row { grid-template-columns: 1fr; }
  .form-card { padding: 24px 20px; }
  .form-day-head { margin: -24px -20px 20px; padding: 22px 24px; }
  .sponsor-example figcaption { padding: 22px 22px 24px; }
  .facts li { grid-template-columns: 1fr; gap: 2px; }
}
@media (max-width: 480px) {
  .gallery.g3, .gallery.g4 { grid-template-columns: 1fr; }
}
