/* Grundlegende Schriftformatierung */
body, input, select, textarea, label, button {
  font-family: Arial, sans-serif;
  font-size: 16px;
  color: #000000;
}

/* Entfernt Unterstreichungen / Linien bei Auswahlfeldern */
select, input, textarea {
  border: 1px solid #dfe3e5;
  border-radius: 6px;
  padding: 10px;
  background-color: #ffffff;
  box-sizing: border-box;
  font-weight: 400 !important; /* <<< NEU */
}

/* Schrift in Dropdown-Optionen */
select option {
  font-weight: 400 !important; /* <<< NEU */
}

/* Hover- und Fokus-Styling für moderne Anmutung */
select:focus, input:focus, textarea:focus {
  outline: none;
  border-color: #134094;
  box-shadow: 0 0 4px rgba(19, 64, 148, 0.3);
}

/* Labels, Pflichtfelder, Preistext untereinander und ohne Linien */
label, .required, .price-info, .eaRequired, .eaPriceLine {
  display: block;
  margin-top: 6px;
  margin-bottom: 2px;
  font-weight: 500;
  color: #000000;
  border: none !important;
}

.required {
  color: #000000;
}

.price-info {
  margin-top: 0;
  padding: 0;
}

/* Preishinweis und Pflichtfeld – gleiche Höhe */
.price-info-wrapper {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 10px;
}

/* Buttons */
button, .btn, input[type="submit"] {
  background-color: #134094;
  border: none;
  color: white;
  padding: 12px 18px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 16px;
  font-weight: 600;
}

button:hover, .btn:hover, input[type="submit"]:hover {
  background-color: #0f336b;
}

/* Sektionen moderner strukturieren */
.section, .form-section, .container-section {
  padding: 20px;
  background-color: #f7f9fa;
  border-radius: 10px;
  margin-bottom: 20px;
  border: 1px solid #dfe3e5;
}

/* Überschriften modernisieren */
h1, h2, h3 {
  font-weight: 700;
  color: #134094;
}

/* Abstände zwischen Formelementen */
.form-group, .form-row {
  margin-bottom: 15px;
}

/* Entfernt horizontale Trennlinien und dünne Linien über/unter Bereichen */
hr,
.header-line,
.page-header,
.section-header,
.event-header,
.top-border,
.bottom-border {
  display: none !important;
  border: none !important;
}

/* Entfernt Linien bei EventsAir-Standard-Containern */
.eaSection, .eaHeader, .eaContainer {
  border: none !important;
  border-top: none !important;
  border-bottom: none !important;
}

/* Entfernt Linien in Auswahlbereichen (z. B. Vorabendveranstaltung) */
.eaChoiceGroup, .eaRadioGroup, .eaFormGroup {
  border: none !important;
}

/* Checkboxen und Radio-Buttons modernisieren */
input[type="checkbox"], input[type="radio"] {
  transform: scale(1.2);
  accent-color: #134094;
}

/* Karten/Boxen für mehr Struktur */
.box, .card {
  padding: 15px;
  background-color: #ffffff;
  border-radius: 8px;
  border: 1px solid #dfe3e5;
  margin-bottom: 15px;
  font-weight: 400; /* weniger fett */
}

/* Tabellen vereinfachen */
table {
  width: 100%;
  border-collapse: collapse;
}

td, th {
  padding: 10px;
  border-bottom: 1px solid #dfe3e5;
}

th {
  background-color: #f0f2f4;
  text-align: left;
}

/* Entfernt obere Linien unter Logo & "Zurück zur Startseite" (EventsAir spezifisch) */
.eaContentArea > div:first-child,
.eaNavigation,
.eaBreadcrumb,
.eaPageHeading,
.page-heading,
.eaHeaderBar,
.top-border,
.bottom-border {
  border: none !important;
  border-top: none !important;
  border-bottom: none !important;
  box-shadow: none !important;
}

/* Entfernt Linien in der Vorabendveranstaltung – exakte EventsAir-Klassen */
.eaMultipleChoiceGroup,
.eaRadioButtonGroup,
.eaQuestion,
.eaQuestionContainer,
.eaQuestionHeader,
.eaQuestionBody {
  border: none !important;
  border-top: none !important;
  border-bottom: none !important;
  box-shadow: none !important;
}

/* Untere Hinweise exakt untereinander */
.eaFooterNotes,
.eaTermsConditions,
.eaPriceLine,
.eaRequiredLabel {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
}

/* Wrapper erzwingen – gleiche Höhe */
.eaFooterNotesWrapper,
.price-info-wrapper,
.eaFormFooter {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 0 !important;
}

/* Pflichtfeldkennzeichnung sicherstellen */
.eaRequiredLabel {
  color: #000 !important;
  font-weight: 600 !important;
}

/* Preishinweis */
.eaPriceLine {
  color: #000 !important;
  font-size: 16px !important;
}

/* Entfernt Linien rund um das Logo – Tabellenzellen ohne Borders */
table td,
table tr,
td[style*="line-height"],
tr[style*="line-height"] {
  border: none !important;
  border-top: none !important;
  border-bottom: none !important;
}

/* Entfernt automatische Linien bei EventsAir-Header-Tabellen */
.eaHeaderTable,
.eaHeaderTable td,
.eaHeaderTable tr {
  border: none !important;
  box-shadow: none !important;
}

/* Entfernt Linie bei der Vorabendveranstaltung – direkt um <strong>-Elemente */
strong {
  border: none !important;
  border-bottom: none !important;
  box-shadow: none !important;
}

/* EventsAir packt solche Texte oft in Container mit Rahmen */
.eaQuestionHeader strong,
.eaQuestion strong,
.eaQuestionHeader,
.eaQuestion,
.eaContentBlock,
.eaContentBlockHeader {
  border: none !important;
  border-bottom: none !important;
  box-shadow: none !important;
}

/* Häufige EventsAir-Klasse für genau diese Linie */
.eaQuestionBorder,
.eaSectionBorder {
  border: none !important;
  border-top: none !important;
  border-bottom: none !important;
}

/* ===================== */
/* NEUE ANPASSUNGEN */
/* ===================== */

/* 1. Vorabendveranstaltung – alle Linien entfernen */
.row.checkbox.form-group.has-feedback,
.row.checkbox.form-group.has-feedback label,
.row.checkbox.form-group.has-feedback strong,
.row.checkbox.form-group.has-feedback::before,
.row.checkbox.form-group.has-feedback::after {
  border: none !important;
  border-bottom: none !important;
  box-shadow: none !important;
  background: transparent !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
}

/* 2. Pflichtfeld explizit blocken */
span.required, span.eaRequiredLabel {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #000 !important;
  font-weight: 600 !important;
}

/* 3. Preishinweis wie Pflichtfeld untereinander ausrichten */
span.price-info, span.eaPriceLine {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
}
