@charset "utf-8";
/* CSS Document */

@font-face {
    font-family: 'fira_sansregular';
    src: url('fonts/firasans-regular-webfont.eot');
    src: url('fonts/firasans-regular-webfont.eot?#iefix') format('embedded-opentype'),
         url('fonts/firasans-regular-webfont.woff2') format('woff2'),
         url('fonts/firasans-regular-webfont.woff') format('woff'),
         url('fonts/firasans-regular-webfont.ttf') format('truetype'),
         url('fonts/firasans-regular-webfont.svg#fira_sansregular') format('svg');
    font-weight: normal;
    font-style: normal;

}

@font-face {
    font-family: 'fira_sanslight';
    src: url('fonts/firasans-light-webfont.eot');
    src: url('fonts/firasans-light-webfont.eot?#iefix') format('embedded-opentype'),
         url('fonts/firasans-light-webfont.woff2') format('woff2'),
         url('fonts/firasans-light-webfont.woff') format('woff'),
         url('fonts/firasans-light-webfont.ttf') format('truetype'),
         url('fonts/firasans-light-webfont.svg#fira_sanslight') format('svg');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'fira_sansbold';
    src: url('fonts/firasans-bold-webfont.eot');
    src: url('fonts/firasans-bold-webfont.eot?#iefix') format('embedded-opentype'),
         url('fonts/firasans-bold-webfont.woff2') format('woff2'),
         url('fonts/firasans-bold-webfont.woff') format('woff'),
         url('fonts/firasans-bold-webfont.ttf') format('truetype'),
         url('fonts/firasans-bold-webfont.svg#fira_sansbold') format('svg');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'fira_sansthin';
    src: url('fonts/firasans-thin-webfont.eot');
    src: url('fonts/firasans-thin-webfont.eot?#iefix') format('embedded-opentype'),
         url('fonts/firasans-thin-webfont.woff2') format('woff2'),
         url('fonts/firasans-thin-webfont.woff') format('woff'),
         url('fonts/firasans-thin-webfont.ttf') format('truetype'),
         url('fonts/firasans-thin-webfont.svg#fira_sansthin') format('svg');
    font-weight: normal;
    font-style: normal;
}

html, body, h2, h3, h4, h5, h6, p, input, textarea, select, form {
	font-family: "fira_sansregular", Arial, Helvetica, sans-serif;
	font-size: 15px;
	color: #3c3c3c;
	font-weight: normal;
	padding: 0px;
	margin: 0px;
}

h2, h3, h4, .footer .footer-menu ul li a, .footer .footer-address-heading{
	font-family: "fira_sansbold", Arial, Helvetica, sans-serif;
	line-height: 1.4;
}

.telephone {
	font-family: "fira_sanslight", Arial, Helvetica, sans-serif;
}

.left-boxes h2 a, .testimonials .testimonials-link a, .smile-gallery .gallery-link a {
	font-family: "fira_sansthin", Arial, Helvetica, sans-serif;
}

.testimonials h2, .smile-gallery h2 {
	font-family: "fira_sansregular", Arial, Helvetica, sans-serif; /* Had to overwrite the common H2 font family */
}

.question-mark{
	font-family: Arial, Helvetica, sans-serif;
}

/*Main Menu*/
.panel ul li a, .menu-close-button, ul#tree li a {
	font-family: "calibribold", Arial, Helvetica, sans-serif!important;
	font-weight: normal !important;
}

.clear-float {
	clear: both !important;
}

.holder:after, .main-containers .header-wrapper:after, .main-menu ul:after, .address:after, .socialmedia:after, .bucket-menu ul:after, .get-social ul:after, .content-wrapper:after, .search-area form:after, .contact-form form:after, .contact-hours-sub:after, .appoinment-form form:after, .smile-gallery .gallery-ba-text:after, .gallery-wrapper:after, .gallery-wrapper .gallery-ba-text:after, .footer .footer-menu ul:after, .main-containers-sub:after, .logo-gallery:after, .header-menu-mobile:after, .footer-wrapper .footer:after, .customNavigation:after, .contact-info:after {
	content: '.';
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}

a, ul#tree li a{
	color: #8410b5;
	text-decoration: none;
}

	a:hover {
		color: #14011d;
	}

img {
	border: 0px;
}

h1 {
	line-height: 1;
	color: #8410b5;
	font-size: 36px;
	font-weight: normal;
	padding: 0px;
	margin: 31px 0px 15px 10px;
}

h2 {
	font-size: 18px;
	margin: 19px 0px 0px 0px;
}

h3 {
	font-size: 17px;
	margin: 12px 0px 10px 0px;
}

h4 {
	font-size: 16px;
	margin: 14px 0px 10px 0px;
}

.holder{
	width: 100%;
	margin: 0px auto;
	position: relative;	
}

.hide-from-mobile{
	display: none;	
}

/* Header Styels - Start */

.header {
	position: relative;
	width: 100%;	
}

/*Top Icon Menu*/
.header-top-icons {
    width: 100%;
    margin-right: auto;
    margin-left: auto;
	background: url(../images/mobile/top-menu-bg.jpg) repeat-x left top;
}

    .header-menu-mobile {
        margin: 0;
        padding: 0;
        list-style-type: none;
    }
	
        .header-menu-mobile li {
            height: 52px;
            width: 19%;
            float: left;
            display: block;
            text-align: center;
        }
		
            .header-menu-mobile li a {
                height: 52px;
                width: 100%;
                display: block;
                text-indent: -9999px;
            }
			
                .header-menu-mobile li.menu {
                    border-right: 1px solid #FFFFFF;
                    background: url(../images/mobile/menu_icon.png) no-repeat center center;
                }
				
                    .header-menu-mobile li.call {
                        border-left: 1px solid #042F62;
                        border-right: 1px solid #FFFFFF;
                        background: url(../images/mobile/call_icon.png) no-repeat center center;
                    }
					
                        .header-menu-mobile li.appointment {
                            border-left: 1px solid #042F62;
                            border-right: 1px solid #FFFFFF;
                            background: url(../images/mobile/appointment_icon.png) no-repeat center center;
                        }
						
                            .header-menu-mobile li.contact {
                                border-left: 1px solid #042F62;
                                border-right: 1px solid #FFFFFF;
                                background: url(../images/mobile/contact_icon.png) no-repeat center center;
                            }
							
                                .header-menu-mobile li.directions {
                                    border-left: 1px solid #042F62;
                                    background: url(../images/mobile/map_icon.png) no-repeat center center;
                                }

	.logo-mobile {
		width: 100%;
		height: auto;
		margin: 10px 0px 10px 0px;
	}
	
		.logo img{
			width: 460px;
			height: 80px;
		}
		
	.telephone{
		font-size: 18px;
		line-height: 1.4;
		text-align: center;
	}
	
		.telephone, .address, .address a{
			color: #202020;
		}
		
	.address{
		font-size: 14px;
		text-align: center;
		line-height: 1.2;
		margin: 10px 0px 15px 0px;
	}

		.address .directions{
			text-decoration: underline;
		}
		
			.address .directions:hover{
				color: #3685aa;
			}
	
.banner-mobile{
	width: 100%;
	height: auto;
	margin: 0px 0px 10px 0px;
}

.search-area {
	width: 248px;
	height: 60px;
	margin: 0px 0px 0px -12px;
	position: relative;
}

	.search-area .search{
		text-align: left;		
		width: 230px;
		height: 26px;
		padding: 9px 7px 6px 12px;
		margin: 0px;
	}
	
		.search-area .search, .smile-gallery {
			background: #439bde;
			-moz-border-radius: 2px;
			-webkit-border-radius: 2px;
			border-radius: 2px; /* future proofing */
			-khtml-border-radius: 2px; /* for old Konqueror browsers */
		}
	
		.search-area .search-text{
			color: #ffffff;
			font-size: 14px;
			background: none;
			border: 0px;
			width: 200px;
		}
		
			.search-area .go-button{
				text-indent: -9999px;
				width: 18px;
				height: 18px;
				position: absolute;
				right: 14px;
				top: 8px;
				border: 0px;
				cursor: pointer;
				margin: 0px;
				background: url(../images/search-go-button.png) no-repeat left top;
			}
			
.get-social ul, .footer .footer-menu ul{
	list-style-type: none;
}

	.get-social ul{
		margin: 0px 0px 0px 40px;
		padding: 28px 0px 10px 0px;
	}

		.get-social ul li{
			width: 26px;
			height: 26px;
			margin: 0px 8px 0px 0px;
			float: left;
		}
		
.bucket-menu-mobile ul li a{
	border-radius: 0px!important;
}

.content-wrapper{
	width: 100%;
	margin: 0px;
	padding: 10px 0px 0px 0px;
	background: #ffffff;
}

	.right-content .para{
		line-height: 1.6;
		margin: 0px 25px 10px 12px;
	}
	
		.right-content .para ul li{
			margin: 0px 0px 12px 0px;
		}
	
			.right-content h1.home-heading {
				margin: 0px 0px 15px 12px;
			}
			
				.right-content .proc-pics {
					margin: 24px 24px 15px 6px;
					width: auto;
					max-width: 100%;
					float: left;
				}
				
					.right-content .proc-pics img{
						margin: 0px 0px 35px 0px;
					}

.smile-gallery {
	text-align: center;
	width: 95%;
	margin: 32px 0px 10px 13px;
	padding: 0px 0px 16px 0px;
	position: relative;
	overflow: hidden;
}
	
	.smile-gallery h2{
		padding: 19px 0px 0px 0px;	
		margin: 0px;
		text-align: center;
	}
			
		.smile-gallery .gallery-ba-text{
			margin: 4px 0px 6px 0px;		
			text-align: center;
			color: #ffffff;
		}
			
			.smile-gallery .gallery-text{
				display: block;
				float: left;
				width: 165px;
				line-height: 1;
			}

				.smile-gallery .after{
					margin: 0px 0px 0px 5px;
					width: 165px;
				}

					.smile-gallery .gallery-link{
						display: block;
						width: 63%;
						margin: 8px 0px 0px 30%;
						text-align: center;
						
					}
					
						.smile-gallery .gallery-link a{
							color: #8410b5;
							display: block;
							width: 215px;
							padding: 13px 0px 16px 0px;
							background: url(../images/bg-images.png) no-repeat left -1336px;
						}
						
							.smile-gallery .gallery-link a:hover{
								color: #116eb4;
							}

.ui-mobile [data-role=page], .ui-mobile [data-role=dialog], .ui-page {
	position: relative !important;
}

/* Sub Page Styels - Start */

.app-form {
	margin: 0px 10px 20px 10px;
}

.contact-info{
	width: 100%;
}

.contact-info .contact-left{
	float: left;
	width: 50%;
}

	.contact-info .contact-right{
		float: right;
		width: 50%;
	}

		.contact-hours-sub{
			margin: 20px 0px 30px 0px;
			width: 360px;
			line-height: 1.6;
		}

			.contact-hours-sub .contact-date{
				float: left;
				width: 105px;
			}
			
				.contact-hours-sub .contact-time{
					float: right;
					width: 250px;
				}

.google-map {
	margin: 40px 0px;
	width: 420px;
	height: 650px!important;
}

.treeview li {
	margin: 0px!important;
}

	.treeview li  a:hover{
		color: #14011d!important;
	}
	
.testimonial-content {
	margin: 25px 0px 35px;
	padding: 0px 0px 10px;
}

	.testimonial-content  {
		border-bottom: 1px dashed #a7a0a0;
	}

/* Sub Page Styels - End */

/* Footer Styels - Start */

.footer-wrapper {
	width: 100%;
	margin: 0px auto;
	background: #656565;
}

	.footer-wrapper .footer {
		margin: 0px auto;
		position: relative;
		text-align: center;
		font-size: 14px;
	}
		
		.footer-wrapper .footer, .footer-wrapper .footer a{
			color: #ffffff;
		}
	
			.footer .footer-menu ul li a.selected, .footer-wrapper .footer a:hover{
				color: #439bde;
			}
			
				.footer .footer-menu ul{
					margin: 0px;
					padding: 0px 0px 0px 10px;
				}
					
					 .footer .footer-menu ul li {
						float: left;
						line-height: 1.55;
						padding: 0px 4px 10px 0px;
					}
				
						.footer .footer-menu ul li a {
							float: left;
							text-align: left;
							padding: 0px 0px 0px 15px;
							margin: 0px;
							background: url(../images/bullet-icon.png) no-repeat left 6px;
						}
		
							.footer .copyright, .footer .powered{
								line-height: 1.2;
							}
							
								.footer .copyright{
									padding: 3px 0px 7px 0px;
								}
							
									.footer .powered{
										padding: 0px 0px 20px 0px;
									}
									
										.footer .footer-address {
											padding: 10px 0px 10px 0px;
										}
									
											.footer .footer-address-heading{						
												padding: 3px 0px 7px 0px;
												line-height: 1.2;
											}

/* Footer Styels - End */			

.ui-page-active {
	overflow: hidden!important; /* -------- To remove the unwanted scroll bar from Opera Mobile Emulator --------- */
}	


/* Footer Styels - End */			
/************************************************************************************
	FANCYBOX
*************************************************************************************/
/*! fancyBox v2.1.5 fancyapps.com | fancyapps.com/fancybox/#license */
.fancybox-wrap, .fancybox-skin, .fancybox-outer, .fancybox-inner, .fancybox-image, .fancybox-wrap iframe, .fancybox-wrap object, .fancybox-nav, .fancybox-nav span, .fancybox-tmp {
	padding: 0;
	margin: 0;
	border: 0;
	outline: none;
	vertical-align: top;
}
.fancybox-wrap {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 8020;
}
.fancybox-skin {
	position: relative;
	background: #f9f9f9;
	color: #444;
	text-shadow: none;
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
	border-radius: 4px;
}
.fancybox-opened {
	z-index: 8030;
}
.fancybox-opened .fancybox-skin {
	-webkit-box-shadow: 0 10px 25px rgba(0, 0, 0, 0.5);
	-moz-box-shadow: 0 10px 25px rgba(0, 0, 0, 0.5);
	box-shadow: 0 10px 25px rgba(0, 0, 0, 0.5);
}
.fancybox-outer, .fancybox-inner {
	position: relative;
}
.fancybox-inner {
	overflow: hidden;
}
.fancybox-type-iframe .fancybox-inner {
	-webkit-overflow-scrolling: touch;
}
.fancybox-error {
	color: #444;
	font: 14px/20px "Helvetica Neue", Helvetica, Arial, sans-serif;
	margin: 0;
	padding: 15px;
	white-space: nowrap;
}
.fancybox-image, .fancybox-iframe {
	display: block;
	width: 100%;
	height: 100%;
}
.fancybox-image {
	max-width: 100%;
	max-height: 100%;
}
#fancybox-loading, .fancybox-close, .fancybox-prev span, .fancybox-next span {
	background-image: url('../fancybox/fancybox_sprite.png');
}
#fancybox-loading {
	position: fixed;
	top: 50%;
	left: 50%;
	margin-top: -22px;
	margin-left: -22px;
	background-position: 0 -108px;
	opacity: 0.8;
	cursor: pointer;
	z-index: 8060;
}
#fancybox-loading div {
	width: 44px;
	height: 44px;
	background: url('../fancybox/fancybox_loading.gif') center center no-repeat;
}
.fancybox-close {
	position: absolute;
	top: -18px;
	right: -18px;
	width: 36px;
	height: 36px;
	cursor: pointer;
	z-index: 8040;
}
.fancybox-nav {
	position: absolute;
	top: 0;
	width: 40%;
	height: 100%;
	cursor: pointer;
	text-decoration: none;
	background: transparent url('../fancybox/blank.gif'); /* helps IE */
	-webkit-tap-highlight-color: rgba(0,0,0,0);
	z-index: 8040;
}
.fancybox-prev {
	left: 0;
}
.fancybox-next {
	right: 0;
}
.fancybox-nav span {
	position: absolute;
	top: 50%;
	width: 36px;
	height: 34px;
	margin-top: -18px;
	cursor: pointer;
	z-index: 8040;
	visibility: hidden;
}
.fancybox-prev span {
	left: 10px;
	background-position: 0 -36px;
}
.fancybox-next span {
	right: 10px;
	background-position: 0 -72px;
}
.fancybox-nav:hover span {
	visibility: visible;
}
.fancybox-tmp {
	position: absolute;
	top: -99999px;
	left: -99999px;
	visibility: hidden;
	max-width: 99999px;
	max-height: 99999px;
	overflow: visible !important;
}
/* Overlay helper */

.fancybox-lock {
	overflow: hidden !important;
	width: auto;
}
.fancybox-lock body {
	overflow: hidden !important;
}
.fancybox-lock-test {
	overflow-y: hidden !important;
}
.fancybox-overlay {
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden;
	display: none;
	z-index: 8010;
	background: url('../fancybox/fancybox_overlay.png');
}
.fancybox-overlay-fixed {
	position: fixed;
	bottom: 0;
	right: 0;
}
.fancybox-lock .fancybox-overlay {
	overflow: auto;
	overflow-y: scroll;
}
/* Title helper */

.fancybox-title {
	visibility: hidden;
	font: normal 13px/20px "Helvetica Neue", Helvetica, Arial, sans-serif;
	position: relative;
	text-shadow: none;
	z-index: 8050;
}
.fancybox-opened .fancybox-title {
	visibility: visible;
}
.fancybox-title-float-wrap {
	position: absolute;
	bottom: 0;
	right: 50%;
	margin-bottom: -35px;
	z-index: 8050;
	text-align: center;
}
.fancybox-title-float-wrap .child {
	display: inline-block;
	margin-right: -100%;
	padding: 2px 20px;
	background: transparent; /* Fallback for web browsers that doesn't support RGBa */
	background: rgba(0, 0, 0, 0.8);
	-webkit-border-radius: 15px;
	-moz-border-radius: 15px;
	border-radius: 15px;
	text-shadow: 0 1px 2px #222;
	color: #FFF;
	font-weight: bold;
	line-height: 24px;
	white-space: nowrap;
}
.fancybox-title-outside-wrap {
	position: relative;
	margin-top: 10px;
	color: #fff;
}
.fancybox-title-inside-wrap {
	padding-top: 10px;
}
.fancybox-title-over-wrap {
	position: absolute;
	bottom: 0;
	left: 0;
	color: #fff;
	padding: 10px;
	background: #000;
	background: rgba(0, 0, 0, .8);
}

/*Retina graphics!*/
@media only screen and (-webkit-min-device-pixel-ratio: 1.5),  only screen and (min--moz-device-pixel-ratio: 1.5),  only screen and (min-device-pixel-ratio: 1.5) {
#fancybox-loading, .fancybox-close, .fancybox-prev span, .fancybox-next span {
	background-image: url('../fancybox/fancybox_sprite@2x.png');
	background-size: 44px 152px; /*The size of the normal image, half the size of the hi-res image*/
}
#fancybox-loading div {
	background-image: url('../fancybox/fancybox_loading@2x.gif');
	background-size: 24px 24px; /*The size of the normal image, half the size of the hi-res image*/
}
}

/* 
 * 	Core Owl Carousel CSS File
 *	v1.3.2
 */

/* clearfix */
.owl-carousel .owl-wrapper:after {
	content: ".";
	display: block;
	clear: both;
	visibility: hidden;
	line-height: 0;
	height: 0;
}
/* display none until init */
.owl-carousel{
	display: none;
	position: relative;
	width: 94%;
	-ms-touch-action: pan-y;
	margin: 22px 0px 0px 15%;
}
.owl-carousel .owl-wrapper{
	display: none;
	position: relative;
	-webkit-transform: translate3d(0px, 0px, 0px);
}
.owl-carousel .owl-wrapper-outer{
	overflow: hidden;
	position: relative;
	width: 93%;
}
.owl-carousel .owl-wrapper-outer.autoHeight{
	-webkit-transition: height 500ms ease-in-out;
	-moz-transition: height 500ms ease-in-out;
	-ms-transition: height 500ms ease-in-out;
	-o-transition: height 500ms ease-in-out;
	transition: height 500ms ease-in-out;
}
	
.owl-carousel .owl-item{
	float: left;
	width: 337px!important;
	margin: 0px 1.5% 0px 0px;
}
.owl-controls .owl-page,
.owl-controls .owl-buttons div{
	cursor: pointer;
}
.owl-controls {
	-webkit-user-select: none;
	-khtml-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

.owl-carousel .owl-item img{
	max-width: 100%;
}

/* mouse grab icon */
.grabbing { 
    cursor:url(grabbing.png) 8 8, move;
}

/* fix */
.owl-carousel  .owl-wrapper,
.owl-carousel  .owl-item{
	-webkit-backface-visibility: hidden;
	-moz-backface-visibility:    hidden;
	-ms-backface-visibility:     hidden;
  -webkit-transform: translate3d(0,0,0);
  -moz-transform: translate3d(0,0,0);
  -ms-transform: translate3d(0,0,0);
}

/*
* 	Owl Carousel Owl Demo Theme 
*	v1.3.2
*/

.owl-theme .owl-controls{
	margin-top: 10px;
	text-align: center;
}

/* Styling Next and Prev buttons */

.owl-theme .owl-controls .owl-buttons div{
	color: #FFF;
	display: inline-block;
	zoom: 1;
	*display: inline;/*IE7 life-saver */
	margin: 5px;
	padding: 3px 10px;
	font-size: 12px;
	-webkit-border-radius: 30px;
	-moz-border-radius: 30px;
	border-radius: 30px;
	background: #869791;
	filter: Alpha(Opacity=50);/*IE7 fix*/
	opacity: 0.5;
}
/* Clickable class fix problem with hover on touch devices */
/* Use it for non-touch hover action */
.owl-theme .owl-controls.clickable .owl-buttons div:hover{
	filter: Alpha(Opacity=100);/*IE7 fix*/
	opacity: 1;
	text-decoration: none;
}

/* Styling Pagination*/

.owl-theme .owl-controls .owl-page{
	display: inline-block;
	zoom: 1;
	*display: inline;/*IE7 life-saver */
}
.owl-theme .owl-controls .owl-page span{
	display: block;
	width: 12px;
	height: 12px;
	margin: 5px 7px;
	filter: Alpha(Opacity=50);/*IE7 fix*/
	opacity: 0.5;
	-webkit-border-radius: 20px;
	-moz-border-radius: 20px;
	border-radius: 20px;
	background: #869791;
}

.owl-theme .owl-controls .owl-page.active span,
.owl-theme .owl-controls.clickable .owl-page:hover span{
	filter: Alpha(Opacity=100);/*IE7 fix*/
	opacity: 1;
}

/* If PaginationNumbers is true */

.owl-theme .owl-controls .owl-page span.owl-numbers{
	height: auto;
	width: auto;
	color: #FFF;
	padding: 2px 10px;
	font-size: 12px;
	-webkit-border-radius: 30px;
	-moz-border-radius: 30px;
	border-radius: 30px;
}

/* preloading images */
.owl-item.loading{
	min-height: 150px;
	background: url(AjaxLoader.gif) no-repeat center center
}

.customNavigation{
	text-align: center;
	position: absolute; /* position: absolute; */
	top: 96px;
	width: 97.7%;
	/* float: left; */
	z-index: 10000;
}

	.customNavigation .prev{
		margin-left: 1%;
		float: left; 
	}
	
		.customNavigation .next{
			float: right;
			margin-right: -2%;
		}

.customNavigation a{
	-webkit-user-select: none;
	cursor: pointer;
	-khtml-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}


/*
/* 
 * HTML5 ✰ Boilerplate
 *
 * What follows is the result of much research on cross-browser styling. 
 * Credit left inline and big thanks to Nicolas Gallagher, Jonathan Neal,
 * Kroc Camen, and the H5BP dev community and team.
 *
 * Detailed information about this CSS: h5bp.com/css
 * 
 * Dreamweaver modifications:
 * 1. Commented out selection highlight
 * 2. Removed media queries section (we add our own in a separate file)
 *
 * ==|== normalize ==========================================================
 */


/* =============================================================================
   HTML5 display definitions
   ========================================================================== */

article, aside, details, figcaption, figure, footer, header, hgroup, nav, section { display: block; }
audio, canvas, video { display: inline-block; *display: inline; *zoom: 1; }
audio:not([controls]) { display: none; }
[hidden] { display: none; }

/* =============================================================================
   Base
   ========================================================================== */

/*
 * 1. Correct text resizing oddly in IE6/7 when body font-size is set using em units
 * 2. Force vertical scrollbar in non-IE
 * 3. Prevent iOS text size adjust on device orientation change, without disabling user zoom: h5bp.com/g
 */

html { font-size: 100%; overflow-y: scroll; -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; }

/* body { margin: 0; font-size: 13px; line-height: 1.231; }

body, button, input, select, textarea { font-family: sans-serif; color: #222; } */

/* 
 * Remove text-shadow in selection highlight: h5bp.com/i
 * These selection declarations have to be separate
 * Also: hot pink! (or customize the background color to match your design)
 */

/* Dreamweaver: uncomment these if you do want to customize the selection highlight
 *::-moz-selection { background: #fe57a1; color: #fff; text-shadow: none; }
 *::selection { background: #fe57a1; color: #fff; text-shadow: none; }
 */

/* =============================================================================
   Links
   ========================================================================== */

/* a { color: #00e; }
a:visited { color: #551a8b; }
a:hover { color: #06e; }
a:focus { outline: thin dotted; } */

/* Improve readability when focused and hovered in all browsers: h5bp.com/h */
a:hover, a:active { outline: 0; }


/* =============================================================================
   Typography
   ========================================================================== */

abbr[title] { border-bottom: 1px dotted; }

b, strong { font-weight: bold; }

blockquote { margin: 1em 40px; }

dfn { font-style: italic; }

hr { display: block; height: 1px; border: 0; border-top: 1px solid #ccc; margin: 1em 0; padding: 0; }

ins { background: #ff9; color: #000; text-decoration: none; }

mark { background: #ff0; color: #000; font-style: italic; font-weight: bold; }

/* Redeclare monospace font family: h5bp.com/j */
pre, code, kbd, samp { font-family: monospace, monospace; _font-family: 'courier new', monospace; font-size: 1em; }

/* Improve readability of pre-formatted text in all browsers */
pre { white-space: pre; white-space: pre-wrap; word-wrap: break-word; }

q { quotes: none; }
q:before, q:after { content: ""; content: none; }

small { font-size: 85%; }

/* Position subscript and superscript content without affecting line-height: h5bp.com/k */
sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; }
sup { top: -0.5em; }
sub { bottom: -0.25em; }


/* =============================================================================
   Lists
   ========================================================================== */

ul, ol { margin: 1em 0; padding: 0 0 0 40px; }
dd { margin: 0 0 0 40px; }
nav ul, nav ol { list-style: none; list-style-image: none; margin: 0; padding: 0; }


/* =============================================================================
   Embedded content
   ========================================================================== */

/*
 * 1. Improve image quality when scaled in IE7: h5bp.com/d
 * 2. Remove the gap between images and borders on image containers: h5bp.com/e 
 */

img { border: 0; -ms-interpolation-mode: bicubic; vertical-align: middle; }

/*
 * Correct overflow not hidden in IE9 
 */

svg:not(:root) { overflow: hidden; }


/* =============================================================================
   Figures
   ========================================================================== */

figure { margin: 0; }


/* =============================================================================
   Forms
   ========================================================================== */

form { margin: 0; }
fieldset { border: 0; margin: 0; padding: 0; }

/* Indicate that 'label' will shift focus to the associated form element */
label { cursor: pointer; }

/* 
 * 1. Correct color not inheriting in IE6/7/8/9 
 * 2. Correct alignment displayed oddly in IE6/7 
 */

legend { border: 0; *margin-left: -7px; padding: 0; }

/*
 * 1. Correct font-size not inheriting in all browsers
 * 2. Remove margins in FF3/4 S5 Chrome
 * 3. Define consistent vertical alignment display in all browsers
 */

button, input, select, textarea { font-size: 100%; margin: 0; vertical-align: baseline; *vertical-align: middle; }

/*
 * 1. Define line-height as normal to match FF3/4 (set using !important in the UA stylesheet)
 * 2. Correct inner spacing displayed oddly in IE6/7
 */

button, input { line-height: normal; *overflow: visible; }

/*
 * Reintroduce inner spacing in 'table' to avoid overlap and whitespace issues in IE6/7
 */

table button, table input { *overflow: auto; }

/*
 * 1. Display hand cursor for clickable form elements
 * 2. Allow styling of clickable form elements in iOS
 */

button, input[type="button"], input[type="reset"], input[type="submit"] { cursor: pointer; -webkit-appearance: button; }

/*
 * Consistent box sizing and appearance
 */

input[type="checkbox"], input[type="radio"] { box-sizing: border-box; }
input[type="search"] { -webkit-appearance: textfield; -moz-box-sizing: content-box; -webkit-box-sizing: content-box; box-sizing: content-box; }
input[type="search"]::-webkit-search-decoration { -webkit-appearance: none; }

/* 
 * Remove inner padding and border in FF3/4: h5bp.com/l 
 */

button::-moz-focus-inner, input::-moz-focus-inner { border: 0; padding: 0; }

/* 
 * 1. Remove default vertical scrollbar in IE6/7/8/9 
 * 2. Allow only vertical resizing
 */

textarea { overflow: auto; vertical-align: top; resize: vertical; }

/* Colors for form validity */
input:valid, textarea:valid {  }
input:invalid, textarea:invalid { background-color: #f0dddd; }


/* =============================================================================
   Tables
   ========================================================================== */

table { border-collapse: collapse; border-spacing: 0; }
td { vertical-align: top; }


/* ==|== primary styles =====================================================
   Author: 
   ========================================================================== */
















/* ==|== non-semantic helper classes ========================================
   Please define your styles before this section.
   ========================================================================== */

/* For image replacement */
.ir { display: block; border: 0; text-indent: -999em; overflow: hidden; background-color: transparent; background-repeat: no-repeat; text-align: left; direction: ltr; }
.ir br { display: none; }

/* Hide from both screenreaders and browsers: h5bp.com/u */
.hidden { display: none !important; visibility: hidden; }

/* Hide only visually, but have it available for screenreaders: h5bp.com/v */
.visuallyhidden { border: 0; clip: rect(0 0 0 0); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; }

/* Extends the .visuallyhidden class to allow the element to be focusable when navigated to via the keyboard: h5bp.com/p */
.visuallyhidden.focusable:active, .visuallyhidden.focusable:focus { clip: auto; height: auto; margin: 0; overflow: visible; position: static; width: auto; }

/* Hide visually and from screenreaders, but maintain layout */
.invisible { visibility: hidden; }

/* Contain floats: h5bp.com/q */ 
.clearfix:before, .clearfix:after { content: ""; display: table; }
.clearfix:after { clear: both; }
.clearfix { zoom: 1; }


/* ==|== print styles =======================================================
   Print styles.
   Inlined to avoid required HTTP connection: h5bp.com/r
   ========================================================================== */
 
 @media print {
  * { background: transparent !important; color: black !important; text-shadow: none !important; filter:none !important; -ms-filter: none !important; } /* Black prints faster: h5bp.com/s */
  a, a:visited { text-decoration: underline; }
  a[href]:after { content: " (" attr(href) ")"; }
  abbr[title]:after { content: " (" attr(title) ")"; }
  .ir a:after, a[href^="javascript:"]:after, a[href^="#"]:after { content: ""; }  /* Don't show links for images, or javascript/internal links */
  pre, blockquote { border: 1px solid #999; page-break-inside: avoid; }
  thead { display: table-header-group; } /* h5bp.com/t */
  tr, img { page-break-inside: avoid; }
  img { max-width: 100% !important; }
  @page { margin: 0.5cm; }
  p, h2, h3 { orphans: 3; widows: 3; }
  h2, h3 { page-break-after: avoid; }
}
