:root {
	--merchant-primary-color: #2C66FF;
	--merchant-light-color: rgba(44, 102, 255, 0.1);
}

.top-menus .nav-tabs .nav-link {
	border: 0;
	flex: 1 1;
	text-align: center;
	padding: 5px 0;
}

.top-menus .nav-tabs .nav-link.active {
	border-bottom: 5px solid var(--saraga-color);
}

.btn-secondary.disabled,
.btn-secondary:disabled,
.btn-secondary.disabled:hover,
.btn-secondary:disabled:hover {
	color: #fff;
	background-color: #6c757d;
	border-color: #6c757d;
}

.btn-merchant,
.btn-merchant:focus {
	border-radius: 6px;
	padding: 4px 8px;
	border-radius: 6px;
	display: flex;
	flex-direction: row;
	justify-content: center;
	align-items: center;
	font-size: 0.8rem;
	border: 1px solid #7E8494;
	flex-wrap: wrap;
	box-shadow: 0px 2px 5px 0px rgb(0 0 0/.25);
	border-color: #BEBEC1;
	color: #212529;
	position: relative;
}

.navigation .active {
	color: var(--merchant-primary-color);
}

.wrappers {
	margin: 5px 0;
}

.btn.item-filters {
	border-radius: 25px;
	box-shadow: none;
}

.btn-merchant-primary {
	background: var(--merchant-primary-color);
	color: #fff;
	border-color: var(--merchant-primary-color);
}

.bg-merchant-primary {
	background: var(--merchant-primary-color);
	color: #fff;
}

.btn-merchant-primary:hover {
	color: #fff;
	font-weight: bold;
}

.btn-merchant-outline-primary {
	background: #fff;
	color: var(--merchant-primary-color);
	border-color: var(--merchant-primary-color);
}

.btn-merchant-outline-primary:hover {
	color: var(--merchant-primary-color);
	background: rgba(44, 102, 255, 0.1);
	font-weight: bold;
}

.btn-credits,
.btn-merchant.active,
.item-filters.active {
	color: #2C66FF;
	font-weight: 600;
	background: rgba(44, 102, 255, 0.1);
	border: 1px solid #2C66FF;
}

.item-dates .today {
	position: absolute;
	top: -1rem;
	color: #2C66FF;
	font-weight: bold;
}

.calendar .item-dates.active,
.calendar-info .box.selected {
	color: #FFF;
	background: #2C66FF;
	border-color: var(--merchant-primary-color);
}

.btn-credits *,
.btn-merchant.active *,
.item-filters.active * {
	color: #2C66FF;
}

.calendar .item-dates.active * {
	color: #fff;
}

@media screen and (max-width:768px) {
	.list-dates .btn-merchant {
		padding: 4px;
	}
}

.text-merchant {
	color: var(--merchant-primary-color);
}

.card {
	border-radius: 6px;
	overflow: hidden;
}

.list-filters button,
.list-filters button:focus {
	width: max-content;
	flex: 0 0 max-content;
	padding-left: 15px;
	padding-right: 15px;
}

.sort-by .form-control {
	padding: 4px 8px;
	border-radius: 6px;
	border: 1.5px solid #E5E7EF;
	height: 28px;
	min-width: 100px;
	flex: 1 1 100px;
	text-align: center;
}

.flex-wrapper,
.class-attribute,
.class-location_timeslot div {
	display: flex;
	flex-direction: row;
	align-items: center;
	flex-wrap: wrap;
}

.grid-wrapper {
	display: grid;
	grid-template-columns: repeat(7, auto);
	gap: 10px;
	margin-bottom: 10px;
}

.flex-wrapper>*:not(:last-child) {
	margin-right: 10px;
}

.class-attribute li:not(:last-child):after {
	content: "\f1db";
	margin: 10px;
	font-family: FontAwesome;
	font-size: 8px;
}

.class-location_timeslot {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
}

.class-location_timeslot i {
	padding-bottom: 0;
}

.item-classes .card-footer {
	background: #fff;
	border-top-style: dashed;
}

.calendar .today *,
.calendar-info .box.today {
	border-color: var(--merchant-primary-color);
	color: var(--merchant-primary-color);
}

.calendar .item-dates>.today,
.calendar-info .box.today {
	color: var(--merchant-primary-color) !important;
}

.calendar-info .box {
	width: 20px;
	height: 20px;
	border: 1px solid black;
	margin-right: 0.5rem;
	display: flex;
	justify-content: center;
	align-items: center;
}

.generate-calendar,
.class-unavailable {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	min-height: 275px;
	position: absolute;
	top: 0px;
	left: 0;
	right: 0;
	z-index: 100;
	bottom: 0px;
	background: #fff;
	height: 100%;
}

/* .item-classes .card-body:before {
	content: '';
	border-left: 6px solid orange;
	position: absolute;
	left: 0.25rem;
	z-index: 1;
	top: 0.25rem;
	bottom: 0.25rem;
	border-radius: 0.5rem;
} */
.list-credit_history .item-credit_history {
	display: block;
}

.list-credit_history .item-credit_history:not(:last-child) {
	margin-bottom: 1rem;
}

.phone-prefix {
	position: absolute;
	padding: 0.75rem;
}

.slick-dots li {
	margin: 0;
}

.slick-prev {
	left: 1rem !important;
	z-index: 1;
}

.slick-next {
	right: 1rem !important;
	z-index: 1;
}

.slick-dots {
	bottom: 1rem;
}

.custom-carousels .items img {
	width: 100%;
	object-fit: cover;
	aspect-ratio: 5/3;
	border-radius: 1rem;
}

.carousel-gallery .items img {
	aspect-ratio: 2/1;
}

@media (max-width: 992px) {

	.custom-carousels .items img,
	.carousel-gallery .items img {
		border-radius: .5rem;
	}

	.btn-action-booking {
		position: fixed;
		/* bottom: 65px; */
		left: 0.75rem;
		right: 0.75rem;
		width: auto;
	}

	.container {
		width: 100%;
	}
}


.carousel-item img {
	max-height: 100% !important;
	object-fit: cover;
	aspect-ratio: 4/3;
}

.link-copy,
.sharing {
	cursor: pointer;
}

.sharing {
	width: 2rem;
	justify-content: center;
	align-items: center
}

.sharing i {
	width: 100%;
	font-size: 1.25em;
	text-align: center;
}

@supports not (aspect-ratio: auto) {
	.carousel-item img {
		object-fit: cover;
		min-height: 420px;
	}

	.custom-carousels .items img {
		height: calc(100vw / 2);
	}
}

.item-coach:not(:last-child)::after {
	content: ', ';
}

.map-embed iframe {
	height: 300px !important;
}

.body-content span {
	font-size: 14px;
}

.link-transaction-detail:hover {
	color: inherit;
	box-shadow: 0 0 5px 3px rgb(0 0 0/.25);
	border-radius: 6px;
	overflow: hidden;
}

#wallet_transactions .item-transactions:not(:last-child) {
	padding-bottom: 1rem;
	border-bottom: 1px solid #d8d8d8;
}

.list-packages .item-packages button:focus,
.list-packages .item-packages button:hover {
	background-color: var(--merchant-light-color);
	color: var(--merchant-primary-color);
}

.list-packages .item-packages button:focus {
	outline-color: var(--merchant-primary-color);
	font-weight: bold;
}

.list-packages .item-packages button:hover .package-detail {
	border-color: var(--merchant-primary-color);
}

#topup-confirmation .content,
#topup-payment .content,
#class-detail .content,
#profile-detail .content {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: 100%;
	height: 100%;
}

#topup-confirmation .content > [class*="-content"],
#topup-payment .content > [class*="-content"],
#class-detail .content > [class*="-content"],
#profile-detail .content > [class*="-content"] {
	width: 100%;
}
@media screen and (max-width:480px){
	#topup-confirmation .content > [class*="-content"].align-self-end,
	#topup-payment .content > [class*="-content"].align-self-end,
	#class-detail .content > [class*="-content"].align-self-end,
	#profile-detail .content > [class*="-content"].align-self-end {
		padding-bottom: 80px;
	}
}

#class-detail .item-overview {
	flex: 0 0 max-content;
	width: max-content;
	padding-left: 1rem;
}

.item-overview .icon-container {
	border-radius: 50% !important;
	color: #7E8494;
	background-color: #f8f9fa;
	border: 1px solid #dee2e6 !important;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 30px;
	height: 30px;
}

.item-packages .package-content {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: space-between;
	width: 100%;
}

.item-packages .package-content .package-detail {
	flex: 1;
	border-radius: 6px;
	overflow: hidden;
	border: 1px solid rgba(0, 0, 0, .125);
	border-top-right-radius: 0;
	border-bottom-right-radius: 0;
}

.item-packages .package-content .package-arrow {
	flex: 0 0 max-content;
	font-size: 24px;
	border-radius: 6px;
	overflow: hidden;
	border: 1px solid var(--merchant-primary-color);
	border-top-left-radius: 0;
	border-bottom-left-radius: 0;
}
.venue-description ol {
	list-style: decimal-leading-zero;
	padding-left: 1.25rem;
}
.credit {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: end;
	gap: 10px;
}
.credit .credit-item {
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	align-items: center;
	border-radius: 5px;
	padding: 5px;
}
.credit .credit-item.free {
	background: var(--success);
}
.credit .credit-item.paid {
	background: var(--info);
}
.credit .credit-item .label {
	color: #fff;
	line-height: 1;
}
.credit .credit-item .amount {
	color: #fff;
	display: block;
	width: 100%;
	padding: 0 5px;
	text-align: center;
	font-weight: bolder;
}