#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; background: #ffffff; border-radius: 16px; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.07); border: 1px solid #e5e7eb; }
.bd-form-header { text-align: center; margin-bottom: 24px; }
.bd-form-title { font-size: 24px; font-weight: 700; color: #1f1f1f; margin: 0 0 8px 0; }
.bd-form-subtitle { font-size: 16px; color: #6b6b6b; margin: 0; }
.bd-form-field { margin-bottom: 18px; position: relative; }
.bd-form-field label { display: block; font-size: 14px; font-weight: 600; color: #333333; margin-bottom: 8px; }
.bd-form-field input[type="text"], .bd-form-field input[type="email"], .bd-form-field input[type="tel"], .bd-form-field 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; }
.bd-form-field input:focus, .bd-form-field select:focus { border-color: #8BA48C; outline: none; box-shadow: 0 0 0 3px rgba(139, 164, 140, 0.2); }
.bd-row { display: flex; gap: 16px; }
.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; }
.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; }
.bd-submit-button:hover:not(:disabled) { background: #6C8A70; }
.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; }
@media (max-width: 600px) { .bd-row { flex-direction: column; } #benahidiri-booking-form-wrapper { padding: 18px; } }