body, html {
  height: 100%;
  margin: 0;
  color: #333;
  font-family: "Tahoma", "Verdana", "Arial", sans-serif;
  font-size: 18px;  
  font-weight: bold;
  box-sizing: border-box;
  background-color: #fff;
  width: 100%;
  min-width: 320px;
  /*  note: without overflow: scroll sticky header slides off the page as soon as the scroll gets past the initial viewpoint */
  /*  but with overflow: scroll the come-in divs don't toggle the javascript code */
  /* overflow: scroll;    /* fixes the sticky header but come-in divs don't toggle the javascript code  */
  /* overflow-y: auto;   same as above  */

}

* {
	box-sizing: border-box;
}
@media (max-width:600px) { html {font-size: 14px;}}
@media (min-width:600.01px) and (max-width:992px) { html {font-size: 16px;}}


h1, h2, h3, h4, h5 {
  font-family: "Tahoma", "Verdana", sans-serif;
  color: #000000;
}

a {
	color:  #6797db;   /* default blue didn't show out from black text well */
	text-decoration: none;
}
a:hover {
	color: #ff6600;
	text-decoration: underline;
}

.pagetitle {
	width: 100%;
	text-align: center;
}

.ptext {padding:40px 72px 0px 72px;}  /*text-align:left;min-height:50px;} */
.ptext:last-of-type {
	padding-bottom: 40px;
}	
@media (min-width:600.01px) and (max-width:992px) { 
	.ptext {
		padding: 32px 48px 0px 48px;
	}
	.ptext:last-of-type {
		padding-bottom: 32px;
	}	
}
@media (max-width:600px) { 
	.ptext {
		padding: 16px 36px 0px 36px;
	}
	.ptext:last-of-type {
		padding-bottom: 16px;
	}	
}


.pagemargins {
	margin: 4%;
}

.responsiveimage {
	width: 100%;
/* use inline for different size pics for	max-width: 100%;  */
	height: auto;
	border: 0;
	box-sizing: border-box;
}


.slidercontainer {
	overflow: hidden!important;
	box-sizing: border-box!important;
	max-width: 100% !important;
	width: 100% !important;
	min-width: 100% !important;
	/*padding-top: 129px;*/
	padding-top: 0px;   /* NOT NEEDED FOR STICKY TOP NAV NOW 159px;  */
}
/*
@media (max-width:600px) { .slidercontainer {padding-top:0px;}}
@media (min-width:601px) and (max-width:992px) { .slidercontainer {padding-top:145px;}}
NOT NEEDED NOW FOR STICKY TOP NAV  */

/********************************************
           Flexslider Caption Text
********************************************/
.flexslider .slides li {
	position:relative;
}
.flex-caption {
    position:absolute;
	width: 100%;
	/* height: 10%;  let default to existing text */
    bottom: 0;
    left:0;
	right:0;
    padding:4px 4em;  /* 2px 6px;*/
	/* margin: 0; margin defaulting is a bit up from bottom of photo */
    color: white;
    font-size: 1.0em;
    line-height: 1.25em;
    text-transform: uppercase;
 	background-color: rgba(0, 0, 0, 0.5);
	box-sizing: border-box;
	text-align: center;
}
@media (max-width:991px) { .flex-caption {font-size: .75em;line-height:1.0em;} }

.flex-caption a {
	color: white;
	text-decoration: underline;
}
.flex-caption a:hover {
	color: #ff6600;
}
.flex-caption2 {
    position:absolute;
    bottom: 0;
    left:50%;
	transform: translate(-50%,0);
    padding: 12px 12px;
    color: white;
    font-size: 1.0em;
    line-height: 1.25em;
    text-transform: uppercase;
 	background-color: rgba(0, 0, 0, 0.5);
	box-sizing: border-box;
	text-align: center;
}
@media (max-width:991px) { .flex-caption2 {font-size: .75em;line-height:1.0em;} }

.flex-caption2 a {
	color: white;
	text-decoration: underline;
}
.flex-caption2 a:hover {
	color: #ff6600;
}

/****************************************** 
user message under slider 
******************************************/
/* so far, used to confirm that the contactpopup message has been sent */
.usermsg {
	width: 100%;
	background-color: yellow;
	color: black;
	text-align: center;
	font-weight: bold;
	margin: 0;
	padding: 3px;
	display: none;
}

/********************************************
banner for top of page when needed 
*********************************************/
.banner {
	width: 100%;
	color: black;
	/* set background-color with .lightx colors */
	text-align: center;
	padding: 8px;
	font-weight: normal;
	font-size: 14px;
	box-sizing: border-box;
}

@media (max-width:992px) { 
	.banner {
		padding-left: 40px;
		padding-top: 8px;
		padding-bottom: 8x;
		padding-right: 40px;
	}
}

.lightorange { background-color: #ff9955; }
.lightblue { background-color: #6399dd; }
.lightgreen { background-color: #57ee66; }
.lightpurple { background-color: #ae44ff; }
.lightyellow { background-color: #e7ee55; }


/************************************************
           Header bar 
************************************************/
.headerbar {
	min-width: 100%;
	max-width: 100%;
	height:115px;
	min-height:115px;
	max-height:115px;
	background-color: #224f90;
	padding-left: 225px;
	padding-top: 5px;
	padding-bottom: 5px;
	padding-right: 5px;
	box-sizing: border-box;
	font-size: 16px;
}

@media (max-width:992px) { 
	.headerbar {
		padding-left: 205px;
		padding-top: 5px;
		padding-bottom: 5px;
		padding-right: 5px;
	}
}


@media (min-width:600.01px) {
	.alltopheader {
		position: relative;   /*static;   /* sticky;  /* STICKY */
		z-index: 205;
		box-sizing: border-box;
		width: 100%;
		/* top: 0px; */
    } 
}
@media (max-width:600px) {
	.alltopheader {
		position: relative;
		z-index: 1;   /* default? */
		box-sizing: border-box;
		width: 100%;
		/* top: 0px; */
	}
}

/*  logo   */
#logo {
    position: absolute;   /* STICKY was fixed */
	width: 215px;
	top: 0;
	left: 0;
	display: block;
	margin: 0px;
	padding: 10px 10px 0px 10px;
	opacity: 1.0!important;
	z-index: 2;
}

@media (max-width: 992px) { 
	#logo {   
		width: 175px;
		padding: 3px 3px 0 3px;
		position: absolute;
		top: 13px;
	} 
}

#logoWVI {
    position: absolute;   /* STICKY was fixed */
	width: 215px;
	top: 121px;
	left: 0;
	display: block;
	margin: 0px;
	padding: 10px 10px 0px 10px;
	opacity: 1.0!important;
	z-index: 2;
}

@media (max-width: 992px) { 
	#logoWVI {   
		width: 175px;
		/*top: 92px;*/
		padding: 3px 3px 0 3px;
		position: absolute;
	} 
}

.call-button {
	outline: none;
	z-index: 2;
	display: block;
	border: none;   /* 2px solid #000; */
	border-radius: 4px;
	background-color: #CCCCCC;
	color: #000000;
	font-weight: bold;
	font-size: 16px;
	text-decoration: none;
	padding: 12px;
	text-align: center; 
	line-height: 1em;
	margin-top: 22px;
	margin-left: 12px;
	margin-right: 20px;
	box-shadow:0 2px 2px 0 rgba(0,0,0,0.2);
	position: absolute;   /* STICKY  fixed;  */
	top: 0px;
	right: 0px;
	box-sizing: border-box;
}

@media (min-width: 600.01px) and (max-width:992px){
	.call-button{
		top: 0px; 
		right: 0px;
		font-size: 14px;
		padding: 8px;
		margin-top: 75px;
		margin-right: 12px;
		position: absolute;
		box-sizing: border-box;
		
		i { 
		  animation: rotate-shake 10s infinite ease-in-out;
		};
	}
}

@media (max-width:600px){
	.call-button{
		top: 0px; 
		right: 0px;
		font-size: 14px;
		padding: 8px;
		margin-top: 62px;
		margin-right: 12px;
		position: absolute;
		box-sizing: border-box;
		
		i { 
		  animation: rotate-shake 10s infinite ease-in-out;
		};
	}
}

.call-button:hover {
	color: #ff6600;
	i { 
      animation: rotate-shake 10s infinite ease-in-out;
	};
}

@keyframes rotate-shake {
  0% {transform: rotate(0deg);}
  1% {transform: rotate(20deg);}
  2% {transform: rotate(-18deg);}
  3% {transform: rotate(16deg);}
  4% {transform: rotate(-14deg);}
  5% {transform: rotate(12deg);}
  6% {transform: rotate(-10deg);}
  7% {transform: rotate(5deg);}
  8% {transform: rotate(-2deg);}
  9% {transform: rotate(0deg);}
  100% {transform: rotate(0deg);}
}


/**********************************************************************/
/*          menu CSS                                                  */
/**********************************************************************/
.topnav {
  overflow: hidden;
  background-color: #333;

  /* my edits below */
  text-transform: uppercase; 
  width: 100%;
  left: 0px;
  right: 0px;
  padding-left: 235px;
  /* z-index: 20;  */
  box-sizing: border-box;
  font-weight: normal;
}

.topnav a {
  display: block;
  color: #f2f2f2;
  padding: 14px 16px;
  text-decoration: none;
  text-align: center;
  font-size: 17px;
  font-weight: normal;
  float: left;
}

.active {
  background-color: #ff6600;   /* orange to coordinate */
  color: white;
}

.topnav .icon {
  display: none;
}

.dropdown {
  float: left;
  overflow: hidden;
}

.dropdown .dropbtn {
  font-size: 17px;    
  border: none;
  outline: none;
  color: white;
  padding: 14px 16px;
  background-color: inherit;
  font-family: inherit;
  margin: 0;
  font-weight: normal;
}

.dropdown-content {
/*  display: none; */
  position: absolute;
  background-color: #f9f9f9;
  min-width: 160px;
  border-radius: 0 0 6px 6px;
  box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
  z-index: 1;
}

.dropdown-content a {
  float: none;
  color: black;
  padding: 12px 16px;
  text-decoration: none;
  display: block;
  text-align: left;
}

.topnav a:hover, .dropdown:hover .dropbtn {
  background-color: #555;
  color: white;
}

.dropdown-content a:hover {
  background-color: #ddd;
  color: black;
}

/*
.dropdown:hover .dropdown-content {
  display: block;
}*/

.nopointerevents {
	pointer-events: none;
}

@media screen and (max-width: 992px) {
/*  .topnav a:not(:first-child), .dropdown .dropbtn {   */
/*  first-child is the hamburger-or-times button which since I am putting at top, should also be hidden? */
  .topnav { /* a, .dropdown .dropbtn {  /* a, .dropdown .dropbtn { */
    display: none;
  }
  .topnav a.icon {
    float: right;
    display: block;
  }
}

@media screen and (max-width: 992px) {
  .topnav.responsive {
	/* position: relative; */

	/* my edits here */
	position: absolute;   /* STICKY fixed;  */
	top: 0;
	left: 0;
	right: 0;
	padding-left: 0px;
	text-align: center;
	display: block;
	z-index: 100;
  }

  .topnav.responsive .icon {
    position: absolute;
    right: 0;
    top: 0;
  }
  .topnav.responsive a {
    float: none;
    display: block;
	
	/* my edits */
    /* text-align: left; */
	text-align: center;
  }
  .topnav.responsive .dropdown {float: none;}
  .topnav.responsive .dropdown-content {
	  position: relative;
  }
  .topnav.responsive .dropdown .dropbtn {
    display: block;
    width: 100%;
  }
}

/* end menu CSS  */

.w3-hamburger-position {
	position: absolute;
	top: 0px;
	right: 0px;
	margin: 12px;
}




/********************************************
        Mission Statement on Home Page
********************************************/
.mission-cont {
	width: 100%;
	font-family: "Noto Serif", sans-serif;
	font-size: 20px; 
	letter-spacing: 1.5px;
	line-height: 1.5em;
	padding: 72px;
	text-align: center;
	background: #dfdfdf;
	box-sizing: border-box;
	font-weight: bold;
}
@media (max-width:992px) { .mission-cont {font-size: 16px; padding: 48px;}}


/****************************************/
/*** membership & awards             ****/
/****************************************/

.memberships {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	align-items: center;
	box-sizing: border-box;
	flex-wrap: wrap;
}
.seal-container {
	margin: 36px;
	width: 200px;
	max-width: 98%;
	min-width: 20%;
	vertical-align: top;
}
.seal-container img {
	padding: 0;
	width: 100%;
	border: 0;
}


/****************************************/
/*** brands                          ****/
/****************************************/

.brandsflex {
	margin: 0 0 3em 0;
	padding: 0;
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	align-items: center;
	box-sizing: border-box;
	flex-wrap: wrap;
}
.brand-container {
	margin: 36px;
	width: 200px;
	max-width: 200px;
	min-width: 200px;
	vertical-align: top;
	text-align: center;
}
.brand-container-large-icons {
	margin: 36px;
	width: 350px;
	max-width: 95%;
	vertical-align: top;
	text-align: center;
}
.brand-container img, .brand-container-large-icons img {
	padding: 0;
	width: 100%;
	border: 0;
	margin-bottom: 1em;
}
.brand-container img:hover, .brand-container-large-icons img:hover {
transform: scale(1.25, 1.25);
}

.brand-container a, .brand-container-large-icons a {
	text-decoration: none;
}
.brand-container a:hover, .brand-container-large-icons a:hover {
	text-decoration: underline;
}
.brand-container i, .brand-container-large-icons i {
	vertical-align: middle;
/*	line-height: 0.5em;
*/
}


#bodylink a {
   color: #65b5fa;
   text-decoration: none!important;
   /* font-weight: bold;  */
}

#bodylink a:hover {
   /* text-decoration: underline;  */
   color: #04c806;
   /*  font-weight: bold;  */
}


#CarrierButton {
	outline: none;
	z-index: 2;
	display: inline-block;
	border: none;  /* 2px solid #000; */
	border-radius: 4px;
	background-color: #CCCCCC;
	color: #000000;
	font-weight: bold;
	font-size: 16px;
	text-decoration: none;
	padding: 12px;
	text-align: center; 
	line-height: 1em;
/*	margin-top: 22px; */
/*	margin-left: 12px;
	margin-right: 20px;  */
/*	box-shadow:0 2px 2px 0 rgba(0,0,0,0.2);  */
	box-sizing: border-box;
	cursor: pointer;
}
#CarrierButton:hover {
	color: #ff6600;
}



/* Used on HVAC page */
.appt-button-page-body {
	outline: none;
	display: inline-block;
	border: none;  /* 2px solid #000;   /* none; */
	border-radius: 4px;
	background-color: #CCCCCC;
	color: #000000;
	font-weight: bold;
	font-size: 16px;
	text-decoration: none;
	padding: 12px;
	text-align: center; 
	line-height: 1em;
	margin: 0;
	box-shadow: none;   /* 2px 2px 2px 0 rgba(0,0,0,0.2); */
	box-sizing: border-box;
}

@media (max-width:992px){
	.appt-button-page-body{
		width: 30%;
		min-width: 275px;
		font-size: 14px;
		text-align: center;
		margin: 12px;
		overflow: hidden;
		padding: 8px;
		
		i { 
		  animation: rotate-shake 10s infinite ease-in-out;
		};
	}
}


.appt-button-page-body:hover {
	color: #ff6600;
	text-decoration: underline;
	i { 
      animation: rotate-shake 10s infinite ease-in-out;
	};
}

.contactpopupbutton {
	outline: none;
	display: inline-block;
	border: none;  /* 2px solid #000;   /* none; */
	border-radius: 4px;
	background-color: #cccccc;
	color: #000000;
	font-weight: bold;
	font-size: 16px;
	text-decoration: none;
	padding: 12px;
	text-align: center; 
	line-height: 1em;
	margin: 0;
	box-shadow: none;   /* 2px 2px 2px 0 rgba(0,0,0,0.2); */
	box-sizing: border-box;
	min-width: 250px;
}

@media (max-width:992px){
	.contactpopupbutton{
		width: 30%;
		min-width: 250px;
		font-size: 14px;
		text-align: center;
		overflow: hidden;
		padding: 8px;
		
		i { 
		  animation: rotate-shake 10s infinite ease-in-out;
		};
	}
}


.contactpopupbutton:hover {
	color: #ff6600;
	text-decoration: underline;
	i { 
      animation: rotate-shake 10s infinite ease-in-out;
	};
}


.togglefinancingbuttonarea a {
	color: #000;
	text-decoration: none;
	outline: none;
/*  display: block; */
	border: none;  /* 2px solid #000;   /* none; */
	border-radius: 4px;
	background-color: #CCCCCC;
	font-weight: bold;
	font-size: 16px;
	text-align: center; 
	line-height: 1.3em;
	padding: 12px;
	box-shadow: none;   /* 2px 2px 2px 0 rgba(0,0,0,0.2); */
	box-sizing: border-box;
	width: 30%;
	min-width: 250px;
	text-align: center;
	overflow: hidden;
	margin: 12px;
}

@media (max-width:992px){
	.togglefinancingbuttonarea a {
		font-size: 14px;
		padding: 8px;
	}
}

.togglefinancingbuttonarea a:hover {
	color: #ff6600;
	text-decoration: underline;
}




.footer1 {
	font-size: 18px;
	width: 100%;
	left: 0;
	right: 0;
	padding: 24px 0;
	margin: 64px 0 0 0;
	background-color: #224f90;   /* fallback for older browsers */
/*	background: -webkit-linear-gradient(to right, #224f90, #3171cb 45%, #79a3df 65%, #6797db);  /* Chrome 10-25, Safari 5.1-6 */
/*	background: linear-gradient(to right, #224f90, #3171cb 45%, #79a3df 65%, #6797db); /* W3C, IE 10+/ Edge, Firefox 16+, Chrome 26+, Opera 12+, Safari 7+ */
	color: #000000;

	box-sizing: border-box;
	display: flex;
	justify-content: center;
	align-items: flex-start;
	flex-wrap: wrap;
	line-height: 1.5em;
}
@media (max-width: 600px) {
	.footer1 {
/*		flex-direction: column;
		align-items: center;  */
		margin: 0 0;
		padding: 18px 0;
		font-size: 16px;
	}
}
.footer1 a {
	color: #000000;
	text-decoration: none;
}
.footer1 .footer1-section {
	vertical-align: top;
	margin: 36px;
}
.underline-links a{
/*	text-decoration: underline!important;  */
	display: block!important;
	font-size: 16px;
}
.footer1 a:hover{
	color: #ff6600;
}

@media (max-width: 600px) {
	.underline-links a{
		font-size: 14px;
	}
}
/*.footer1(:first-child) { margin-left:0px }
.footer1(:last-child) { margin-right:0px }
*/
.footerlogo {
	width: 175px;
	max-width: 175px;
	min-width: 175px;
	margin: 0;
	padding: 0;
}
@media (max-width: 600px) { 
	.footerlogo {   
		width: 135px;
		max-width: 135px;
		min-width: 135px;
	} 
}



.footer2 {
   font-size: 12px;
   font-weight: normal;
/*  height: 36px;
   min-height: 36px;
   max-height: 36px; */
   width: 100%;
   left: 0;
   right: 0;
   padding: 12px 36px;
   margin: 0;
   background-color: #333333;
   color: #efefef;
   vertical-align: middle;
   box-sizing: border-box;
   line-height: 1.5em;
}
.footer2 .dev {
	float:right;
	display: inline;
}
@media (max-width: 992px) {
	.footer2 {
		padding: 12px 24px;
		width: 100%;
		text-align: center;
	
	}
	.footer2 .dev {
		float: none;
		display: block;
		margin-left: 0;
		margin-right: 0;
	}
}
.footer2 a {
	color: #efefef;
	text-decoration: none;
}
.footer2 a:hover {
	color: #225f90;
	text-decoration: underline;
}



.indented {
   padding: 25px 80px;
}


.emergencyservicesarea {
	background-color: #224f90;
	color: white;
	padding: 20px 40px;
	margin: 0;
	display: flex;
	justify-content: center;
	align-items: flex-start;
	box-sizing: border-box;
	flex-wrap: wrap;
}
.emergencyservicesarea .symbol {
	font-size: 100px;
}

.emergencyservicesarea a {
	color: white;
}
.emergencyservicesarea a:hover {
	color: #ff6600;
}
@media (min-width: 600.01px) and (max-width: 992px) {
	.emergencyservicesarea {
		margin: 0 0;
		padding: 10px;
		font-size: 16px;
		text-align: center;
		align-items: center;
	}
	.emergencyservicesarea .symbol {
		font-size: 72px;
	}
}

@media (max-width: 600px) {
	.emergencyservicesarea {
		margin: 0 0;
		padding: 4px;
		font-size: 14px;
		text-align: center;
		align-items: center;
	}
	.emergencyservicesarea .symbol {
		font-size: 64px;
	}
}


/* Google font styles */
.material-symbols-outlined {
  font-variation-settings:
  'FILL' 1,
  'wght' 400,
  'GRAD' 0,
  'opsz' 20
}
.material-symbols-filled {
  font-variation-settings:
  'FILL' 1,
  'wght' 400,
  'GRAD' 0,
  'opsz' 24
}



/****************************************************************************
   Cards
*****************************************************************************/
/******   * {   <--- can't do this since I already have my page set up  ****/
.rcard-global {
margin: 0;
padding: 0;
box-sizing: border-box;
/* font-size: 18px;  */
}

.rcard-section {
display: flex;
justify-content: center;
align-items: center;
box-sizing: border-box;
flex-wrap: wrap;
margin: 0;
padding: 30px;
background-color: #dfdfdf;
}


@media (max-width: 768px) {
	.rcard-section {
		flex-direction: column;
		align-items: center;
		margin: 0 0;
		padding: 0;
	}
}


.rcard-container {
	width: 275px;   /* 20em; */
	max-width: 85%;
	min-width: 275px;
	height: 450px;
	max-height: 450px;
	min-height: 450px;
	background-color: #FCFCFC;
	overflow: hidden;
	border-radius: 1em;
	border: 2px solid rgb(0, 0, 0);
	text-align: center;
	font-family: 'Tahoma', 'Verdana', sans-serif;
	font-size: 16px; 
	margin: 30px;    /* 1.5em; */
	box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
	box-sizing: border-box;
}


@media (max-width: 768px) {
	.rcard-container {
	  margin: 0.5em 0;
	  padding: 0;
	}
}


.rcard-top-image {
padding: 1em 0;
background-image: linear-gradient(70deg, #224f90, #3171cb);   /* #61A1DD, #0083FD);  */
height: 130px;
max-height: 130px;
min-height: 130px;
box-sizing: border-box;
}
.rcard-top-image .img-container {
width: 90px;
max-width: 90px!important;
height: 90px;
max-height: 90px!important;
border-radius: 50%;
border: 1px solid rgb(0, 0, 0);
box-shadow: 0 0.4em 1em;   /*  0 0.6em 1.8em;  */
/* object-fit: contain;   /* 3-28-25 cover; */
background-color: #FCFCFC;
box-sizing: border-box;
overflow: hidden;
margin: auto;
}
.rcard-top-image img {
width: 65px;
max-width: 65px!important;
height: 65px;
max-height: 65px!important;
margin: 13px;
}

.rcard-top-image i, .rcard-top-image span {
width: 90px;
max-width: 90px!important;
height: 90px;
max-height: 90px!important;
border-radius: 50%;
border: 1px solid rgb(0, 0, 0);
/* not needed, img-container now does this  box-shadow: 0 0.4em 1em;   /*  0 0.6em 1.8em;  */
object-fit: contain;   /* cover;  */
background-color: #FCFCFC;
font-size: 64px;
padding-top: 13px;
overflow: hidden;
text-align: center;
justify-content: center;
box-sizing: border-box;
color: #606060;
}

.rcard-content {
color: #565656;
padding: 0.25em 1em 0px 1em;
font-size: 1em;
height: 245px;    /* 320px; */
min-height: 245px;
max-height: 245px;
box-sizing: border-box;
}

.rcard-linksarea {
color: #224f90;      /*   old 565656   */
padding: 0px 1em 0px 1em;
margin: 0px;
height: 75px;
min-height: 75px;
max-height: 75px;
box-sizing: border-box;
}

.rcard-name {
font-size: 1.25em;
text-transform: uppercase;
}

.rcard-username {
font-size: 1em;
color: #9e9e9e;
}

.rcard-links {
display: flex;
justify-content: center;
margin: 0;   /*  1.5em 0 0 0 */
/* font-size: 0.8em; */
}

.rcard-links-tinycaption {
	font-size: 0.5em;
	text-transform: uppercase;
}

.rcard-container a {
text-decoration: none;
color: #565656;
transition: all 0.3s;
font-size: 1.5em;
margin-right: 1.2em;
}

.rcard-container a:last-child {
margin: 0;
}

.rcard-smalliconlinksblue:hover {
color: #3171cb;   /* #224f90; */
transform: scale(1.125, 1.125);
}

.rcard-details {
/* margin-bottom: 1.8em;  */
margin: 0;  /* sufficient margin is set from padding of this entire card  */
font-size: 1em!important;
font-weight: bold;
}


/* CSS for action button link */
.rcard-effect {
text-align: center;
display: inline-block;
position: relative;
text-decoration: none;
color: #ffffff;
text-transform: capitalize;
width: 175px;
height: 35px;
/* background-image: linear-gradient(60deg, #0083FD, #888888 40% 60%, #61A1DD); */
background-color: #565656;
font-size: 0.7em;   /* 1.2em  */
padding: 0.5em 0.5em;
border-radius: 5em;
overflow: hidden;
}

.rcard-effect.rcard-effect-4:before {
content: "\f2b6";
font-family: FontAwesome;
display: flex;
align-items: center;
justify-content: center;
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
text-align: center;
font-size: 0.75em;
transform: scale(0, 1);
color: #ffffff;
}

.rcard-effect.rcard-effect-4:hover {
text-indent: -9999px;
}

.rcard-effect.rcard-effect-4:hover:before {
transform: scale(1, 1);
text-indent: 0;
}
/*****************************/
/***** end CSS for cards  ****/
/*****************************/


/**********************************/
/***** CSS for repairs/parts  ******/
/**********************************/

.parts {
	width: 100%;
	aspect-ratio: 4/3;
	background: url(graphics/steidinger-brothers-parts-stocking.jpg) no-repeat center;
	background-color: #000;
	background-size: cover;
	background-blend-mode: overlay;
	background-color: #dfdfdf;
	position: static;
	box-sizing: border-box;
}
/*@media (max-width: 600) {
	.parts {
		background: url(graphics/steidinger-brothers-parts-stocking.jpg) no-repeat center;
	}
}*/


.parts-back {
	background-color: rgba(255, 255, 255, 0.8 );
	-webkit-backdrop-filter: grayscale(75%);
	backdrop-filter: grayscale(75%);
	height: 100%;
	width: 100%; 
}


.parts-block {
	/* position: relative; */
	font-family: tahoma,sans-serif;
	font-size: 1.5em;
	color: rgba(245, 245, 245);
	text-align: center;

	/* my edits */
	display: flex;
	justify-content: center;
	align-items: flex-start;   /* center;  */
	box-sizing: border-box;
	flex-wrap: wrap;
	margin: 0;
	padding: 0;
}

.parts-block .parts-inner-box {
  /* position: relative; */
	background-color: rgba(100, 100, 100, 0.6 );
	-webkit-backdrop-filter: grayscale(60%);
	backdrop-filter: grayscale(60%);
  /* my edits */
  box-sizing: border-box;
  /* width: 275px; */
  width: 100%;
  height: 100%;
  padding: 5%;   /* 0 30px 30px; */
  border-radius: 1em;
  margin: 20%;
}


/**********************************/
/***** CSS for testimonials  ******/
/**********************************/

.reviews {
	width: 100%;
	background: url(graphics/reviewsbackground.jpg) no-repeat center;
	background-color: #000;
	background-size: cover;
	background-blend-mode: overlay;
	background-color: #dfdfdf;
	position: static;
	box-sizing: border-box;
}
@media (max-width: 600) {
	.reviews {
		background: url(graphics/reviewsbackground_s.jpg) no-repeat center;
	}
}


.reviews-back {
	background-color: rgba(255, 255, 255, 0.8 );
	-webkit-backdrop-filter: grayscale(75%);
	backdrop-filter: grayscale(75%);
	height: 100%;
	width: 100%; 
}


.testimonial-block {
	/* position: relative; */
	font-family: tahoma,sans-serif;

	/* my edits */
	display: flex;
	justify-content: center;
	align-items: flex-start;   /* center;  */
	box-sizing: border-box;
	flex-wrap: wrap;
	margin: 0;
	padding: 0;
}

.testimonial-block .inner-box {
  /* position: relative; */
  background-color: #444;
  /* my edits */
  box-sizing: border-box;
  width: 275px;
  padding: 30px;   /* 0 30px 30px; */
  border-radius: 1em;
  margin: 25px;
}



/* .testimonial-block .inner-box .image { */
.testimonial-block .inner-box .stars {
  /* position: relative; */
  overflow: hidden;
  margin-bottom: 25px;
  display: inline-block;
  
  /* my edits */
/*  margin-top: 12px;    /* -50 */
/*  width: 250px;         /* 100 */
/*  height: 24px;         /* 100 */
  border-radius: 0;    /* 50% */
  font-size: 24px;
  color: #ffff33;
  letter-spacing: -0.75em; 
}
.testimonial-block .inner-box .content {
  position: relative;
}
.testimonial-block .inner-box .content .qleft {
  position: absolute;
  left: 0;
  top: -35px;
  font-size: 30px;
  font-style: italic;
  color: #da5e00;
}
.testimonial-block .inner-box .content .qright {
  position: absolute;
  right: 0;
  bottom: 0;   /* -35px; */
  font-size: 30px;
  font-style: italic;
  color: #da5e00;
}
.testimonial-block .inner-box .content .author-info {
  position: relative;
  font-size: 16px;
  font-weight: 500;
  color: #fff;
  
  /* my edits */
  margin-top: 18px;
}
.testimonial-block .inner-box .content .reviewer {
  position: relative;
  font-size: 16px;
  font-weight: 500;
  color: #ddd;    /* fff; */
  
  /* my edits */
  margin-top: 18px;
}
.testimonial-block .inner-box .content .reviewdate {
  position: relative;
  color: #ddd;      /* #aaa; */
  font-size: 14px;
  font-style: italic;
}
.testimonial-block .inner-box .content .text {
  position: relative;
  margin-top: 20px;
  color: #ddd;       /*  #aaa; */
  font-size: 15px;
}

/**********************************/
/*** end CSS for testimonials *****/
/**********************************/


/*********************************/
/***  CSS for listing towns  *****/
/* INDEX PAGE
/*********************************/
.servicearea {
	background-image: url("graphics/livco-bg-gs.jpg");
	background-repeat: no-repeat;
	background-position: center bottom;
	padding: 32px 48px;
}
.townslisted ul {  
    columns: 15rem;  
    column-gap: 3rem;  
	list-style: none;
	text-align: center;
	padding-left: 0;
	margin: 0;
} 
.townslisted li {
	break-inside: avoid;
}
.townslisted {
}


/***************************************/
/***  Left fixed buttons             ***/
/***************************************/
.leftbuttonscontainer {
  /* overflow: hidden; */
  font-size: 24px;
  position: fixed;
  top: 45%;
  left: 0;
  z-index: 200;
}
.leftbuttonscontainer a {
	text-decoration: none;
}
.tag {
  display: flex;
  width: fit-content;
  transform: translateX(-100%);
  transition: all 0.3s ease-out;
  cursor: pointer;

  
  .caption {
    background: blue;
    color: white;
    height: 50px;
    padding-left: 8px;
    padding-right: 8px;
    text-align: center;
    line-height: 50px;
    font-size: 16px;
  }

  .blue { background: #6797db; }
  .green { background: #009900; }
  .lightorange { background: #ff9047; }
  .purple { background: #673ab7; }

  .icon {
    position: absolute;
    color: white;
    width: 50px;
    height: 50px; 
    border-radius: 0 5px 5px 0;
    text-align: center;
    line-height: 50px;
  }
  
  &:hover, &:focus {
    transform: translateX(0);
  }
}

/*****************************************/
/*****  Popup Contact Form            ****/
/*****************************************/
.contactpopup { 
	display: none;
	background-color: #3171cb;
	color:#000;
	position: fixed;
	top: 5%;
	margin-left: auto;
	margin-right: auto;
	width:400px;
	max-width: 95%;
	border-radius: 6px;
	box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
	box-sizing: border-box; 
	z-index: 210;
	font-size: 14px;
}

@media screen and (max-width:600px) {
	.contactpopup {
		top: 2px;
		margin-left: 0px;
	}
}

.contactpopup .upper {
	height:102px;
	max-height: 102px;
	overflow: hidden;
	box-sizing: border-box;
}
.contactpopup .upper .w3-small {
	line-height: 0.9;
}

.contactpopup .lower {
  padding: 0 15px 15px 15px;
  height: 425px;
  max-height: 90%;
	overflow-x: hidden;
	overflow-y: scroll;
}
.contactpopup h2 {
	border-radius: 6px 6px 0px 0px;
	text-align: left;
	color: #fff;
	text-shadow: none;
	/* default might be fine  font-size: 16px;
	font-weight: 600; */ 
	/* background-color: #224f90;  */
	margin: 0px;
	padding: 8px;
	cursor: pointer;
}
.contactpopup h2 span {
	font-weight: bold;
}
.contactpopup p {
	text-align: center;
	padding: 0px 15px;    /* 15px 15px 0px 15px; */
	font-size: 16px;
	margin-top: 0;
}
.contactpopup .closebutton {
	position: absolute;
	color: #fff;
	top: 0;
	right: 0;
	font-weight: normal;
	font-size: 48px;
	padding: 0px 8px;
	cursor: pointer;
	background-color: transparent;  /* #eeeeee; */
	border-radius: 0 6px 0 0;
	line-height: 0.8em;
}

.contactpopup .sub-result-error {
	background-color: white;
	color: red;
	padding: 0 8px;
	text-align: center;
}

.contactpopup label {
	line-height: 2em;
	padding-bottom: 0;
}

.contactpopup input:not(.checkitems) {
  box-sizing: border-box;
	width: 100%;
	height: 2.5em;
	margin-top: 0;
	margin-bottom: 4px;
	padding: 8px;
	background: #ffffff;
	outline: none;
	color: #000;
	border-radius: 6px;
  border-right: solid 1px #000;
	border-top: solid 1px #000;
	border-left: solid 1px #000;
  border-bottom: none;
	transition: all 0.3s ease-in-out;
	 -webkit-transition: all 0.3s ease-in-out;
	 -moz-transition: all 0.3s ease-in-out;
	 -ms-transition: all 0.3s ease-in-out;
}

.contactpopup .checkitems {
  height: auto;
  border-radius: 6px;
  margin-bottom: 4px;
  text-align: center;
}

.contactpopup textarea {
  box-sizing: border-box;
  resize: none;
	 width: 100%;
  margin-left: auto;
  margin-right: auto;
	height: 6em;
	padding: 10px;
	background: #ffffff;
	outline: none;
	color: #000;
  border-radius: 6px;
  border-right: solid 1px #000;
	border-top: solid 1px #000;
	border-left: solid 1px #000;
  border-bottom: none;
	transition: all 0.3s ease-in-out;
	 -webkit-transition: all 0.3s ease-in-out;
	 -moz-transition: all 0.3s ease-in-out;
	 -ms-transition: all 0.3s ease-in-out;
}

.contactpopup .checks {
  box-sizing: border-box;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 4px;
	padding: 15px;
	background: #ffffff;
	outline: none;
	color: #000;
	border-radius: 6px;
	border-right: solid 1px #000;
	border-top: solid 1px #000;
	border-left: solid 1px #000;
  border-bottom: none;
	transition: all 0.3s ease-in-out;
	 -webkit-transition: all 0.3s ease-in-out;
	 -moz-transition: all 0.3s ease-in-out;
	 -ms-transition: all 0.3s ease-in-out;
}

.contactpopup button {
  width: 100%;
  border-radius: 0;
  border: 1px solid black;
  height: 2.5em;
  background-color: #cccccc;
  font-weight: bold;
  color: #000000;
  font-size: 18px;
  cursor: pointer;
  margin-bottom: 4px;
  border-radius: 6px;
}

.contactpopup .resetbtn {
	cursor: pointer;
}

.contactpopup .xxcheckwithCSS:required:invalid:not(:placeholder-shown), .xxcheckwithCSS:focus:invalid:not(:placeholder-shown) {
	background: url(graphics/circle-exclamation.svg);
	background-size: 16px;
	background-repeat: no-repeat;
	background-position: center right;
	background-color: #ffffff;
}

.contactpopup .xxcheckwithCSS:valid {
	background: url(graphics/check.svg);
	background-size: 16px;
	background-repeat: no-repeat;
	background-position: center	right;
	background-color: #ffffff;
}
.xxbad {
	background: url(graphics/circle-exclamation.svg);
	background-size: 16px;
	background-repeat: no-repeat;
	background-position: center right;
	background-color: #ffffff;
}
.xxgood {
	background: url(graphics/check.svg);
	background-size: 16px;
	background-repeat: no-repeat;
	background-position: center	right;
	background-color: #ffffff;
}	
.xxnone { background: none; background-color: #ffffff; }


.fixed {
	position: fixed;
}
/*******************************/
/*  end contact popup form CSS */
/*******************************/

.tooltip {
  position: relative;
  display: inline-block;
}

.tooltip .tooltiptext {
  visibility: hidden;
  width: 140px;
  background-color: #555;
  color: #fff;
  font-size: 12px;
  text-align: center;
  border-radius: 6px;
  padding: 5px;
  position: absolute;
  z-index: 1;
  bottom: 150%;
  left: 50%;
  margin-left: -75px;
  opacity: 0;
  transition: opacity 0.3s;
}

.tooltip .tooltiptext::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -5px;
  border-width: 5px;
  border-style: solid;
  border-color: #555 transparent transparent transparent;
}

.tooltip:hover .tooltiptext {
  visibility: visible;
  opacity: 1;
}
.contactpopuplink {
	cursor: pointer;
}
.contactpopupbuttonwrapper a:hover {
	color: ff6600;
}
.xxcontactpopupbutton {
	cursor: pointer;
	display: flex;
	justify-content: center;
	align-items: flex-start;
	box-sizing: border-box;
	margin: 36px;
}
.captionbutton {
	background-color: #6797db;
    color: white;
    height: 60px;
    padding-left: 8px;
    padding-right: 8px;
    text-align: center;
    line-height: 60px;
    font-size: 18px;
	border-radius: 5px 0px 0px 5px;
	box-sizing: border-box;
}
.iconbutton {
	background-color: #6797db; 
    /*position: absolute;*/
    color: white;
    width: 60px;
    height: 60px; 
    border-radius: 0 5px 5px 0;
    text-align: center;
    line-height: 60px;
	box-sizing: border-box;
}


/*****************************************/
/***  Contact Page Contact Form       ****/
/*****************************************/
.contactform-container { 
	background-color: #efefef;
	color:#000;
	width: 100%;
	box-sizing: border-box; 
	padding: 36px 72px;
/* leave to default	font-size: 14px;  */
	display: block;
}

@media screen and (max-width:600px) {
	.contactform-container {
		padding: 48px;
/*  leave to default		font-size: 12px;  */
	/* do I need to set a smaller font-size?  */
	}
}

.contactform-container .contents {
	width: 90%;
	max-width: 600px;
	min-width: 230px;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

/*  leave links to page default  .contactform-container a {
	color: #3171cb;
}
.contactform-container a:hover {
	color: #00ff00;
}
*/
.contactform-container .upper {
}

.contactform-container .lower {
/* needed?  padding: 0 15px 15px 15px;  */
}
.contactform-container h2 {
	text-align: center:
}
.contactform-container h2 span {
	font-weight: bold;
}
.contactform-container p {
	text-align: center;
	padding-top: 24px;
	padding-bottom: 0px;
}
.contactform-container p:last-of-type {
	padding-bottom: 24px;
}
.contactform-container a {
	text-decoration: none;
}

.contactform-container label {
	line-height: 2em;
	padding-bottom: 0;
}

.contactform-container input:not(.checkitems) {
  box-sizing: border-box;
	width: 100%;
	height: 2.5em;
	margin-top: 0;
	margin-bottom: 4px;
	padding: 8px;
	background: #ffffff;
	outline: none;
	color: #000;
	border-radius: 6px;
  border-right: solid 1px #000;
	border-top: solid 1px #000;
	border-left: solid 1px #000;
  border-bottom: none;
	transition: all 0.3s ease-in-out;
	 -webkit-transition: all 0.3s ease-in-out;
	 -moz-transition: all 0.3s ease-in-out;
	 -ms-transition: all 0.3s ease-in-out;
}

.contactform-container .checkitems {
  height: auto;
  border-radius: 6px;
  margin-bottom: 4px;
  text-align: center;
}

.contactform-container textarea {
  box-sizing: border-box;
  resize: none;
	 width: 100%;
  margin-left: auto;
  margin-right: auto;
	height: 6em;
	padding: 10px;
	background: #ffffff;
	outline: none;
	color: #000;
  border-radius: 6px;
  border-right: solid 1px #000;
	border-top: solid 1px #000;
	border-left: solid 1px #000;
  border-bottom: none;
	transition: all 0.3s ease-in-out;
	 -webkit-transition: all 0.3s ease-in-out;
	 -moz-transition: all 0.3s ease-in-out;
	 -ms-transition: all 0.3s ease-in-out;
}

.contactform-container .checks {
  box-sizing: border-box;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 4px;
	padding: 15px;
	background: #ffffff;
	outline: none;
	color: #000;
	border-radius: 6px;
	border-right: solid 1px #000;
	border-top: solid 1px #000;
	border-left: solid 1px #000;
  border-bottom: none;
	transition: all 0.3s ease-in-out;
	 -webkit-transition: all 0.3s ease-in-out;
	 -moz-transition: all 0.3s ease-in-out;
	 -ms-transition: all 0.3s ease-in-out;
}

.contactform-container button {
  width: 100%;
  border-radius: 0;
  border: 1px solid black;
  height: 2.5em;
  background-color: #3171cb;
  font-weight: bold;
  color: #000000;
  font-size: 18px;
  cursor: pointer;
  margin-bottom: 4px;
  border-radius: 6px;
}
.contactform-container .resetbtn {
	cursor: pointer;
}

.contactform-container input:required:invalid:not(:placeholder-shown), input:focus:invalid:not(:placeholder-shown) {
	background: url(graphics/circle-exclamation.svg);
	background-size: 16px;
	background-repeat: no-repeat;
	background-position: center right;
	background-color: #ffffff;
}

.contactform-container input:valid {
	background: url(graphics/check.svg);
	background-size: 16px;
	background-repeat: no-repeat;
	background-position: center	right;
	background-color: #ffffff;
}

/*******************************/
/*  end contact popup form CSS */
/*******************************/

.contactpgtop {
	margin: 0;
	padding: 0;
	display: flex;
	justify-content: center;
	align-items: flex-start;
	box-sizing: border-box;
	flex-wrap: wrap;
}

.addresscard {
	margin: 36px 48px;
	box-sizing: border-box;
}

.hourscard {
	width: 375px;
	max-width: 95%;
	/* border: 1px solid black; */
	background-color: #efefef;
	border-radius: 6px;
	box-shadow:0 2px 2px 0 rgba(0,0,0,0.2);
	padding: 12px;
	margin: 36px 48px;
	box-sizing: border-box;
}	
@media (max-width: 600px) {
	.hourscard {
		font-size: 14px;
	}
}

.hourslist ul {
	list-style: none;
	margin-left: 8px;
	padding-left: 0px;
}
.townslistedcontactpage {
	margin-bottom: 72px;
	text-align: center;
}
.townslistedcontactpage ul {
	list-style-type: disc;
	display: inline;
	padding: 0px;
	margin: 0;
}
.townslistedcontactpage li {
	display: inline;
	padding: 0;
	margin: 8px 0px 0px 8px;
}
.townslistedcontactpage li:first-child {
	list-style-type: none;
	margin-left: none;
}

/********************************/
/*****   scroll into view     ***/
/*******************************/
.module {
	overflow: hidden;
}
.come-in {
  transform: translateY(200px);
  animation: come-in 0.8s ease forwards;
}
/*.come-in:nth-child(odd) {
  animation-duration: 0.6s;
}*/

@keyframes come-in {
  to { transform: translateY(0); }
}


/***********************************************************
    generic flex container for several images/icons/etc
************************************************************/
.flexcontainer {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	padding: 36px;
}

/*******************************************************
     rounded card pictures
********************************************************/
.cardpics {
	width: 360px;
	max-width: 95%;
	height: 504px;
	/* max-height: 504px; */
	border: none;
	border-width: none;
	border-radius: 6%;
	box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
	box-sizing: content-box;
	margin-right: 24px;
	margin-bottom: 24px; 
}
.cardpics:last-child {
	margin-right: 0px;
}

/********************************************/
/***  team (or any other) photo with overlayed text */
/*************************************************/


.picoverlaysection {
  position: relative;
  box-sizing: border-box;
}

.picoverlaysection img {
  border: none;
  border-width: 0;
  width: 100%;
  max-width: 1500px;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

.overlay {
  position: absolute;
  background: linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 59%, rgba(0, 0, 0, 0.65) 100%));
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, rgba(0, 0, 0, 0)), color-stop(59%, rgba(0, 0, 0, 0)), color-stop(100%, rgba(0, 0, 0, 0.65)));
  background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 59%, rgba(0, 0, 0, 0.65) 100%);
  z-index: 1;
  height:100%;  
  top: 0;
  left: 0;
  width: 100%;
  opacity: 100;
  transition: opacity .5s ease-out;
  box-sizing: border-box;
}

.picoverlaysection:hover .overlay {
  opacity: 0;
}

.picoverlaysection .overlay {
	box-sizing: border-box;
}

/* use flex-caption for this caption and it will match the style of the top sliders  */



/*********************************/
/*  misc still used from w3.css  */
/*********************************/

.w3-tiny{font-size:10px!important}
.w3-small{font-size:12px!important}
.w3-medium{font-size:15px!important}
.w3-large{font-size:18px!important}
.w3-xlarge{font-size:24px!important}
.w3-xxlarge{font-size:36px!important}
.w3-xxxlarge{font-size:48px!important}
.w3-jumbo{font-size:64px!important}
.w3-xjumbo{font-size+6
:85px!important}
.w3-xxjumbo{font-size:120px!important}

.w3-show{display:block!important;}
.w3-hide{display:none!important}
@media (max-width:600px){.w3-hide-small{display:none!important}}
@media (min-width:992.01px){.w3-hide-large{display:none!important}}
@media (max-width:992px) and (min-width:600.01px){.w3-hide-medium{display:none!important}}

.w3-red {color: red;}
.w3-white {color: white;}


