/* Booked Appointment Booking v2.0.6 - Main Styles */
.booked-appt-list { margin: 0; padding: 0; list-style: none; }
.booked-appt-list li { padding: 10px 0; border-bottom: 1px solid #eee; }
.booked-appt-list li:last-child { border-bottom: none; }
.booked-calendar-wrap { position: relative; width: 100%; margin: 0 auto; }
.booked-calendar { width: 100%; border-collapse: collapse; margin: 0; }
.booked-calendar thead th { text-align: center; padding: 10px; background: #f5f5f5; border: 1px solid #ddd; }
.booked-calendar tbody td { text-align: center; padding: 8px; border: 1px solid #eee; vertical-align: top; }
.booked-calendar tbody td.today { background: #e8f4fd; }
.booked-calendar tbody td.selected { background: #0073aa; color: #fff; }
.booked-calendar tbody td a { display: block; color: inherit; text-decoration: none; }
.booked-prev, .booked-next { cursor: pointer; padding: 5px 10px; background: #0073aa; color: #fff; border: none; border-radius: 3px; }
.booked-prev:hover, .booked-next:hover { background: #005177; }
.booked-month-title { display: inline-block; font-size: 18px; font-weight: bold; margin: 0 15px; }
.booked-form { margin: 20px 0; }
.booked-form input, .booked-form select, .booked-form textarea { width: 100%; padding: 8px 12px; margin-bottom: 10px; border: 1px solid #ddd; border-radius: 3px; box-sizing: border-box; font-size: 14px; }
.booked-form button, .booked-form input[type="submit"] { background: #0073aa; color: #fff; border: none; padding: 10px 20px; border-radius: 3px; cursor: pointer; font-size: 14px; }
.booked-form button:hover, .booked-form input[type="submit"]:hover { background: #005177; }
.booked-notice { padding: 10px 15px; border-radius: 3px; margin: 10px 0; }
.booked-notice.error { background: #ffe0e0; border-left: 4px solid #dc3232; }
.booked-notice.success { background: #d4edda; border-left: 4px solid #46b450; }
.booked-timeslot { display: inline-block; padding: 5px 10px; margin: 3px; border: 1px solid #ddd; border-radius: 3px; cursor: pointer; }
.booked-timeslot:hover, .booked-timeslot.selected { background: #0073aa; color: #fff; border-color: #0073aa; }
.booked-timeslot.unavailable { opacity: 0.4; cursor: not-allowed; }
.booked-modal-wrap { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.6); z-index: 9999; display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; -webkit-justify-content: center; justify-content: center; }
.booked-modal { background: #fff; border-radius: 5px; padding: 30px; max-width: 500px; width: 90%; position: relative; max-height: 90vh; overflow-y: auto; }
.booked-modal-close { position: absolute; top: 10px; right: 15px; font-size: 24px; cursor: pointer; color: #999; line-height: 1; }
.booked-profile-tabs { list-style: none; margin: 0; padding: 0; display: -webkit-flex; display: flex; border-bottom: 2px solid #0073aa; }
.booked-profile-tabs li { margin: 0; }
.booked-profile-tabs li a { display: block; padding: 10px 20px; color: #555; text-decoration: none; }
.booked-profile-tabs li.active a, .booked-profile-tabs li a:hover { background: #0073aa; color: #fff; }
