@font-face {
  font-family: Roxie Rossa;
  src: url('../fonts/Roxie-rossa.otf') format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root {
  --white-75: #ffffffbf;
  --white: #fff;
  --white-90: #ffffffe6;
  --orange: #ff8400;
  --black: #000;
  --white-20: #fff3;
  --black-40: #0006;
  --black-60: #0009;
  --white-40: #fff6;
  --trans: #3898ec00;
  --white-60: #fff9;
  --white-80: #fffc;
  --white-10: #ffffff1a;
  --orange-40: #ff840066;
  --orange-80: #ff8400cc;
  --black-75: #000000bf;
  --black-90: #000000e6;
  --black-10: #0000001a;
  --black-25: #00000040;
}

.w-backgroundvideo-backgroundvideoplaypausebutton:focus-visible {
  outline-offset: 2px;
  border-radius: 50%;
  outline: 2px solid #3b79c3;
}

body {
  color: var(--white-75);
  font-family: Arial, Helvetica Neue, Helvetica, sans-serif;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.25rem;
}

h1 {
  color: var(--white);
  margin-top: 20px;
  margin-bottom: 10px;
  font-family: 'Franklin Gothic Medium', 'Arial Narrow Bold', Arial, sans-serif;
  font-size: 4rem;
  font-weight: 700;
  line-height: 4.25rem;
  letter-spacing: -0.02em;
}

h2 {
  z-index: 2;
  color: var(--white-90);
  margin-top: 20px;
  margin-bottom: 10px;
  font-family: 'Franklin Gothic Medium', 'Arial Narrow Bold', Arial, sans-serif;
  font-size: 3rem;
  font-weight: 700;
  line-height: 3.25rem;
  letter-spacing: -0.02em;
  position: relative;
}

h3 {
  color: var(--white-90);
  margin-top: 20px;
  margin-bottom: 10px;
  font-family: 'Franklin Gothic Medium', 'Arial Narrow Bold', Arial, sans-serif;
  font-size: 3rem;
  font-weight: 700;
  line-height: 3.25rem;
  letter-spacing: -0.02em;
}

h4 {
  color: var(--white);
  margin-top: 10px;
  margin-bottom: 10px;
  font-family: 'Franklin Gothic Medium', 'Arial Narrow Bold', Arial, sans-serif;
  font-size: 3rem;
  font-weight: 700;
  line-height: 3.25rem;
  letter-spacing: -0.02em;
}

h5, h6 {
  margin-top: 10px;
  margin-bottom: 10px;
  font-family: 'Franklin Gothic Medium', 'Arial Narrow Bold', Arial, sans-serif;
  font-size: 2rem;
  font-weight: 700;
  line-height: 2.25rem;
  letter-spacing: -0.02em;
}

p {
  z-index: 2;
  color: #bfbfbf;
  margin-top: 10px;
  margin-bottom: 10px;
  position: relative;
}

a {
  color: var(--orange);
  text-decoration: none;
}

img {
  border-radius: 7px;
  max-width: 100%;
  display: inline-block;
}

.body-1 {
  background-color: #1a1a1a;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  min-width: 100vw;
  max-width: 100vw;
  padding-top: 10px;
  display: flex;
}

.navigation {
  z-index: 9999;
  border: 1px solid var(--white-20);
  background-color: #1a1a1a80;
  -webkit-backdrop-filter: blur(5px);
  backdrop-filter: blur(5px);
  border-radius: 20px;
  flex-flow: row;
  justify-content: center;
  align-items: center;
  width: 95vw;
  height: 10vh;
  display: flex;
  position: fixed;
}

.desktop-menu {
  z-index: 3;
  justify-content: space-between;
  align-items: center;
  width: 100vw;
  max-width: 100%;
  height: 100%;
  padding-left: 5%;
  padding-right: 5%;
  display: flex;
  position: relative;
}

.hero-section {
  justify-content: space-between;
  align-items: center;
  width: 90%;
  min-height: 50vh;
  margin-top: 10vh;
  display: flex;
}

.hero-section.home-hero-section {
  border-radius: 5px;
  justify-content: center;
  align-items: center;
  width: 98%;
  height: 80vh;
  margin-top: 0;
  padding-left: 5%;
  overflow: hidden;
}

.section {
  flex-flow: row;
  justify-content: space-around;
  align-items: center;
  width: 90%;
  min-height: 50vh;
  padding-top: 10vh;
  padding-bottom: 10vh;
  display: flex;
}

.section.home-id-section {
  flex-flow: row;
  justify-content: space-between;
  align-items: center;
  width: 95%;
  min-height: auto;
  padding-bottom: 5vh;
}

.section.home-hover-services {
  justify-content: center;
  align-items: flex-start;
  width: 95vw;
  min-height: 50vh;
  margin-top: 0;
  padding-top: 0;
}

.section.footer {
  border-top: 1px solid var(--orange);
  background-image: linear-gradient(#0009, #0009), url('../images/Elements-Landscaping-Team_1.avif');
  background-position: 0 0, 50%;
  background-size: auto, cover;
  background-attachment: scroll, fixed;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 90vh;
  margin-bottom: 0;
  padding: 5vh 5vw 0;
  position: relative;
  overflow: hidden;
}

.section.form-component {
  justify-content: space-around;
  align-items: center;
  width: 100%;
}

.section.featured-service {
  justify-content: space-between;
  align-items: stretch;
  width: 95%;
}

.section.review-section {
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  min-height: 200vh;
  margin-top: 10vh;
  position: relative;
}

.section.service-gal {
  border: 1px solid var(--black-60);
  border-radius: 20px;
  flex-flow: row;
  flex: none;
  justify-content: flex-end;
  align-items: center;
  width: 95%;
  height: 75vh;
  margin-top: 5vh;
  margin-bottom: 10vh;
  padding-top: 0;
  padding-bottom: 0;
  overflow: hidden;
}

.section.feature {
  border: 1px solid var(--white-20);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  border-radius: 20px;
  justify-content: space-around;
  align-items: center;
  width: 95%;
  margin-bottom: 20px;
  transition: transform 1s cubic-bezier(.19, 1, .22, 1), border-color 1s cubic-bezier(.19, 1, .22, 1);
}

.section.feature:hover {
  border: 1px solid var(--orange);
  transform: scale(1.01);
}

.section.service-id {
  justify-content: flex-start;
  align-items: flex-start;
  display: none;
}

.section.about-feature {
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
}

.section.blog-directory {
  width: 100%;
  display: none;
}

.section.blog-home-section {
  border-right: 1px solid var(--white-40);
  border-left: 1px solid var(--white-40);
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
}

.section.calculator {
  background-color: #1a1a1a;
  justify-content: space-around;
  align-items: flex-start;
  width: 95%;
  min-height: 80vh;
  padding-top: 20vh;
  padding-bottom: 15vh;
}

.nav-logo {
  width: 50px;
  margin-right: 20px;
  transition: transform .65s cubic-bezier(.19, 1, .22, 1);
}

.nav-logo:hover {
  transform: scale(1.05);
}

.nav-logo-link {
  justify-content: center;
  align-items: center;
  display: flex;
}

.nav-typemark {
  color: var(--white-75);
  font-family: Roxie Rossa, Verdana, sans-serif;
  font-size: 1.5rem;
  line-height: 1.75rem;
  transition: color .65s cubic-bezier(.19, 1, .22, 1), transform .65s cubic-bezier(.19, 1, .22, 1);
}

.nav-typemark:hover {
  color: var(--white);
  transform: scale(1.05);
}

.h1 {
  font-size: 5rem;
  line-height: 5.25rem;
  position: relative;
}

.h1.service-h1 {
  z-index: 2;
  text-align: center;
  font-size: 4rem;
  line-height: 4.25rem;
}

.h1.h1-about {
  margin-top: 40px;
  margin-bottom: 40px;
}

.h1.calculator-h1 {
  padding-left: 2.5rem;
}

.button-1 {
  border: 1px solid var(--trans);
  background-color: var(--trans);
  color: var(--white-75);
  font-family: Arial, Helvetica Neue, Helvetica, sans-serif;
  transition: all .625s cubic-bezier(.19, 1, .22, 1);
}

.button-1:hover {
  border: 1px solid var(--orange);
  color: var(--white);
}

.holder {
  margin-top: 10px;
  margin-bottom: 10px;
  transition: transform .65s cubic-bezier(.19, 1, .22, 1);
  position: relative;
}

.holder:hover {
  background-color: #1a1a1a00;
  transform: scale(1.1);
}

.holder-accent {
  border-top: 1px solid var(--orange);
  border-left: 1px solid var(--orange);
  border-radius: 0;
  width: 5px;
  height: 5px;
  position: absolute;
  inset: 0% auto auto 0%;
}

.holder-accent.tr {
  border-right: 1px solid var(--orange);
  border-left-style: none;
  inset: 0% 0% auto auto;
}

.holder-accent.br {
  border-style: none solid solid none;
  border-right-width: 1px;
  border-right-color: var(--orange);
  border-bottom-width: 1px;
  border-bottom-color: var(--orange);
  inset: auto 0% 0% auto;
}

.holder-accent.bl {
  border-bottom: 1px solid var(--orange);
  border-top-style: none;
  inset: auto auto 0% 0%;
}

.home-hero-div {
  z-index: 10;
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  padding-right: 20px;
  display: flex;
  position: relative;
}

.p1 {
  max-width: 90%;
  margin-top: 10px;
  margin-bottom: 10px;
}

.p1.max-75-100 {
  width: 75%;
  max-width: 75%;
}

.h2 {
  color: var(--white-90);
  margin-top: 0;
  margin-bottom: 0;
  font-weight: 400;
  line-height: 3.25rem;
}

.h2.coming-soon {
  color: var(--white-40);
  font-family: Arial, Helvetica Neue, Helvetica, sans-serif;
  font-size: 1rem;
  line-height: 1rem;
}

.div-50 {
  flex-flow: column;
  flex: none;
  justify-content: center;
  align-items: flex-start;
  width: 50%;
  display: flex;
}

.div-50.gallery-content {
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  background-color: #0003;
  height: 100%;
  padding: 40px;
}

.div-50.blog-home-heading-div {
  display: none;
}

.div-50.bordered {
  border-radius: 20px;
  padding: 20px;
}

.particles-js {
  z-index: -1;
  background-image: linear-gradient(180deg, black 50%, var(--trans)), linear-gradient(90deg, var(--trans), #ff840080 50%, var(--trans));
  width: 100%;
  height: 100%;
  position: fixed;
  inset: 0%;
}

.hero-video {
  z-index: 1;
  width: 60%;
  position: relative;
}

.hero-video.home-hero {
  border-radius: 5px;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  height: 100%;
  margin-top: 0;
  display: flex;
  position: absolute;
  inset: 0%;
}

.hover-services-block {
  flex-flow: wrap;
  justify-content: flex-end;
  align-items: center;
  width: 25%;
  margin-top: 20px;
  display: flex;
}

.hover-tile {
  z-index: 1;
  border: 1px solid var(--white-60);
  color: var(--white-75);
  border-radius: 20px;
  justify-content: flex-start;
  align-items: center;
  height: 20%;
  margin-top: 10px;
  margin-bottom: 10px;
  margin-right: 10px;
  padding: 7px 15px;
  transition: all .525s cubic-bezier(.19, 1, .22, 1);
  display: flex;
  position: relative;
}

.hover-tile:hover {
  z-index: 2;
  border-color: var(--orange);
  color: var(--orange);
}

.hover-tile-text {
  text-align: center;
  font-family: Arial, Helvetica Neue, Helvetica, sans-serif;
  font-size: 1rem;
  line-height: 1.75rem;
}

.side-photos-div {
  flex-flow: column;
  width: 75%;
  min-height: 50vh;
  display: flex;
  position: relative;
}

.side-image {
  z-index: 1;
  object-fit: cover;
  border-radius: 7px;
  width: 100%;
  margin-bottom: 10px;
  transition: transform .5s cubic-bezier(.19, 1, .22, 1), opacity .5s cubic-bezier(.19, 1, .22, 1);
  display: block;
  position: relative;
  top: auto;
}

.footer-typemark {
  color: var(--white);
  font-family: Roxie Rossa, Verdana, sans-serif;
  font-size: 20vw;
  line-height: 1;
  display: block;
}

.footer-typemark.mobile-typemark {
  display: none;
}

.footer-div {
  justify-content: space-around;
  display: flex;
}

.footer-link-holder {
  z-index: 50;
  flex-flow: column;
  justify-content: space-around;
  align-items: center;
  max-height: 30vh;
  display: flex;
  position: relative;
}

.footer-link {
  color: var(--white-75);
  text-align: center;
  margin: 10px 20px;
  padding: 10px;
  line-height: 1.5rem;
}

.wide-div {
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  display: flex;
}

.wide-div.horizontal {
  text-align: center;
  flex-flow: column;
  justify-content: space-between;
  align-items: center;
}

.pool-marquee-image {
  border-radius: 20px;
  width: 48%;
}

.pool-marquee-image.show-mobile {
  display: none;
}

.pool-marquee-image.show-desktop {
  display: block;
}

.copyright {
  text-align: center;
  padding-top: 20px;
  padding-bottom: 20px;
  position: absolute;
  inset: auto 0% 0%;
}

.tabs-content {
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  padding: 0 20px 20px;
  display: none;
}

.featured-service-word {
  color: var(--orange);
  letter-spacing: 3px;
  margin-bottom: 10px;
  font-size: .7rem;
}

.form-block {
  width: 50%;
  padding: 40px;
  transition: all .75s cubic-bezier(.19, 1, .22, 1);
  display: block;
}

.form-1 {
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  display: flex;
}

.field {
  border: 1px solid var(--white-60);
  background-color: var(--white-10);
  border-radius: 5px;
  font-family: Arial, Helvetica Neue, Helvetica, sans-serif;
  line-height: 1.4;
  display: block;
}

.field:hover {
  border-color: var(--orange);
  background-color: #ffffff1a;
}

.field.bigger-field {
  min-height: 150px;
}

.button {
  border: 1px solid var(--white-60);
  color: var(--white-75);
  background-color: #3898ec00;
  border-radius: 5px;
  padding-top: 5px;
  padding-bottom: 5px;
}

.button:hover {
  border-color: var(--orange);
}

.button.margin-20-top {
  margin-top: 20px;
  padding-top: 10px;
  padding-bottom: 10px;
}

.h3.form-heading {
  color: var(--white-90);
  margin-top: 0;
}

.h3.home-review-h3 {
  text-align: center;
  margin-bottom: 10vh;
  position: sticky;
  top: 42%;
}

.form-image {
  width: 50%;
}

.review-author {
  margin-top: 10px;
  margin-bottom: 10px;
  font-weight: 700;
}

._5star {
  width: 150px;
  margin-top: 10px;
  margin-bottom: 10px;
}

.review-block {
  z-index: 5;
  border: 1px solid var(--white-60);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  color: var(--white-75);
  border-radius: 20px;
  width: 300px;
  padding: 20px;
  transition: color .65s cubic-bezier(.19, 1, .22, 1), border-color .65s cubic-bezier(.19, 1, .22, 1);
  position: absolute;
}

.review-block:hover {
  border-color: var(--white-75);
  color: var(--white-90);
}

.review-block.mary-c {
  top: 10%;
  left: 10%;
}

.review-block.tony-b {
  top: 15%;
  right: 15%;
}

.review-block.susan-d {
  color: var(--white-75);
  top: 25%;
  left: 35%;
}

.review-block.debra-m {
  top: 45%;
  right: 10%;
}

.review-block.simone-t {
  top: 65%;
  left: 50%;
}

.review-block.cj-p {
  top: 45%;
  left: 10%;
}

.hero-section {
  margin-top: 12vh;
}

.hero-section.service {
  z-index: 2;
  border-radius: 20px;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 95%;
  min-height: 50vh;
  padding-left: 5vw;
  padding-right: 5vw;
  position: relative;
  overflow: hidden;
}

.hero-section.about {
  flex-flow: column;
}

.hero-section.blog-home {
  border-bottom: 1px solid var(--white-40);
  background-image: linear-gradient(#00000026, #00000026), url('../images/flare--flora.jpg');
  background-position: 0 0, 50%;
  background-size: auto, cover;
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  min-height: 40vh;
  padding-left: 5vw;
  padding-right: 5vw;
}

.hero-section.home-hero {
  border: 1px solid var(--white-20);
  border-radius: 20px;
  width: 95%;
  height: 80vh;
  padding-left: 5vw;
  padding-right: 5vw;
  position: relative;
  overflow: hidden;
}

.footer-list {
  flex-flow: row;
  justify-content: space-between;
  align-items: center;
  display: flex;
}

.hero-img {
  width: 40%;
  margin-left: 40px;
  display: block;
}

.hero-img.abs {
  z-index: -1;
  opacity: .5;
  object-position: 50% 0%;
  width: 100%;
  margin-left: 0;
  display: block;
  position: absolute;
  left: 0%;
  right: 0%;
  overflow: hidden;
}

.gallery-track {
  flex: 1;
  justify-content: flex-end;
  align-items: stretch;
  margin-top: 20px;
  margin-right: 40px;
  display: flex;
  position: relative;
  overflow: visible;
}

.gallery-track.show-desktop {
  margin-top: 20px;
  margin-bottom: 20px;
}

.gallery-track.show-mobile {
  display: none;
}

.gallery-img {
  object-fit: cover;
  flex: none;
  width: 600px;
  margin-left: 20px;
  display: block;
  position: relative;
}

.slider-controller {
  border: 1px solid var(--white-75);
  opacity: .75;
  border-radius: 50%;
  width: 50px;
  height: 50px;
  transition: all .7s cubic-bezier(.19, 1, .22, 1);
}

.slider-controller:hover {
  border-color: var(--orange);
  opacity: 100;
}

.slider-controller.right {
  background-image: url('../images/arrow.png');
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: 30px;
  margin-left: 10px;
}

.slider-controller.left {
  background-image: url('../images/arrow.png');
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: 30px;
  transform: rotate(180deg);
}

.slider-button-holder {
  margin-top: 10px;
}

.feature-img {
  width: 100px;
}

.nav-link {
  color: var(--white-60);
  white-space: nowrap;
  margin-left: 40px;
  margin-right: 40px;
  padding: 10px;
  font-size: .8rem;
  line-height: 1rem;
  transition: color .625s cubic-bezier(.19, 1, .22, 1);
}

.nav-link:hover {
  color: var(--white-80);
}

.nav-link.about-us {
  display: none;
}

.desktop-navlinks {
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.button-2 {
  border: 1px solid var(--white-40);
  background-color: var(--trans);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  color: var(--white-60);
  border-radius: 5px;
  transition: all .525s;
}

.button-2:hover {
  border-color: var(--orange);
  color: var(--orange);
}

.button-2.margin-10-top {
  margin-top: 10px;
}

.button-2.desktop-button {
  margin-left: 40px;
}

.code-embed {
  width: 90vw;
  height: 50vh;
}

.directory {
  width: 30vw;
  height: 100%;
  min-height: 20vh;
}

.customer {
  text-align: left;
  border-radius: 5px;
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  height: 50vh;
  margin-left: 40px;
  margin-right: 40px;
  padding: 20px;
  display: flex;
}

.about-tile-title {
  color: var(--white-80);
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 2rem;
}

.about-tile {
  flex-flow: column;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  margin-top: 40px;
  display: flex;
}

.about-tile-p {
  color: var(--white-60);
}

.div-for-thumbnails {
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  display: flex;
}

.video-thumbnail {
  border: 1px solid var(--trans);
  color: var(--white-60);
  text-align: center;
  border-radius: 5px;
  width: 50vw;
  padding: 40px;
  transition: all .6s cubic-bezier(.075, .82, .165, 1);
}

.video-thumbnail:hover {
  border: 1px solid var(--orange-40);
  background-color: #ff840040;
}

.h4 {
  font-size: 2rem;
  line-height: 2.25rem;
}

.about-div {
  justify-content: space-around;
  align-items: center;
  width: 100%;
  display: flex;
}

.about-pic {
  width: 40vw;
  margin-left: 40px;
  margin-right: 40px;
}

.about-pic.about-show-tablet {
  display: none;
}

.filter-holder {
  justify-content: center;
  align-items: center;
  display: flex;
}

.filter {
  background-color: var(--orange-40);
  opacity: .9;
  color: var(--orange);
  border-radius: 20px;
  margin-left: 20px;
  margin-right: 20px;
  padding: 5px 10px;
  font-size: .8rem;
  line-height: 1rem;
}

.coveror {
  z-index: 3;
  background-color: var(--black-40);
  width: 100%;
  height: 100%;
  display: flex;
  position: absolute;
  inset: 0%;
}

.code-embed-2 {
  color: var(--white-60);
  display: block;
}

.calculator-wrapper {
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 90%;
  margin-top: auto;
  margin-bottom: auto;
  display: flex;
}

.calculator-h1 {
  text-align: left;
  margin-top: 0;
  margin-bottom: 10px;
  padding-left: 20px;
}

.checkbox-field {
  flex-flow: row;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.controller-div, .results-div {
  width: 50%;
  height: 80px;
  display: none;
}

.calc-field-label {
  color: var(--orange-80);
}

.material-type-wrapper {
  display: none;
}

.material-img-wrapper {
  object-fit: cover;
  border-radius: 5px;
  width: 40%;
  height: 150px;
  overflow: hidden;
}

.material-img {
  border-radius: 5px;
  width: 70%;
}

.material-description {
  width: 60%;
}

@media screen and (max-width: 991px) {
  h4 {
    margin-top: 20px;
    font-size: 2rem;
    line-height: 2.25rem;
  }

  .desktop-menu {
    z-index: 889;
  }

  .hero-section.home-hero-section {
    flex-flow: column;
    width: 100%;
    padding-top: 10vh;
    padding-bottom: 10vh;
  }

  .section.home-id-section {
    flex-flow: column;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    padding-top: 0;
    padding-bottom: 0;
  }

  .section.home-hover-services {
    flex-flow: column;
    justify-content: flex-start;
    align-items: center;
    min-height: auto;
    padding-top: 0;
  }

  .section.footer {
    background-image: linear-gradient(#000000bf, #000000bf), url('../images/Walkway-Cranberry.jpg');
    background-size: auto, cover;
    justify-content: center;
    align-items: center;
    height: 110vh;
    padding-top: 10vh;
    padding-bottom: 10vh;
  }

  .section.form-component {
    flex-flow: column;
    padding-top: 10vh;
    padding-bottom: 10vh;
  }

  .section.featured-service {
    flex-flow: column;
  }

  .section.service-gal {
    flex-flow: column;
    justify-content: center;
    align-items: flex-start;
    padding-bottom: 5vh;
  }

  .section.feature {
    flex-flow: column;
    padding-left: 20px;
    padding-right: 20px;
  }

  .section.feature:hover {
    border-color: var(--white-20);
    transform: none;
  }

  .section.calculator {
    flex-flow: column;
    justify-content: space-around;
    align-items: center;
    width: 95%;
  }

  .nav-logo {
    width: 40px;
    margin-right: 10px;
  }

  .h1 {
    font-size: 4rem;
    line-height: 4.25rem;
  }

  .button-1 {
    font-size: .8rem;
  }

  .button-1:hover {
    border-style: solid;
    border-color: var(--trans);
    color: var(--white-75);
  }

  .holder:hover {
    background-color: #1a1a1a00;
    transform: none;
  }

  .p1, .p1.max-75-100 {
    max-width: 100%;
  }

  .h2 {
    font-size: 3rem;
    line-height: 3.75rem;
  }

  .h2.coming-soon {
    text-align: center;
  }

  .div-50 {
    width: 90%;
  }

  .div-50.gallery-content {
    background-color: var(--trans);
    border-left-style: none;
    width: 90%;
    height: auto;
    margin-top: 5vh;
    margin-left: 5vw;
    padding: 0;
  }

  .div-50.feature-div {
    text-align: center;
    justify-content: center;
    align-items: center;
  }

  .div-50.bordered {
    width: 100%;
  }

  .particles-js {
    background-image: linear-gradient(0deg, #ff84004d, #ff840000 25%);
  }

  .hero-video {
    width: 100%;
    margin-top: 40px;
  }

  .hover-services-block {
    justify-content: center;
    align-items: center;
    width: 75vw;
    height: auto;
    min-height: auto;
    margin-top: 20px;
    margin-right: 0;
    padding-left: 5vw;
    padding-right: 5vw;
    display: flex;
    overflow: auto;
  }

  .hover-tile {
    border-width: 1px;
    border-color: var(--white-75);
    color: var(--white-75);
    border-radius: 7px;
    flex: none;
    justify-content: center;
    align-items: center;
    width: auto;
    height: 10%;
    margin-right: 10px;
    padding-top: 10px;
    padding-bottom: 10px;
  }

  .hover-tile:hover {
    border-color: var(--white);
    color: var(--white-75);
    transform: none;
  }

  .hover-tile-text {
    flex: none;
    font-family: Arial, Helvetica Neue, Helvetica, sans-serif;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.25rem;
  }

  .side-photos-div {
    width: 100%;
    margin-top: 20px;
  }

  .footer-typemark {
    margin-top: 0;
    margin-bottom: 0;
    display: none;
  }

  .footer-typemark.mobile-typemark {
    margin-bottom: 40px;
    font-size: 5rem;
    display: block;
  }

  .footer-div {
    flex-flow: column;
    justify-content: center;
    align-items: center;
  }

  .footer-link-holder {
    width: auto;
    max-height: none;
  }

  .footer-link {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  .wide-div.horizontal {
    flex-flow: column;
    width: 100%;
    padding-left: 5vw;
    padding-right: 5vw;
  }

  .pool-marquee-image {
    width: 100%;
    margin-top: 20px;
    margin-bottom: 20px;
    margin-right: 0;
  }

  .pool-marquee-image.show-mobile {
    display: block;
  }

  .pool-marquee-image.show-desktop {
    display: none;
  }

  .copyright {
    padding-left: 20px;
    padding-right: 20px;
  }

  .tabs-content {
    width: 100%;
    padding: 0;
  }

  .form-block {
    width: 90%;
    margin-top: 40px;
    padding: 0;
  }

  .field:hover {
    border-color: var(--white-60);
    background-color: #ffffff0d;
  }

  .button.margin-20-top {
    border-color: var(--orange);
  }

  .h3 {
    color: var(--white-90);
  }

  .h3.form-heading {
    margin-top: 20px;
    font-size: 2rem;
    line-height: 2.25rem;
  }

  .form-image {
    width: 95%;
  }

  .review-block, .review-block:hover {
    color: var(--white-75);
  }

  .review-block.mary-c {
    left: 0%;
  }

  .review-block.tony-b {
    right: 5%;
  }

  .review-block.susan-d {
    top: 30%;
    left: 5%;
  }

  .review-block.debra-m {
    top: 40%;
    right: 0%;
  }

  .review-block.simone-t {
    left: auto;
    right: 5%;
  }

  .review-block.cj-p {
    top: 50%;
    left: 5%;
  }

  .hero-section.service {
    min-height: 75vh;
  }

  .footer-list {
    flex-flow: column;
  }

  .hero-img {
    object-fit: cover;
    border-radius: 0;
    width: 100%;
    margin-left: 0;
  }

  .hero-img.abs {
    height: 100%;
  }

  .gallery-track {
    justify-content: flex-end;
    align-items: stretch;
    margin-right: 0;
  }

  .gallery-track.show-desktop {
    display: none;
  }

  .gallery-track.show-mobile {
    justify-content: flex-start;
    align-items: stretch;
    width: 100%;
    padding-left: 5vw;
    padding-right: 5vw;
    display: flex;
    overflow: auto;
  }

  .gallery-img {
    margin-left: 0;
    margin-right: 20px;
  }

  .slider-button-holder {
    margin-top: 10px;
    display: none;
  }

  .feature-img {
    margin-bottom: 20px;
  }

  .nav-video {
    border-radius: 10px;
    width: 60%;
    height: 300px;
    position: relative;
    top: auto;
  }

  .collection-item {
    justify-content: center;
    align-items: center;
    display: flex;
  }

  .nav-link {
    margin-left: 10px;
    margin-right: 10px;
    font-size: .7rem;
    line-height: .9rem;
  }

  .nav-link:hover {
    color: var(--white-60);
  }

  .desktop-navlinks {
    display: flex;
  }

  .button-2:hover {
    border-color: var(--white-75);
    color: var(--white-75);
  }

  .customer {
    text-align: center;
    justify-content: center;
    align-items: center;
    width: 90%;
    height: auto;
    margin-left: 0;
    margin-right: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .about-tile-title {
    font-size: 1rem;
    line-height: 1.5rem;
  }

  .video-thumbnail {
    border-style: none;
    width: auto;
    margin-top: 5vh;
    margin-bottom: 5vh;
  }

  .video-thumbnail:hover {
    background-color: var(--trans);
    border-style: none;
  }

  .about-div {
    flex-flow: column;
    display: flex;
  }

  .about-pic {
    width: 90%;
    margin-left: 0;
    margin-right: 0;
  }

  .about-pic.about-show-desktop {
    display: none;
  }

  .about-pic.about-show-tablet {
    display: block;
  }

  .calculator-wrapper {
    width: 100%;
    height: 107vh;
  }

  .nav-replacement {
    flex-flow: row;
    justify-content: center;
    align-items: center;
    margin-top: 5%;
    padding: 20px;
    display: none;
    position: absolute;
    inset: 0% 0% auto auto;
  }
}

@media screen and (max-width: 767px) {
  .section.review-section {
    min-height: auto;
  }

  .hover-services-block {
    width: 80vw;
  }

  .hover-tile-text {
    font-size: .8rem;
    line-height: 1rem;
  }

  .h3 {
    font-size: 2rem;
    line-height: 2.25rem;
  }

  .h3.home-review-h3 {
    position: relative;
  }

  .review-block {
    width: 100%;
    margin-top: 10px;
    margin-bottom: 10px;
    position: relative;
  }

  .review-block.mary-c {
    top: auto;
    left: auto;
  }

  .review-block.tony-b {
    top: auto;
    right: auto;
  }

  .review-block.susan-d {
    top: auto;
    left: auto;
  }

  .review-block.debra-m, .review-block.simone-t {
    top: auto;
    right: auto;
  }

  .review-block.cj-p {
    top: auto;
    left: auto;
  }

  .feature-img {
    margin-bottom: 0;
  }

  .calculator-wrapper {
    height: 110vh;
  }

  .calculator-h1 {
    font-size: 1.8rem;
  }

  .nav-replacement {
    margin-top: 0%;
  }
}

@media screen and (max-width: 479px) {
  .desktop-menu {
    justify-content: space-between;
    align-items: center;
  }

  .section.footer {
    height: auto;
    min-height: 100vh;
  }

  .section.review-section {
    margin-top: 0;
    padding-top: 5vh;
    padding-bottom: 5vh;
  }

  .section.feature {
    justify-content: center;
    align-items: center;
  }

  .nav-logo {
    width: 50px;
    margin-right: 0;
    display: block;
  }

  .nav-typemark {
    font-size: 1.5rem;
    display: none;
  }

  .h1 {
    font-size: 3rem;
    line-height: 3.25rem;
  }

  .h1.service-h1 {
    font-size: 3rem;
    line-height: 3.75rem;
  }

  .h1.h1-about {
    font-size: 3rem;
  }

  .button-1 {
    padding: 5px 10px;
  }

  .p1 {
    max-width: 100%;
  }

  .p1.max-75-100 {
    width: auto;
  }

  .h2 {
    font-size: 2rem;
    line-height: 2.25rem;
  }

  .h2.coming-soon {
    font-family: Arial, Helvetica Neue, Helvetica, sans-serif;
    font-size: .8rem;
    line-height: 1rem;
  }

  .div-50 {
    width: auto;
  }

  .hover-services-block {
    width: 100%;
  }

  .hover-tile {
    margin-top: 5px;
    margin-bottom: 5px;
  }

  .side-photos-div {
    margin-top: 40px;
  }

  .footer-link-holder {
    max-height: none;
  }

  .pool-marquee-image.show-mobile {
    width: auto;
  }

  .copyright {
    font-size: .8rem;
  }

  .h3.home-review-h3 {
    margin-top: 5vh;
    margin-bottom: 5vh;
    top: auto;
  }

  .review-block.mary-c {
    top: 7%;
  }

  .review-block.tony-b {
    top: 17%;
  }

  .review-block.susan-d {
    top: 32%;
    left: auto;
    right: 0%;
  }

  .review-block.simone-t {
    top: 75%;
    left: 0;
    right: auto;
  }

  .hero-section.service {
    padding-top: 10vh;
    padding-bottom: 10vh;
  }

  .hero-section.blog-home {
    background-image: linear-gradient(#00000080, #00000080), url('../images/flare--flora.jpg');
    background-position: 0 0, 50%;
    background-size: auto, cover;
  }

  .gallery-img {
    width: 80vw;
  }

  .feature-img {
    width: 50px;
  }

  .nav-video {
    width: 100%;
  }

  .nav-link {
    margin-left: 5px;
    margin-right: 5px;
    padding: 5px;
  }

  .customer {
    width: auto;
  }

  .about-tile {
    flex-flow: column;
  }

  .video-thumbnail {
    padding: 20px;
  }

  .calculator-wrapper {
    height: 125vh;
  }

  .calculator-h1 {
    font-size: 1.8rem;
  }
}


@font-face {
  font-family: 'Roxie Rossa';
  src: url('../fonts/Roxie-rossa.otf') format('opentype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}