#ba_prev_step,#ba_submit_btn{
	display:none;
}
.ba-booking-shell {
    max-width: 100%;
    margin: 0px auto;
    padding: 25px 25px;
    border-radius: 0px;
    background: #eae7da; /* solid orange, no gradient */
    box-shadow: 0 22px 55px rgba(0, 0, 0, 0.18);
    box-sizing: border-box;
}

.ba-booking-header {
    text-align: left;
    margin-bottom: 16px;
}

.ba-booking-header h2 {
    margin: 0 0 4px;
    font-size: 35px;
    color: #263B7E;
	text-align:center;
}

.ba-booking-header p {
    margin: 0;
    color: #000;
    font-size: 18px;
	text-align:center;
}

.ba-step-indicator {
    list-style: none;
    padding: 0;
    margin: 4px 0 18px;
    display: flex;
    justify-content: space-between;
    gap: 8px;
}

.ba-step-indicator-item {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 6px 4px 10px;
    border-radius: 0;
    background: transparent;
    border: none;
    color: #6e6565;
    font-size: 13px;
    box-sizing: border-box;
}

.ba-step-circle {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: inline-flex;
    justify-content: center;
    background: #f3f4f6;
    color: #f97316;
    font-weight: 700;
    font-size: 18px;
	line-height:32px;
    border: 2px solid #e5e7eb;
}

.ba-step-label {
    white-space: nowrap;
    font-size: 18px;
		
}

.ba-step-indicator-active {
   color:#263B7E;
}

.ba-step-indicator-active .ba-step-circle {
    background: rgb(242 106 84);
    color: #fff;
}

.ba-step-indicator-completed {
    color: #263b7e;
}

.ba-step-indicator-completed .ba-step-circle {
    background: rgb(242 106 84);
    color: #fff;

}

.ba-booking-wrapper {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    padding: 15px 20px;
    border-radius: 18px;
    background-color: #f26a54;
    box-shadow: 0 14px 32px rgba(15, 23, 42, 0.22);
    box-sizing: border-box;
}

#ba-booking-form {
    flex: 1 1 60%;
    min-width: 280px;
}

.ba-step h3 {
    margin-top: 0;
    margin-bottom: 0px;
    font-size: 22px;
    color: #c2410c;
}

.ba-step-subtitle {
    margin: 0 0 14px;
    font-size: 18px;
    color: #fff;
}

.ba-summary-sidebar {
    flex: 0 0 190px;
    max-width: 190px;
    background: #ffffff;
    border-radius: 14px;
    padding: 14px 14px 10px;
    box-sizing: border-box;
    border: 1px solid rgba(15, 23, 42, 0.06);
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

.ba-summary-sidebar h4 {
    margin-top: 0;
    margin-bottom: 8px;
    font-size: 18px;
    color: #000000;
    letter-spacing: 0.18px;
    text-transform: capitalize;
}

.ba-summary-sidebar p {
    margin: 0 0 10px;
    font-size: 11px;
    color: #4b5563;
}

.ba-side-label {
    display: block;
    color: #9ca3af;
    font-weight: 600;
    font-size: 10px;
    text-transform: capitalize;
    letter-spacing: 0.08em;
}
button#ba_next_step {
    background-color: #263b7e;
    
}
.ba-summary-sidebar #ba_side_type,
.ba-summary-sidebar #ba_side_service,
.ba-summary-sidebar #ba_side_date,
.ba-summary-sidebar #ba_side_time {
    display: block;
    margin-top: 2px;
    font-size: 14px;
	letter-spacing:1px;
    line-height: 1.2;
    font-weight: 500;
    color: #ec6e17;
	text-transform:capitalize;
}

.ba-phone-wrapper #ba_phone_code {
    max-width: 90px;
}

.ba-confirm-card {
    border: 1px solid #fed7aa;
    border-radius: 12px;
    padding: 14px 16px;
    background: #fff7ed;
	font-size:16px;
}
.ba-confirm-card p strong{
       font-weight: 700;
    color: #000000;
    letter-spacing: 1px;
}

.ba-confirm-card p span{
    letter-spacing: 1px;
}

.ba-step {
    display: none;
}

.ba-step-active {
    display: block;
}

.ba-field {
    margin-bottom: 16px;
}

.ba-field label {
    display: flex;
    margin-bottom: 6px;
	color:#000000;
	font-size:16px;
	letter-spacing:1px
}

.ba-field input[type="text"],
.ba-field input[type="email"],
.ba-field input[type="tel"],
.ba-field input[type="date"],
.ba-field select {
    width: 100%;
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid #d1d5db;
    font-size: 14px;
    box-sizing: border-box;
    background-color: #f9fafb;
}

.ba-field input:focus,
.ba-field select:focus {
    outline: none;
    border-color: #f97316;
    box-shadow: 0 0 0 1px rgba(249, 115, 22, 0.3);
}

.ba-phone-wrapper {
    display: flex;
    gap: 8px;
}

.ba-phone-wrapper select {
    max-width: 90px;
}

.ba-date-time-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
}

.ba-date-field,
.ba-time-field {
    flex: 1 1 180px;
}

.ba-step-footer {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    margin-top: 16px;
    flex-wrap: wrap;
}

.ba-btn {
    border-radius: 999px;
    padding: 9px 20px;
    border: none;
    font-size: 14px;
    cursor: pointer;
}

.ba-btn-primary {
    background-color: #f97316;
    color: #ffffff;
}

.ba-btn-primary:hover {
    background-color: #ea580c;
}

.ba-btn-secondary {
    background-color: #e5e7eb;
    color: #111827;
}

.ba-btn-secondary:disabled {
    opacity: 0.6;
    cursor: default;
}

.ba-hidden {
    display: none !important;
}

.ba-status {
    margin-top: 12px;
}

.ba-status-message {
    display: none;
    font-size: 18px;
    padding: 8px 10px;
    border-radius: 4px;
	line-height: 1.5rem;
}

.ba-status-error {
    display: block;
    background-color: #fef2f2;
    color: #fff;
    border: 1px solid #fecaca;
}

.ba-status-success {
    display: block;
    background-color: #166534;
    color: #ffffff;
    border: 1px solid #bbf7d0;
}

.ba-small {
    font-size: 18px;
    color: #fff;
	margin-bottom:10px;
}

#ba_new_booking{
    background-color: #166534;
    color: #ffffff;
    font-size: 15px;
    font-weight: bolder;
    text-transform: uppercase;
}
.ba-summary-confirm p {
    margin: 4px 0;
}
span.close-popup {
    background-color: #f26a54;
    color: #fff;
    height: 26px;
    width: 26px;
    text-align: center;
    line-height: 27px;
    border-radius: 50%;
    font-size: 26px;
    font-weight: bold;
}
.ba-side-label {
    display: inline-block;
    min-width: 58px;
    font-size: 14px;
    color: #6b7280;
}

.ba-thankyou {
	width:100%;
    margin-top: 0px;
    padding: 20px 22px;
    border-radius: 12px;
    background: linear-gradient(135deg, #fffbeb, #fef3c7);
    border: 1px solid #fed7aa;
}

.ba-thankyou h3 {
    margin-top: 0;
    color: #c2410c;
}

.ba-booking-wrapper h3 {
    color: #fff;
}



.ba-btn-full {
    width: 100%;
    margin-top: 12px;
}

@media (max-width: 768px) {
    .ba-booking-shell {
        margin: 16px;
        padding: 0px;
		box-shadow: none;
    }

    .ba-booking-wrapper {
        flex-direction: column-reverse;
        padding: 16px;
		gap:10px;
    }

    .ba-summary-sidebar {
        order: -1;
        max-width: 100%;
        flex: 1 1 auto;
		display:flex;
		flex-wrap:wrap;
    }

    .ba-step-indicator {
        flex-direction: row;
		flex-wrap:wrap;
		margin-bottom:0px;
		gap: 2px;
    }
	#booking-appointment-popup .popup-content {
    max-width: 95%;
		background-color:#eae7da;
		
}
	.ba-booking-header h2 {
    font-size: 25px;
		padding:0px;
}
	.ba-booking-header p {
    font-size: 16px;
}
	.ba-step-circle {
    width: 28px;
    height: 28px;
    font-size: 16px;
    line-height: 26px;
    border: 1px solid #e5e7eb;
}
	.close-popup {
    top: 2px!important;
    right: 2px!important;
}
	.ba-step-label {
    font-size: 15px;
}
.ba-booking-header {
    margin-bottom: 6px;
}
	.ba-summary-sidebar p {
    width: 50%;
}
	.ba-summary-sidebar h4 {
width:100%;
}
	.ba-step-subtitle {
    font-size: 15px;
    line-height: 16px;
}
	.ba-field {
    margin-bottom: 10px;
}
	.ba-date-time-grid {
    gap: 5px;
}
	.ba-small {
    font-size: 15px;
    margin: 5px 0px 0px;
		line-height:18px;
}
	.ba-step-footer {
    margin-top: 5px;
}
	.ba-field label {

    letter-spacing: 0px;
}
	.ba-step h3 {
    padding-bottom: 0px;;
}
}

.ba-time-message {
    margin-top: 6px;
    padding: 5px 10px;
    background: #fff3cd;
    border: 1px solid #ffeeba;
    color: #856404;
    font-size: 14px;
    border-radius: 4px;
}


.ba-terms-checkbox {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  font-size: 14px;
  line-height: 1.5;
  user-select: none;
}

/* Hide default checkbox */
.ba-terms-checkbox input {
  position: absolute;
  opacity: 0;
}

/* Custom box */
.ba-checkmark {
  width: 20px;
  height: 20px;
  border: 2px solid #1e293b;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  margin-top: 2px;
}

/* Checked state */
.ba-terms-checkbox input:checked + .ba-checkmark {
  background-color:#ffffff;
  border-color: #f77216;
}

/* Tick */
.ba-checkmark::after {
  content: "✓";
  color: #263b7e;
  font-size: 16px;
 font-weight:800;
  display: none;
	margin-top:2px;
}

.ba-terms-checkbox input:checked + .ba-checkmark::after {
  display: block;
}


/* Error state */
.ba-terms-checkbox input:invalid + .ba-checkmark {
  border-color: #fff;
}

span.ba-terms-text a {
    color: #fff;
    text-decoration: underline;
}
button#ba_submit_btn {
    background-color: #263b7e;
}
div#ba_thankyou h3 {
    color: #000;
}

@media only screen and (min-width:768px) and (max-width:1024px){
	#booking-appointment-popup .popup-content {
    max-width: 95%;
}
}