:root {
	--apm-primary: #40c8eb;
	--apm-primary-hover: #28a3c4;
	--apm-primary-soft: #9de4f8;
	--apm-surface-dark: #0e2f3d;
	--apm-surface-mid: #3d6f84;
	--apm-surface-nav: #4a8094;
	--apm-ink: #1a2830;
	--apm-link: #0f5a6e;
	--apm-accent-line: #40c8eb;
	--apm-card: #eaf4f8;
	--apm-text-muted: #5c6e76;
	/* Header logo native 298×156; display height --logo-header-h, width = h×(298/156). Sharp retina: ~596×312 PNG/SVG */
	--logo-src-w: 362;
	--logo-src-h: 156;
	--logo-header-h: 100px;
}

body, html {width: 100%; height: 100%; padding: 0; margin: 0; font-family: 'Lato', sans-serif; font-weight: 400; font-size: 17px; color: #2a3a42; -webkit-text-size-adjust: 100%;}
body {overflow-x: hidden;}
a {text-decoration: none;}
.clear {clear: both;}
input,textarea,button {outline:none;}
a img {border: none;}
form {padding: 0; margin: 0;}
img {max-width: 100%; height: auto;}
#system-message , #system-message-container {
  	display: none !important;
	} 

.content {
    margin: 0 auto;
    text-align: left;
    width: 100%;
    max-width: 1300px;
    padding: 0 15px;
    box-sizing: border-box;
	}

.btn {
    width: 100%;
    max-width: 250px;
    border-radius: 5px;
    font-weight: 600;
    font-size: 18px;
    display: inline-block;
    border: 2px solid transparent;
    transition: all 0.3s;
    cursor: pointer;
    box-sizing: border-box;
	}

.btn-primary {
    background: #123842;
    color: #fff;
    border-color: #123842;
	}

.btn-primary a {
    color: #fff;
    padding: 13px 34px;
    display: block;
	}

.btn-primary:hover {
    background: transparent;
    color: #123842;
	}

.btn-primary:hover a {
    color: #123842;
	}

.table {
    display: table;
    vertical-align: middle;
	}

.table-row {
    display: table-row;
	}

.table-cell {
    display: table-cell;
    vertical-align: middle;
	}
	
.activeFeedbackField {
    display: inline-block;
    position: relative;
    width:0;
    overflow:hidden;
    }

.activeFeedbackField input{
    position:absolute;
    left:10px;
    }

.activeFeedbackDescription {
    padding-top: 5px;
    margin: 0;
    }

/*Top Nav Banner*/
.top-banner {
    background: #0e2f3d;
    display: flex;
    align-items: center; 
    justify-content: space-between; 
    min-height: 47px;
    padding: 0 20px; 
    position: relative; 
	}

.top-banner-left {
	flex-grow: 1;
	}

.top-banner-middle {
	flex: 1;
	}

.top-buttons {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	gap: 5px;
	}

.top-button a {
	color: #fff;
	padding: 5px 15px;
	border-radius: 5px;
	text-transform: uppercase;
	font-weight: 600;
	}

.top-button.ra a {
	background-color: #35badb;
	}

.top-button.pp a {
	background-color: #40c8eb;
	}

.top-banner-right {
	flex-grow: 1;
	}
	
.social-btns {
	display: flex;
	justify-content: center; 
	align-items: center;
	gap: 5px;
	}

.social-btns-wrapper {
    position: absolute;
    right: 20px; 
    display: flex;
    justify-content: center;
    width: calc(50% - 20px); 
	}

.social-button {
    width: 31px;
    height: 31px;
    transition: 0.3s;
    background-color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
	}

.social-button:hover {
	background-color: #c6e6f3;
	}

.social-button a i {
    transition: 0.3s;
	font-size: 18px;
    color: #0e2f3d;
	}

.social-button:hover a i {
    color: #ffffff;
	}

nav {
	position: relative;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 9000;
    transition: all 0.3s;
	box-shadow: 3px 3px 3px #0000001e;
	}

#homepage nav {
	position: absolute;
	}

#homepage nav.slide {
	position: relative;
  	display: none;
	}

nav.slide {
	position: fixed;
	}

/* Sticky clone (second <nav>): hidden until scripts.js adds .fixed at scroll>200px; avoids duplicate header-phones row */
nav.inner-nav.slide:not(.fixed) {
	display: none !important;
}

nav.slide.fixed , .inner-nav.slide.fixed {
	position: fixed !important;
  	display: block;
	}

nav .content {
    display: flex;
    align-items: center;
    padding: 0;
    background-color: #e9f4f8;
    width: 100%;
    box-sizing: border-box;
    max-width: 100%;
    justify-content: space-evenly;
    padding-left: 90px;
	}

.inner-logo {
	padding: 10px 14px;
    display: flex;
    vertical-align: middle;
	max-width: min(300px, calc(var(--logo-header-h) * var(--logo-src-w) / var(--logo-src-h) + 36px));
	flex-shrink: 0;
	box-sizing: border-box;
	}

.inner-logo a {
	display: flex;
	align-items: center;
	justify-content: center;
	}

.inner-logo img {
	width: auto;
	max-width: 100%;
	max-height: var(--logo-header-h);
	aspect-ratio: var(--logo-src-w) / var(--logo-src-h);
	height: auto;
	object-fit: contain;
	object-position: left center;
	display: block;
	}

.topmenu ul {
    padding: 0;
    margin: 0;
    display: flex;
	}

.topmenu ul li {
    list-style: none;
    padding: 0 15px;
    position: relative;
	}

.topmenu ul li.parent:after {
    content: '';
    position: absolute;
    top: 10px;
    right: 0;
    width: 0;
    height: 0;
    margin: 0 2px;
    vertical-align: middle;
    border-top: 4px solid;
    border-right: 4px solid transparent;
    border-left: 4px solid transparent;
  	color: #0e2f3d;
	}

.topmenu ul li a , span.nav-header , span.separator {
    text-decoration: none;
    font-size: 19px;
    color: #0e2f3d;
    transition: all 0.3s;
    white-space: nowrap;
	text-transform: uppercase;
	cursor: pointer;
	}

.topmenu > ul > li.parent {
	cursor: pointer;
	}

.topmenu ul li.active ul li a {
    /*color: #40c8eb;*/
	display: block;
	width: max-content;
	max-width: 100%;
	}

.topmenu li.active a {
    color: #40c8eb;
	}
	
	.topmenu li.active ul li a {
	    color: #0e2f3d;
		}

    .topmenu ul li a:hover {
        color: #40c8eb;
    }

    .topmenu ul li.active ul li a:hover,.topmenu ul li ul li.active a {
        color: #40c8eb;
    }

    .topmenu ul li ul li a:hover {
        color: #40c8eb;
    }
.topmenu ul li ul {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 100%;
    width: max-content;
    max-width: calc(100vw - 40px);
    display: block;
    background: #eaf4f8;
    max-height: 0;
    overflow-y: hidden;
    overflow-x: hidden;
    transition: all 0.2s;
    box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
    box-sizing: border-box;
	}

/*nav.fixed .topmenu ul li ul {
    background: #4a8094;
	}*/

.topmenu ul li:hover ul {
    padding-top: 10px;
    max-height: 3000px;
    overflow-y: auto;
    overflow-x: hidden;
    border-bottom: 3px solid #40c8eb;
	}

.topmenu ul li ul li {
    display: block;
    padding: 10px 15px;
	width: max-content;
	max-width: 100%;
	box-sizing: border-box;
	}

.topmenu ul li ul li a,
.topmenu ul li ul li span.nav-header,
.topmenu ul li ul li span.separator {
	white-space: nowrap;
	width: max-content;
	max-width: 100%;
	display: block;
	box-sizing: border-box;
	}

.hamburger {
    display: none;
	}

.header-phones {
    background: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 30px;
    flex-wrap: wrap;
    min-height: 28px;
    padding: 10px 25px;
	}

/* .top-phone {
	font-weight: 600;
	color: #1a2830;
	border-right: 1px solid #000;
	padding-right: 10px;
	} */

/* .top-phone:last-child {
	border-right: none;
	padding-right: 0;
	} */

.phone-btn-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 25px;
    flex-wrap: wrap;
	}

.top-phone {
	font-weight: 600;
	font-size: 18px;
	color: #1a2830;
  	display: inline-block;
	}

/* .top-phone a {
	font-weight: 600;
	color: #1a2830;
	} */

a.ra-btn {
    background-color: #40c8eb;
    color: #fff;
    border: 2px solid #40c8eb;
    padding: 2px 10px;
    font-weight: 700;
    border-radius: 5px;
    display: inline-block;
    margin: 0;
    font-size: 18px;
    transition: 0.3s all;
	}

a.ra-btn:hover {
  	background-color: #28a3c4;
	}

a.phone-link {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
	transition: 0.3s all;
	font-weight: 600;
	font-size: 18px;
	color: #0a296a;
	}

a.phone-link:hover {
	opacity: 0.5;
	}

a.phone-link img {
    border: 2px solid #0a296a;
    border-radius: 50%;
    padding: 3px;
	}

/* Slider block*/
.slider-block {
    text-align: center;
	position: relative;
	}

.slider-overlay {
    position: absolute;
    top: 5%;
	left: 13%;
    background: rgb(0 0 0 / 75%);
    padding: 15px 25px;
    border-radius: 15px;
	}

.slider-overlay h3 { 
    color: #fff;
    font-size: 24px;
    margin: 0;
	}

.slider-overlay ul {
    text-align: left;
    color: #fff;
    list-style: none;
    padding: 0;
    margin: 20px 0;
	} 

.slider-overlay ul li {
    margin: 5px 0;
    position: relative;
    padding: 0 0 0 30px;
	} 
	
.slider-overlay ul li:before {
	content: '';
	position: absolute;
	left: 0;
    top: 1px;
	width: 24px;
	height: 24px;
	background: url(../images/bullet.png) no-repeat center;
	background-size: cover;
	}

.slider-overlay ul li a {
	color: #fff;
	font-size: 20px;
	} 
	
.slider-tagline {
	background: #0e2f3d;
    box-sizing: border-box;
    padding: 20px 25px;
    text-align: center;
    color: #fff;
    font-size: 31px;
	}

.slider-tagline p {
	margin: 0;
	padding: 0;
	}

/* About block*/
.about-block {
	box-sizing: border-box;
	position: relative;
	padding: 0 25px;
	}	

.about-block-title {
	text-align: center;
	color: #1a2830;
	font-size: 42px;
	font-weight: 400;
	border-bottom: 2px solid #40c8eb;
	max-width: 800px;
	margin: 55px auto;
	padding-bottom: 20px;
	}

.about-block-wrap {
	max-width: 1155px;
	display: flex;
	gap: 20px;
	margin: 0 auto;
	align-items: start;
	justify-content: space-between;
	}

.about-block-left {
	color: #1a2830;
    font-size: 20px;
    max-width: 600px;
	}

.about-block-right {
	padding-top: 15px;
	max-width: 400px;
	width: 100%;
	}

/*Doctors block*/
.doctors-block {
    position: relative;
	}

.doctors-block-title {
	text-align: center;
	color: #1a2830;
	font-size: 44px;
	font-weight: 400;
	border-bottom: 2px solid #40c8eb;
	max-width: 800px;
	margin: 55px auto;
	padding-bottom: 20px;
	}

.doctors-boxes {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 40px;
    flex-wrap: wrap;
    padding: 73px 25px 0;
	}

.doctor-box {
	background: #eaf4f8;
    max-width: 330px;
    border-radius: 20px;
    text-align: center;
    padding-bottom: 20px;
    position: relative;
    width: 100%;
	}

.doctor-box a:first-child {
	display: block;
	width: 250px;
	height: 250px;
	margin: -73px auto 35px;
	border-radius: 50%;
	overflow: hidden;
	box-shadow: 3px 3px 3px rgb(0 0 0 / 45%);
	border: 3px solid #9de4f8;
	}

.doctor-box img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
	object-position: center;
	}

.doctor-box p {
	color: #1a2830;
    max-width: 335px;
    margin: 0 auto 0px;
    font-size: 20px;
	}

.doctors-name {
	color: #0d4f62 !important;
	font-weight: 600;
	}

.doctor-box p span {
	font-weight: 600;
	}

.doctor-blue-button {
	font-size: 20px;
    background-color: #40c8eb;
    color: #fff;
    display: block;
    margin: 35px auto 10px;
    padding: 10px;
    border-radius: 10px;
    max-width: 270px;
    font-weight: 600;
	}

.doctor-blue-button:hover {
    background-color: #28a3c4;
	}

.doctor-orange-button {
	font-size: 20px;
	background-color: #3bc4e8;
	color: #fff;
	display: block;
	margin: 10px auto;
	padding: 10px;
	border-radius: 10px;
	max-width: 270px;
	font-weight: 600;
	}

.doctor-orange-button:hover {
	background-color: #2498b8;
	}

.blue-background {
	background: #0e2f3d;
	height: 335px;
	position: absolute;
	bottom: 0;
	width: 100%;
	z-index: -1;
	}

/*4 Reasons To Choose*/

.reasons-block {
    background: #123842;
    padding: 5px 25px 50px;
    box-sizing: border-box;
	}

.reasons-title {
	text-align: center;
	color: #ffffff;
	font-size: 44px;
	font-weight: 400;
	margin: 55px auto;
	padding-bottom: 20px;
	}

.reasons-wrap {
    display: flex;
    justify-content: center;
    align-items: center;
    background: #fff;
    padding: 25px;
    box-sizing: border-box;
    max-width: 1445px;
    margin: 0 auto;
    border-radius: 10px;
    gap: 40px;
	}

.reasons-right {
	max-width: 565px;
	}

.reasons-right ul {
	list-style-type: none;
	padding-left: 0;
  }

  .reasons-right ul li {
    color: #1a2830;
    margin: 55px 0 60px;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 10px;
	}

/*Locations block*/

.locations-title-wrap {
	width: 100%;
	}

.locations-title {
    width: 100%;
    text-align: center;
    color: #1a2830;
    font-size: 44px;
    font-weight: 400;
    border-bottom: 2px solid #40c8eb;
    max-width: 800px;
    margin: 55px auto;
    padding-bottom: 20px;
	}

.locations-block {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 40px;
    padding: 0 25px 60px;
	}

.reviews-block {
    background: #eaf4f8;
    padding: 64px 25px 60px;
    box-sizing: border-box;
	}

.reviews-block .locations-title {
    margin: 0 auto 48px;
	}

.reviews-block-content {
    max-width: 1200px;
    margin: 0 auto;
	}

.location-wrap {
    background: #eaf4f8;
    max-width: 450px;
    border-radius: 20px;
    padding: 25px 0;
    display: inline-block;
    vertical-align: top;
    width: 100%;
	}

.map-wrap {
	max-width: 390px;
	width: 100%;
	height: 285px;
	margin: 0 auto;
	}

.loc-name {
	color: #1a2830;
	font-weight: 600;
	margin: 0;
	text-align: center;
	margin: 25px 0 0;
	}

.loc-address {
	color: #1a2830;
	text-align: center;
	margin: 0;
	}

.loc-number {
	color: #1a2830;
	text-align: center;
	margin: 0;
	}

.loc-button {
    display: block;
    color: #fff;
    background: #40c8eb;
    text-align: center;
    font-size: 25px;
    padding: 5px 25px;
    max-width: 150px;
    margin: 25px auto;
    border-radius: 15px;
	}

.loc-button:hover {
	background: #2498b8;
	}

.loc-schedule {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 20px;
	}

.loc-left p {
	margin: 0;
	color: #1a2830;
	}

.loc-right p {
	margin: 0;
	color: #1a2830;
	}

/*Blogs block*/

.blogs-block {
	padding: 50px 0;
	}

.blogs-block .content {
    text-align: center;
    max-width: 95%;
    border-radius: 20px;
    padding-top: 20px;
	}

.blogs-block h3 {
    width: 100%;
    text-align: center;
    color: #1a2830;
    font-size: 44px;
    font-weight: 400;
    border-bottom: 2px solid #40c8eb;
    max-width: 800px;
    margin: 55px auto;
    padding-bottom: 20px;
	}

.blogs-list ul {
    display: inline-block;
    padding: 0;
    margin: 0 auto;
    text-align: left;
	}

.blogs-list ul li {
    list-style: none;
    display: block;
    padding: 8px 0 8px 15px;
    position: relative;
	}

.blogs-list ul li::before {
    /* content: '•'; */
  	content: '\2022';
    position: absolute;
    left: 0;
    top: 10px;
    color: #fff;
	display: none;
	}

.blogs-list ul li a {
    text-decoration: none;
    text-transform: uppercase;
    text-align: center;
    display: block;
    margin: 10px 0;
    line-height: 20px;
    font-size: 18px;
    color: #1a2830;
    font-weight: bold;
	-webkit-transition: 0.5s all ease-in-out;
    transition: 0.5s all ease-in-out;
	}

.blogs-list ul li a:hover {
    text-decoration: underline;
	color: #0f5a6e;
	}

.blogs-block .btn {
    margin-top: 30px;
	margin-bottom: 30px;
	}

.k2ItemsBlock.blogs ul {
	display: flex;
    align-items: start;
    justify-content: center;
	}

.k2ItemsBlock.blogs ul li {
	display: flex;
    flex-direction: column-reverse;
	}

.itemListSubCategories {display: none;}

/*Footer*/
footer {
    background: #123842;
	}

.footer-logo {
    display: inline-block;
    vertical-align: text-bottom;		
	}

footer .content {
	text-align: center;
	}

.logo-footer {
	display: inline-block;
	vertical-align: middle;
	padding: 30px;
	max-width: 430px;
	}

.quick-links-block {
	display: inline-block;
	vertical-align: middle;
	padding: 30px;
	text-align: left;
	}

footer h4 {
	font-size: 18px;
	font-weight: 400;
	color: #ffffff;
	margin-top: 0;
	padding-top: 0;
	display: none;
	}

.quick-links-block ul {
	padding: 0;
	margin: 0;
	}

.quick-links-block ul li {
	display: block;
	list-style: none;
	padding: 2px 0;
	color: #ffffff;
	font-size: 18px;
	}

.quick-links-block ul li a , .quick-links-block ul li.a {
	color: #ffffff;
	font-size: 18px;
	line-height: 25px;
	text-decoration: none;
	}

.quick-links-block ul li a:hover {
	color: #9de4f8;
	text-decoration: underline;
	}

.quick-links-block ul li ul {
	margin: 5px 0 0 5px;
	}

.bottom-loc-block {
	display: inline-block;
	vertical-align: top;
	padding: 30px 0 30px 30px;
	text-align: left;
	color: #ffffff;
	font-size: 18px;
	line-height: 25px;
	}

.white-text {
	color: #fff;
	}

.offices-block {
	display: flex;
	}

.office {
	padding-right: 30px;
	}

.copy-left, .copy-right {
    text-align: left;
    float: left;
    color: #ffffff;
    font-size: 16px;
    padding: 10px 5px;
	}

.copy-left a, .copy-right a {
	color: #ffffff;
	text-decoration: none;
	}

.copy-left a:hover, .copy-right a:hover {
	text-decoration: underline;
	}

.copy-right {
	text-align: right;
	float: right;
	}

.scroll-to-top {
	position: fixed;
	bottom: 72px;
	left: 20px;
	z-index: 8999;
	opacity: 1;
	transition: all 0.3s;
	display: none;
    cursor: pointer;
	}

.scroll-to-top.active {
	display: block;
	}

.scroll-to-top:hover {
	opacity: 0.8;
	}

.rabutton {
	max-width: 350px;
	position: fixed;
	right: 20px;
	bottom: 80px;
	z-index: 99;
	}

.rabutton .wrap {
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	}
		
.rabutton .buttonrs {
	min-width: 255px;
	min-height: 45px;
	font-size: 18px;
	font-family: 'Lato',sans-serif;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1.3px;
	font-weight: 700;
	color: #fff;
	background: #40c8eb;
	border: none;
	border-radius: 3px;
	box-shadow: 12px 12px 24px rgb(14 47 61 / 22%);
	transition: all 0.3s ease-in-out 0s;
	cursor: pointer;
	outline: none;
	position: relative;
	padding: 10px 20px;
	}
	
.rabutton .buttonrs::before {
	content: '';
	border-radius: 13px;
	min-width: calc(250px + 28px);
	min-height: calc(40px + 4px);
	border: 4px solid #40c8eb;
	box-shadow: 0 0 60px rgb(195 195 195 / 64%);
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	opacity: 0;
	transition: all .3s ease-in-out 0s;
	}
		
.rabutton .buttonrs:hover, .buttonrs:focus {
	color: #40c8eb;
	transform: translateY(-6px);
	background: #fff;
	}
		
.rabutton .buttonrs:hover::before, .rabutton .buttonrs:focus::before {
	opacity: 1;
	}
	
.rabutton .buttonrs::after {
	content: '';
	width: 30px; height: 30px;
	border-radius: 100%;
	border: 6px solid #9de4f8;
	position: absolute;
	z-index: -1;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	animation: ring 1.5s infinite;
	}
		
.rabutton .buttonsr:hover::after, .buttonrs:focus::after {
	animation: none;
	display: none;
	}
		
@keyframes ring {
	0% {
		width: 30px;
		height: 30px;
		opacity: 1;
	}
	100% {
		width: 200px;
		height: 200px;
		opacity: 0;
	}
	}

/*Joomla corrections*/
tr.rsform-block.rsform-block-ref {
    vertical-align: text-bottom;
    }


.social-btns p, .top-phone p, .connect-block p, .doctors-box h2 p {
	display: inline-block;
	padding: 0;
	margin: 0;
	}

.social-btns a {
	color: #0f5a6e;
    display: flex;
	}

/*Rate US*/

.inner-wrap {
    padding: 50px 2% 100px;
    text-align: center;
    }

.inner-wrap h2 {
    font-size: 44px;
    margin: 0 auto;
    font-weight: 500;
    }

.inner-wrap h5 {
    margin: 25px auto;
    }

.google-review {
    margin-top: 60px;
    }


.google-review img:hover {
    transform: scale(1.02);
    transition: all 300ms ease;
    }

/*Rate Us --- END*/

/* How Are We Doing? */
    
.thumbs-wrap {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    flex-direction: row;
    flex-wrap: wrap;
    padding: 0 2% 100px;
    }

.thumbs-wrap .item {
    margin: 0 20px;
    max-width: 300px;
    }

.thumbs-wrap .item:hover {
    transform: scale(1.02);
    transition: all 300ms ease;
    }

.thumbs-wrap .item img {
    width: 100%;
    }

.thumbs-wrap .item span {
    font-size: 23px;
    margin-bottom: 20px;
    display: block;
    font-weight: 600;
    }

/* How Are We Doing? --- END */

/*Inner pages*/
 
.blog-button {
    color: #fff !important;
    background: #123842;
    font-size: 17px;
    padding: 10px;
    display: block;
    text-align: center;
    text-transform: uppercase;
    font-weight: 600;
    max-width: 228px;
    margin: 20px auto;
    border-radius: 6px;
    }

.blog-button:hover {
	background: #0e2f3d;
    }

.laser-banner {
    display: block;
    margin: 20px auto;
    }

.book-appointment-button {
    color: #fff !important;
    background: #123842;
    text-decoration: none !important;
    padding: 10px;
    text-align: center;
    display: block;
    margin: 10px auto;
    max-width: 225px;
    font-weight: 600;
    text-transform: uppercase;
    border-radius: 5px
    }


.book-appointment-button:hover {
    background: #28a3c4;
    }


.blogpage .itemListCategory h2 {
    font-size: 44px;
    color: #5c6e76;
    text-align: center;
    font-weight: 400;
    position: relative;
    margin: 0 0 20px 0;
    padding: 15px 0 20px 0;
	}

.blogpage .itemListCategory {
    background: unset;
    border: unset;
    border-radius: 4px;
    margin: 0 0 0px 0;
    padding: 8px;
    display: block;
    width: 100%;
	}
	
.button.pp {
	color: #fff;
    padding: 5px 15px;
    border-radius: 5px;
    text-transform: uppercase;
    font-weight: 600;
	background-color: #35badb;
	}

.button.pp:hover {
	color: #fff;
	padding: 5px 15px;
	border-radius: 5px;
	text-transform: uppercase;
	font-weight: 600;
	background-color: #2498b8;
	}

.inner-pages {
	padding-bottom: 30px;
	}

.inner-pages a {
	color: #0f5a6e;
	}

.inner-pages img {
	max-width: 100% !important;
	height: auto !important;
	}

.inner-pages .page-header h2 {
	font-size: 44px;
	color: #5c6e76;
	text-align: center;
	font-weight: 400;
	position: relative;
	margin: 0 0 20px 0;
	padding: 15px 0 20px 0;
	}

.inner-pages .page-header h2::after {
	content: '';
	height: 5px;
	width: 100px;
	position: absolute;
	bottom: 0;
	left: 50%;
	margin: 0 0 0 -50px;
	background: #40c8eb;
	}

.inner-pages .doctor {
	width: 350px;
	max-width: 100%;
	float: right;
	clear: right;
	margin: 0 0 12px 18px;
	text-align: center;
	padding: 0;
	color: #5c6e76;
	font-weight: 700;
	box-sizing: border-box;
	}

.inner-pages .doctor img {
	display: block;
	width: 100% ;
	height: auto;
	margin: 0 auto 10px;
	border-radius: 12px;
	border: 3px solid #9de4f8;
	box-sizing: border-box;
	}

.inner-btn a {
    color: #fff;
    padding: 5px 15px;
    border-radius: 5px;
    text-transform: uppercase;
    font-weight: 700;
    background-color: #40c8eb;
    display: inline-block;
    transition: 0.3s all;
    border: 2px solid #40c8eb;
    }

.inner-btn a:hover {
    background-color: #28a3c4;
    }

/*K2*/
div.latestItemsCategory {
	background: transparent;
	border: none;
	border-radius: 4px;
	margin: 0;
	padding: 0;
	}

div.latestItemsCategory h2 {
	font-size: 44px;
	color: #5c6e76;
	text-align: center;
	font-weight: 400;
	position: relative;
	margin: 0 0 20px 0;
	padding: 15px 0 20px 0;
	}

div.latestItemsCategory h2 a {
	color: #5c6e76;
	}

div.latestItemsCategory h2::after {
	content: '';
	height: 5px;
	width: 100px;
	position: absolute;
	bottom: 0;
	left: 50%;
	margin: 0 0 0 -50px;
	background: #40c8eb;
	}

h2.latestItemTitle a {
	color: #123842;
	}

#k2Container.latestView {
	padding-top: 0;
	}

#k2Container {
	padding-top: 40px;
	}

div.itemToolbar {
	display: none;
	}

div.k2LatestCommentsBlock ul, div.k2TopCommentersBlock ul, div.k2ItemsBlock ul, div.k2LoginBlock ul, div.k2UserBlock ul.k2UserBlockActions, div.k2UserBlock ul.k2UserBlockRenderedMenu, div.k2ArchivesBlock ul, div.k2AuthorsListBlock ul, div.k2CategoriesListBlock ul, div.k2UsersBlock ul {
	padding: 10px 20px;
	margin: 0;
	}

div.k2LatestCommentsBlock ul li, div.k2TopCommentersBlock ul li, div.k2ItemsBlock ul li, div.k2LoginBlock ul li, div.k2ArchivesBlock ul li, div.k2AuthorsListBlock ul li, div.k2CategoriesListBlock ul li, div.k2UsersBlock ul li {
	margin: 0;
	display: block;
	padding: 8px 0 8px 15px;
	}

.clearList {
	display: none !important;
	}

#second {
	margin: 0;
	width: 100%;
	float: left;
	margin-top: 10px;
	}

#one {
	float: left;
	width: 53%;
	padding-right: 2%;
	}

#two {
	width: 45%;
	float: right;
	margin-bottom: 20px;
	}

#address {
	float: left;
	width: 45%;
	}

#week {
	float: left;
	width: 105px;
	}

#hours {
	float: left;
	width: 200px;
	}

#offices {
	margin: 0;
	width: 100%;
	float: left;
	}

#offices.images {
	margin-top: 23px;
	text-align: center;
	}

#offices.images img {
	/* margin: 5px; */
	max-width: 100;
	height: auto;
	}

#map {
	margin: 20px 0;
	float: left;
	width: 100%;
	}

#osmap.osmap-sitemap .even {
	padding: 2px 0;
	}

.offices-images {
    gap: 15px;
    margin-top: 20px;
    width: 100%;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    }

.offices-images img {
    width: 100%;
    height: 250px;
    object-fit: cover;
    display: block;
    }

.contact-section {
    max-width: 100%;
    margin: 40px auto;
    border-radius: 15px;
    overflow: hidden;
    border: 2px solid #40c8eb;
    }

.contact-section .section-title {
    background: #40c8eb;
    color: #fff;
    padding: 10px 15px;
    margin: 0;
    font-size: 26px;
    border-radius: 10px;
    }

.contact-section .contact-flex {
    display: flex;
    gap: 20px;
    padding: 15px;
    box-sizing: border-box;
    }

.contact-section .contact-map {
    flex: 1;
    min-height: 350px;
    }

.contact-section .contact-map iframe {
    width: 100%;
    height: 100%;
    border: 0;
    border-radius: 8px;
    }

.contact-section .contact-info {
    flex: 1 1 20%;
    display: flex;
    flex-direction: column;
    }

.contact-section .info-columns {
    display: flex;
    gap: 20px;
    flex-wrap: nowrap;
    justify-content: space-between;
    }

.contact-section .office-hours h3,.contact-section .contact-address h3 {
    color: #40c8eb;
    margin: 0 0 10px;
    }

.contact-section .contact-address p {
    font-size: 17px;
    }

.contact-section .office-hours-list {
    list-style: none;
    padding: 0;
    margin: 0;
    max-width: 260px;
    }

.contact-section .office-hours-list li {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0;
    font-size: 17px;
    gap: 5px;
    }

.contact-section .office-hours-list .day {
    font-weight: 700;
    }

.contact-section .office-hours-list .time {
    white-space: nowrap;
    }

.contact-section .contact-actions {
    display: flex;
    flex-direction: column;
    gap: 15px;
    min-width: 200px;
    }

.contact-section .office-btn {
    text-align: center;
    padding: 10px;
    color: #fff;
    text-decoration: none;
    border-radius: 10px;
    font-weight: 700;
    transition: 0.3s all;
    }

.contact-section .btn-red {
    background: #c62828;
    }

.contact-section .btn-teal {
    background: #40c8eb;
    }

.contact-section .btn-orange {
    background: #f39c12;
    }

.contact-section .office-btn:hover {
    opacity: 0.5;
    }

.contact-section .contact-description {
    margin: 25px auto 0;
    text-align: center;
    font-size: 17px;
    }

.contact-section .contact-slider {
    margin: 20px auto 0;
    text-align: center;
    }

.contact-section .contact-slider .n2-section-smartslider {
    max-width: 300px;
    margin: 0 auto;
    }

/*body.rsform h1 , body.sitemap h1 {
	font-size: 44px;
	color: #5c6e76;
	text-align: center;
	font-weight: 400;
	position: relative;
	margin: 0 0 20px 0;
	padding: 15px 0 20px 0;
	}

body.rsform h1::after , body.sitemap h1::after {
	content: '';
	height: 5px;
	width: 100px;
	position: absolute;
	bottom: 0;
	left: 50%;
	margin: 0 0 0 -50px;
	background: #40c8eb;
	}*/

.formTableLayout {
	margin: 0 auto;
	}

#Send, #submit {
	background: #0e2f3d;
	color: #fff;
	border-color: #0e2f3d;
	padding: 5px 20px 7px ;
	border-radius: 5px;
	font-size: 17px;
	font-weight: bold;
	font-family: 'Lato', sans-serif;
	border: 2px solid transparent;
	}

#Send:hover, #submit:hover {
	background: #fff;
	color: #0e2f3d;
	border: 2px solid #40c8eb;
	cursor: pointer;
	}

.formTableLayout tr.rsform-block>td {
	padding: 5px;
	font-weight: 600;
	}

input, textarea, button , select {
	outline: none;
	padding: 4px;
	}

/*Rsform*/

form#userForm {
	text-align: left;
  	}

body.rsform .formTableLayout {
	border: none;
	margin: 0 auto;
	}

body.rsform h1 {
	margin-bottom: 30px;
	/*text-align: center;*/
	}

.formTableLayout tr.rsform-block>td {
	padding: 5px;
	font-weight: 600;
	}

input, textarea, button , select {
	outline: none;
	padding: 4px;
	}
  
.rsform-block.rsform-block-describe-nature-of-appointment {
	vertical-align: top;
	}

/*Joomla content*/

body#homepage .content.h {display: none;}

.content.full {
	flex-wrap: wrap;
    display: flex;
	}

.divContent {
	flex: 0 0 80%;
	/*max-width: 1000px;
	float: left;*/
	}

.divRight {
	flex: 0 0 20%;
	/*max-width: 300px;
	float: right;*/
	}

.divRight .moduletable {
	margin-top: 25px;
	padding-left: 40px;
	}

.divRight .moduletable ul {
	padding: 0px 4px !important;
	}

.divRight .moduletable ul li {
	padding: 5px 0 5px 3px !important;
	}

body#bfa #k2Container {
    padding-top: 0;
	}

.latestItemsCategory {
	float: none;
    width: 100%;
	}

div.genericItemReadMore {
    display: none !important;
	}

div.k2ArchivesBlock ul li a {
	color: #0f5a6e;
	}

.blogpage.db div#itemListLinks {
    display: none;
}

@media only screen and (max-width: 1700px) {

.slider-overlay {
	top: 4%;
	}

.slider-overlay ul {
	margin: 10px 0 0;
	}

.slider-overlay ul li {
	margin: 2px 0;
	}

.slider-overlay ul li:before {
	content: '';
	position: absolute;
	left: 0;
	top: 3px;
	width: 20px;
	height: 20px;
	background: url(../images/bullet.png) no-repeat center;
	background-size: cover;
	}
}


@media only screen and (max-width: 1675px) {
footer {
	padding-bottom: 140px;
	}
}


@media only screen and (max-width: 1500px) {
/*Header*/

.top-banner-middle {
    flex: 2;
	}

nav .content {
	padding-left: unset;
	}

.topmenu ul li a, span.nav-header, span.separator {
    font-size: 16px;
	}

/*Welcome To Block*/ 

.about-block-wrap {
    max-width: 1045px;
	}

.about-block-left {
    color: #1a2830;
    font-size: 18px;
    max-width: 600px;
	}

/*Doctors Box*/	
.doctor-box {
	max-width: 320px
	}

/*4 Reasons Block*/
.reasons-wrap {
	max-width: 1045px;
	}

.reasons-right ul li {
	margin: 40px 0 30px;
	}

/*Location Block*/
.location-wrap {
    max-width: 320px;
	}

.map-wrap {
	max-width: 280px;
	width: 100%;
	height: 285px;
	margin: 0 auto;
	}

.doctor-blue-button {
	font-size: 18px;
	max-width: 250px;
	}

.doctor-orange-button {
	font-size: 18px;
	max-width: 250px;
	}


/*Blog Block*/
.k2ItemsBlock.blogs ul li:nth-child(4), .k2ItemsBlock.blogs ul li:nth-child(5), .k2ItemsBlock.blogs ul li:nth-child(6) {
	display: none;
	}

}
	
@media only screen and (max-width: 1460px) {

.slider-tagline {
	padding: 10px 25px;
	font-size: 20px;
	}

.slider-overlay ul li {
	margin: 2px 0;
	padding: 0 0 0 25px;
    }

.slider-overlay ul li a {
	color: #fff;
	font-size: 18px;
	}

.slider-overlay ul li:before {
	content: '';
	position: absolute;
	left: 0;
	top: 3px;
	width: 18px;
	height: 18px;
	background: url(../images/bullet.png) no-repeat center;
	background-size: cover;
    }

/*Doctors Block*/
.doctors-block {
    background: #152f3d;
	padding: 0px 25px;
	}

.doctors-block-title {
	color: #fff;
	border-bottom: 1px solid #fff;
	padding-top: 40px;
	}

.doctors-boxes {
	padding: 0;
	}

.doctor-box {
	margin-top: 70px;
    }


.blue-background {
	display: none;
	}	
  
}

@media only screen and (max-width: 1350px) {
/*Slider*/

.slider-block {
    background: #123842;
	}

.slider-overlay {
    position: relative;
    top: unset;
    left: unset;
    background: rgb(0 0 0);
    padding: 15px 25px;
    border-radius: 15px;
    max-width: 320px;
    margin: 20px auto 0;
	}

.slider-overlay h3 {
	font-size: 22px;
	}

.slider-tagline {
	font-size: 24px;
	}

/*Welcome Block*/	
.about-block-wrap {
    flex-direction: column;
    justify-content: center;
    align-items: center;
	}

.about-block-left {
	max-width: unset;
	}

.contact-section .section-title {
    font-size: 18px;
    }

.contact-section .office-hours-list li,.contact-section .contact-address p,.contact-section .contact-description {
    font-size: 15px;
    }
}

@media only screen and (max-width: 1300px) {
.topmenu ul li {
	padding: 0 10px;
	}

.topmenu ul li a, span.nav-header, span.separator {
	font-size: 15px;
    }

.topmenu ul li.parent:after {
	right: -5px;
	}
	
}

@media only screen and (max-width: 1215px) {
#address {
	width: 100%;
	}

#week {
	margin: 20px 0 0;
	}

#hours {
	float: left;
	margin: 20px 0 0;
	}

#map iframe {
	height: 575px;
	}
}

@media only screen and (max-width: 1150px) {
/*Footer */
.logo-footer {
	max-width: 330px;
	}
}

@media only screen and (max-width: 1089px) {
	:root {
	--logo-header-h: 60px;
	}

/*Header*/
.inner-logo {
    padding: 8px 10px;
	}

.topmenu ul li {
    padding: 0 7px;
	}

.topmenu ul li.parent:after {
	right: -5px;
	}

.phone-btn-wrap {
    gap: 15px;
	}

.top-phone,
a.phone-link,
a.ra-btn {
    font-size: 16px;
	}

a.phone-link img {
    width: 16px;
	}

/*Doctors Block*/
.doctors-block {
    background: #152f3d;
	padding: 0px 25px;
	}

.doctors-block-title {
	color: #fff;
	border-bottom: 1px solid #fff;
	padding-top: 40px;
	}

.doctors-boxes {
	padding: 0;
	}

.doctor-box {
	margin-top: 70px;
    }


.blue-background {
	display: none;
	}	
}

@media only screen and (max-width: 1080px) {
/*Footer */
.logo-footer {
	display: block;
	margin: 0 auto;
	}
  
/*sidebar*/
	
.divContent {
	flex: 0 0 70%;
	}
	
.divRight {
    flex: 0 0 30%;
	}
  
/*Rate Us*/

.inner-wrap {
    padding: 30px 2% 60px;
    }

.inner-wrap h2 {
    font-size: 32px;
    }

.google-review img {
    width: 300px !important;
    }

/*Rate Us -- END*/
  
.contact-section .contact-flex {
    flex-direction: column;
    }

.contact-section .contact-map iframe {
    height: 350px;
    }

.contact-section .contact-info {
    flex: 1;
    align-items: center;
    }
}

@media only screen and (max-width: 950px) { 

@media only screen and (max-width: 950px) {
	:root {
	--logo-header-h: 54px;
	}
}

/*Header*/
.top-banner-left {
    flex-grow: 1;
    display: none;
	}  

.inner-logo {
	padding: 10px;
	}

.hamburger {
	display: inline-block;
	position: relative;
	z-index: 9002;
	margin: 17px;
	}

.hamburger--slider.is-active .hamburger-inner {
	transform: translate3d(0, 10px, 0) rotate(45deg);
	position: fixed;
	top: 25px;
	}

.topmenu {
	position: fixed;
	z-index: 9001;
	top: -150%;
	bottom: 0;
	left: 0;
	right: 0;
	width: 100%;
	height: 100%;
	overflow-x: hidden;
	overflow-y: auto;
	background: #e9f4f8;
	transition: all 0.3s;
	}

.topmenu.active {
	top: 0;
	}

.topmenu ul {
	display: block;
	padding: 20px 15px 15px 15px;
	}

.topmenu ul li {
	display: block;
	padding: 5px;
	}

.topmenu ul li.parent:after {
	display: none;
	}

.topmenu ul li a , span.nav-header , span.separator {
	font-size: 15px;
	}

.topmenu ul li ul {
	position: relative;
	top: 0;
	left: 0;
	width: auto;
	display: block;
	background: transparent;
	border-bottom: none;
	max-height: 3000px;
	overflow-y: visible;
	padding: 5px 0 0 0;
	box-shadow: unset;
	}

.topmenu ul li ul li {
	padding: 5px 10px;
	}

nav.fixed .topmenu ul li ul {
	background: transparent;
	}

.topmenu ul li:hover ul {
	overflow-y: visible;
	padding: 5px 0 0 0;
	}

nav .content {
	display: flex;
	justify-content: space-between;
    }

nav .content .clear {
	display: none;
	}


table.pe td {
	display: block;
	}

table.pe ul {
	margin: 0;
	}

/*4 Reasons Block*/	

.reasons-wrap {
    flex-direction: column;
	}

.reasons-right {
	max-width: unset;
	}

.reasons-right ul li {
	margin: 5px 0;
	}

}

@media only screen and (max-width: 950px) {
	:root {
	--logo-header-h: 54px;
	}
}

@media only screen and (max-width: 830px) {
.maintext-block h3 {
	font-size: 14px;
	}

.copy-left, .copy-right {
	text-align: center;
	float: left;
	font-size: 14px;
	padding: 0px;
	width: 100%;
	}
	
.copy-right p {
	margin-top: 0;
	}

#map iframe {
	height: 547px;
	}
  
.offices-images {
    grid-template-columns: repeat(2, 1fr);
    }
}

@media screen and (max-width: 800px) {
/* How Are We Doing? */
.thumbs-wrap .item {
    max-width: 35%;
    margin: 0 10px 20px 10px;
    }

.thumbs-wrap .item span {
    font-size: 18px;
    }

/* How Are We Doing? --- END */
}

@media only screen and (max-width: 767px) {

.btn {
	width: 100%;
	max-width: 180px;
	border-radius: 5px;
	padding: 10px 10px;
	font-weight: 600;
	font-size: 14px;
	}
  
.blogs-block .btn {
  	padding: 0;
  	}

/*Header*/	
.top-banner {
    justify-content: space-between;
	}

.top-banner-right {
	flex-grow: unset;
	}

.top-banner-middle {
	flex: unset;
    }

.top-phone {
	border-right: none;
	padding-right: 0px;
	}

.header-phones {
	gap: 15px;
	justify-content: center;
	}

/*Footer*/
  
footer {
    padding-bottom: 80px;
	}
  
footer .content {
	text-align: left;
	}

.logo-footer {
	display: block;
    vertical-align: top;
    padding: 30px 0 15px;
    max-width: 300px;
	}

.copy-left, .copy-right {
	float: left;
	font-size: 12px;
    }

footer h4 {
	font-size: 14px;
	}

.quick-links-block ul li ul {
	margin: 3px 0 0 5px;
	}

.quick-links-block ul li , .quick-links-block ul li a , .quick-links-block ul li.a {
	font-size: 14px;
	line-height: 18px;
	}

.bottom-loc-block {
	font-size: 14px;
	line-height: 18px;
	}

.scroll-to-top {
	width: 45px;
    left: 15px;
    bottom: 15px;
	}

.rabutton {
	max-width: 250px;
	bottom: 15px;
	}

.rabutton .buttonrs {
	min-width: 250px;
	font-size: 15px;
	}

.rabutton .buttonrs::before {
	min-width: calc(234px + 16px);
	min-height: calc(36px + 9px);
	}

/*Inner pages*/
.inner-pages .page-header h2 , body.rsform h1 , body.sitemap h1 , .latestItemsCategory h2 {
	font-size: 28px;
	}
  
/*sidebar*/
	
.divContent {
	flex: 0 0 70%;
	}
	
.divRight {
    flex: 0 0 30%;
	}

.footer-logo {
	margin: 0 auto;
	display: block;
	}

/*Titles*/
.about-block-title {
    font-size: 28px;
    max-width: 455px;
    margin: 25px auto;
	}

.doctors-block-title {
	font-size: 28px;
	max-width: 455px;
	margin: 25px auto;
	}

.reasons-title {
	font-size: 28px;
	margin: 25px auto;
	}

.locations-title {
	font-size: 28px;
	max-width: 455px;
	margin: 25px auto;
	}

.blogs-block h3 {
	font-size: 28px;
    max-width: 400px;
	margin: 25px auto;
	}

.contact-section .info-columns {
	flex-direction: column;
    }

.contact-section .section-title {
	font-size: 22px;
    }

.formCaption {width:100% !important;}
input#Email , input#Your_Email {width:90% !important;}
form#userForm textarea {width:90% !important;}
}

@media only screen and (max-width: 760px) {

.k2ItemsBlock.blogs ul {
	flex-wrap: wrap;
	}

#one {
	width: 100%;
	padding-right: 0px;
	}

#two {
	width: 100%;
	}

#map iframe {
	height: 450px;
	}
}

@media only screen and (max-width: 730px) {
.phone-btn-wrap {
    flex-direction: column;
    gap: 10px;
	}

img.pe , img.se , img.np {
	float: none !important;
	margin: 0 0 10px 0 !important;
	max-width: 100%;
	height: auto;
	}

tbody#rsform_3_page_0 td , tbody#rsform_4_page_0 td {
	display: block;
	}

textarea#Message , tbody#rsform_4_page_0 textarea {
	width: 90%;
	display: block;
	}
}

@media only screen and (max-width: 550px) {
.top-banner {
	justify-content: center;
	gap: 15px;
	flex-wrap: wrap;
	padding: 15px 25px 10px;
    }
}

@media only screen and (max-width: 590px) {
/*sidebar*/
	
.divContent , .divRight {
	flex: 0 0 100%;
	}
	
.divRight .moduletable {
    padding-left: 5px;
	margin-bottom: 60px;
	}
}

@media only screen and (max-width: 550px) {
/*Footer */
.logo-footer {
	display: block;
	margin: 0 auto;
	}

.offices-block {
	display: block;
	}

.office {
	padding-right: 10px;
	padding-bottom: 23px;
	}
  
.offices-images {
    grid-template-columns: 1fr;
    }
  
tbody#rsform_5_page_0 td {
	display: block;
	}

tbody#rsform_3_page_0 td , tbody#rsform_4_page_0 td {display: block;}

textarea#Message , tbody#rsform_4_page_0 textarea {
  	width: 90%;
  	display: block;
  	}

.rsform-input-box {
  	width: 65% !important; 
  	display: block;
  	}

table#cal4_0 tbody td {
	display: table-cell;
	}
}

@media only screen and (max-width: 460px) {
nav.slide.fixed .header-phones, .inner-nav.slide.fixed .header-phones  {
	display: none;
	}

nav.slide.fixed .top-banner, .inner-nav.slide.fixed .top-banner  {
	display: none;
	}


.top-buttons {
    flex-wrap: wrap;
    gap: 20px;
	}
}

@media only screen and (max-width: 400px) {
.slider-overlay {
	max-width: 260px;
	}
}