/* Anmeldeseite (/anmeldung/) – Termin-Details, Speaker-Bio, Mail-CTA.
   Eigene Datei: bb-form.css lädt nur mit [sibwp_form]-Shortcode,
   bb-startseite.css nur auf der Front – beides hier nicht verfügbar. */

.bb-termin { padding: 20px 0 110px; }

.bb-termin-grid {
  display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  gap: 72px; align-items: start;
}

/* Linke Spalte: Impuls + Speakerin */
.bb-termin-topic-lead {
  font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--bb-label); font-weight: 600; margin-bottom: 10px;
}
.bb-termin-topic {
  font-family: var(--bb-serif); font-size: clamp(30px, 3.6vw, 42px);
  font-weight: 500; line-height: 1.15; color: var(--bb-navy); margin-bottom: 18px;
}
.bb-termin-speaker { font-size: 17px; color: var(--bb-ink); font-weight: 600; margin-bottom: 4px; }
.bb-termin-speaker-role { font-size: 14px; color: var(--bb-muted); margin-bottom: 26px; }

/* Speaker-Foto neben Name/Rolle (gleiche Quelle wie in der Aussendung) */
.bb-termin-speaker-row { display: flex; gap: 20px; align-items: center; margin-bottom: 26px; }
.bb-termin-speaker-row .bb-termin-speaker { margin-bottom: 4px; }
.bb-termin-speaker-row .bb-termin-speaker-role { margin-bottom: 0; }
.bb-termin-photo {
  width: 110px; height: auto; flex: 0 0 auto;
  border: 1px solid var(--bb-line); display: block;
}
.bb-termin-bio { max-width: 640px; font-size: 17px; line-height: 1.8; color: var(--bb-ink-soft); }
.bb-termin-bio p + p { margin-top: 20px; }

/* Rechte Spalte: Eckdaten + Anmeldung */
.bb-termin-aside {
  background: var(--bb-cream); border: 1px solid var(--bb-line);
  padding: 36px 34px;
}
.bb-termin-facts dt {
  font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--bb-label); font-weight: 600; margin-top: 18px;
}
.bb-termin-facts dt:first-of-type { margin-top: 0; }
.bb-termin-facts dd {
  font-family: var(--bb-serif); font-size: 20px; color: var(--bb-navy);
  font-weight: 600; line-height: 1.35; margin: 4px 0 0;
}
.bb-termin-facts dd small {
  display: block; font-family: var(--bb-sans); font-size: 14px;
  font-weight: 400; color: var(--bb-ink-soft); margin-top: 2px;
}

.bb-anmelden-cta {
  display: block; text-align: center; margin-top: 30px; padding: 18px 32px;
  background: var(--bb-navy); border: 1px solid var(--bb-navy);
  text-decoration: none; font-size: 14px; letter-spacing: 0.16em;
  text-transform: uppercase; font-weight: 600; transition: all 0.3s;
}
.bb-anmelden-cta:hover {
  background: var(--bb-navy-deep); border-color: var(--bb-navy-deep);
  transform: translateY(-2px); box-shadow: 0 16px 32px -12px rgba(15, 39, 68, 0.4);
}
/* Kadences globaler a:hover würde die Textfarbe kippen – fix halten. */
.bb-anmelden-cta,
.bb-anmelden-cta:hover,
.bb-anmelden-cta:focus,
.bb-anmelden-cta:focus-visible,
.bb-anmelden-cta:active { color: var(--bb-cream) !important; }

/* Formular */
.bb-anmelden-form { margin-top: 28px; }
.bb-anmelden-form > p { margin: 0 0 16px; }
.bb-anmelden-form label {
  display: block; font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--bb-label); font-weight: 600; margin-bottom: 6px;
}
.bb-anmelden-form input {
  display: block; width: 100%; padding: 12px 14px; border: 1px solid var(--bb-line);
  border-radius: 0; background: #fff; font: 400 16px/1.4 var(--bb-sans); color: var(--bb-ink);
}
.bb-anmelden-form input:focus { outline: 2px solid var(--bb-navy); outline-offset: 1px; }
.bb-anmelden-form button.bb-anmelden-cta { width: 100%; cursor: pointer; font-family: var(--bb-sans); }

/* Honeypot: visuell raus, für Bots normal */
.bb-anmelden-hp {
  position: absolute !important; left: -9999px !important;
  width: 1px; height: 1px; overflow: hidden;
}

.bb-anmelden-form input[type="number"] { max-width: 120px; }

/* Verteiler-Checkbox: bewusst NICHT vorangekreuzt (DSGVO) */
.bb-anmelden-form .bb-anmelden-check label {
  display: flex; gap: 10px; align-items: flex-start;
  font-size: 13px; letter-spacing: 0; text-transform: none;
  color: var(--bb-ink-soft); font-weight: 400; line-height: 1.6; cursor: pointer;
}
.bb-anmelden-form .bb-anmelden-check input[type="checkbox"] {
  display: inline-block; width: 18px; height: 18px; margin-top: 2px;
  flex: 0 0 auto; accent-color: var(--bb-navy);
}

/* Kalender-Buttons (nach Erfolg) */
.bb-cal-row { margin-top: 18px; }
.bb-cal-label {
  display: block; font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--bb-label); font-weight: 600; margin-bottom: 10px;
}
.bb-cal-btn {
  display: inline-block; padding: 9px 16px; margin: 0 8px 8px 0;
  background: var(--bb-navy); border: 1px solid var(--bb-navy);
  text-decoration: none; font-size: 13px; font-weight: 600; letter-spacing: 0.04em;
  transition: background 0.3s;
}
.bb-cal-btn:hover { background: var(--bb-navy-deep); }
.bb-cal-btn,
.bb-cal-btn:hover,
.bb-cal-btn:focus,
.bb-cal-btn:active { color: var(--bb-cream) !important; }

.bb-form-notice { padding: 14px 16px; font-size: 15px; line-height: 1.6; margin-bottom: 18px; }
.bb-form-notice--ok { background: var(--bb-paper); border-left: 3px solid var(--bb-brass); color: var(--bb-ink-soft); }
.bb-form-notice--ok strong { color: var(--bb-navy); }
.bb-form-notice--err { background: #faeded; border-left: 3px solid #a13c3c; color: #5a2424; }
.bb-form-notice--err a { color: #5a2424; }

.bb-anmelden-privacy {
  font-size: 13px; line-height: 1.6; color: var(--bb-muted);
  margin: 14px 0 0; text-align: left;
}
.bb-anmelden-privacy a {
  color: var(--bb-navy); text-decoration: underline;
  text-decoration-color: var(--bb-brass); text-underline-offset: 3px;
}

.bb-anmelden-alt {
  font-size: 14px; line-height: 1.7; color: var(--bb-ink-soft);
  margin-top: 16px; text-align: center;
}
.bb-anmelden-alt a {
  color: var(--bb-navy); text-decoration: underline;
  text-decoration-color: var(--bb-brass); text-underline-offset: 3px;
}

/* Abmeldeseite */
.bb-abmelden-wrap { max-width: 480px; margin: 0 auto; text-align: center; }
.bb-abmelden-form {
  background: var(--bb-cream); border: 1px solid var(--bb-line);
  padding: 34px 32px;
}
.bb-abmelden-mail {
  font-family: var(--bb-serif); font-size: 20px; font-weight: 600;
  color: var(--bb-navy); margin: 0 0 20px; word-break: break-all;
}
.bb-abmelden-form .bb-anmelden-cta { width: 100%; cursor: pointer; font-family: var(--bb-sans); margin-top: 0; }

@media (max-width: 860px) {
  .bb-termin-grid { grid-template-columns: 1fr; gap: 48px; }
  .bb-termin-aside { padding: 30px 26px; }
}
