/* ---------- MAIN BODY ---------- */
* {
  margin: 0;
  padding: 0;
}
img {
  margin: 0;
  border: 0;
}
body {
  font-family: 'Montserrat', sans-serif;
  color: #222;
  font-size: 0.9em;
  font-weight: 300;
    line-height: 1.9EM;
}
#clear {
  clear: both;
}
a {
  text-decoration: none;
}
a:visited {
  text-decoration: none;
}
.grey {
  color: #ccc;
}
.red{
	color:red;
}
.primary {
  color: #5485a6;
}
.secondary {
  color: #ffb701;
}
.quirk {
  width: max-content;
  padding-bottom: 10px;
}
li.tick {
  list-style-type: none;
  background: url(../images/tick.png) top left no-repeat;
  padding-left: 60px;
  min-height: 40px;
  background-size: 25px;
}
li.tick-2 {
  list-style-type: none;
  background: url(../images/tick-2.png) top left no-repeat;
  padding-left: 60px;
  min-height: 40px;
  background-size: 25px;
}
/* ---------- MOBILE MENU ---------- */
#top-nav-menu {
  display: none;
}
#top-nav-menu img, #menu img {
  -moz-transform: scale(0.5);
  -webkit-transform: scale(0.5);
  transform: scale(0.5);
}
#menu a {
  color: #5485a6;
}
#menu {
  display: none;
  z-index: 100;
  width: 100%;
  position: fixed;
  top: 0;
  background: #fff;
  text-align: center;
  line-height: 3em;
  box-shadow: 0 2px 10px #666;
}
#menu hr, #section-1-content hr, #section-2-content hr, #section-3-content hr, #section-4-content hr {
  width: 80%;
  margin-left: 10%;
  border: 0;
  height: 1px;
  background-color: #eee;
}
/* ---------- BANNER AND CONTENTS ---------- */
#banner-home, #banner-about, #banner-services, #banner-contact, #banner-reviews {
  width: 100%;
  background-size: cover;
  position: relative;
  color: #fff;
  text-align: left;
}
#banner-home {
  background: url("../images/banner-background-home.jpg") center;
  min-height: 600px;
	text-align: center;
}
#banner-about {
  background: url("../images/banner-background-about.jpg") center left;
background-position:left;
}
#banner-services {
  background: url("../images/banner-background-test.jpg") center;
}
#banner-reviews {
  background: url("../images/banner-background-reviews.jpg") right;
}
#banner-contact {
  background: url("../images/banner-background-contact.jpg") center left;
}
#banner-home-content {
  margin:0 auto;
  width: 90%;
  max-width: 1200px;
  padding: 160px 5% 80px 5%;
  text-align: left;
  position: relative;
  font-size: 0.9em;
  line-height: 1.5em;
}
#banner-about-content, #banner-services-content {
  margin: 0 auto;
  width: 90%;
  max-width: 1200px;
  padding: 50px 5%;
  text-align: left;
  position: relative;
  font-size: 0.9em;
  line-height: 1.5em;
}
#banner-nav {
  display: flex;
  justify-content: space-between;
  background: #fff;
  padding: 30px;
  align-items: center;
}
.cta-group {
  display: flex;
  column-gap: 40px;
  margin-top: 50px;
  align-self: top;
  text-align: center;
}
.cta-group img {
  max-height: 30px;
  margin-left: 20px;
  align-self: top;
}
.banner-cta {
  color: #fff;
  font-size: 0.7em;
  font-weight: 700;
  padding: 15px 60px;
  border: solid 1px #5485a6;
  background-color: #5485a6;
}
.banner-cta:hover {
  color: #5485a6;
  border: solid 1px #fff;
  background-color: #fff;
}
.banner-cta-2 {
  color: #fff;
  font-size: 0.7em;
  font-weight: 700;
  padding: 15px 60px;
  border: solid 1px #fff;
}
.banner-cta-2:hover {
  color: #5485a6;
  border: solid 1px #fff;
  background-color: #fff;
}
.banner-cta-3 {
  color: #FF9103;
  background-color: #172931;
  font-size: 0.7em;
  font-weight: 700;
  padding: 15px 60px;
  border: solid 1px #FF9103;
}
.banner-cta-4 {
  color: #172931;
  background-color: #FF9103;
  font-size: 0.7em;
  font-weight: 700;
  padding: 15px 60px;
  border: solid 1px #172931;
}
.banner-cta-3:hover, .banner-cta-4:hover {
  color: #ffb701;
  border: solid 1px #fff;
  background-color: #fff;
}
#banner-home-content h1, #banner-about-content h1, #banner-services-content h1 {
  font-weight: 800;
  font-size: 4em;
  line-height: normal;
}
#banner-home-content h2, #banner-about-content h2, #banner-services-content h2 {
  font-weight: 700;
  font-size: 1.8em;
  line-height: normal;
  color: #ffb701;
}
/* ---------- LOGO ---------- */
#logo {
  text-align: left;
}
#logo img, #footer img {
  max-height: 30px;
}
/* ---------- NAVIGATION ---------- */
#top-nav {
  display: flex;
}
#nav {
  vertical-align: middle;
  font-size: 0.7em;
  font-weight: 500;
}
#nav a {
  margin: 15px;
  color: #202b2c;
}
#nav a:hover {
  color: #5485a6;
}
#nav a.nav-cta {
  color: #fff;
  font-size: 0.7em;
  font-weight: 700;
  padding: 10px 35px;
  border: solid 1px #5485a6;
  background-color: #5485a6;
  align-self: center;
  text-align: center;
}
#nav a.nav-cta:hover {
  color: #5485a6;
  border: solid 1px #fff;
  background-color: #fff;
}
/* ---------- SOCIAL MEDIA ---------- */
#phone {
  text-align: right;
  background: #ff9202;
  color: #fff;
  font-size: 0.8em;
  padding: 10px 20px;
  align-items: center;
  width: 35%;
}
#social {
  text-align: right;
  background: #3c5a68;
  color: #fff;
  font-size: 0.8em;
  padding: 10px;
  align-items: center;
  flex: 1;
}
#social a {
  color: #fff;
}
#social a:hover {
  color: #5485a6;
}
#footer-social {
  vertical-align: middle;
  text-align: left;
}
#phone img, #social img {
  max-width: 15px;
  margin: 0 20px;
}
#footer-social img {
  max-width: 15px;
}
/* ---------- WRAPPERS ---------- */
#wrapper-counters {
  width: 100%;
}
#wrapper-counters-about {
  width: 100%;
  background:#FFB701;
}
#wrapper-counters h1 {
  font-weight: 700;
  font-size: 2em;
  color: #ffb701;
}
#wrapper-counters-about h1 {
  font-weight: 700;
  font-size: 2em;
  color: #fff;
}
#wrapper-intro {
  width: 100%;
}
#wrapper-about, #wrapper-general-handyman-jobs, #wrapper-garden-outdoors, #wrapper-flooring, #wrapper-doors-windows, #wrapper-kitchen-bathroom-plumbing, #wrapper-building{
width: 100%;
background-size: cover;
height:400px;
}
#wrapper-about{
background:url("../images/about.jpg") center;
}
#wrapper-general-handyman-jobs{
background:url("../images/general-handyman-jobs.jpg") center;
}
#wrapper-garden-outdoors{
background:url("../images/garden-outdoors.jpg") center;
}
#wrapper-flooring{
background:url("../images/flooring.jpg") center;
}
#wrapper-doors-windows{
background:url("../images/doors-windows.jpg") center;
}
#wrapper-kitchen-bathroom-plumbing{
background:url("../images/kitchen-bathroom-plumbing.jpg") center;
}
#wrapper-building{
background:url("../images/building.jpg") center;
}
#wrapper-services {
  background: #ff9202;
  background-size: cover;
  display: flex;
}
#wrapper-services-page{
  width: 100%;
}
#wrapper-client-testimonials {
  background: #3c5a68;
  background-size: cover;
  padding: 50px 0;
  text-align: center;
  position: relative;
}
/* ---------- CONTENT ---------- */
#section-counters-content, #section-intro-content, #section-about-content{
  margin: 0 auto;
  width: 90%;
  max-width: 1200px;
  padding: 25px 5%;
  display: flex;
  justify-content: space-around;
}
#section-contact-content {
  margin: 0 auto;
  width: 90%;
  max-width: 1200px;
  padding: 75px 5%;
  justify-content: space-around;
}
#section-contact-content a{color:#FF9102}
#section-intro-content {
  line-height: 1.5em;
}
#intro {
  text-align: left;
  padding: 30px;
  margin-left: 50px;
}
#intro .quirk {
  color: #FFB701;
  text-align: left;
}
.about-data {
  text-align: center;
}
.about-data img {
  max-width: 40px;
}
#section-services-content {
  width: 60%;
  max-width: 1200px;
  padding: 75px 5%;
  color: #172931;
}
#section-services-image {
  background: url("../images/services-background-home.jpg") left;
  background-size: cover;
  min-width: 50%;
  min-height: 300px;
}
.half-content {
  width: 40%;
  max-width: 600px;
}
#section-intro-content img {
  max-width: 350px;
  align-self: center;
}
#section-client-testimonials-content {
  margin: 0 auto;
  padding: 30px;
  color: #fff;
}
#section-services-page-content {
	margin: 0 auto;
	text-align: left;
	padding: 30px;
	display:flex;
	flex-wrap: wrap;
	gap:10px;
}
.service{
	width:30%;
	margin:0 auto;
	font-size: 0em;
	display:flex;
	flex-wrap: wrap;
	align-items: stretch;
}
.service:hover .service-text{
	background:#222;
	color:#fff;
}
.service:hover .service-image img{
	opacity: 0.2;
}
.service-image{
	background:url("../images/service-background.jpg") center;
	background-size: cover;
}
.service-image img{
	max-width: 100%;
	transition: 0.4s;
}
.service-text{
	height:120px;
	background:#FFB701;
	padding:20px;
	text-align: center;
	font-size: 12px;
	transition: 0.4s;
}
.service a:visited{
	color:#222;
}
#section-client-testimonials-content img {
  max-width: 90px;
}
#section-intro-content h1 {
  font-weight: 700;
  font-size: 3em;
  margin-bottom: 40px;
  line-height: normal;
}
#section-services-content h1 {
  font-weight: 700;
  font-size: 3em;
  color: #fff;
}
#section-services-content h2 {
  color: #fff;
}
#section-counters-content h2 {
  font-weight: 700;
  font-size: 0.8em;
}
#section-services-page-content h2{
	color:#FF9102;
}
#section-services-page-content .service-text h2{
	color:#fff;
}
a.tel {
  color: #2370D8;
}
.cta-1 {
  color: #fff;
  font-weight: 500;
  padding: 15px 40px;
  background-color: #ef7347;
}
.cta-1:hover {
  color: #ef7347;
  background-color: #fff;
}
.testimonials-wrapper {
  display: flex;
  flex-flow: row wrap;
  justify-content: space-around;
  align-items: flex-start;
}
.testimonial-item {
  border: solid 1px #eee;
  max-width: 25%;
  padding: 30px 2%;
  margin: 15px 1%;
  text-align: center;
  box-shadow: 2px 2px 15px #efefef;
  flex-grow: 1;
}
.testimonial-item img {
  max-width: 100px;
}
/* ---------- TESTIMONIALS SLIDER ---------- */
.testimonials-container {
  max-width: 100%;
}
.container {
  width: 100%;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
.testimonial {
  position: relative;
  max-width: 900px;
  width: 100%;
  overflow: hidden;
}
.testimonial img {
  width: 150px;
}
.testimonial .slide {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  row-gap: 30px;
  height: 100%;
  width: 100%;
}
.slide p {
  text-align: center;
  padding: 0 10px;
  font-size: 14px;
  font-weight: 400;
}
.slide .quote-icon {
  font-size: 30px;
  color: #5FCED0;
}
.slide .details {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.details .name {
  font-size: 14px;
  font-weight: 600;
  color: #FF9102;
}
.details .job {
  font-size: 12px;
  font-weight: 400;
}
/* swiper button css */
.nav-btn {
  height: 40px;
  width: 40px;
  border-radius: 50%;
  transform: translateY(30px);
  background-color: rgba(0, 0, 0, 0.1);
  transition: 0.2s;
}
.nav-btn:hover {
  background-color: rgba(0, 0, 0, 0.2);
}
.nav-btn::after, .nav-btn::before {
  font-size: 20px;
  color: #fff;
}
.swiper-pagination-bullet {
  background-color: rgba(0, 0, 0, 0.8);
}
.swiper-pagination-bullet-active {
  background-color: #5FCED0;
}
/* ---------- FOOTER---------- */
#footer {
  font-size: 0.7em;
  text-align: left;
  background: #172931;
  );
  background-size: cover;
  padding: 35px 5%;
  color: #fff;
  line-height: 2em;
}
#footer-content {
  display: flex;
  justify-content: space-between;
}
#footer a {
  color: #fff;
}
#footer a:hover {
  color: #ccc;
}
#footer-content-left {
  align-self: center;
}
#footer-social img {}
#nav-contact-footer {}
#nav-contact-footer img, #footer-content-left img {
  max-height: 15px;
  margin-right: 10px;
  vertical-align: middle;
}
#footer-content-middle {
  align-self: center;
}
#footer-content-right {
  align-self: center;
}
/* ---------- FORM---------- */
.form-section {
  background: #efefef;
  padding: 30px 5% 30px 5%;
  position: relative;
  text-align: center;
}
.DD, .MM {
  width: 50px;
}
.YYYY {
  width: 100px;
}
select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
label {
  width: 200px;
  border: none;
}
textarea, input, .packages {
  font-family: 'Montserrat', sans-serif;
  color: #444;
  font-size: 1em;
  background: #fff;
  font-weight: 200;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
textarea {
  width: 90%;
  height: 100px;
  padding: 10px;
  border: none;
}
input, .packages {
  width: 90%;
  max-width: 300px;
  height: 35px;
  padding: 5px 5px 5px 5px;
  margin: 15px;
  border: none;
}
/* The container */
.form-container {
  width: 300px;
  max-width: 90%;
  margin: 0 auto;
  display: block;
  position: relative;
  padding-left: 35px;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
/* Hide the browser's default checkbox */
.form-container input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
  height: 0;
  width: 0;
}
/* Create a custom checkbox */
.checkmark {
  position: absolute;
  top: 0;
  left: 0;
  height: 25px;
  width: 25px;
  background-color: #fff;
}
/* On mouse-over, add a grey background color */
.form-container:hover input ~ .checkmark {
  background-color: #ccc;
}
/* When the checkbox is checked, add a blue background */
.form-container input:checked ~ .checkmark {
  background-color: #5485a6;
}
/* Create the checkmark/indicator (hidden when not checked) */
.checkmark:after {
  content: "";
  position: absolute;
  display: none;
}
/* Show the checkmark when checked */
.form-container input:checked ~ .checkmark:after {
  display: block;
}
/* Style the checkmark/indicator */
.form-container .checkmark:after {
  left: 9px;
  top: 5px;
  width: 5px;
  height: 10px;
  border: solid white;
  border-width: 0 3px 3px 0;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}
.submit {
  width: 90%;
  max-width: 295px;
  height: 35px;
  padding: 15px 15px 30px 15px;
  color: #fff;
  background-color: #5485a6;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.submit:hover {
  background-color: #fff;
  color: #5485a6;
}
/* ---------- TABLET RESPONSIVENESS ---------- */
@media screen and (min-width:715px) and (max-width:1160px) {
  #logo, #nav, #nav-02, #social {}
  #banner-home {
    background-size: cover;
  }
  #banner-nav {
    margin-bottom: 40px;
  }
  #banner-home-content {
	padding: 20px 5%;
	line-height: 1.5em;
  }
  #banner-home-content h1 {
    font-size: 2.2em;
  }
  #wrapper-intro {}
  #intro-image, #intro {
    width: auto;
    text-align: center;
    padding: 0;
    margin: 0 auto;
  }
  #intro-header {
    justify-content: space-around;
    margin: 0 auto;
  }
  #section-intro-content {
    flex-direction: column;
  }
  #section-intro-content, #section-services-content {
    width: 90%;
    padding: 40px 5%;
    line-height: 1.5em;
    margin: 0 auto;
  }
  #wrapper-services {
    flex-direction: column;
  }
  #section-services-content {
    width: 90%;
    padding: 55px 5%;
  }
	.service{
		width:45%;
	}
  #section-services-image {
    width: 100%;
  }
  .testimonial-item {
    max-width: 42%;
  }
  .cta-group {
    justify-content: space-between;
  }
  #footer-content-left, #footer-content-middle, #footer-content-right {
    width: 90%;
    text-align: center;
  }
  #footer-content-middle {
    margin-top: 20px;
  }
}
/* ---------- MOBILE RESPONSIVENESS ---------- */
@media screen and (max-width:714px) {
  #top-nav-menu {
    z-index: 100;
    display: inline;
    position: fixed;
    top: 65px;
    left: 0;
    padding: 5px;
    background: rgba(255, 255, 255, .85);
  }
  #nav, #nav-02, #social, #top-nav {
    display: none;
  }
  #logo {
    width: 90%;
    text-align: center;
    padding: 10px 5%;
  }
  #banner-home {
    background-size: cover;
  }
  #banner-home-content {
    padding: 20px 5% 40px 5%;
    line-height: 1.7em;
  }
  #banner-home-content h1 {
    font-size: 3em;
  }
  #banner-nav {
    margin-bottom: 20px;
  }
  #section-counters-content {
    flex-wrap: wrap;
    column-count: 2;
    row-gap: 20px;
  }
  .about-data {
    width: 50%;
  }
  #section-intro-content {
    flex-direction: column;
  }
  #intro-image, #intro {
    width: 90%;
    text-align: center;
    padding: 40px 5%;
    margin-left: 0;
  }
  #wrapper-services {
    flex-direction: column;
  }
	#wrapper-about, #wrapper-general-handyman-jobs, #wrapper-garden-outdoors, #wrapper-flooring, #wrapper-doors-windows, #wrapper-kitchen-bathroom-plumbing, #wrapper-building{
		height:200px;
		background-size: cover;
}
  #section-services-content {
    width: 90%;
    padding: 55px 5%;
  }
  #section-client-testimonials-content {
    width: 90%;
    padding: 0px 5%;
  }
  .half-content {
    max-width: none;
    width: 90%;
  }
  #section-1-content h1 {
    line-height: 1.2em;
  }
  .testimonial-item {
    max-width: 90%;
  }
  .cta-group {
    flex-direction: column;
    row-gap: 20px;
  }
  #intro {
    width: 90%;
    text-align: left;
    padding: 40px 5%;
  }
  #intro-header {
    justify-content: space-around;
  }
  #section-intro-content img {
    max-width: 90%;
    object-fit: contain;
  }
	/*-- POSSIBLY-CHANGE --*/
	.service{
		width:45%;
		display:block;
		
	}
	.service-image img{
		width:100%;
		max-width: none;
	}
	.service-text{
		height: auto;
	}
  #footer-content {
    display: flex;
    justify-content: space-between;
    flex-direction: column;
  }
  #footer-content-left, #footer-content-middle, #footer-content-right {
    width: 100%;
    text-align: center;
  }
  #footer-content-middle {
    margin: 40px 0;
  }
  #footer-social {
    width: 100%;
    text-align: center;
  }
  #footer-social img {
    margin: 0 20px;
  }
  .slide p {
    padding: 0 20px;
  }
  .nav-btn {
    display: none;
  }
  input, .submit {
    max-width: none;
  }
}
/* ---------- PRINT ---------- */
@media print {
  #footer, #header, #menu {
    display: none
  }
  body {
    font: 12pt georgia, serif
  }
  h1 {
    font-size: 18pt
  }
  h2 {
    font-size: 16pt;
    color: #000
  }
}