/* ============================================= */
/* 5. BUCHUNGSFORMULAR & PROZESS (FINAL V4)      */
/* ============================================= */

/* --- Grundstruktur für Formular-Container (mit Theme-Umrandung) --- */
.form-section, .booking-form-column {
    position: relative;
    background: var(--light-color);
    padding: var(--space-lg);
    border-radius: var(--border-radius);
    box-shadow: var(--shadow-light);
    margin-top: var(--space-lg);
    border: 2px solid var(--primary-color);
}
.booking-form-column {
    margin-top: 0;
}
.form-section h3, .form-fieldset-title {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--dark-color);
    margin-top: 0;
    margin-bottom: var(--space-md);
    padding-bottom: var(--space-sm);
    border-bottom: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}
.form-badge-img {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 60px;
    opacity: 0.7;
}

/* --- Globale Stile für alle Formularfelder (NEUE STRUKTUR) --- */
.form-group, .form-field {
    margin-bottom: var(--space-md);
}
/* NEU: Das ist die feste Überschrift über dem Feld */
.form-group .form-field-heading {
    display: block;
    font-weight: 600;
    font-size: 1.1rem;
    color: var(--dark-color);
    margin-bottom: var(--space-xs);
}
.form-group label, .form-field label {
    display: block;
    font-weight: 600;
    margin-bottom: var(--space-xs);
}
.form-group input, .form-group select, .form-group textarea,
.form-field input, .form-field select, .form-field textarea {
    width: 100%;
    border: 2px solid var(--border-color);
    border-radius: var(--border-radius);
    padding: var(--space-sm);
    font-size: 1rem;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus,
.form-field input:focus, .form-field select:focus, .form-field textarea:focus {
    outline: none;
    border-color: var(--primary-color);
    box-shadow: 0 0 0 3px rgba(13, 110, 253, 0.15);
}
.input-group {
    position: relative;
}
.input-group i {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 15px; /* Icon nach links verschoben */
    color: var(--text-color-light);
    z-index: 3;
    transition: color 0.2s ease;
}
.form-group .input-group input {
    padding-left: 45px; /* Platz für das Icon schaffen */
}
.form-group input:focus + i {
    color: var(--primary-color);
}


/* --- Spezifische Layouts & Komponenten --- */
.form-group-row, .form-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}
@media (min-width: 768px) {
    .form-group-row, .form-grid {
        grid-template-columns: 1fr 1fr;
    }
}
.form-field-description {
    font-size: 0.85rem;
    color: var(--text-color-light);
    margin-top: var(--space-xs);
    padding-left: 2px;
}
.form-field-description i {
    margin-right: 4px;
}
.form-fieldset {
    border: none;
    padding: 0;
    margin: 0 0 var(--space-lg) 0;
    border-bottom: 1px solid var(--border-color);
    padding-bottom: var(--space-lg);
}
.form-fieldset:last-of-type {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}
.form-presets {
    display: flex;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
    border-bottom: 1px solid var(--border-color);
    padding-bottom: var(--space-md);
}
.preset-btn {
    flex: 1;
    padding: 10px;
    font-size: 0.9rem;
    font-weight: 600;
    border-radius: var(--border-radius);
    border: 2px solid var(--border-color);
    background-color: transparent;
    color: var(--text-color-light);
    cursor: pointer;
    transition: all var(--transition-speed) ease;
}
.preset-btn:hover {
    background-color: var(--grey-bg);
    color: var(--dark-color);
}
.preset-btn.active {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
    color: var(--light-color);
}
.radio-card-group {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}
@media (min-width: 576px) {
    .radio-card-group {
        grid-template-columns: repeat(2, 1fr);
    }
}
.radio-card-wrapper input[type="radio"] { display: none; }
.radio-card {
    display: block;
    padding: var(--space-md);
    border: 2px solid var(--border-color);
    border-radius: var(--border-radius);
    cursor: pointer;
    transition: all 0.2s ease;
    position: relative;
    height: 100%;
}
.radio-card:hover { border-color: var(--primary-color-dark); }
.radio-card-wrapper input[type="radio"]:checked + .radio-card {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 1px var(--primary-color);
}
.radio-card-title { font-weight: 600; color: var(--dark-color); display: block; }
.radio-card-body { display: block; font-size: 0.9rem; color: var(--text-color-light); margin-top: var(--space-xs); }
.radio-card-wrapper input[type="radio"]:checked + .radio-card::after {
    content: '\f00c';
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    position: absolute;
    top: 10px;
    right: 15px;
    color: var(--primary-color);
    font-size: 1.2rem;
}

/* ========================================================== */
/* Stile für den Buchungsprozess (Step 2, 3, 4)               */
/* ========================================================== */
.journey-details-card {
    background-color: var(--grey-bg);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius);
    padding: var(--space-md);
    margin-bottom: 0;
}
.journey-details-card h4 {
    margin-top: 0;
    margin-bottom: var(--space-md);
    padding-bottom: var(--space-sm);
    border-bottom: 1px solid var(--border-color);
    font-size: 1.2rem;
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}
.details-row {
    display: flex;
    align-items: flex-start;
    gap: var(--space-sm);
    margin-bottom: var(--space-sm);
    font-size: 0.95rem;
}
.details-row .icon {
    font-size: 1.1rem;
    color: var(--primary-color);
    margin-top: 2px;
    width: 20px;
    text-align: center;
}
.details-row .content strong { display: block; color: var(--dark-color); }
.details-row .content span { color: var(--text-color-light); }
.journey-vehicle {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    margin-top: var(--space-md);
    padding-top: var(--space-md);
    border-top: 1px solid var(--border-color);
}
.journey-vehicle img {
    max-width: 100px;
    height: auto;
    border-radius: var(--border-radius);
}
.booking-layout-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}
.booking-layout-grid .form-fieldset-title {
    border-bottom: none;
}
.booking-layout-grid .toggle-switch {
    display: inline-block;
    cursor: pointer;
    user-select: none;
}
.booking-layout-grid .toggle-switch input {
    display: none;
}
.booking-layout-grid .toggle-switch span:last-of-type {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--primary-color);
    transition: color 0.2s ease;
    text-decoration: underline;
    text-decoration-style: dotted;
    text-underline-offset: 4px;
}
.booking-layout-grid .toggle-switch:hover span:last-of-type {
    color: var(--primary-color-dark);
}
#price-breakdown p {
    display: flex;
    justify-content: space-between;
    margin-bottom: var(--space-sm);
    color: var(--text-color);
}
#price-breakdown p.final-price {
    font-size: 1.5rem;
    font-weight: bold;
    color: var(--dark-color);
}
#price-breakdown hr {
    margin: var(--space-md) 0;
    border: none;
    border-top: 1px solid var(--border-color);
}
.booking-summary-column .journey-vehicle .content strong {
    display: block;
}
.booking-summary-column .journey-vehicle .content span:last-of-type {
    font-weight: 600;
}
/* ============================================= */
/* KONTAKT- & ANFRAGEFORMULAR VERBESSERUNGEN     */
/* ============================================= */

/* Unsichtbares Feld als Spam-Falle (Honeypot) */
.honeypot {
    display: none;
}

/* Button-Styling aus dem HTML entfernen */
.inquiry-form .btn-primary {
    width: 100%;
}