/* File: assets/css/public.css (Versi Final dengan Gaya Form yang Konsisten) */

#benahidiri-booking-form-wrapper {
    font-family: Inter, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    max-width: 640px;
    margin: 40px auto;
    padding: 24px 32px;
    background: #ffffff;
    border-radius: 16px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.07);
    border: 1px solid #e5e7eb;
}

#benahidiri-booking-form-wrapper .bd-form-header {
    text-align: center;
    margin-bottom: 24px;
}
#benahidiri-booking-form-wrapper .bd-form-title {
    font-size: 24px;
    font-weight: 700;
    color: #1f1f1f;
    margin: 0 0 8px 0;
}
#benahidiri-booking-form-wrapper .bd-form-subtitle {
    font-size: 16px;
    color: #6b6b6b;
    margin: 0;
}

#benahidiri-booking-form-wrapper .bd-form-field {
    margin-bottom: 18px;
    position: relative;
}

#benahidiri-booking-form-wrapper .bd-form-field label {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: #333333;
    margin-bottom: 8px;
}

#benahidiri-booking-form-wrapper input[type="text"],
#benahidiri-booking-form-wrapper input[type="email"],
#benahidiri-booking-form-wrapper input[type="tel"],
#benahidiri-booking-form-wrapper input[type="number"],
#benahidiri-booking-form-wrapper input[type="date"],
#benahidiri-booking-form-wrapper input[type="file"],
#benahidiri-booking-form-wrapper select {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid #d0d5dd;
    border-radius: 10px;
    font-size: 16px;
    background: #fff;
    transition: border-color 0.2s, box-shadow 0.2s;
    box-sizing: border-box;
}

#benahidiri-booking-form-wrapper input:focus,
#benahidiri-booking-form-wrapper select:focus {
    border-color: #8BA48C;
    outline: none;
    box-shadow: 0 0 0 3px rgba(139, 164, 140, 0.2);
}
#benahidiri-booking-form-wrapper input[type="file"] {
    padding: 8px;
}

#benahidiri-booking-form-wrapper .bd-row { display: flex; gap: 16px; }
#benahidiri-booking-form-wrapper .bd-col { flex: 1; }

.bd-help-text { font-size: 14px; color: #6b6b6b; padding: 12px; background-color: #f7f7f7; border-radius: 8px; margin-bottom: 12px; }
#bd-date-chips-container { display: flex; flex-wrap: wrap; gap: 8px; }
.bd-chip { padding: 8px 14px; border: 1px solid #d0d5dd; border-radius: 999px; font-size: 14px; color: #333; cursor: pointer; user-select: none; transition: all 0.2s ease-in-out; }
.bd-chip:hover { background-color: #f0f0f0; border-color: #b0b0b0; }
.bd-chip.active { background-color: #8BA48C; color: #fff; border-color: #8BA48C; font-weight: 600; }
.bd-session-summary { background-color: #f7f9fa; border-left: 4px solid #8BA48C; padding: 16px; margin: 20px 0; border-radius: 8px; }
.bd-session-summary h4 { margin: 0 0 10px 0; color: #1f1f1f; }
.bd-session-summary ul { list-style: none; padding: 0; margin: 0; color: #333; }
.bd-session-summary li { margin-bottom: 6px; }

#benahidiri-booking-form-wrapper .bd-submit-button {
    width: 100%;
    background: #8BA48C;
    color: #fff;
    padding: 14px 18px;
    font-size: 16px;
    font-weight: 700;
    border: none;
    border-radius: 10px;
    cursor: pointer;
    transition: background-color 0.2s;
}
#benahidiri-booking-form-wrapper .bd-submit-button:hover:not(:disabled) { background: #6C8A70; }
#benahidiri-booking-form-wrapper .bd-submit-button:disabled { background-color: #ccc; cursor: not-allowed; }

.bd-form-message { margin-top: 15px; padding: 12px; border-radius: 8px; text-align: center; display: none; }
.bd-form-message.success { background-color: #dcfce7; color: #166534; }
.bd-form-message.error { background-color: #fee2e2; color: #991b1b; }
.bd-spinner { border: 4px solid #f3f3f3; border-top: 4px solid #8BA48C; border-radius: 50%; width: 24px; height: 24px; animation: spin 1s linear infinite; margin: 0 auto; }
@keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }

.bd-radio-group { border: 1px solid #d0d5dd; border-radius: 10px; padding: 8px; }
.bd-radio-option { display: flex; align-items: center; padding: 8px; }
.bd-radio-option input[type="radio"] { margin-right: 12px; width: auto; accent-color: #8BA48C; }
.bd-radio-option label { margin-bottom: 0; font-weight: 500; width: 100%; cursor: pointer; }
.bd-radio-option:hover { background-color: #f7f9fa; border-radius: 6px; }

.bd-confirm-button { display: block; width: 100%; box-sizing: border-box; background: #8BA48C; color: #fff !important; padding: 14px 18px; font-size: 16px; font-weight: 700; text-align: center; text-decoration: none; border: none; border-radius: 10px; cursor: pointer; transition: background-color 0.2s; margin-top: 1em; }
.bd-confirm-button:hover { background: #6C8A70; color: #fff !important; }
.bd-checkout-box { border: 1px solid #e5e7eb; padding: 24px; border-radius: 16px; background: #fff; }
.bank-item { padding: 12px; background-color: #f7f9fa; border: 1px solid #e5e7eb; border-radius: 8px; margin-bottom: 10px; }
#benahidiri-payment-confirmation-form small { display: block; margin-top: 8px; color: #6b6b6b; }

@media (max-width: 600px) { .bd-row { flex-direction: column; } #benahidiri-booking-form-wrapper { padding: 18px; } }
/* Styles for Countdown Timer */
#bd-countdown-wrapper {
    text-align: center;
    background-color: #fff9e6;
    border: 1px solid #ffedd5;
    border-radius: 10px;
    padding: 16px;
    margin: 24px 0;
}
#bd-countdown-wrapper span {
    display: block;
    font-size: 14px;
    color: #92400e;
    margin-bottom: 8px;
}
#bd-countdown {
    font-size: 28px;
    font-weight: 700;
    color: #d97706;
    font-family: monospace;
}
#bd-countdown-wrapper.expired {
    background-color: #fee2e2;
    border-color: #fecaca;
}
#bd-countdown-wrapper.expired span {
    color: #991b1b;
    font-size: 16px;
    font-weight: bold;
}