/* webseite/assets/css/search-widget.css */

/* --- LAYOUT CONTAINER (Clean Look statt Booking-Gelb) --- */
.booking-wrapper {
    background-color: transparent;
    padding: 0;
    align-items: center; 
}

.booking-field {
    background: white;
    border: 1px solid #e5e7eb; /* Sanfter grauer Rahmen */
    border-radius: 8px; /* Deutlich runder */
    height: 54px;
    position: relative;
    display: flex;
    align-items: center;
    transition: all 0.2s;
    width: 100%;
}

.booking-field:hover {
    border-color: #b0b0b0;
    box-shadow: 0 2px 4px rgba(0,0,0,0.02);
}

.booking-field:focus-within {
    border-color: #2563eb;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

/* --- SUCH-BUTTON --- */
.search-submit-btn {
    width: 100%;
    height: 54px;
    background-color: #2563eb; /* Standard Web-Blau */
    color: white;
    font-size: 16px; /* Etwas kleiner als Booking */
    font-weight: 600;
    border-radius: 8px; /* Runder */
    border: none;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    transition: background-color 0.2s, transform 0.1s, box-shadow 0.2s;
    box-shadow: 0 4px 6px -1px rgba(37, 99, 235, 0.2);
}

.search-submit-btn:hover { background-color: #1d4ed8; }
.search-submit-btn:active { transform: scale(0.98); }

/* --- FLATPICKR KALENDER --- */
.flatpickr-calendar {
    border: 1px solid #e5e7eb !important;
    box-shadow: 0 10px 25px rgba(0,0,0,0.1) !important;
    border-radius: 12px !important;
    padding: 16px !important;
    margin-top: 8px;
    font-family: inherit;
    width: auto !important;
}

.flatpickr-months { margin-bottom: 15px; }

/* Hervorhebung für den HEUTIGEN Tag */
.flatpickr-day.today {
    border: 2px solid #2563eb !important;
    color: #2563eb !important;
    font-weight: 800 !important;
}

/* Wenn heute ausgewählt ist, soll die Schrift weiß werden */
.flatpickr-day.today.selected, 
.flatpickr-day.today.startRange, 
.flatpickr-day.today.endRange,
.flatpickr-day.today.inRange {
    color: #ffffff !important;
}

/* ANPASSUNG: Wenn heute blockiert/gebucht ist, das Blau für den Rahmen beibehalten! */
.flatpickr-day.today.flatpickr-disabled {
    border-color: #60a5fa !important; /* Sichtbares, leicht abgeschwächtes Blau für den Rahmen */
    border-width: 2px !important;
    color: #9ca3af !important; /* Graue Schrift (durchgestrichen) bleibt */
    background-color: #f3f4f6 !important; /* Grauer Hintergrund bleibt */
}

.flatpickr-day.selected, .flatpickr-day.startRange, .flatpickr-day.endRange {
    background: #2563eb !important; /* Passendes Blau */
    border-color: #2563eb !important;
    border-radius: 6px !important;
}

.flatpickr-day.inRange {
    background: #eff6ff !important;
    box-shadow: -5px 0 0 #eff6ff, 5px 0 0 #eff6ff !important;
    border-color: #eff6ff !important;
    color: #1e3a8a !important;
}

/* Footer im Kalender */
.flatpickr-custom-footer {
    border-top: 1px solid #f3f4f6;
    padding-top: 12px;
    margin-top: 8px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.flex-option-btn {
    padding: 6px 12px;
    border: 1px solid #e5e7eb;
    border-radius: 6px; /* Eckiger als vorher */
    background: white;
    font-size: 12px;
    font-weight: 500;
    color: #374151;
    cursor: pointer;
    transition: all 0.2s;
}

.flex-option-btn:hover { background: #f9fafb; border-color: #d1d5db; }

.flex-option-btn.active {
    border-color: #2563eb;
    background-color: #eff6ff;
    color: #2563eb;
    font-weight: 600;
}

/* --- GÄSTE DROPDOWN --- */
.guest-dropdown-menu {
    display: none;
    position: absolute;
    top: 100%;
    right: 0;
    width: 320px;
    background: white;
    border-radius: 12px;
    border: 1px solid #e5e7eb;
    box-shadow: 0 10px 25px rgba(0,0,0,0.1);
    padding: 24px;
    z-index: 60;
    margin-top: 8px;
    cursor: default;
}

@media (max-width: 768px) {
    .guest-dropdown-menu { width: 100%; left: 0; }
}

.guest-dropdown-menu.show { display: block; }

.counter-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

.counter-btn {
    width: 32px;
    height: 32px;
    border: 1px solid #e5e7eb;
    background: white;
    color: #374151;
    border-radius: 50%; /* Rund statt eckig */
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    cursor: pointer;
    transition: all 0.2s;
}

.counter-btn:hover:not(:disabled) { border-color: #2563eb; color: #2563eb; background: #f9fafb; }
.counter-btn:disabled { opacity: 0.4; cursor: not-allowed; }

.counter-value {
    width: 30px;
    text-align: center;
    font-weight: 600;
    color: #111827;
}

/* --- KINDER ALTER SELEKTOREN --- */
.children-age-wrapper {
    margin-top: 10px;
    margin-bottom: 10px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}
