/* =========================================================================
   BOBO Broadcast — Hauptstyles
   Nike/Champions-League-Look: dark, datenreich, asymmetrisches Grid.
   ========================================================================= */

.bc { min-height: 100vh; color: #fff;
  background:
    linear-gradient(rgba(11,13,15,.55), rgba(11,13,15,.74)),
    url(../assets/Rasen.png) center bottom / cover fixed,
    #0b0d0f;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --bc-mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  --bc-lime: #c8ff4c;
}
.bc * { box-sizing: border-box; }

/* -------------------------------------------------------------------------
   TICKER
   ------------------------------------------------------------------------- */
.bc-ticker {
  background: #000; border-bottom: 1px solid rgba(255,255,255,.08);
  overflow: hidden; white-space: nowrap; position: relative;
}
.bc-ticker-track {
  display: inline-block; padding: 8px 0; font-family: var(--bc-mono);
  font-size: 11px; letter-spacing: 1px; text-transform: uppercase; color: rgba(255,255,255,.55);
  animation: bcTick 45s linear infinite;
}
.bc-ticker-track span { padding: 0 24px; }
.bc-ticker-track span b { color: var(--bc-lime); font-weight: 700; }
@keyframes bcTick { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* -------------------------------------------------------------------------
   NAVIGATION
   ------------------------------------------------------------------------- */
.bc-nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(11,13,15,.9); backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.bc-nav-inner {
  max-width: 1560px; margin: 0 auto; padding: 16px 32px;
  display: grid; grid-template-columns: auto 1fr auto; gap: 32px; align-items: center;
}
.bc-brand { display: flex; align-items: center; gap: 12px; text-decoration: none; color: #fff; }
.bc-brand-mark {
  width: 42px; height: 42px; background: var(--bc-lime); color: #000;
  display: grid; place-items: center; font-weight: 900; font-size: 18px; letter-spacing: -1px;
  clip-path: polygon(0 0, 100% 0, 100% 80%, 80% 100%, 0 100%);
  flex-shrink: 0;
}
.bc-brand-text strong { display: block; font-weight: 900; font-size: 14px; letter-spacing: 0; text-transform: uppercase; }
.bc-brand-text span { display: block; font-family: var(--bc-mono); font-size: 10px; color: rgba(255,255,255,.5); letter-spacing: 1px; margin-top: 2px; }
.bc-nav-links { display: flex; gap: 2px; justify-self: center; }
.bc-nav-links a {
  padding: 10px 16px; font-size: 12px; font-weight: 900; color: rgba(255,255,255,.65);
  text-decoration: none; text-transform: uppercase; letter-spacing: 1px;
  position: relative; transition: color .15s ease;
}
.bc-nav-links a:hover, .bc-nav-links a.is-active { color: var(--bc-lime); }
.bc-nav-links a.is-active::before {
  content: ''; position: absolute; left: 16px; right: 16px; bottom: -1px; height: 2px; background: var(--bc-lime);
}
.bc-nav-right { display: flex; align-items: center; gap: 10px; }
.bc-lang { display: flex; font-family: var(--bc-mono); font-size: 11px; border: 1px solid rgba(255,255,255,.15); }
.bc-lang button { padding: 6px 10px; background: none; border: 0; color: rgba(255,255,255,.5); cursor: pointer; font-family: inherit; font-weight: 700; }
.bc-lang button.is-active { background: var(--bc-lime); color: #000; }

/* Mobile Hamburger */
.bc-hamburger {
  display: none; background: none; border: 1px solid rgba(255,255,255,.15); color: #fff;
  cursor: pointer; width: 38px; height: 38px; align-items: center; justify-content: center;
  font-size: 18px; line-height: 1; padding: 0;
}
.bc-mobile-menu {
  display: none; position: absolute; top: 100%; left: 0; right: 0;
  background: rgba(11,13,15,.98); border-bottom: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(12px); z-index: 100;
}
.bc-mobile-menu.is-open { display: block; }
.bc-mobile-menu a {
  display: block; padding: 14px 24px; font-size: 13px; font-weight: 900;
  color: rgba(255,255,255,.7); text-decoration: none; text-transform: uppercase; letter-spacing: 1px;
  border-left: 3px solid transparent; border-bottom: 1px solid rgba(255,255,255,.05);
  transition: all .15s ease;
}
.bc-mobile-menu a:hover, .bc-mobile-menu a.is-active { color: var(--bc-lime); border-left-color: var(--bc-lime); background: rgba(200,255,76,.04); }

/* -------------------------------------------------------------------------
   BUTTONS
   ------------------------------------------------------------------------- */
.bc-btn {
  display: inline-flex; align-items: center; gap: 8px; padding: 12px 20px;
  background: transparent; border: 1px solid rgba(255,255,255,.2); color: #fff;
  font-size: 12px; font-weight: 900; text-transform: uppercase; letter-spacing: 1px;
  text-decoration: none; cursor: pointer; transition: all .15s ease;
  font-family: inherit;
}
.bc-btn:hover { border-color: var(--bc-lime); color: var(--bc-lime); }
.bc-btn:disabled { opacity: .35; cursor: not-allowed; }
.bc-btn--primary { background: var(--bc-lime); color: #000; border-color: var(--bc-lime); }
.bc-btn--primary:hover { background: #fff; border-color: #fff; color: #000; }
.bc-btn--block { width: 100%; justify-content: center; }

/* -------------------------------------------------------------------------
   HERO — asymmetrisches Grid
   ------------------------------------------------------------------------- */
.bc-hero {
  position: relative; padding: 40px 32px; max-width: 1560px; margin: 0 auto;
}
.bc-hero-grid {
  display: grid; grid-template-columns: 1.6fr 1fr; grid-template-rows: auto auto;
  gap: 16px;
}
.bc-hero-main {
  position: relative; overflow: hidden; aspect-ratio: 16/11; grid-row: span 2;
  background: url(../assets/slider1.jpg) center/cover;
}
.bc-hero-main::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(0deg, rgba(0,0,0,.9) 0%, rgba(0,0,0,.3) 50%, rgba(0,0,0,0) 100%);
}
.bc-hero-main-body {
  position: absolute; left: 0; right: 0; bottom: 0; padding: 40px;
  display: flex; flex-direction: column; gap: 16px;
}
.bc-live-badge {
  display: inline-flex; align-items: center; gap: 8px; align-self: flex-start;
  background: #ff3030; padding: 5px 10px; font-family: var(--bc-mono); font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
}
.bc-live-badge i { width: 6px; height: 6px; border-radius: 999px; background: #fff; animation: bcPulse 1.2s infinite; }
@keyframes bcPulse { 0%, 100% { opacity: 1; } 50% { opacity: .3; } }
.bc-hero-main h1 {
  font-size: clamp(48px, 8vw, 112px); font-weight: 900; line-height: .85; letter-spacing: -3px;
  text-transform: uppercase; margin: 0; color: #fff;
}
.bc-hero-main h1 em { font-style: normal; color: var(--bc-lime); }
.bc-hero-main p { font-size: 14px; color: rgba(255,255,255,.8); max-width: 480px; line-height: 1.5; margin: 0; }
.bc-hero-main-meta {
  display: flex; gap: 24px; padding-top: 16px; border-top: 1px solid rgba(255,255,255,.15);
  font-family: var(--bc-mono); font-size: 11px; color: rgba(255,255,255,.6); text-transform: uppercase; letter-spacing: 1px;
}
.bc-hero-main-meta b { color: var(--bc-lime); }
.bc-hero-cta { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 4px; }

.bc-hero-side-card {
  background: rgba(20,23,26,.55); border: 1px solid rgba(255,255,255,.08);
  padding: 28px;
  display: flex; flex-direction: column;
}
.bc-hero-side-card--coach { padding: 0; overflow: hidden; position: relative; }
.bc-hero-side-card--coach .bc-coach-photo {
  aspect-ratio: 4/3; background: linear-gradient(180deg, rgba(200,255,76,.08), #0b0d0f);
  display: grid; place-items: end center; overflow: hidden;
}
.bc-hero-side-card--coach img { width: 85%; height: auto; filter: drop-shadow(0 20px 40px rgba(0,0,0,.7)); }
.bc-hero-side-card--coach .bc-coach-tag {
  position: absolute; top: 16px; left: 16px;
  font-family: var(--bc-mono); font-size: 10px; font-weight: 700; color: var(--bc-lime);
  background: rgba(0,0,0,.6); padding: 5px 10px; letter-spacing: 1px; text-transform: uppercase;
}
.bc-hero-side-card--coach .bc-coach-foot {
  padding: 20px 24px; border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(20,23,26,.55);
}
.bc-hero-side-card--coach h3 { font-size: 18px; font-weight: 900; margin: 0 0 4px; text-transform: uppercase; letter-spacing: -.2px; }
.bc-hero-side-card--coach span { font-family: var(--bc-mono); font-size: 11px; color: rgba(255,255,255,.55); text-transform: uppercase; letter-spacing: .5px; }

.bc-hero-stats h4 { font-family: var(--bc-mono); font-size: 10px; color: var(--bc-lime); letter-spacing: 1.5px; text-transform: uppercase; margin: 0 0 20px; display: flex; align-items: center; gap: 10px; }
.bc-hero-stats h4::after { content: ''; flex: 1; height: 1px; background: rgba(255,255,255,.1); }
.bc-hero-stats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px 16px; }
.bc-hero-stats-grid > div { display: flex; flex-direction: column; gap: 4px; }
.bc-hero-stats-grid b { font-size: 36px; font-weight: 900; letter-spacing: -1px; color: #fff; line-height: 1; }
.bc-hero-stats-grid b em { color: var(--bc-lime); font-style: normal; }
.bc-hero-stats-grid span { font-family: var(--bc-mono); font-size: 10px; color: rgba(255,255,255,.5); text-transform: uppercase; letter-spacing: .8px; }

/* -------------------------------------------------------------------------
   SECTIONS
   ------------------------------------------------------------------------- */
.bc-section { max-width: 1560px; margin: 0 auto; padding: 40px 32px; }
.bc-section-head { display: grid; grid-template-columns: 1fr auto; gap: 24px; align-items: end; margin-bottom: 32px; padding-bottom: 24px; border-bottom: 1px solid rgba(255,255,255,.1); }
.bc-section-head h2 { font-size: clamp(32px, 4vw, 56px); font-weight: 900; line-height: .95; letter-spacing: -1.2px; text-transform: uppercase; margin: 0; }
.bc-section-head h2 em { font-style: normal; color: var(--bc-lime); }
.bc-section-head .bc-head-meta { font-family: var(--bc-mono); font-size: 11px; color: rgba(255,255,255,.5); text-transform: uppercase; letter-spacing: 1px; display: flex; gap: 16px; }
.bc-section-head .bc-head-meta span { display: inline-flex; align-items: center; gap: 6px; }
.bc-section-head .bc-head-meta b { color: var(--bc-lime); font-weight: 700; }

/* -------------------------------------------------------------------------
   PROGRAMME
   ------------------------------------------------------------------------- */
.bc-programs { display: grid; grid-template-columns: repeat(6, 1fr); gap: 1px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.08); }
.bc-program {
  background: rgba(15,18,21,.5); padding: 24px; cursor: pointer; transition: all .2s ease;
  display: flex; flex-direction: column; gap: 12px; aspect-ratio: 3/4;
  position: relative; overflow: hidden;
}
.bc-program:hover { background: rgba(21,26,31,.62); }
.bc-program:hover .bc-program-num { color: var(--bc-lime); }
.bc-program-num { font-family: var(--bc-mono); font-size: 11px; color: rgba(255,255,255,.4); letter-spacing: 1px; }
.bc-program-icon { width: 40px; height: 40px; color: var(--bc-lime); margin-top: auto; }
.bc-program h3 { font-size: 17px; font-weight: 900; margin: 0 0 6px; text-transform: uppercase; letter-spacing: -.2px; line-height: 1; }
.bc-program p { font-size: 12px; color: rgba(255,255,255,.6); line-height: 1.5; margin: 0; }
.bc-program-foot { margin-top: 8px; display: flex; justify-content: space-between; align-items: center; padding-top: 10px; border-top: 1px solid rgba(255,255,255,.08); font-family: var(--bc-mono); font-size: 10px; color: rgba(255,255,255,.45); text-transform: uppercase; letter-spacing: .5px; }
.bc-program-foot b { color: var(--bc-lime); }

/* -------------------------------------------------------------------------
   BUCHUNG (Booking)
   ------------------------------------------------------------------------- */
.bc-booking-wrap {
  background: rgba(15,18,21,.5); backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px);
  border: 1px solid rgba(255,255,255,.08);
  display: grid; grid-template-columns: 320px 1fr; min-height: 700px;
}
.bc-booking-side {
  background: #000; padding: 32px 28px; border-right: 1px solid rgba(255,255,255,.08);
  display: flex; flex-direction: column;
}
.bc-booking-side h3 { font-size: 26px; font-weight: 900; line-height: .95; text-transform: uppercase; letter-spacing: -.5px; margin: 0 0 12px; }
.bc-booking-side h3 em { font-style: normal; color: var(--bc-lime); }
.bc-booking-side p { font-size: 12px; color: rgba(255,255,255,.55); line-height: 1.5; margin: 0 0 32px; }
.bc-step-list { display: flex; flex-direction: column; gap: 2px; margin-bottom: auto; }
.bc-step-list > div {
  padding: 14px 12px; display: grid; grid-template-columns: 24px 1fr auto; gap: 12px;
  align-items: center; font-family: var(--bc-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 1px;
  color: rgba(255,255,255,.4); border-left: 2px solid transparent;
}
.bc-step-list > div.is-done { color: rgba(255,255,255,.7); }
.bc-step-list > div.is-active { color: var(--bc-lime); border-left-color: var(--bc-lime); background: rgba(200,255,76,.05); }
.bc-step-list > div b { font-weight: 700; }
.bc-step-num { color: rgba(255,255,255,.3); font-weight: 700; }
.bc-step-list > div.is-active .bc-step-num { color: var(--bc-lime); }
.bc-step-value { color: rgba(255,255,255,.5); font-size: 10px; }
.bc-booking-live {
  padding: 12px; background: rgba(200,255,76,.05); border: 1px solid rgba(200,255,76,.2);
  display: flex; align-items: center; gap: 10px; font-family: var(--bc-mono); font-size: 10px; letter-spacing: 1px; text-transform: uppercase; color: var(--bc-lime);
}
.bc-booking-live i { width: 6px; height: 6px; border-radius: 999px; background: var(--bc-lime); animation: bcPulse 1.5s infinite; }

.bc-booking { padding: 32px; }
.bc-label { display: block; font-family: var(--bc-mono); font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255,255,255,.5); margin-bottom: 12px; }

.bc-book-row { margin-bottom: 24px; }
.bc-book-row--controls { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }

.bc-seg { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; }
.bc-seg button {
  padding: 12px; background: #0b0d0f; border: 1px solid rgba(255,255,255,.1);
  cursor: pointer; color: rgba(255,255,255,.7); transition: all .15s ease;
  display: flex; flex-direction: column; align-items: flex-start; gap: 4px; font-family: inherit;
}
.bc-seg button:hover { border-color: rgba(255,255,255,.3); }
.bc-seg button.is-active { border-color: var(--bc-lime); background: rgba(200,255,76,.08); color: #fff; }
.bc-seg b { font-size: 16px; font-weight: 900; }
.bc-seg b i { font-family: var(--bc-mono); font-style: normal; font-weight: 400; font-size: 10px; color: rgba(255,255,255,.4); margin-left: 2px; }
.bc-seg em { font-family: var(--bc-mono); font-style: normal; font-size: 11px; color: var(--bc-lime); font-weight: 700; }

.bc-coach-pick { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; }
.bc-coach-pick button {
  padding: 8px; background: #0b0d0f; border: 1px solid rgba(255,255,255,.1);
  cursor: pointer; transition: all .15s ease;
  display: flex; align-items: center; gap: 8px; text-align: left; font-family: inherit;
  color: rgba(255,255,255,.75);
}
.bc-coach-pick button:hover { border-color: rgba(255,255,255,.3); }
.bc-coach-pick button.is-active { border-color: var(--bc-lime); background: rgba(200,255,76,.08); }
.bc-coach-av {
  width: 32px; height: 32px; background: rgba(200,255,76,.12) center/cover no-repeat;
  border: 1px solid rgba(200,255,76,.3); flex-shrink: 0;
  display: grid; place-items: center; color: var(--bc-lime); font-weight: 900; font-size: 11px; font-family: var(--bc-mono);
}
.bc-coach-meta b { display: block; font-size: 11px; font-weight: 900; color: #fff; text-transform: uppercase; letter-spacing: .2px; }
.bc-coach-meta em { display: block; font-family: var(--bc-mono); font-size: 9px; font-style: normal; color: rgba(255,255,255,.5); letter-spacing: .5px; }

.bc-book-row--cal { display: grid; grid-template-columns: 1.1fr 1fr; gap: 24px; align-items: start; }

/* Kalender */
.bc-cal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; padding-bottom: 12px; border-bottom: 1px solid rgba(255,255,255,.08); }
.bc-cal-head h4 { font-family: var(--bc-mono); font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; margin: 0; color: #fff; }
.bc-cal-head button { width: 28px; height: 28px; background: #0b0d0f; border: 1px solid rgba(255,255,255,.1); color: #fff; cursor: pointer; font-size: 14px; font-family: inherit; }
.bc-cal-head button:hover { border-color: var(--bc-lime); color: var(--bc-lime); }

.bc-cal-dow { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; margin-bottom: 2px; }
.bc-cal-dow span { text-align: center; font-family: var(--bc-mono); font-size: 9px; font-weight: 700; color: rgba(255,255,255,.35); text-transform: uppercase; letter-spacing: 1px; padding: 6px 0; }
.bc-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; }
.bc-cal-day {
  aspect-ratio: 1; border: 1px solid transparent; background: #0b0d0f;
  cursor: pointer; color: rgba(255,255,255,.8); font-weight: 700; font-family: var(--bc-mono);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px;
  transition: all .1s ease; position: relative; font-size: 12px;
}
.bc-cal-day:not(:disabled):hover { border-color: var(--bc-lime); color: var(--bc-lime); }
.bc-cal-day--empty { background: transparent; border: 0; cursor: default; }
.bc-cal-day--past, .bc-cal-day--closed { color: rgba(255,255,255,.15); cursor: not-allowed; background: rgba(255,255,255,.02); }
.bc-cal-day--full { color: rgba(255,60,60,.6); cursor: not-allowed; background: rgba(255,60,60,.05); border-color: rgba(255,60,60,.15); }
.bc-cal-day.is-selected { background: var(--bc-lime); color: #000; border-color: var(--bc-lime); }
.bc-cal-num { font-size: 13px; font-weight: 700; }
.bc-cal-dot { width: 3px; height: 3px; background: var(--bc-lime); opacity: .7; }
.bc-cal-day--low .bc-cal-dot { background: #ffb040; }
.bc-cal-day--full .bc-cal-dot { display: none; }
.bc-cal-day.is-selected .bc-cal-dot { display: none; }

.bc-cal-legend { display: flex; gap: 16px; margin-top: 12px; font-family: var(--bc-mono); font-size: 10px; color: rgba(255,255,255,.45); text-transform: uppercase; letter-spacing: .8px; }
.bc-cal-legend span { display: inline-flex; align-items: center; gap: 6px; }
.bc-lg { width: 6px; height: 6px; }
.bc-lg--open { background: var(--bc-lime); }
.bc-lg--low { background: #ffb040; }
.bc-lg--full { background: #ff3c3c; }

/* Slots */
.bc-slots { background: #0b0d0f; border: 1px solid rgba(255,255,255,.08); padding: 16px; min-height: 300px; }
.bc-slots-head { margin-bottom: 12px; padding-bottom: 12px; border-bottom: 1px solid rgba(255,255,255,.08); }
.bc-slots-head h4 { font-family: var(--bc-mono); font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; margin: 4px 0 0; color: #fff; }
.bc-slots-empty { color: rgba(255,255,255,.35); }
.bc-slots-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 4px; }
.bc-slot {
  padding: 10px 8px; background: rgba(20,23,26,.55); border: 1px solid rgba(255,255,255,.08);
  cursor: pointer; transition: all .15s ease; color: rgba(255,255,255,.8); font-family: inherit;
  display: flex; flex-direction: column; align-items: center; gap: 2px;
}
.bc-slot:hover:not(:disabled) { border-color: var(--bc-lime); color: var(--bc-lime); }
.bc-slot.is-selected { background: var(--bc-lime); color: #000; border-color: var(--bc-lime); }
.bc-slot.is-taken { background: rgba(255,60,60,.06); border-color: rgba(255,60,60,.2); color: rgba(255,60,60,.5); cursor: not-allowed; text-decoration: line-through; }
.bc-slot b { font-family: var(--bc-mono); font-size: 13px; font-weight: 700; }
.bc-slot em { font-family: var(--bc-mono); font-style: normal; font-size: 9px; letter-spacing: .5px; text-transform: uppercase; opacity: .8; }
.bc-slots-none { padding: 40px 0; text-align: center; font-family: var(--bc-mono); font-size: 11px; color: rgba(255,255,255,.35); text-transform: uppercase; letter-spacing: 1px; }
.bc-slots-cta { margin-top: 16px; }

/* Formular */
.bc-booking--form .bc-form-head { display: flex; align-items: center; gap: 16px; margin-bottom: 24px; padding-bottom: 16px; border-bottom: 1px solid rgba(255,255,255,.08); }
.bc-booking--form h3 { font-size: 22px; font-weight: 900; margin: 0; text-transform: uppercase; letter-spacing: -.3px; }
.bc-back { padding: 6px 12px; background: #0b0d0f; border: 1px solid rgba(255,255,255,.1); color: rgba(255,255,255,.7); cursor: pointer; font-family: var(--bc-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 1px; }
.bc-form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-bottom: 24px; }
.bc-form-wide { grid-column: 1 / -1; }
.bc-form-grid label span { display: block; font-family: var(--bc-mono); font-size: 10px; font-weight: 700; letter-spacing: 1.2px; color: rgba(255,255,255,.5); text-transform: uppercase; margin-bottom: 6px; }
.bc-form-grid input, .bc-form-grid textarea, .bc-form-grid select {
  width: 100%; padding: 11px 12px; background: #0b0d0f; border: 1px solid rgba(255,255,255,.12);
  color: #fff; font-family: inherit; font-size: 13px;
}
.bc-form-grid input:focus, .bc-form-grid textarea:focus, .bc-form-grid select:focus { outline: 0; border-color: var(--bc-lime); }
.bc-form-summary { display: grid; grid-template-columns: 1fr auto; gap: 20px; align-items: end; padding-top: 20px; border-top: 1px solid rgba(255,255,255,.1); }
.bc-summary-box { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.bc-summary-box > div { display: flex; flex-direction: column; gap: 3px; padding: 10px; background: #0b0d0f; border: 1px solid rgba(255,255,255,.08); }
.bc-summary-box span { font-family: var(--bc-mono); font-size: 9px; font-weight: 700; letter-spacing: 1px; color: rgba(255,255,255,.45); text-transform: uppercase; }
.bc-summary-box b { font-size: 13px; font-weight: 900; color: var(--bc-lime); }
.bc-form-summary .bc-btn--primary { min-width: 200px; padding: 14px 24px; }

/* Bestätigung */
.bc-booking--done { text-align: center; padding: 60px 40px; }
.bc-done-icon { width: 70px; height: 70px; margin: 0 auto 20px; background: var(--bc-lime); color: #000; display: grid; place-items: center; }
.bc-done-title { font-size: 28px; font-weight: 900; margin: 0 0 10px; text-transform: uppercase; letter-spacing: -.3px; }
.bc-done-sub { font-family: var(--bc-mono); font-size: 12px; color: rgba(255,255,255,.6); margin: 0 0 24px; letter-spacing: .5px; }
.bc-booking--done .bc-summary-box { max-width: 560px; margin: 0 auto 24px; text-align: left; }

/* Trainer-Karten */
.bc-coaches { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.08); }
.bc-coach-card { background: rgba(15,18,21,.5); padding: 0; display: flex; flex-direction: column; }
.bc-coach-photo-big { aspect-ratio: 4/3; background: linear-gradient(180deg, rgba(200,255,76,.08), #0b0d0f); overflow: hidden; display: grid; place-items: end center; position: relative; }
.bc-coach-photo-big img { width: 100%; height: 100%; object-fit: cover; object-position: center top; filter: contrast(1.1); }
.bc-coach-init { font-size: 84px; font-weight: 900; color: var(--bc-lime); letter-spacing: -3px; opacity: .7; }
.bc-coach-card-body { padding: 24px; flex: 1; display: flex; flex-direction: column; gap: 12px; }
.bc-coach-card-num { font-family: var(--bc-mono); font-size: 10px; color: var(--bc-lime); letter-spacing: 1px; }
.bc-coach-card h3 { font-size: 20px; font-weight: 900; margin: 0; text-transform: uppercase; letter-spacing: -.3px; }
.bc-coach-card .bc-role { font-family: var(--bc-mono); font-size: 11px; color: rgba(255,255,255,.6); letter-spacing: .5px; text-transform: uppercase; display: block; }
.bc-coach-card .bc-tag { font-size: 12px; color: rgba(255,255,255,.55); line-height: 1.5; display: block; }
.bc-coach-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; margin-top: auto; padding-top: 16px; border-top: 1px solid rgba(255,255,255,.08); }
.bc-coach-stats > div { padding: 0 12px; border-right: 1px solid rgba(255,255,255,.08); }
.bc-coach-stats > div:first-child { padding-left: 0; }
.bc-coach-stats > div:last-child { border-right: 0; }
.bc-coach-stats b { display: block; font-family: var(--bc-mono); font-size: 12px; font-weight: 700; color: var(--bc-lime); }
.bc-coach-stats span { display: block; font-family: var(--bc-mono); font-size: 9px; color: rgba(255,255,255,.4); text-transform: uppercase; letter-spacing: .5px; margin-top: 2px; }

/* -------------------------------------------------------------------------
   FOOTER
   ------------------------------------------------------------------------- */
.bc-footer { padding: 40px 32px 24px; border-top: 1px solid rgba(255,255,255,.08); background: #000; }
.bc-footer-inner { max-width: 1560px; margin: 0 auto; }
.bc-footer-top { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 32px; padding-bottom: 32px; border-bottom: 1px solid rgba(255,255,255,.08); margin-bottom: 20px; }
.bc-footer-brand { display: flex; gap: 14px; align-items: flex-start; }
.bc-footer-brand-text strong { display: block; font-weight: 900; font-size: 14px; text-transform: uppercase; }
.bc-footer-brand-text p { font-family: var(--bc-mono); font-size: 11px; color: rgba(255,255,255,.5); margin: 6px 0 14px; line-height: 1.6; max-width: 320px; letter-spacing: .3px; }
.bc-footer h5 { font-family: var(--bc-mono); font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--bc-lime); margin: 0 0 12px; }
.bc-footer a { display: block; font-size: 12px; color: rgba(255,255,255,.65); text-decoration: none; padding: 4px 0; font-family: var(--bc-mono); letter-spacing: .3px; }
.bc-footer a:hover { color: var(--bc-lime); }
.bc-footer-bottom { display: flex; justify-content: space-between; align-items: center; gap: 20px; flex-wrap: wrap; }
.bc-footer-bottom > div { font-family: var(--bc-mono); font-size: 10px; color: rgba(255,255,255,.4); letter-spacing: .5px; text-transform: uppercase; }
.bc-powered { display: inline-flex; flex-direction: column; align-items: flex-start; gap: 10px; }
.bc-powered span { font-family: var(--bc-mono); font-size: 9px; color: rgba(255,255,255,.4); text-transform: uppercase; letter-spacing: 1px; }
.bc-powered-logos { display: flex; flex-direction: row; align-items: center; gap: 16px; flex-wrap: nowrap; }
.bc-sponsor { display: block; }
.bc-sponsor--matkovic { height: 40px; filter: brightness(1.4); }
.bc-sponsor--vinwash { height: 64px; border-radius: 8px; }

/* -------------------------------------------------------------------------
   RESPONSIVE
   ------------------------------------------------------------------------- */
@media (max-width: 1100px) {
  .bc-hero-grid { grid-template-columns: 1fr; }
  .bc-hero-main { grid-row: auto; aspect-ratio: 16/9; }
  .bc-programs { grid-template-columns: repeat(3, 1fr); }
  .bc-booking-wrap { grid-template-columns: 1fr; }
  .bc-booking-side { border-right: 0; border-bottom: 1px solid rgba(255,255,255,.08); }
  .bc-book-row--controls, .bc-book-row--cal { grid-template-columns: 1fr; }
  .bc-coaches { grid-template-columns: 1fr; }
  .bc-footer-top { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 720px) {
  .bc-nav-inner { grid-template-columns: auto 1fr auto; }
  .bc-nav-links { display: none; }
  .bc-hamburger { display: flex; }
  .bc-programs { grid-template-columns: repeat(2, 1fr); }
  .bc-coach-pick, .bc-seg, .bc-form-grid, .bc-summary-box { grid-template-columns: 1fr; }
  .bc-footer-top { grid-template-columns: 1fr; }
  .bc-hero-main-meta { flex-wrap: wrap; gap: 12px; }
  .bc-hero-main-body { padding: 24px; }
}
@media (max-width: 480px) {
  .bc-programs { grid-template-columns: 1fr; }
  .bc-nav-inner { padding: 12px 16px; }
  .bc-hero { padding: 20px 16px; }
  .bc-section { padding: 32px 16px; }
}
