html, body { min-height: 100vh; }
body {
	margin: 0;
	padding: 15px;
	background: #6cb1cf;
	background: radial-gradient(circle,rgba(128, 195, 224, 1) 0%, rgba(30, 102, 130, 1) 100%);
	font-family: sans-serif;
}
header, section { 
	max-width: 600px;
	margin: auto;
}
header  { 
	padding-top: 45px; 
}
.header-collumn {
	padding-top: 20px;
	padding-left: 48px;
}
section {
	background-color: #ffffff;
	padding: 20px;
	border-radius: 7px;
	border: 5px solid rgb(14 225 54 / 22%);
	color: #616262;
	min-height: 730px;
	margin: auto !important;
}
h1 { 
	color: #c0d34e;
	text-shadow: 0 1px 3px #41577c;
	margin-bottom: 6px;
}
h1 span {
	display: block;
	font-size: large;
	font-weight: normal;
}
img.logo { 
	border-radius: 75px;
	box-shadow: 0px 9px 33px #b9e4f3;
}
h2 { 
	color: #2a93c9;
	margin-top: 0;
	font-size: 1.6em;
	font-weight: bold;
}
h3 {
	font-size: 1.2rem;
	margin-bottom: 18px;
}
h3 span {
	margin-right: 8px;
	border-radius: 12px;
	border: 1px solid #2a93c9;
	display: inline-block;
	width: 25px;
	text-align: center;
	color: #2a93c9;
}
a {
	text-decoration: none;
	color: #315ca4;
}
a.iconic {
	display: flex;
	align-items: end;
	justify-content: center;
}
a.iconic img {
	padding-right: 5px;
}
a:hover { color: #673ab7; }
.btn-primary {
	padding: 15px 32px;
	border-radius: 7px;
	border: 1px solid #4e7f22;
	font-size: 1.1rem;
	color: #4d5a00;
	background: linear-gradient(to bottom, #d2ff52 0%, #5b9427 100%);
	font-weight: bold;
	text-shadow: 0px 1px 2px #ffffff;
}
.btn-primary:hover {
	background: linear-gradient(to bottom, #fff95d 0%, #51a704 100%) !important;
	box-shadow: 0px 2px 5px 0px #00000045;
	text-shadow: none;
}
.btn-primary:active {
	background: linear-gradient(to bottom, #78b044 0%, #b0d44b 100%) !important;
	text-shadow: none;
}
.btn-default {
	background: linear-gradient(to bottom, #ffffff 0%, #e9e7e7 100%);
	border: 1px solid #d5d1d1;
}
.btn-default.active {
	color: #ffffff;
	background: linear-gradient(to bottom, #75b798 0%, #198754 100%);
	border-color: #198754;
}
.btn-accent {
	background: linear-gradient(to bottom, #fefcea 0%, #ffe38f 100%);
	border: 1px solid #FFC107;
	padding-bottom: 10px;
}
.mb-50 { margin-bottom: 50px; }
.float-left {
	float: left;
	margin-right: 5px;
}
small {
	color: #ababab;
}
.grid-item small {
	display: block;
	overflow-wrap: break-word;
	/* word-break: break-all; */
	/* white-space: normal; */
	white-space: pre-wrap;
}
.dropdown-menu li a {
	border-bottom: 1px dashed #dfd9d9;
}
ul.dropdown-menu a {
	white-space: normal!important;
}
ul.dropdown-menu {
	max-width: 300px;
}
.grid-flex {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 16px;
}
.grid-item {
	flex: 0 0 calc(20% - 10px); 
	box-sizing: border-box;
	text-align: center;
}
.grid-item img, 
.grid-item a {
	border-radius: 7px;
	margin-bottom: 5px;
}
.grid-item img {
	width: 150px;
}
.grid-item a {
	display: block;
	padding: 7px;
	border: 1px solid #ffffff;
}
.grid-item a:hover,
.grid-item a.active {
	background: linear-gradient(to bottom, #f7f4da 0%, #fff5da 100%);
	border-color: #fce0ae;
}
@media (min-width: 1024px) {
	.grid-item {
		flex-basis: calc(15% - 12px);
	}
}
@media (min-width: 600px) and (max-width: 1023px) {
	.grid-item {
		flex-basis: calc(20% - 8px); 
	}
}
@media (max-width: 599px) {
	.grid-item {
		/*flex-basis: 100%;*/
		flex-basis: calc(30% - 8px); 
	}
}
.offcanvas-header.bg-success .btn-close,
.modal-header.bg-success .btn-close{
	background-color: #8BC34A;
}
.modal-header .bg-danger-subtle .btn-close {
	background-color: #e59199;
}
.hidden {
	opacity: 0;
	transition: opacity 0.5s ease-in-out;
}
.visible {
	opacity: 1;
}
.grid-item:has(a.disabled), a.disabled {
	display: none!important;
}

#pnlGender [data-gender].active img,
.invert {
	filter: invert(100%);
}
img.success {
	filter: invert(60%) sepia(0.8) hue-rotate(100deg);
}
#pnlDoctors div {
	border: 2px solid transparent;
	border-radius: 8px;
	margin-bottom: 8px;
}
#pnlDoctors img {
	display: none;
}
#pnlDoctors small {
	display: block;
}
#pnlDoctors span {
	margin-top: 2px;
	border-radius: 50%;
	padding: .5rem;
	margin-right: .5rem;
}

#selectTime .btn-default:not(.available) {
	color: #cecece;
    pointer-events: none;
    background:	none;
    background-color: #f9f9f9;
    border-color: #f9f9f9;
    text-decoration: line-through;
}
#selectTime button.available:not(.active) {
	background: linear-gradient(to bottom, #ffffff 0%, #d3f0d5 100%);
    color: #2e7d32;
    border: 1px solid #b8e1ce;
}
#selectTime button.sel {
	background: linear-gradient(to bottom, #ffffff 0%, #d3f0d5 100%);
    color: #2e7d32;
}

/* DATEPICKER STYLES*/

.air-datepicker-cell {
    transition: all 0.15s ease-in-out;
    position: relative;
    border-radius: 50% !important;
}

.air-datepicker-cell.available-date {
    background-color: #e8f5e9; 
    color: #2e7d32;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.air-datepicker-cell.available-date:hover {
    background-color: #c8e6c9;
    transform: scale(1.05);
}

.air-datepicker-cell.active-choice {
    background-color: #4caf50 !important; 
    color: white !important;
    font-weight: bold;
    box-shadow: 0 2px 8px rgba(76, 175, 80, 0.4);
    border-radius: 50%;
}

.air-datepicker-cell.unavailable-date {
    background-color: #f5f5f5;
    color: #bdbdbd;
    cursor: not-allowed;
    text-decoration: line-through;
    opacity: 0.6;
}

.air-datepicker-cell.unavailable-date:hover {
    background-color: #f5f5f5;
    transform: none;
}

@media (max-width: 768px) {
    .air-datepicker-cell.available-date,
    .air-datepicker-cell.unavailable-date {
        padding: 8px;
        font-size: 14px;
    }
}