

/*------------------------------------*\
	IMAGE BANNER
\*------------------------------------*/


.bg-blue {
	background: #6faadc;
}
.bg-green {
	background: #b7d601;
}
.app-block {
	position: relative;
	padding: 35px 10% 0;
}
.app-block p {
	position: absolute;
	width: 50%;
	top: 50%;
	transform: translateY(-50%);
	font-size: 1.8em;
	line-height: 1.3;
	font-style: italic;
	text-align: center;
	color: #fff;
}
.app-block img {
	display: block;
	position: relative;
	float: right;
	width: 28%;
	bottom: 0;
}
.no-img {
	padding: 7% 10%;
}
.no-img p {
	position: relative;
	width: 100%;
	max-width: 550px;
	top: inherit;
	transform: none;
	margin: 0 auto;
}
.left-img p {
	right: 10%;
}
.left-img img {
	float: left;
}


@media only screen and (max-width: 1200px) {
	.app-block p {
		font-size: 1.5em;
	}
}

@media only screen and (max-width: 960px) {
	.app-block p {
		font-size: 1.3em;
	}
}

@media only screen and (max-width: 820px) {
	.app-block {
		padding: 30px 10% 0;
	}
	.app-block p,
	.app-block img {
		position: relative;
		width: 100%;
	}
	.left-img p {
		right: inherit;
	}
	.app-block p {
		max-width: 500px;
		top: inherit;
		transform: none;
		margin: 0 auto 30px;
	}
	.app-block img {
		float: none;
		max-width: 250px;
		bottom: 0;
		margin: 0 auto;
	}
}

@media only screen and (max-width: 500px) {
	.app-block {
		padding: 25px 8% 0;
	}
	.app-block p {
		font-size: 1.15em;
		margin-bottom: 25px;
	}
}





/*------------------------------------*\
	FIND A DENTIST
\*------------------------------------*/


.find-a-dentist-wrap {
	padding: 80px 15% 100px;
}

.find-a-dentist {
	margin-top: 45px;
}

.find-a-dentist h2,
.find-a-dentist h3,
.find-a-dentist p,
.find-a-dentist a,
.find-a-dentist label {
	color: #676767;
}
.find-a-dentist h2 {
	font-size: 1.2em;
	margin-bottom: 25px;
}
.find-a-dentist h3 {
	text-decoration: underline;
}

.search-block {
	padding-bottom: 20px;
	margin-bottom: 30px;
}
.search-location {
	border-bottom: 2px solid #e0e0e0;
}
.search-filter {
	padding: 0 !important;
	margin: 0 !important;
}
.search-distance {
	float: left;
	width: 180px;
}
.search-dentist {
	float: left;
}
.search-btns input[type=submit]:first-of-type {
	background: #e0e0e0;
	margin-right: 10px;
}

.find-a-dentist label {
	display: block;
	font-size: 1em;
	margin-bottom: 8px;
}

.find-a-dentist input[type=text],
.find-a-dentist select {
	position: relative;
	display: block;
	width: 100%;
	font-family: "Gotham SSm A", "Gotham SSm B", Arial, sans-serif;
	font-size: 0.95em;
	line-height: 1.2;
	font-weight: 400;
	color: #676767;
	background: #fff;
	padding: 8px;
	border: 2px solid #e0e0e0;
	border-radius: 5px;
	margin-bottom: 12px;
	-webkit-transition: all .5s ease;
					transition: all .5s ease;
}
.find-a-dentist select::-ms-expand {
	display: none;
}
.find-a-dentist select {
	padding: 8px 20px 8px 8px;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	-ms-word-break: normal;
	word-break: normal;
	background-image: none;
	cursor: pointer;
}
.select-style {
	position: relative;
	max-width: 115px;
}
.select-style:after {
	position: absolute;
	content: '\25be';
	color: #676767;
	font-size: 1.4em;
	right: 10px;
	top: 6px;
	pointer-events: none;
	z-index: 2;
}
.find-a-dentist input[type=text]:focus,
.find-a-dentist select:focus {
	border: 2px solid #b8d600;
}
.find-a-dentist input[type=submit] {
	-webkit-transform: translateZ(0) scale(1.0, 1.0);
					transform: translateZ(0) scale(1.0, 1.0);
	-webkit-transition: all .5s ease;
					transition: all .5s ease;
}
.find-a-dentist input[type=submit]:hover {
	-webkit-transform: translateZ(0) scale(1.05, 1.05);
					transform: translateZ(0) scale(1.05, 1.05);
}

.input-wrap {
	position: relative;
}
.search-location .label-field,
.or-icon {
	float: left;
}
.label-field {
	width: 220px;
}
.input-wrap .label-field:first-of-type {
	max-width: 115px;
}
.input-wrap .label-field:last-of-type {
	max-width: 115px;
	margin-left: 20px;
}

.or-icon {
	margin: 20px 40px 0;
}
.or-icon span {
	display: block;
	width: 45px;
	height: 45px;
	font-size: 1.1em;
	font-weight: 800;
	color: #fff;
	text-align: center;
	padding-top: 14px;
	background: #b8d600;
	border-radius: 50%;
}

.search-block input[type=submit] {
	display: block;
	float: none;
	font-family: "Gotham SSm A", "Gotham SSm B", Arial, sans-serif;
	font-size: 1.2em;
	font-weight: 800;
	color: #fff;
	padding: 15px 35px;
	background: #b8d600;
	border: 0;
	border-radius: 30px;
	margin-top: 25px;
}
.search-block input[type=submit] {
	display: inline-block;
}
.search-location input[type=submit]:last-of-type {
	display: inline-block;
	margin-left: 8px;
}

.input-validation {
	position: absolute;
	font-size: 0.9em;
	line-height: 1.1;
	font-weight: 600;
	color: #f33b33;
	background: #fff;
	padding: 10px;
	border: 2px solid #f33b33;
	border-radius: 5px;
	box-shadow: 3px 3px 8px rgba(0,0,0, 0.2);
	margin-top: 2px;
}
.input-validation span {
	display: inline-block;
	color: #fff;
	background: #f33b33;
	padding: 0 4px 1px;
	border-radius: 2px;
	margin-right: 7px;
}
.input-validation:before,
.input-validation:after {
	position: absolute;
	content: '';
}
.input-validation:before {
	top: -12px;
	left: 20px;
	border-left: 12px solid transparent;
	border-right: 12px solid transparent;
	border-bottom: 12px solid #f33b33;
}
.input-validation:after {
	top: -9px;
	left: 22px;
	border-left: 10px solid transparent;
	border-right: 10px solid transparent;
	border-bottom: 10px solid #fff;
}

#map {
	position: relative;
	height: 600px;
	margin-bottom: 30px;
}

.search-info {
	background: #e0ebfb;
	padding: 15px 20px;
	border-radius: 5px;
}
.search-results {
	margin: 50px 0 40px;
}
.search-info p,
.search-results p,
.search-results a {
	font-size: 0.95em;
	margin: 0;
}
.search-info p {
	font-weight: 800;
}

.result-profile {
	margin-bottom: 25px;
}
.result-info,
.result-address {
	float: left;
	width: 42%;
}
.result-info h3 {
	font-size: 1.1em;
	font-weight: 600;
	margin-bottom: 3px;
}
.result-info a {
	text-decoration: underline;
}
.result-info a:hover {
	color: #b8d600;
}
.result-distance {
	float: right;
	width: 16%;
}
.result-distance p {
	float: right;
	width: 95px;
	font-weight: 800;
	text-align: center;
	background: #e0e0e0;
	padding: 4px;
	border-radius: 20px;
}

.result-pages-wrap {
	float: right;
}
.result-pages-wrap button,
.jplist-holder {
	display: inline-block;
	background: none;
	border: none;
}
.result-pages-wrap button {
	font-size: 0.95em;
	line-height: 1.1;
	font-weight: 800;
	color: #676767;
	user-select: none;
	padding: 0;
	margin-left: 3px;
}
.result-pages-wrap button[data-type="prev"] {
	margin: 0;
}
.result-pages-wrap button:hover,
button.jplist-selected {
	color: #b8d600;
}

.survey-bar {
	position: relative;
	background: #6faadc;
	border-radius: 5px;
	margin-top: 12px;
}
.survey-bar p {
	font-size: 0.95em;
	font-weight: 800;
	color: #fff;
	margin: 0;
}
.survey-bar input[type=text] {
	border: 2px solid #e0ebfb;
	margin: 10px 0 0;
}
.survey-bar input[type=submit] {
	float: none;
	display: block;
	font-family: "Gotham SSm A", "Gotham SSm B", Arial, sans-serif;
	font-size: 0.95em;
	font-weight: 800;
	text-align: center;
	color: #6faadc;
	background: #e0ebfb;
	padding: 10px 15px 9px;
	border: 0;
	border-radius: 5px;
	margin: 0;
}
.survey-bar ::-webkit-input-placeholder {
	color: #b2b2b2;
}
.survey-bar :-moz-placeholder {
	color: #b2b2b2;
}
.survey-bar ::-moz-placeholder {
	color: #b2b2b2;
}
.survey-bar :-ms-input-placeholder {
	color: #b2b2b2;
}

.survey-find {
	padding: 15px 25px;
}
.survey-find p {
	float: left;
	margin: 8px 22px 0 0;
}
.survey-find input[type=submit] {
	float: left;
	padding: 10px 20px 9px;
}
.survey-invite {
	padding: 25px;
}
.survey-invite .invite-inputs {
	float: left;
	width: 100%;
	max-width: 220px;
}
.survey-inputs input[type=submit] {
	float: left;
	margin: 58px 0 0 22px;
}
p.survey-message {
	position: absolute;
	font-weight: 800 !important;
	color: #e0ebfb;
}
.survey-invite p.survey-message {
	left: 460px;
	bottom: 35px;
}
.survey-email {
	padding: 25px 25px 60px;
}
.survey-blocks {
	margin-top: 5px;
}
.email-block,
.survey-email .survey-inputs {
	float: left;
	width: 50%;
}
.email-block {
	padding-right: 4%;
}
.email-block p {
	font-weight: 400;
}
.email-submit {
	margin-top: 27px;
}
.email-submit input[type=text] {
	float: left;
	width: 70%;
}
.email-submit input[type=submit] {
	float: left;
	width: 25%;
	margin: 10px 0 0 5%;
}
.survey-email .survey-inputs {
	padding-left: 4%;
	border-left: 1px solid #e0ebfb;
}
.survey-email .invite-inputs {
	float: left;
	width: 55%;
}
.survey-email .survey-inputs input[type=submit] {
	width: 40%;
	padding: 10px 0 9px;
	margin-left: 5%;
}
.survey-email p.survey-message {
	bottom: 22px;
}

@media only screen and (max-width: 1300px) {
	.find-a-dentist-wrap {
		padding: 80px 10% 100px;
	}
}

@media only screen and (max-width: 1220px) {
	.survey-email {
		padding: 25px;
	}
	.email-block,
	.survey-email .survey-inputs {
		float: none;
		width: 100%;
		padding: 0;
	}
	.survey-blocks {
		max-width: 660px;
	}
	.email-block {
		padding-bottom: 25px;
	}
	.email-submit {
		margin: 0;
	}
	.email-submit input[type=text],
	.survey-email .invite-inputs {
		width: 65%;
	}
	.email-submit input[type=submit],
	.survey-email .survey-inputs input[type=submit] {
		width: 30%;
	}
	.survey-email .survey-inputs {
		padding-top: 20px;
		border-top: 1px solid #e0ebfb;
		border-left: none;
	}
	.survey-email p.survey-message {
		position: relative;
		bottom: inherit;
		clear: both;
		padding-top: 15px;
	}
}

@media only screen and (max-width: 1015px) {
	.survey-invite p.survey-message {
		position: relative;
		left: inherit;
		bottom: inherit;
		margin-top: 15px;
	}
}

@media only screen and (max-width: 950px) {
	.find-a-dentist-wrap {
		padding: 50px 10% 80px;
	}
	.result-info h3 {
		font-size: 1em;
	}
	.result-info {
		width: 48%;
	}
	.result-address {
		width: 36%;
	}
}

@media only screen and (max-width: 750px) {
	.find-a-dentist {
		margin-top: 30px;
	}
	.find-a-dentist h2 {
		margin-bottom: 20px;
	}
	.or-icon {
		float: none;
		margin: 20px 0;
	}
	.input-wrap .label-field:first-of-type {
		float: none;
	}
	.input-wrap .label-field:last-of-type {
		max-width: 115px;
		margin-left: 20px;
	}
	#map-container {
		height: 450px;
	}
	#google-map {
		width: 100%;
		margin-bottom: 20px;
	}
	.search-results {
		margin: 40px 0;
	}
	.result-info,
	.result-address {
		float: none;
		width: 100%;
	}
	.result-info {
		margin-bottom: 12px;
	}
}

@media only screen and (max-width: 690px) {
	.email-submit input[type=text],
	.survey-email .invite-inputs {
		width: 57%;
	}
	.email-submit input[type=submit],
	.survey-email .survey-inputs input[type=submit] {
		width: 38%;
	}
}

@media only screen and (max-width: 550px) {
	.search-block {
		padding-bottom: 10px;
		margin-bottom: 20px;
	}
	.find-a-dentist h2 {
		margin-bottom: 15px;
	}
	.search-block input[type=submit] {
		font-size: 1.1em;
		padding: 10px 35px;
		margin-top: 20px;
	}
	.search-info p,
	.search-results p,
	.search-results a {
		font-size: 0.85em;
	}
	.result-distance {
		float: none;
		width: 100%;
		margin-bottom: 12px;
	}
	.result-distance p {
		width: 85px;
	}
	.result-distance p {
		float: none;
	}
	.result-pages {
		text-align: center;
	}
	.result-pages-wrap {
		float: none;
		display: inline-block;
	}
	.search-info {
		padding: 12px 15px;
	}
	.search-info p {
		font-size: 0.85em;
	}
	.survey-find {
		padding: 12px 20px;
	}
	.survey-invite,
	.survey-email {
		padding: 20px;
	}
	.survey-invite .invite-inputs,
	.email-submit input[type=text],
	.survey-email .invite-inputs {
		float: none;
		max-width: 270px;
	}
	.email-submit input[type=text],
	.survey-email .invite-inputs,
	.email-submit input[type=submit],
	.survey-email .survey-inputs input[type=submit] {
		width: 100%;
	}
	.survey-inputs input[type=submit],
	.email-submit input[type=submit],
	.survey-email .survey-inputs input[type=submit] {
		float: none;
		max-width: 170px;
		margin: 12px 0 0;
	}
}

@media only screen and (max-width: 571px) {
	.search-location input[type=submit] {
		margin: 25px 0 15px 0 !important;
	}
}

@media only screen and (max-width: 500px) {
	.search-distance,
	.search-dentist {
		float: none;
		width: 100%;
	}
	.search-dentist {
		margin-top: 25px;
	}
}

@media only screen and (max-width: 450px) {
	.input-wrap .label-field {
		float: none;
	}
	.input-wrap .label-field:last-of-type {
		margin: 15px 0 0;
	}
	#map-container {
		height: 350px;
	}
}

@media only screen and (max-width: 405px) {
	.survey-find p {
		float: none;
		margin: 0 0 8px 0;
	}
	.survey-find input[type=submit] {
		float: none;
		padding: 10px 30px 9px;
	}
}





/*------------------------------------*\
	FIND A DENTIST - INFOBOX
\*------------------------------------*/


.gm-style-iw .gm-style-iw-c {
	max-width: 100%;
}

.infobox {
	background: #fff;
	padding: 30px 25px 0 30px;
	border-radius: 5px;
	overflow-y: auto;
}

.infobox-close {
	position: absolute;
	font-size: 28px;
	font-weight: 800;
	color: #fff;
	top: -5px;
	right: 4px;
	cursor: pointer;
	z-index: 1;
}
.infobox-close:before {
	position: absolute;
	content: '';
	width: 0;
	height: 0;
	top: 0;
	right: -4px;
	border-left: 50px solid transparent;
	border-top: 50px solid #6faadc;
	z-index: -1;
}

.infobox-controls {
	text-align: center;
	padding-bottom: 12px;
	border-bottom: 1px solid #e0e0e0;
	margin: -15px 0 20px;
}

.paging-info {
	display: inline-block;
	font-size: 14px !important;
	font-weight: 800;
	color: #666;
}

.infobox h2 {
	font-size: 18px !important;
	color: #6faadc;
	margin: 0 0 10px;
}
.infobox h3 {
	font-size: 15px !important;
	margin: 0 0 5px;
}
.infobox p,
.infobox a {
	display: block;
	font-size: 12px !important;
	line-height: 20px !important;
	color: #666;
	margin: 0;
}
.infobox a {
	display: inline-block;
	text-decoration: underline;
}
.infobox a:hover {
	color: #6faadc;
}

.infobox-dentist {
	padding-bottom: 15px;
	border-bottom: 1px solid #e0e0e0;
	margin-bottom: 15px;
}
.infobox-dentist:last-of-type {
	border-bottom: none;
	padding-bottom: 30px;
	margin: 0;
}

@media only screen and (max-width: 800px) {
	.infobox {
		padding: 20px 20px 0;
	}
	.infobox-controls {
		padding-bottom: 10px;
		margin: -10px 0 15px;
	}
	.paging-info {
		font-size: 0.8em;
	}
	.infobox h2 {
		font-size: 16px !important;
		margin: 0 0 10px;
	}
	.infobox h3 {
		font-size: 14px !important;
	}
	.infobox p,
	.infobox a {
		font-size: 12px !important;
	}
	.infobox-dentist {
		padding-bottom: 10px;
		margin-bottom: 10px;
	}
	.infobox-dentist:last-of-type {
		padding-bottom: 20px;
		margin: 0;
	}
}

@media only screen and (max-width: 450px) {
	.infobox {
		padding: 20px 20px 0;
	}
}


/*------------------------------------*\
	INFOBOX - SLIDER
\*------------------------------------*/


.slick-slider {
	position: relative;
	display: block;
	box-sizing: border-box;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	-webkit-touch-callout: none;
	-khtml-user-select: none;
	-ms-touch-action: pan-y;
	touch-action: pan-y;
	-webkit-tap-highlight-color: transparent;
}
.slick-list {
	position: relative;
	display: block;
	overflow: hidden;
	margin: 0;
	padding: 0;
}
.slick-list:focus {
	outline: none;
}
.slick-list.dragging {
	cursor: pointer;
	cursor: hand;
}
.slick-slider .slick-track,
.slick-slider .slick-list {
	-webkit-transform: translate3d(0, 0, 0);
		 -moz-transform: translate3d(0, 0, 0);
		  -ms-transform: translate3d(0, 0, 0);
		   -o-transform: translate3d(0, 0, 0);
		      transform: translate3d(0, 0, 0);
}
.slick-track {
	position: relative;
	top: 0;
	left: 0;
	display: block;
	margin-left: auto;
	margin-right: auto;
}
.slick-track:before,
.slick-track:after {
	display: table;
	content: '';
}
.slick-track:after {
	clear: both;
}
.slick-loading .slick-track {
	visibility: hidden;
}
.slick-slide {
	display: none;
	float: left;
	height: 100%;
	min-height: 1px;
}
[dir='rtl'] .slick-slide {
	float: right;
}
.slick-slide img {
	display: block;
}
.slick-slide.slick-loading img {
	display: none;
}
.slick-slide.dragging img {
	pointer-events: none;
}
.slick-initialized .slick-slide,
.slider.slick-initialized .slide {
	display: block;
}
.slider.slick-initialized .slide {
	display: block;
}
.slick-loading .slick-slide {
	visibility: hidden;
}
.slick-vertical .slick-slide {
	display: block;
	height: auto;
	border: 1px solid transparent;
}
.slick-arrow.slick-hidden {
	display: none;
}

.slick-prev,
.slick-next {
	display: block;
	position: absolute;
	font-size: 0;
	line-height: 0;
	top: -48px;
	border: solid #666;
	border-width: 0 4px 4px 0;
	padding: 4px;
	cursor: pointer;
	color: transparent;
	outline: none;
	background: transparent;
}
.slick-prev:hover,
.slick-prev:focus,
.slick-next:hover,
.slick-next:focus {
	color: transparent;
	background: transparent;
	outline: none;
}
.slick-prev:hover,
.slick-next:hover {
	border: solid #6faadc;
	border-width: 0 4px 4px 0;
}
.slick-prev {
	left: 18px;
	transform: rotate(135deg);
}
[dir='rtl'] .slick-prev {
	right: 18px;
	left: auto;
}
.slick-next {
	right: 18px;
	transform: rotate(-45deg);
}
[dir='rtl'] .slick-next {
	right: auto;
	left: 18px;
}
.slick-disabled {
	opacity: 0;
	pointer-events: none;
}


@media only screen and (max-width: 800px) {
	.slick-prev,
	.slick-next {
		top: -40px;
	}
	.slick-prev,
	[dir='rtl'] .slick-next {
		left: 28px;
	}
	.slick-next,
	[dir='rtl'] .slick-prev {
		right: 28px;
		left: auto;
	}
}

@media only screen and (max-width: 500px) {
	.infobox-close {
		font-size: 25px;
	}
	.infobox-close:before {
		border-left: 45px solid transparent;
		border-top: 45px solid #6faadc;
	}
}




