/* Styles definition here */

.elementor-widget-tabs .elementor-tab-content {
	padding: 0;
}

#fbuilder fieldset {
	border: none;
}

#fbuilder legend,
#fbuilder .pbPrevious {
	display: none !important;
}

/* --- 1. GŁÓWNY KONTENER (Compact Asian Dark) --- */
#fbuilder, 
.cp_appbooking_public_form_container {
    color: #f0f0f0;
    padding: 25px;
    box-sizing: border-box;
    font-size: 13px; /* Bazowa wielkość czcionki */
    background-color: #FFC409 !important;
}

#fbuilder * { box-sizing: border-box; }

/* --- 2. NAGŁÓWEK (Mniejszy) --- */
#fbuilder h1 {
    color: #000000 !important;
    font-weight: 500 !important;
    font-size: 22px !important; /* Zmniejszono z 35px */
    text-transform: uppercase;
    letter-spacing: 2px;
    border-bottom: 1px solid #d32f2f;
    padding-bottom: 8px; /* Mniej odstepu */
    margin-bottom: 15px; /* Mniej odstepu */
    text-align: center;
    font-family: 'montserrat';
}

/* --- 3. INPUTY (Bardziej płaskie) --- */
#fbuilder label {
    color: #000000 !important;
    font-size: 12px; /* Mniejsza czcionka */
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 2px; /* Bliżej inputa */
    font-weight: bold;
}

#fbuilder span.r { color: #d32f2f; }

#fbuilder input[type="text"],
#fbuilder input[type="email"],
#fbuilder select {
    border: 1px solid #444 !important;
    border-left: 3px solid #d32f2f !important;
    padding: 8px 10px !important; /* Mniejszy padding wewnątrz */
    border-radius: 0 !important;
    width: 100% !important;
    height: auto !important;
/*     margin-bottom: 8px; */
    font-size: 13px !important;
	background-color: white !important;
}

#fbuilder input:focus, #fbuilder select:focus {
    border-color: #d4af37 !important;
    outline: none;
}

/* --- 4. KALENDARZ (Kluczowa kompresja) --- */
#fbuilder .fieldCalendar {
    width: 100% !important;
    margin: 0 !important;
}

#fbuilder .ui-datepicker-inline {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    background: #fff !important;
    border: none !important;
    font-size: 12px !important; /* Mniejsza czcionka w kalendarzu */
}

/* Nagłówek kalendarza (Cieńszy pasek) */
#fbuilder .ui-datepicker-header {
    background: #d32f2f !important;
    border: none;
    color: white;
    padding: 0 !important; /* Cieńszy nagłówek */
}

#fbuilder .ui-datepicker-title {
    margin: 0 !important;
	font-size: 22px;
	color: white;
}

/* Komórki kalendarza (Mniejsze kwadraty) */
#fbuilder .ui-datepicker th { padding: 3px 0 !important; font-size: 11px; color: black !important; }
#fbuilder .ui-datepicker td span, 
#fbuilder .ui-datepicker td a {
    padding: 3px !important; /* Mniejszy odstęp w dniach */
    text-align: center;
}

#fbuilder .ui-state-active,
#fbuilder .ui-widget-content .ui-state-active {
    background: #d32f2f !important;
    color: #000000 !important;
    border: none !important;
}

#fbuilder a.ui-state-default:hover {
	background-color: #b71c1c !important;
}

/* Strzałki kalendarza */

body #fbuilder .ui-datepicker .ui-datepicker-prev, 
body #fbuilder .ui-datepicker .ui-datepicker-next {
    top: 0 !important;
    cursor: pointer;
    width: 20px !important;
    height: 20px !important;
}

/* --- 5. SLOTY GODZINOWE (Kompaktowe) --- */
#fbuilder .slots {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 5px; /* Mniejszy odstęp */
    margin-top: 10px;
    width: 100%;
}

.ahb_m4 #fbuilder .slots {
	padding: 0 !important;
}

.ahb_m4 #fbuilder .fieldCalendar, #fbuilder .slotsCalendar {
	width: 100%;
}

#fbuilder .slots span {
    width: 100%;
    text-align: center;
    color: #d32f2f !important;
    font-weight: bold;
    margin-bottom: 5px;
    padding-bottom: 3px;
    border-bottom: 1px solid #d32f2f;
    font-size: 14px;
}

#fbuilder .availableslot {
    display: inline-block !important;
    margin: 0 !important;
    width: auto !important;
}

#fbuilder .availableslot a {
    display: block !important;
    background: transparent !important;
    border: 1px solid #555 !important;
    color: #000000 !important;
    border-radius: 0 !important;
    padding: 5px 8px !important; /* Mniejsze guziki */
    font-size: 12px;
    text-decoration: none !important;
    transition: 0.3s;
}

#fbuilder .availableslot a:hover,
#fbuilder .availableslot a.selected {
    background: #d32f2f !important;
    color: #000 !important;
    border-color: #d4af37 !important;
}

.ahb_m4 #fbuilder .slots div.currentSelection a {
	font-weight: bold;
    background: #d32f2f !important;
}

/* --- POPRAWKA 1: WYBRANE SLOTY (Cieńszy pasek) --- */
#fbuilder .usedSlots > div {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    background-color: #2a2a2a !important;
    border: 1px solid #444;
    border-left: 3px solid #d4af37 !important;
    padding: 6px 10px !important; /* Cieńszy pasek */
    margin-bottom: 5px !important;
    color: #fff !important;
    font-size: 12px !important;
    width: 100% !important;
}

#fbuilder .usedSlots a,
#fbuilder .usedSlots .cpefb_remove_slot {
    background-color: #d32f2f !important;
    color: #fff !important;
    border-radius: 50% !important;
    width: 20px !important; /* Mniejszy X */
    height: 20px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-decoration: none !important;
    font-size: 10px !important;
    margin: 0 !important;
}

/* --- 6. PRZYCISK SUBMIT (Mniejszy) --- */
#fbuilder .pbSubmit, 
#custom_booking_btn, .pbNext {
    background-color: #d32f2f !important;
    color: #fff !important;
    border: none;
    padding: 10px 20px !important; /* Mniejszy przycisk */
    text-transform: uppercase;
    font-weight: bold;
    letter-spacing: 1px;
    font-size: 14px;
    width: 100%;
    margin-top: 15px; /* Mniejszy odstęp od góry */
    cursor: pointer;
    transition: 0.3s;
    border-radius: 0 !important;
	text-align: center;
}

#fbuilder .pbSubmit:hover,
#custom_booking_btn:hover,
.pbNext:hover {
    background-color: #b71c1c !important;
}

#fbuilder .cpefb_error { color: red; font-size: 11px; margin-top: 2px; }

#fbuilder .ui-datepicker .ui-datepicker-next {
    right: 10px !important;
    top: -4px !important;
}

#fbuilder .ui-datepicker .ui-datepicker-prev {
    left: 10px !important;
    top: -4px !important;
}

/* MOBILE */
@media screen and (max-width: 640px) {
    #fbuilder, .cp_appbooking_public_form_container {
        padding: 10px; /* Jeszcze mniej paddingu na telefonie */
    }
    .ahb_m2 #fbuilder .ui-datepicker .ui-datepicker-prev, 
    .ahb_m2 #fbuilder .ui-datepicker .ui-datepicker-next {
        width: 18px; height: 18px; margin: 5px;
    }
}

/* Stylizacja ramki informacyjnej */
.booking-info-box {
    background-color: #e3f2fd; /* Jasnoniebieski tło */
    border-left: 4px solid #2196F3; /* Niebieski pasek z lewej */
    padding: 15px;
    border-radius: 4px;
    display: flex;
    align-items: flex-start;
    gap: 15px;
    font-size: 13px;
    line-height: 1.5;
    color: #333;
}

.booking-info-box .info-icon {
    font-size: 24px;
    margin-top: -6px;
}

/* Wyróżnienie punktu o przepadaniu zadatku */
.booking-info-box li strong {
    font-weight: 700;
}

/* Styl dla kręcącego się kółeczka ładowania */
.spinner-loader {
    display: inline-block;
    width: 16px;
    height: 16px;
    border: 2px solid rgba(255,255,255,0.3);
    border-radius: 50%;
    border-top-color: #fff;
    animation: spin 1s ease-in-out infinite;
    margin-right: 8px;
    vertical-align: middle;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* Zmiana stylu przycisku podczas ładowania */
.pbSubmit.loading-active {
    opacity: 0.7;
    cursor: wait !important;
    pointer-events: none; /* Blokuje wielokrotne kliknięcie */
}

/* --- STYLIZACJA KARTY ZASAD REZERWACJI --- */
.saigon-rules-card {
    background-color: #ffffff; 
    border: 1px solid #d4d4d4; 
    padding: 20px; 
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; 
    line-height: 1.6; 
    color: #1a1a1a; 
/*     margin-bottom: 30px;  */
    position: relative;
}

.saigon-rules-top-line {
    position: absolute; 
    top: 0; left: 0; right: 0; 
    height: 3px; 
    background-color: #9e1b1b;
}

.saigon-rules-header {
    text-align: center; 
    margin-bottom: 35px; 
    border-bottom: 1px solid #eaeaea; 
    padding-bottom: 20px;
}

.saigon-rules-header h3 {
    margin: 0; 
    color: #1a1a1a; 
    font-size: 22px; 
    font-weight: 600; 
    text-transform: uppercase; 
    letter-spacing: 1px;
}

.saigon-rules-header p {
    margin: 8px 0 0 0; 
    color: #666; 
    font-size: 14px; 
    text-transform: uppercase; 
    letter-spacing: 0.5px;
}

.saigon-rules-price {
    color: #9e1b1b; 
    font-size: 16px;
    font-weight: bold;
}

.saigon-rules-list {
    display: flex; 
    flex-direction: column; 
    gap: 20px;
}

.saigon-rule-item {
    display: flex; 
    align-items: flex-start; 
    gap: 15px; 
    border-left: 2px solid #eaeaea; 
    padding-left: 15px;
}

/* Dedykowana klasa dla tytułu (zamiast ogólnego strong) */
.saigon-rule-title {
    display: block; 
    font-size: 15px; 
    margin-bottom: 4px; 
    color: #1a1a1a; 
    text-transform: uppercase; 
    letter-spacing: 0.5px;
    font-weight: bold;
}

.saigon-rule-desc {
    font-size: 14px; 
    color: #555;
}

.saigon-rule-warning {
    display: flex; 
    align-items: flex-start; 
    gap: 15px; 
    border-left: 2px solid #9e1b1b; 
    padding-left: 15px; 
    margin-top: 10px; 
    background-color: #fcfcfc; 
    padding-top: 10px; 
    padding-bottom: 10px; 
    border-right: 1px solid #eaeaea; 
    border-top: 1px solid #eaeaea; 
    border-bottom: 1px solid #eaeaea;
}

/* Dedykowana klasa dla tytułu ostrzeżenia */
.saigon-rule-warning-title {
    display: block; 
    font-size: 15px; 
    margin-bottom: 4px; 
    color: #9e1b1b; 
    text-transform: uppercase; 
    letter-spacing: 0.5px;
    font-weight: bold;
}

.saigon-rule-warning-desc {
    font-size: 14px; 
    color: #333;
}