/**
 * Taxi Booking Form Styles
 * 
 * IMPORTANT: All CSS selectors are scoped under .taxi-booking-form-wrapper
 * to prevent conflicts with WordPress themes and other plugins.
 * 
 * Struktur:
 * 1. Base Layout & Container
 * 2. Form Elements (Input, Textarea, Labels)
 * 3. Buttons & Navigation
 * 4. Messages & Alerts
 * 5. Address Input & Location
 * 6. Phone Verification
 * 7. Booking Options
 * 8. Success & Booking Details
 * 9. Google Maps Integration
 * 10. Responsive Design
 */

/* ========================================
   CSS VARIABLES (Dynamic Color System)
   ======================================== */

/* ⚠️ HINWEIS: Diese Variablen werden automatisch überschrieben!
 * 
 * Die Primärfarbe wird über das Admin-Panel gesteuert:
 * WordPress Admin → Taxi Booking → Einstellungen → Design
 * 
 * Das System generiert automatisch:
 * - Alle Farbvarianten (hover, active, light, pale)
 * - Kontrastfarben (für Text auf Buttons)
 * - Textfarben (für Links und Highlights)
 * 
 * Die unten stehenden Werte dienen als FALLBACK,
 * falls das dynamische CSS nicht geladen werden kann.
 */

:root {
    /* ====== BASE COLORS ====== */
    
    /* Primary Brand Color (FALLBACK - wird durch Admin überschrieben)
     * Standard: #21759b
     * Änderbar über: Admin → Einstellungen → Design Tab
     */
    --color-primary: #21759b;
    
    /* Status Colors */
    --color-success: #28a745;
    --color-warning: #ff9800;
    --color-error: #dc2626;
    --color-info: #0c5460;
    
    /* Text Colors */
    --color-text: #333;
    --color-text-muted: #666;
    --color-text-light: #999;
    
    
    /* ====== STATISCHE FALLBACK-FARBEN (Browser-Kompatibilität) ====== */
    /* Diese Werte funktionieren auch in älteren Browsern ohne color-mix() Support
     * Moderne Browser verwenden die dynamisch berechneten Werte aus dem Admin-Panel
     */
    
    /* Primary Variations (basierend auf #21759b) */
    --color-primary-hover: #1a5f7a;
    --color-primary-active: #164e64;
    --color-primary-light: #5ea3c1;
    --color-primary-pale: #d4e9f2;
    
    /* Kontrastfarben (für Text auf Primary-Background)
     * WCAG 2.1 Level AA konform (Kontrast ≥ 4.5:1)
     */
    --color-primary-contrast: #ffffff;
    --color-primary-contrast-hover: #ffffff;
    --color-primary-contrast-active: #ffffff;
    
    /* Primary Text (für Links und Text-Highlights) */
    --color-primary-text: #21759b;
    --color-primary-text-hover: #1a5f7a;
    
    /* Status Kontrastfarben */
    --color-success-contrast: #1e7e34;
    --color-warning-contrast: #cc7a00;
    --color-error-contrast: #ffffff;
    --color-info-contrast: #ffffff;
    
    /* Background Colors */
    --color-bg: #ffffff;
    --color-bg-light: #f9f9f9;
    --color-bg-input: #ffffff;
    --color-bg-disabled: #f0f0f0;
    
    /* Border Colors */
    --color-border: #ddd;
    --color-border-dark: #ccc;
    --color-border-focus: #21759b;
    
    /* Success Variations (basierend auf #28a745) */
    --color-success-hover: #218838;
    --color-success-light: #5dbd6f;
    --color-success-pale: #d4edda;
    --color-success-text: #155724;
    
    /* Warning Variations (basierend auf #ff9800) */
    --color-warning-hover: #e68900;
    --color-warning-light: #ffb84d;
    --color-warning-pale: #fff3cd;
    --color-warning-text: #8a5700;
    
    /* Error Variations (basierend auf #dc2626) */
    --color-error-hover: #c82121;
    --color-error-light: #e65a5a;
    --color-error-pale: #f8d7da;
    --color-error-text: #a31f1f;
    
    /* Info Variations (basierend auf #0c5460) */
    --color-info-hover: #0a4450;
    --color-info-light: #3d7d8a;
    --color-info-pale: #d1ecf1;
    --color-info-text: #084853;
    
    /* Shadows */
    --shadow-sm: 0 2px 10px rgba(0, 0, 0, 0.1);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.15);
    --shadow-success: 0 0 0 3px rgba(40, 167, 69, 0.1);
    --shadow-error: 0 0 0 3px rgba(220, 38, 38, 0.1);
}

/* ========================================
   CONSENT GATE (DSGVO / Borlabs Cookie)
   ======================================== */

.taxi-booking-consent-gate {
    background: #fff;
    border: 2px solid var(--color-primary, #21759b);
    border-radius: 12px;
    padding: 40px 30px;
    text-align: center;
    max-width: 600px;
    margin: 40px auto;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.taxi-booking-consent-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
}

.taxi-booking-consent-icon {
    font-size: 64px;
    line-height: 1;
    animation: taxi-consent-pulse 2s ease-in-out infinite;
}

@keyframes taxi-consent-pulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.1); }
}

.taxi-booking-consent-gate h3 {
    margin: 0;
    font-size: 24px;
    color: #333;
    font-weight: 600;
}

.taxi-booking-consent-gate p {
    margin: 0;
    font-size: 16px;
    line-height: 1.6;
    color: #666;
}

.taxi-booking-consent-services {
    list-style: none;
    padding: 0;
    margin: 0;
    text-align: left;
    width: 100%;
    max-width: 400px;
}

.taxi-booking-consent-services li {
    padding: 15px;
    background: #f8f9fa;
    border-radius: 8px;
    margin-bottom: 10px;
}

.taxi-booking-consent-services li:last-child {
    margin-bottom: 0;
}

.taxi-booking-consent-services strong {
    display: block;
    font-size: 16px;
    color: #333;
    margin-bottom: 5px;
}

.taxi-booking-consent-services li {
    font-size: 14px;
    color: #666;
}

.taxi-booking-consent-actions {
    margin-top: 10px;
}

.taxi-booking-consent-footer {
    font-size: 13px;
    color: #999;
    margin-top: 10px;
}

.taxi-booking-consent-footer a {
    color: var(--color-primary, #21759b);
    text-decoration: underline;
}

.taxi-booking-consent-footer a:hover {
    text-decoration: none;
}

/* Responsive Consent Gate */
@media (max-width: 600px) {
    .taxi-booking-consent-gate {
        padding: 30px 20px;
        margin: 20px;
    }
    
    .taxi-booking-consent-icon {
        font-size: 48px;
    }
    
    .taxi-booking-consent-gate h3 {
        font-size: 20px;
    }
}

/* ========================================
   1. BASE LAYOUT & CONTAINER
   ======================================== */

.taxi-booking-form-wrapper {
    margin: 20px auto;
    padding: 30px;
    background: var(--color-bg);
    border-radius: 8px;
    box-shadow: var(--shadow-sm);
    position: relative;
}

/* Form Header */
.taxi-booking-form-wrapper #form-header {
    margin-bottom: 25px;
}

.taxi-booking-form-wrapper #form-header #section-title {
    margin: 0 0 15px 0;
    padding: 0;
    transition: opacity 0.3s ease;
}

.taxi-booking-form-wrapper #form-header #section-description {
    margin: 0 0 20px 0;
    padding: 0;
    transition: opacity 0.3s ease;
}

.taxi-booking-form-wrapper #form-header #section-title:empty,
.taxi-booking-form-wrapper #form-header #section-description:empty {
    display: none;
    margin: 0;
}

.taxi-booking-form-wrapper .taxi-form-title {
    margin: 0 0 15px 0;
    padding: 0;
    font-size: 24px;
    font-weight: 600;
    color: var(--color-text);
}

.taxi-booking-form-wrapper .taxi-step-description {
    margin: 0 0 25px 0;
    padding: 0;
    font-size: 15px;
    line-height: 1.6;
    color: var(--color-text-muted);
}

/* ========================================
   2. FORM ELEMENTS
   ======================================== */

.taxi-booking-form-wrapper .form-group {
    margin-bottom: 20px;
}

/* Form Row (2 Spalten) */
.taxi-booking-form-wrapper .form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 15px;
}

.taxi-booking-form-wrapper .form-col {
    display: flex;
    flex-direction: column;
}

/* Labels */
.taxi-booking-form-wrapper label {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    font-weight: 600;
    color: var(--color-text);
    font-size: 14px;
    gap: 10px;
}

.taxi-booking-form-wrapper label .label-text {
    flex: 1;
}

/* Label ohne Zähler (normale Anzeige) */
.taxi-booking-form-wrapper label:not(:has(.char-counter)) {
    display: block;
}

/* Zeichen-Zähler */
.taxi-booking-form-wrapper label .char-counter {
    font-weight: 400;
    font-size: 11px;
    color: var(--color-text-light);
    white-space: nowrap;
    flex-shrink: 0;
    letter-spacing: 0.3px;
    transition: color 0.3s ease;
}

.taxi-booking-form-wrapper label .char-counter #booking-note-counter {
    font-weight: 600;
    color: var(--color-text-muted);
    transition: color 0.3s ease;
}

.taxi-booking-form-wrapper label .char-counter.char-warning {
    color: var(--color-warning);
}

.taxi-booking-form-wrapper label .char-counter.char-warning #booking-note-counter {
    color: var(--color-warning);
}

.taxi-booking-form-wrapper label .char-counter.char-limit {
    color: var(--color-error);
}

.taxi-booking-form-wrapper label .char-counter.char-limit #booking-note-counter {
    color: var(--color-error);
}

/* Input Fields & Textarea */
.taxi-booking-form-wrapper input[type="text"],
.taxi-booking-form-wrapper input[type="tel"],
.taxi-booking-form-wrapper input[type="url"],
.taxi-booking-form-wrapper textarea {
    width: 100%;
    padding: 12px;
    border: 2px solid var(--color-border);
    border-radius: 6px;
    font-size: 16px;
    font-family: inherit;
    line-height: 1.5;
    transition: all 0.3s ease;
    box-sizing: border-box;
    background-color: var(--color-bg-input);
}

.taxi-booking-form-wrapper textarea {
    resize: vertical;
    min-height: 80px;
}

/* Hover State für alle Inputs */
.taxi-booking-form-wrapper input[type="text"]:hover,
.taxi-booking-form-wrapper input[type="tel"]:hover,
.taxi-booking-form-wrapper input[type="url"]:hover,
.taxi-booking-form-wrapper textarea:hover {
    border-color: var(--color-border-dark);
}

/* Focus State für alle Inputs */
.taxi-booking-form-wrapper input[type="text"]:focus,
.taxi-booking-form-wrapper input[type="tel"]:focus,
.taxi-booking-form-wrapper input[type="url"]:focus,
.taxi-booking-form-wrapper textarea:focus {
    outline: none;
    border-color: var(--color-primary);
    background-color: var(--color-bg);
}

/* Disabled State für alle Inputs */
.taxi-booking-form-wrapper input[type="text"]:disabled,
.taxi-booking-form-wrapper input[type="tel"]:disabled,
.taxi-booking-form-wrapper input[type="url"]:disabled,
.taxi-booking-form-wrapper textarea:disabled {
    background-color: var(--color-bg-light);
    color: var(--color-text-light);
    cursor: not-allowed;
    opacity: 0.6;
    border-color: var(--color-border);
}

.taxi-booking-form-wrapper input[type="text"]:disabled:hover,
.taxi-booking-form-wrapper input[type="tel"]:disabled:hover,
.taxi-booking-form-wrapper input[type="url"]:disabled:hover,
.taxi-booking-form-wrapper textarea:disabled:hover {
    border-color: var(--color-border);
}

/* Small Text & Help Text */
.taxi-booking-form-wrapper small,
.taxi-booking-form-wrapper .help-text {
    display: block;
    margin-top: 5px;
    font-size: 13px;
    color: var(--color-text-muted);
    font-weight: normal;
}

.taxi-booking-form-wrapper .help-text {
    font-size: 14px;
}

/* ========================================
   3. BUTTONS & NAVIGATION
   ======================================== */

/* Primary Submit Button */
.taxi-booking-form-wrapper .taxi-booking-submit {
    width: 100%;
    padding: 14px;
    background-color: var(--color-primary);
    color: var(--color-primary-contrast);
    border: 2px solid var(--color-primary);
    border-radius: 6px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    outline: none;
    display: block;
    text-align: center;
}

.taxi-booking-form-wrapper .taxi-booking-submit:hover {
    background-color: var(--color-primary-hover);
    border-color: var(--color-primary-hover);
    color: var(--color-primary-contrast-hover);
}

.taxi-booking-form-wrapper .taxi-booking-submit:active {
    background-color: var(--color-primary-active);
    border-color: var(--color-primary-active);
    color: var(--color-primary-contrast-active);
    transform: scale(0.98);
}

.taxi-booking-form-wrapper .taxi-booking-submit:focus-visible {
    outline: 3px solid var(--color-primary-hover);
    outline-offset: 2px;
}

.taxi-booking-form-wrapper .taxi-booking-submit:disabled {
    opacity: 0.7;
    cursor: not-allowed;
    background-color: var(--color-text-light);
}

/* Step Navigation Buttons */
.taxi-booking-form-wrapper .step-nav-btn {
    text-align: center;
    padding: 14px;
    background-color: var(--color-primary);
    color: var(--color-primary-contrast);
    border: 2px solid var(--color-primary);
    border-radius: 6px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    outline: none;
}

.taxi-booking-form-wrapper .step-nav-btn:hover {
    background-color: var(--color-primary-hover);
    border-color: var(--color-primary-hover);
    color: var(--color-primary-contrast-hover);
}

.taxi-booking-form-wrapper .step-nav-btn:active {
    background-color: var(--color-primary-active);
    border-color: var(--color-primary-active);
    color: var(--color-primary-contrast-active);
    transform: scale(0.98);
}

.taxi-booking-form-wrapper .step-nav-btn:focus-visible {
    outline: 3px solid var(--color-primary-hover);
    outline-offset: 2px;
}

.taxi-booking-form-wrapper .step-nav-btn:disabled {
    background-color: var(--color-text-light);
    cursor: not-allowed;
    opacity: 0.6;
}

.taxi-booking-form-wrapper .step-navigation {
    margin-top: 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.taxi-booking-form-wrapper #step-back-btn {
    background-color: transparent;
    color: var(--color-text-muted);
    border: 2px solid var(--color-text-muted);
}

.taxi-booking-form-wrapper #step-back-btn:hover:not(:disabled) {
    border-color: var(--color-primary-text);
    color: var(--color-primary-text);
}

.taxi-booking-form-wrapper #step-back-btn:active:not(:disabled) {
    transform: scale(0.98);
}

/* Back & Link Buttons */
.taxi-booking-form-wrapper .taxi-booking-back {
    background: transparent;
    color: var(--color-primary-text);
    border: 2px solid var(--color-primary-text);
    padding: 14px 30px;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.3s ease;
    font-size: 16px;
    font-weight: 600;
    width: 100%;
    display: block;
    text-align: center;
    margin-top: 10px;
}

.taxi-booking-form-wrapper .taxi-booking-back:hover {
    background: var(--color-primary);
    color: var(--color-bg);
}

.taxi-booking-form-wrapper .taxi-booking-back:active {
    transform: scale(0.98);
}

/* Button Loader */
.taxi-booking-form-wrapper .button-loader {
    display: inline-block;
}

.taxi-booking-form-wrapper .button-loader .spinner {
    display: inline-block;
    width: 16px;
    height: 16px;
    border: 2px solid color-mix(in srgb, currentColor 30%, transparent);
    border-top-color: currentColor;
    border-radius: 50%;
    animation: spinner-rotate 0.6s linear infinite;
}

@keyframes spinner-rotate {
    to {
        transform: rotate(360deg);
    }
}

/* Spinner */
.taxi-booking-form-wrapper .spinner-border {
    display: inline-block;
    width: 2rem;
    height: 2rem;
    vertical-align: text-bottom;
    border: 0.25em solid currentColor;
    border-right-color: transparent;
    border-radius: 50%;
    animation: spinner-border 0.75s linear infinite;
}

.taxi-booking-form-wrapper .spinner-border-sm {
    width: 1rem;
    height: 1rem;
    border-width: 0.2em;
}

@keyframes spinner-border {
    to {
        transform: rotate(360deg);
    }
}

/* ========================================
   4. MESSAGES & ALERTS
   ======================================== */

.taxi-booking-form-wrapper #taxi-booking-messages {
    margin-top: 15px;
}

/* Address Inline Messages */
.taxi-booking-form-wrapper .address-inline-message {
    font-weight: 500;
    font-size: 13px;
    padding: 10px 14px;
    margin-top: 8px;
    border-radius: 6px;
    border: 2px solid;
    animation: slideDown 0.3s ease-out;
}

.taxi-booking-form-wrapper .address-inline-message.error {
    color: var(--color-error-text);
    background-color: var(--color-error-pale);
    border-color: var(--color-error-light);
}

.taxi-booking-form-wrapper .address-inline-message.warning {
    color: var(--color-warning-text);
    background-color: var(--color-warning-pale);
    border-color: var(--color-warning-light);
}

@keyframes slideDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeInDown {
    from {
        opacity: 0;
        transform: translate(-50%, -100%) translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translate(-50%, -100%) translateY(0);
    }
}

/* Alert Messages */
.taxi-booking-form-wrapper .alert {
    padding: 14px;
    margin: 20px 0;
    border-radius: 6px;
    border: 2px solid;
    font-size: 15px;
    line-height: 1.5;
}

.taxi-booking-form-wrapper .alert-danger {
    background-color: var(--color-error-pale);
    border-color: var(--color-error-light);
    color: var(--color-error-text);
}

.taxi-booking-form-wrapper .alert-warning {
    background-color: var(--color-warning-pale);
    border-color: var(--color-warning-light);
    color: var(--color-warning-text);
}

.taxi-booking-form-wrapper .alert-success {
    background-color: var(--color-success-pale);
    border-color: var(--color-success-light);
    color: var(--color-success-text);
}

.taxi-booking-form-wrapper .alert-info {
    background-color: var(--color-info-pale);
    border-color: var(--color-info-light);
    color: var(--color-info-text);
}

/* ========================================
   5. ADDRESS INPUT & LOCATION
   ======================================== */

/* Address Input mit Standort-Button */
.taxi-booking-form-wrapper .address-input-wrapper {
    position: relative;
    display: flex;
    align-items: stretch;
    gap: 0;
}

.taxi-booking-form-wrapper .address-input-wrapper input[type="text"] {
    flex: 1;
    border-radius: 6px 0 0 6px;
    border-right: none;
}

.taxi-booking-form-wrapper .address-input-wrapper input[type="text"]:hover {
    border-color: var(--color-border-dark);
}

.taxi-booking-form-wrapper .address-input-wrapper input[type="text"]:focus {
    border-color: var(--color-primary);
    border-right: none;
}

/* Focus-Border auch auf Location-Button übertragen (mit ~ wegen Clear-Button dazwischen) */
.taxi-booking-form-wrapper .address-input-wrapper input[type="text"]:focus ~ .current-location-btn {
    border-color: var(--color-primary);
}

/* Wenn kein Button vorhanden ist - wichtiger, daher am Ende */
.taxi-booking-form-wrapper .address-input-wrapper.no-location-btn input[type="text"] {
    border-radius: 6px !important;
    border-right: 2px solid var(--color-border) !important;
}

.taxi-booking-form-wrapper .address-input-wrapper.no-location-btn input[type="text"]:hover {
    border-color: var(--color-border-dark) !important;
    border-right-color: var(--color-border-dark) !important;
}

.taxi-booking-form-wrapper .address-input-wrapper.no-location-btn input[type="text"]:focus {
    border-color: var(--color-primary) !important;
    border-right-color: var(--color-primary) !important;
}

/* Current Location Button */
.taxi-booking-form-wrapper .current-location-btn {
    padding: 10px;
    border: 2px solid var(--color-border);
    border-left: none;
    border-radius: 0 6px 6px 0;
    background: var(--color-bg);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-muted);
    transition: all 0.3s ease;
    width: 44px;
    min-width: 44px;
    outline: none;
}

.taxi-booking-form-wrapper .current-location-btn:hover:not(.disabled):not(:disabled) {
    color: var(--color-primary-text);
}

.taxi-booking-form-wrapper .current-location-btn:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: -2px;
}

.taxi-booking-form-wrapper .current-location-btn.loading {
    background: var(--color-warning-pale);
    color: var(--color-warning);
    cursor: wait;
}

.taxi-booking-form-wrapper .current-location-btn.loading .location-icon {
    animation: pulseRotate 1.5s ease-in-out infinite;
}

@keyframes pulseRotate {
    0% {
        transform: scale(1) rotate(0deg);
    }

    50% {
        transform: scale(1.1) rotate(180deg);
    }

    100% {
        transform: scale(1) rotate(360deg);
    }
}

.taxi-booking-form-wrapper .current-location-btn .location-icon {
    width: 20px;
    height: 20px;
    display: block;
}

.taxi-booking-form-wrapper .current-location-btn.disabled,
.taxi-booking-form-wrapper .current-location-btn:disabled {
    background: var(--color-bg-light);
    color: var(--color-text-light);
    border-color: var(--color-border);
    cursor: not-allowed;
    opacity: 0.5;
}

.taxi-booking-form-wrapper .current-location-btn.disabled:hover,
.taxi-booking-form-wrapper .current-location-btn:disabled:hover {
    color: var(--color-text-light);
    transform: none;
}

/* Clear Address Button (X) */
.taxi-booking-form-wrapper .clear-address-btn {
    position: absolute;
    right: 48px; /* Platz für Location Button */
    top: 50%;
    transform: translateY(-50%);
    width: 32px;
    height: 32px;
    padding: 0;
    background: rgba(255, 255, 255, 0.95);
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 4px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-light);
    transition: all 0.2s ease;
    z-index: 2;
    outline: none;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.taxi-booking-form-wrapper .address-input-wrapper.no-location-btn .clear-address-btn {
    right: 10px; /* Wenn kein Location Button vorhanden */
}

.taxi-booking-form-wrapper .clear-address-btn:hover {
    color: var(--color-danger, #e74c3c);
    background: rgba(255, 255, 255, 1);
    border-color: var(--color-danger, #e74c3c);
    transform: translateY(-50%) scale(1.05);
}

.taxi-booking-form-wrapper .clear-address-btn:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
    border-radius: 4px;
}

.taxi-booking-form-wrapper .clear-address-btn svg {
    width: 18px;
    height: 18px;
    display: block;
}

/* Ausgewählte Adresse Anzeige */
.taxi-booking-form-wrapper .selected-address-box {
    margin-top: 10px;
    padding: 15px;
    background: var(--color-bg-light);
    border: 2px solid var(--color-border);
    border-radius: 8px;
    position: relative;
}

.taxi-booking-form-wrapper .selected-address-content {
    display: flex;
    gap: 15px;
    align-items: flex-start;
    flex-direction: row-reverse; /* Foto rechts */
}

.taxi-booking-form-wrapper .selected-address-photo {
    flex-shrink: 0;
}

.taxi-booking-form-wrapper .selected-address-photo img {
    width: 120px;
    height: 120px;
    object-fit: cover;
    border-radius: 6px;
    border: 1px solid var(--color-border);
}

.taxi-booking-form-wrapper .selected-address-info {
    flex: 1;
}

.taxi-booking-form-wrapper .address-poi-name {
    font-size: 21px;
    font-weight: 700;
    color: var(--color-primary);
    margin-bottom: 8px;
}

.taxi-booking-form-wrapper .address-street {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 4px;
}

.taxi-booking-form-wrapper .address-city {
    font-size: 14px;
    color: var(--color-text-muted);
}

.taxi-booking-form-wrapper .change-address-btn {
    margin-top: 12px;
    padding: 8px 16px;
    background: var(--color-bg);
    color: var(--color-primary);
    border: 2px solid var(--color-primary);
    border-radius: 6px;
    font-size: 13px;
    cursor: pointer;
    transition: all 0.3s ease;
    font-weight: 600;
    outline: none;
    display: inline-block;
}

.taxi-booking-form-wrapper .change-address-btn:hover {
    background: var(--color-primary);
    color: var(--color-primary-contrast);
    border-color: var(--color-primary);
}

.taxi-booking-form-wrapper .change-address-btn:active {
    background: var(--color-primary-active);
    color: var(--color-primary-contrast-active);
    border-color: var(--color-primary-active);
    transform: scale(0.98);
}

.taxi-booking-form-wrapper .change-address-btn:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

/* Google Places Autocomplete */
.taxi-booking-form-wrapper .pac-container {
    border-radius: 6px;
    box-shadow: var(--shadow-md);
    border: 2px solid var(--color-border);
    font-family: inherit;
    margin-top: 2px;
}

.taxi-booking-form-wrapper .pac-item {
    padding: 12px 14px;
    cursor: pointer;
    border-top: 1px solid var(--color-border);
    transition: background-color 0.2s ease;
}

.taxi-booking-form-wrapper .pac-item:first-child {
    border-top: none;
}

.taxi-booking-form-wrapper .pac-item:hover {
    background-color: var(--color-bg-light);
}

.taxi-booking-form-wrapper .pac-item-selected {
    background-color: var(--color-primary-pale);
}

.taxi-booking-form-wrapper .pac-icon {
    margin-right: 8px;
}

.taxi-booking-form-wrapper .pac-item-query {
    font-weight: 600;
    color: var(--color-text);
}

/* ========================================
   6. PHONE VERIFICATION
   ======================================== */

/* intl-tel-input Styling */
.taxi-booking-form-wrapper .iti {
    width: 100%;
}

.taxi-booking-form-wrapper .iti__flag-container {
    padding: 0;
}

.taxi-booking-form-wrapper .iti__selected-flag {
    padding: 12px;
    border-radius: 6px 0 0 6px;
}

.taxi-booking-form-wrapper .iti__flag-container:hover .iti__selected-flag,
.taxi-booking-form-wrapper .iti__selected-flag:focus {
    background-color: var(--color-bg-light);
}

.taxi-booking-form-wrapper .iti__country-list {
    max-height: 200px;
    border-radius: 6px;
    box-shadow: var(--shadow-md);
    border: 2px solid var(--color-border);
}

.taxi-booking-form-wrapper .iti__country {
    padding: 12px 14px;
    transition: background-color 0.2s ease;
}

.taxi-booking-form-wrapper .iti__country:hover {
    background-color: var(--color-bg-light);
}

.taxi-booking-form-wrapper .iti__selected-dial-code {
    color: var(--color-text);
    font-weight: 600;
}

.taxi-booking-form-wrapper .iti input[type="tel"] {
    width: 100% !important;
    padding-left: 52px !important;
}

.taxi-booking-form-wrapper #phone-error {
    display: none;
    margin-top: 5px;
    font-size: 13px;
    color: var(--color-error);
}

/* Phone Display */
.taxi-booking-form-wrapper .phone-display {
    background: var(--color-bg-light);
    padding: 14px;
    border: 2px solid var(--color-border);
    border-radius: 6px;
    margin: 15px 0;
    text-align: center;
}

.taxi-booking-form-wrapper .phone-display strong {
    color: var(--color-primary-text);
    font-size: 18px;
}

/* Verifizierungsmethoden */
.taxi-booking-form-wrapper .verification-methods {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 15px;
    margin: 20px 0;
}

.taxi-booking-form-wrapper .verification-method-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 30px 20px;
    background: var(--color-bg-light);
    border: 2px solid var(--color-border);
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.3s ease;
    font-size: 16px;
    outline: none;
}

.taxi-booking-form-wrapper .verification-method-btn:hover:not(:disabled) {
    background: var(--color-bg);
    border-color: var(--color-primary);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.taxi-booking-form-wrapper .verification-method-btn:active:not(:disabled) {
    transform: translateY(0);
}

.taxi-booking-form-wrapper .verification-method-btn:focus-visible {
    outline: 3px solid var(--color-primary);
    outline-offset: 2px;
}

.taxi-booking-form-wrapper .verification-method-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.taxi-booking-form-wrapper .verification-method-btn.loading {
    animation: pulse 1s infinite;
}

@keyframes pulse {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.6;
    }
}

.taxi-booking-form-wrapper .verification-method-btn .method-icon {
    width: 56px;
    height: 56px;
    margin-bottom: 12px;
    display: block;
    color: var(--color-text-secondary);
    transition: all 0.3s;
}

.taxi-booking-form-wrapper .verification-method-btn .method-icon svg {
    width: 100%;
    height: 100%;
    display: block;
}

.taxi-booking-form-wrapper .verification-method-btn:hover .method-icon {
    color: var(--color-primary);
    transform: scale(1.1);
}

.taxi-booking-form-wrapper .verification-method-btn.selected .method-icon {
    color: var(--color-primary);
    transform: scale(1.05);
}

.taxi-booking-form-wrapper .verification-method-btn .method-text {
    font-weight: 600;
    color: var(--color-text);
    display: block;
}

/* Verifizierungscode-Eingabe */
.taxi-booking-form-wrapper #verification_code {
    text-align: center;
    font-size: 24px;
    letter-spacing: 8px;
    font-weight: bold;
}

/* Verifizierungs-Aktionen */
.taxi-booking-form-wrapper .verification-actions {
    text-align: center;
    margin-top: 20px;
}

.taxi-booking-form-wrapper .resend-info {
    margin-bottom: 15px;
    color: var(--color-text-muted);
    font-size: 14px;
}

.taxi-booking-form-wrapper .resend-info strong {
    color: var(--color-info);
    font-weight: 600;
}

/* Resend Code Button/Link */
.taxi-booking-form-wrapper #resend-code-btn {
    background: none;
    border: none;
    padding: 0;
    color: var(--color-primary-text);
    text-decoration: underline;
    cursor: pointer;
    font-size: 14px;
    display: inline-block;
    margin-bottom: 10px;
    outline: none;
}

.taxi-booking-form-wrapper #resend-code-btn:hover {
    color: var(--color-primary-text-hover);
}

.taxi-booking-form-wrapper #resend-code-btn:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 4px;
    border-radius: 2px;
}

.taxi-booking-form-wrapper #resend-code-btn .resend-loader {
    color: var(--color-primary-text);
    text-decoration: none;
}

/* ========================================
   7. BOOKING OPTIONS
   ======================================== */

.taxi-booking-form-wrapper .booking-options-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 10px;
}

.taxi-booking-form-wrapper .booking-option-item {
    display: flex;
    align-items: center;
    padding: 12px;
    background: var(--color-bg-light);
    border: 2px solid var(--color-border);

    border-radius: 6px;
    cursor: pointer;
    transition: all 0.3s ease;
    font-weight: normal;
}

.taxi-booking-form-wrapper .booking-option-item:hover {
    border-color: var(--color-border-dark);
}

.taxi-booking-form-wrapper .booking-option-item:has(input[type="checkbox"]:checked) {
    border-color: var(--color-primary);

}

.taxi-booking-form-wrapper .booking-option-item:has(input[type="checkbox"]:focus) {
    outline: none;
    border-color: var(--color-primary);

}


.taxi-booking-form-wrapper .booking-option-item input[type="checkbox"] {
    margin: 0 12px 0 0;
    width: 18px;
    height: 18px;
    cursor: pointer;
    flex-shrink: 0;
    vertical-align: middle;
    accent-color: var(--color-primary);

}

.taxi-booking-form-wrapper .booking-option-item span {
    font-weight: 500;
    line-height: 18px;
}

.taxi-booking-form-wrapper .booking-option-item input[type="checkbox"]:checked+span {
    font-weight: 600;
    
}

.taxi-booking-form-wrapper .booking-option-item span {
    flex: 1;
    font-size: 15px;
    color: var(--color-text);
}

/* ========================================
   8. SUCCESS & BOOKING DETAILS
   ======================================== */

/* Datenschutz-Hinweis */
.taxi-booking-form-wrapper .privacy-notice {
    margin-bottom: 15px;
}

.taxi-booking-form-wrapper .privacy-notice small {
    color: var(--color-text-muted);
    font-size: 12px;
}

.taxi-booking-form-wrapper .privacy-notice a {
    color: var(--color-primary-text);
    text-decoration: underline;
}

.taxi-booking-form-wrapper .privacy-notice a:hover {
    color: var(--color-primary-text-hover);
}

/* Erfolgs-Wrapper */
.taxi-booking-form-wrapper .booking-success-wrapper {
    text-align: center;
    padding: 40px 20px;
}

.taxi-booking-form-wrapper .booking-success-wrapper h2 {
    color: var(--color-success);
    font-size: 32px;
    margin-bottom: 20px;
}

/* Fehler-Wrapper */
.taxi-booking-form-wrapper .booking-error-wrapper {
    text-align: center;
    padding: 40px 20px;
}

.taxi-booking-form-wrapper .booking-error-wrapper .error-icon {
    margin: 0 auto 20px;
    color: var(--color-error);
    opacity: 0.9;
}

.taxi-booking-form-wrapper .booking-error-wrapper .error-icon svg {
    width: 64px;
    height: 64px;
    display: block;
    margin: 0 auto;
}

.taxi-booking-form-wrapper .booking-error-wrapper .error-title {
    color: var(--color-error);
    font-size: 28px;
    margin-bottom: 16px;
}

.taxi-booking-form-wrapper .booking-error-wrapper .error-message {
    font-size: 16px;
    color: var(--color-text-muted);
    margin: 0 auto 24px;
    line-height: 1.6;
    max-width: 600px;
}

.taxi-booking-form-wrapper .booking-details {
    margin: 20px 0;
    text-align: left;
}

.taxi-booking-form-wrapper .booking-details h3 {
    margin-top: 0;
    color: var(--color-text);
}

.taxi-booking-form-wrapper .booking-details p {
    margin: 10px 0;
    color: var(--color-text-muted);
}

/* Booking Summary Card */
.taxi-booking-form-wrapper .booking-summary-card {  
    margin: 20px 0;
}

.taxi-booking-form-wrapper .booking-summary-card .booking-id-section {
    background: var(--color-bg);
    border: 2px solid var(--color-border);
    border-radius: 8px;
    padding: 12px 16px;
    margin-bottom: 20px;
    text-align: center;
}

.taxi-booking-form-wrapper .booking-summary-card .booking-id-section h3 {
    margin: 0 0 6px 0;
    padding: 0;
    color: var(--color-success);
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.taxi-booking-form-wrapper .booking-summary-card .booking-id {
    display: block;
    font-size: 20px;
    font-weight: 700;
    color: var(--color-success);
    font-family: 'Courier New', monospace;
    letter-spacing: 2px;
}

.taxi-booking-form-wrapper .booking-summary-card .booking-section {
    background: var(--color-bg);
    border: 2px solid var(--color-border);
    border-radius: 8px;
    padding: 16px;
    margin-bottom: 12px;
}

.taxi-booking-form-wrapper .booking-summary-card .booking-section:last-child {
    margin-bottom: 0;
}

.taxi-booking-form-wrapper .booking-summary-card .booking-section h3 {
    margin: 0 0 12px 0;
    padding: 0;
    color: var(--color-text);
    font-size: 15px;
    font-weight: 600;
}

.taxi-booking-form-wrapper .booking-summary-card .booking-field {
    padding: 6px 0;
    color: var(--color-text-muted);
    line-height: 1.5;
    font-size: 14px;
}

.taxi-booking-form-wrapper .booking-summary-card .booking-field strong {
    display: inline-block;
    min-width: 100px;
    color: var(--color-text);
    font-weight: 600;
    margin-right: 8px;
}

/* ========================================
   9. GOOGLE MAPS INTEGRATION
   ======================================== */

.taxi-booking-form-wrapper .taxi-booking-map-container {
    margin: 20px 0;
}

.taxi-booking-form-wrapper .taxi-map-above {
    margin-bottom: 25px;
}

.taxi-booking-form-wrapper .taxi-map-below {
    margin-top: 25px;
}

/* Side-by-Side Layout */
.taxi-booking-form-wrapper.taxi-booking-with-map {
    display: flex;
    gap: 30px;
    align-items: stretch;
}

/* Desktop: 50/50 Split für Form und Karte */
.taxi-booking-form-wrapper.taxi-booking-with-map .taxi-booking-form-content,
.taxi-booking-form-wrapper.taxi-booking-with-map .taxi-booking-map-container {
    flex: 1 1 50%;
    min-width: 0; /* Verhindert Flex-Überlauf */
}

.taxi-booking-form-wrapper.taxi-booking-with-map .taxi-booking-map-container {
    margin: 0;
}

.taxi-booking-form-wrapper.taxi-booking-map-left .taxi-booking-map-container {
    order: -1;
}

.taxi-booking-form-wrapper.taxi-booking-with-map.taxi-booking-map-left #taxi-booking-map,
.taxi-booking-form-wrapper.taxi-booking-with-map.taxi-booking-map-right #taxi-booking-map {
    width: 100%;
}

/* Desktop: Höhe 100% für Side-by-Side */
@media (min-width: 901px) {
    .taxi-booking-form-wrapper.taxi-booking-with-map.taxi-booking-map-left #taxi-booking-map,
    .taxi-booking-form-wrapper.taxi-booking-with-map.taxi-booking-map-right #taxi-booking-map {
        height: 100% !important;
    }
}

/* ========================================
   10. RESPONSIVE DESIGN
   ======================================== */

/* Umbruch für Side-by-Side Layout bei 900px */
@media (max-width: 900px) {
    .taxi-booking-form-wrapper.taxi-booking-with-map {
        flex-direction: column;
        max-width: 100%;
    }

    .taxi-booking-form-wrapper.taxi-booking-with-map .taxi-booking-form-content,
    .taxi-booking-form-wrapper.taxi-booking-with-map .taxi-booking-map-container {
        flex: 1 1 100%;
        width: 100%;
    }

    .taxi-booking-form-wrapper.taxi-booking-with-map .taxi-booking-map-container {
        order: var(--map-responsive-order, 1);
    }

    .taxi-booking-form-wrapper.taxi-booking-with-map.taxi-booking-map-left #taxi-booking-map,
    .taxi-booking-form-wrapper.taxi-booking-with-map.taxi-booking-map-right #taxi-booking-map {
        width: 100% !important;
        /* Höhe kommt aus Inline-Style vom PHP */
    }
}

@media (max-width: 768px) {
    .taxi-booking-form-wrapper {
        padding: 20px;
        margin: 10px;
    }

    .taxi-booking-form-wrapper .form-row {
        grid-template-columns: 1fr;
    }

    .taxi-booking-form-wrapper .verification-methods {
        grid-template-columns: 1fr;
    }

    .taxi-booking-form-wrapper .verification-method-btn {
        padding: 20px;
    }

    .taxi-booking-form-wrapper .verification-method-btn .method-icon {
        width: 36px;
        height: 36px;
    }

    .taxi-booking-form-wrapper #verification_code {
        font-size: 20px;
        letter-spacing: 4px;
    }

    .taxi-booking-form-wrapper .booking-summary-card {
        padding: 16px;
    }
    
    .taxi-booking-form-wrapper .booking-summary-card .booking-id-section {
        padding: 10px 12px;
        margin-bottom: 16px;
    }

    .taxi-booking-form-wrapper .booking-summary-card .booking-id {
        font-size: 18px;
        letter-spacing: 1.5px;
    }
    
    .taxi-booking-form-wrapper .booking-summary-card .booking-section {
        padding: 12px;
        margin-bottom: 10px;
    }
    
    .taxi-booking-form-wrapper .booking-summary-card .booking-section h3 {
        font-size: 14px;
        margin-bottom: 10px;
    }
    
    .taxi-booking-form-wrapper .booking-summary-card .booking-field {
        padding: 5px 0;
        font-size: 13px;
    }
    
    .taxi-booking-form-wrapper .booking-summary-card .booking-field strong {
        display: block;
        min-width: auto;
        margin-bottom: 3px;
    }
    
    .taxi-booking-form-wrapper .booking-error-wrapper .error-title {
        font-size: 24px;
    }
    
    .taxi-booking-form-wrapper .booking-error-wrapper .error-description {
        font-size: 14px;
    }
    
    .taxi-booking-form-wrapper .booking-error-wrapper .error-contact {
        font-size: 14px;
    }
}

@media (max-width: 600px) {
    .taxi-booking-form-wrapper .form-row {
        grid-template-columns: 1fr;
    }
}