.nav-bg{background: linear-gradient(to bottom, #52d5f7, #36b1d6, #488ec3);
}

.home-top-bg {
    background-image: url(../images/home-bg-top-new.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    min-height: 900px;
}


.about-us {
    background: url(../images/about-top.jpg) center center / cover no-repeat;
    background-size: cover;
    background-repeat: no-repeat;
    min-height: 565px;
}

.window-cleaning01 {
    background: url(../images/window-cleaning-top.jpg) center center / cover no-repeat;
    background-size: cover;
    background-repeat: no-repeat;
    min-height: 565px;
}

.contact-us {
    background: url(../images/contact-top.jpg) center center / cover no-repeat;
    background-size: cover;
    background-repeat: no-repeat;
    min-height: 565px;
}

.janitorial-services {
    background: url(../images/janitorial-services-top1-new.jpg) center top / cover no-repeat;
    background-size: cover;
    background-repeat: no-repeat;
    min-height: 565px;
}

.carpet-cleaning{
    background: url(../images/carpet-cleaning-top-new.jpg) center center / cover no-repeat;
    background-size: cover;
    background-repeat: no-repeat;
    min-height: 565px;
}

.residential-top{
    background: url(../images/residential-cleaning-top-new-01.jpg) center center / cover no-repeat;
    background-size: cover;
    background-repeat: no-repeat;
    min-height: 565px;
}


.construction-01{
    background: url(../images/construction-top-01.jpg) center center / cover no-repeat;
    background-size: cover;
    background-repeat: no-repeat;
    min-height: 565px;
}


.soft-w-01{
    background: url(../images/soft-wash-top-new.jpg) center center / cover no-repeat;
    background-size: cover;
    background-repeat: no-repeat;
    min-height: 565px;
}

.tiles-01{
    background: url(../images/tile-and-grout-cleaning-top.jpg) center center / cover no-repeat;
    background-size: cover;
    background-repeat: no-repeat;
    min-height: 565px;
}




h2 {
    font-size: 30px;
    -webkit-text-stroke: 1px #47C0DD;
}


hr {
    margin-top: 29px;
    margin-bottom: 37px;
    border-top: 1px solid #1c1c1c;
}

.mb-4 {
    font-family: 'oswaldbold';
    font-size: 22px;
    line-height: 49px;
}
        .content-wrapper {
            position: relative;
            z-index: 2;
        }
        
        
.hero-title {
    font-size: 82px;
    font-family: 'oswaldbold';
    margin-top: 120px;
    color: #ffffff;
    -webkit-text-stroke: 1px #47C0DD;
    letter-spacing: 1px;
    text-transform: uppercase;
line-height: 92px;
}
        .hero-desc {
            color: #fff;
              font-family: 'oswaldmedium';
            font-size: 1.15em;
            margin-top: 28px;
            margin-bottom: 28px;
        }
.estimate-btn {
    background: #50d8f3;
    font-family: 'oswaldmedium';
    border: none;
    color: #232323;
    border-radius: 25px;
    float: left;
    margin-right: 17px;
    padding: 12px 35px;
    margin-top: 18px;
    font-size: 1.1em;
}
        .estimate-btn:hover, .request-btn:hover {
            background: #42c0e0;
            color: #232323;
        }
.call-box {
    display: flex
;
    align-items: center;
    margin-top: 50px;
    padding: 0;
}
        .call-icon {
            background: #50d8f3;
            color: #232323;
            border-radius: 50%;
            font-size: 2em;
            width: 48px;
            height: 48px;
            text-align: center;
            line-height: 48px;
            margin-right: 17px;
            display: inline-block;
        }
.form-section {
    background: rgb(0 0 0 / 41%);
    border-radius: 22px;
    padding: 40px 33px;
    color: #fff;
    box-shadow: 0 0 18px 3px rgba(0, 0, 0, 0.06);
    margin-top: 2vw;
}
        .form-control,
        .form-control:focus {
            background: transparent;
            border: 1px solid #878787;
            color: #fff;
            border-radius: 25px;
            box-shadow: none;
        }
        .form-group label {
            color: #fff;
            font-weight: 400;
        }
        .request-btn {
            background: #50d8f3;
            border: none;
            color: #232323;
            font-weight: 700;
            border-radius: 25px;
            padding: 12px 35px;
            margin-top: 10px;
            width: 100%;
            font-size: 1.05em;
        }
        .highlight-blue {
            color: #50d8f3;
        }
        .form-error {
            color: #ff6666;
            font-size: 0.95em;
            margin-top: 5px;
        }

   /* welcome */

.welcome-block--- {
    background: linear-gradient(to bottom, #50d8f3 80%, #4889bd 100%);
    padding-top: 174px;
    padding-bottom: 174px;
}

.welcome-block {
    background-image: url(../images/bg-blue.svg);
    background-repeat: no-repeat;
    background-size: cover;
    padding-top: 150px;
    padding-bottom: 118px;
    margin-top: -114px;
}


/* Hero Section */
    .hero {
      min-height: 550px;
      padding: 60px 0 40px 0;
    }

.hero-content {
 
}
.hero-content h1 {
    font-size: 82px;
    font-family: 'oswaldbold';
    color: #ffffff;
    text-transform: uppercase;
    -webkit-text-stroke: 1px #47C0DD;
    margin-bottom: 10px;
}
    .hero-content p {
      font-size: 1.09em;
      max-width: 520px;
        color: #000;
    }
.hero-content .btn {
    background: #bcbcbc;
    border-radius: 32px;
    font-family: 'oswaldbold';
    color: #222;
    font-size: 18px;
    line-height: 34px;
    /* font-weight: bold; */
    text-transform: uppercase;
    margin-top: 20px;
    padding: 12px 54px;
    border: 1px solid #fff;
}
    .hero-images { position: relative; }
.hero-images .img-main {
    width: 82%;
    border-radius: 24px;
    margin-bottom: 38px;
    margin-left: 15%;
    margin-top: 14px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
}
    .hero-images .img-top {
      width: 29%;
      position: absolute;
      left: 0;
      top: -30px;
      border-radius: 12px;
      box-shadow: 0 6px 16px rgba(0,0,0,0.16);
      border: 4px solid #d5f0fb;
    }
.hero-images .years-badge {
    position: absolute;

    bottom: -19px;
    background: #bcbcbc;
    color: #222;
    border-radius: 16px;
    min-width: 119px;
    min-height: 68px;
    width: 30.015407%;
    font-weight: bold;
    font-size: 1.6em;
    padding: 23px;
    box-shadow: 0 2px 16px rgba(0, 0, 0, 0.09);
}
.years-badge span {
    font-size: 70px;
    line-height: 78px;
}
    /* Section Headings */
.section-title {
    font-family: 'oswaldbold';
    text-transform: uppercase;
    font-size: 65px;
    -webkit-text-stroke: 1px #47C0DD;
    margin-bottom: 12px;
    color: #fff;
    margin-top: 23px;
}


.section-title01 {
    font-family: 'oswaldbold';
    font-size: 65px;
    -webkit-text-stroke: 1px #47C0DD;
    margin-bottom: 12px;
    color: #fff;
    margin-top: 23px;
}

.section-offer {
    color: #4cb1d8;
    letter-spacing: 1px;
    font-size: 19px;
}
    .section-sub {
      color: #fff;
      margin-bottom: 18px;
        
        font-size: 26px;
    }


.section-sub p {
    color: #fff;
    font-family: 'oswaldmedium';
    font-size: 17px;
    line-height: 27px;
}


    .black-section {
      background: #000000;
      color: #fff;
      padding: 60px 0 16px 0;
    }
.service-card {
    background: #41c1e2;
    border-radius: 24px;
    padding: 0;
    max-width: 400px;
    min-height: 488px;
    margin: 38px auto;
    color: #fff;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.11);
    border: 10px solid #41c1e2;
    position: relative;
}
    .service-card img {
      border-radius: 24px 24px 0 0;
      width: 100%;
      max-height: 220px;
      object-fit: cover;
      display: block;
    }
    .service-card-body {
      padding: 24px 23px 10px 23px;
    }
.service-card-title {
    font-size: 21px;
    font-family: 'oswaldbold';
    margin-bottom: 16px;
    color: #111;
}
    .service-card-desc {
      font-size: 1.18em;
      color: #fff;
      margin-bottom: 48px;
      line-height: 1.32;
     font-family: 'oswaldmedium';
    }
    .service-arrow-btn {
      position: absolute;
      right: 20px;
      bottom: 18px;
      width: 48px;
      height: 48px;
      background: #111;
      color: #fff;
      border: none;
      border-radius: 50%;
      font-size: 2em;
      text-align: center;
      line-height: 47px;
      cursor: pointer;
      box-shadow: 0 2px 8px rgba(0,0,0,0.18);
      transition: background 0.2s;
    }
    .service-arrow-btn:hover {
      background: #41c1e2;
      color: #111;
      border: 2px solid #111;
    }
    @media (max-width: 520px) {
      .service-card {
        max-width: 98vw;
        border-radius: 22px;
      }
      .service-card-title {
        font-size: 1.35em;
      }
    }


.service-btn {
    margin-top: 16px;
    /* background: #488bbe; */
    background: linear-gradient(to bottom, #50d8f3 80%, #9ad2ff 100%);
    text-transform: uppercase;
    color: #222;
    border: 1px solid #fff;
    border-radius: 32px;
    font-family: 'oswaldbold';
    /* font-weight: bold; */
    /* border: none; */
    padding: 13px 26px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.09);
}
    /* Features Section */
.features-card {
    background: transparent;
    border-radius: 14px;
    min-height: 290px;
    margin-top: 20px;
    padding: 32px 33px;
    margin-bottom: 27px;
    color: #222;
    border: 1px solid #0e0e0e;
    box-shadow: 0 2px 18px rgba(0, 0, 0, 0.06);
    text-align: center;
}

.features-card p {
    color: #ffffff !important;
    font-family: 'oswaldmedium';
    font-size: 1.15em;
    margin-top: 28px;
}
.features-card .fa {
    font-size: 59px;
    margin-bottom: 10px;
    color: #ffffff;
}
.features-card h4 {
    font-size: 28px;
    font-family: 'oswaldbold';
    text-transform: uppercase;
    color: #fff;
}
    /* Testimonials */
    
.testimonial-bg {
    background: url(../images/window-cleaning-01.jpg) center center / cover no-repeat;
    min-height: 600px;
    position: relative;
    padding: 0;
}
.testimonial-slider-center {

    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: 45px;
}
    .testimonial-slider {
      background: #111;
      color: #fff;
      border-radius: 18px;
      max-width: 800px;
      margin: 0 auto;
      padding: 56px 38px 40px 38px;
      position: relative;
      box-shadow: 0 10px 36px rgba(0,0,0,0.36);
      text-align: left;
      min-height: 450px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      overflow: hidden;
    }
    .testimonial-quote {
      font-size: 2.85em;
      font-weight: bold;
      line-height: 1.10;
      margin-bottom: 28px;
    font-family: 'oswaldbold';
    }
    .testimonial-author {
      color: #33caff;
      font-size: 1.08em;
      margin-top: 11px;
  font-family: 'oswaldmedium';
      font-weight: 400;
      letter-spacing: 0.03em;
    }
    .testimonial-arrow {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      background: transparent;
      border: none;
      color: #fff;
      font-size: 2.5em;
      cursor: pointer;
      padding: 0 18px;
      outline: none;
      z-index: 1;
      transition: color 0.2s;
    }
    .testimonial-arrow:hover { color: #29b6d9; }
    .testimonial-arrow.left { left: 0; }
    .testimonial-arrow.right { right: 0; }

    .testimonial-slide {
      opacity: 1;
      transition: opacity 0.7s;
        padding-left: 50px;
        padding-right: 50px;
    }
    .testimonial-slide.fade-out {
      opacity: 0;
      transition: opacity 0.7s;
    }
    .testimonial-slide.fade-in {
      opacity: 1;
      transition: opacity 0.7s;
    }

    @media (max-width: 900px) {
      .testimonial-slider {
        max-width: 96vw;
        padding: 32px 10vw 38px 10vw;
      }
      .testimonial-quote {
        font-size: 2em;
      }
    }
    @media (max-width: 600px) {
      .testimonial-bg { background-size: cover; }
      .testimonial-slider {
        max-width: 99vw;
        padding: 28px 10px 24px 10px;
        min-height: 340px;
      }
      .testimonial-quote {
        font-size: 1.2em;
      }
      .testimonial-author {
        font-size: 1em;
      }
    }

    /* about-us */
.hero-section-about {
      position: relative;
      min-height: 70vh;
      overflow: hidden;
      display: flex;
      align-items: center;
      background: #222;
    }
    .hero-bg-about {
      position: absolute;
      top: 0; left: 0; width: 100%; height: 100%;
      background: url('../images/about-top.jpg') center center/cover no-repeat;
      z-index: 1;
    }

    .hero-content-about {
      position: relative;
      z-index: 3;
      padding: 80px 0 75px 0;
      margin-left: 3vw;
    }
    .hero-small-about {
      color: #ffc233;
      font-size: 2em;
      letter-spacing: 1px;
      margin-bottom: 15px;
    }
.hero-title-about {
    color: #fff;
    font-size: 46px;
    font-weight: bold;
    line-height: 1.05;
    letter-spacing: 1px;
    margin-bottom: 23px;
    font-family: 'oswaldbold';
    text-transform: uppercase;
} 

.hero-btn-about {
      background: #4ed6f3;
      color: #222;
      border: none;
      border-radius: 25px;
      font-size: 1.4em;
      padding: 12px 46px;
      margin-top: 14px;
      outline: none;
      transition: background .18s;
    }
    .hero-btn-about:hover {
      background: #2caeda;
      color: #fff;
    }
    .curved-divider-about {
      position: absolute;
      left: 0;
      bottom: -1px;
      width: 100%;
      z-index: 4;
      pointer-events:none;
    }
    @media (max-width: 900px) {
      .hero-title-about { font-size: 2.2em;}
      .hero-small-about { font-size: 1.06em;}
      .hero-content-about { padding: 48px 0 46px 0;}
    }
    @media (max-width: 600px) {
    .hero-title-about {
        font-size: 2.3em;
    }
      .hero-small-about { font-size: 1em; }
      .hero-content-about { margin-left:0; padding:32px 0 36px 0;}
    }

.footer-bg {
    background: url(../images/footer-bg.jpg) center top / cover no-repeat;
    height: 800px;
}
.footer-mar {
    margin-top: 188px;
    margin-bottom: 187px;
}



.quote-form-card {
      background: rgba(68,196,231,0.98);
      border: 1.8px solid #222;
      border-radius: 10px;
      padding: 42px 32px 30px 32px;
      box-shadow: 0 12px 30px rgba(0,0,0,0.10);
      margin-right: 38px;
    }
.quote-form-card h1 {
    font-size: 47px;
    font-weight: bold;
    margin-bottom: 15px;
    color: #222;
    font-family: 'oswaldbold';
    letter-spacing: 1px;
    text-transform: uppercase;
}
    .quote-form-card h1 .highlight {
      color: #fff;
      background: none;
    }
    .quote-form-card label {
      color: #1b1b1b;
      margin-bottom: 5px;
      font-size: 1.13em;
      font-weight: normal;
    }
    .form-control {
      border-radius: 20px;
      background: rgba(253,253,253,0.85);
      border: 1.7px solid #bcbcbc;
      margin-bottom: 18px;
      height: 40px;
      font-size: 1.13em;
      box-shadow: none;
      color: #222;
    }
    .form-control:focus {
      border-color: #4ecded;
      box-shadow: none;
    }
    .btn-quote {
      background: #222;
      color: #fff;
      border-radius: 22px;
      border: none;
      font-weight: bold;
      font-size: 1.15em;
      padding: 12px 0;
      width: 100%;
      margin-top: 10px;
      transition: background .2s;
    }
    .btn-quote:hover {
      background: #1885a9;
      color: #fff;
    }

    /* Contact Section */
    .contact-box {
      margin: 45px auto 30px auto;
      background: linear-gradient(to bottom, #50d8f3 90%, #4889bd 100%);
      border-radius: 13px;
      min-height: 185px;
      padding: 28px 24px 18px 24px;
      color: #222;
      box-shadow: 0 3px 18px rgba(0,0,0,0.11);
      max-width: 340px;
    }
    .contact-box h3 {
      color: #29b6d9;
      font-size: 1.3em;
      margin-bottom: 16px;
      font-weight: bold;
    }
    .footer {
      background: #111;
      color: #bcbcbc;
      padding: 26px 0 14px 0;
      font-size: 0.95em;
    }
    .footer .col-sm-3, .footer .col-xs-12 {
      margin-bottom: 24px;
    }
    .footer-logo {
      font-weight: bold;
      font-size: 1.32em;
      color: #50d8f3;
      margin-bottom: 6px;
    }
    .footer-links a {
      color: #bcbcbc;
      display: block;
      margin-bottom: 6px;
      text-decoration: none;
    }
    .footer-links a:hover {
      color: #29b6d9;
      text-decoration: underline;
    }
    .footer-social i {
      font-size: 1.25em;
      margin-right: 9px;
      color: #fff;
    }



.contact-card  {
    background: rgba(32, 48, 61, 0.92);
    border-radius: 30px;
    color: #fff;
    padding: 83px;
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.19);
    margin-top: 76px;
    height: 530px;
    position: relative;
    overflow: hidden;
    margin-bottom: 76px;
}
.contact-card-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 30px;
    z-index: 0;
    background: url(../images/floor-cleaning-machine.jpg) center center / cover no-repeat;
    opacity: 0.34;
}
    .contact-card-content {
      position: relative;
      z-index: 1;
    }
.contact-title {
    font-size: 67px;
    color: #3ed1f7;
    font-family: 'oswaldbold';
    margin-bottom: 44px;
}
    .contact-detail-icon {
      display: inline-block;
      width: 32px;
      height: 32px;
      font-size: 1.5em;
      color: #3ed1f7;
      text-align: center;
      margin-right: 16px;
      vertical-align: middle;
    }
.contact-detail-label {

    font-size: 28px;
    vertical-align: middle;
    font-family: 'oswaldbold';
    text-transform: uppercase;
    margin-right: 10px;
}
    .contact-detail {
      font-size: 1.25em;
      margin-bottom: 18px;
      letter-spacing: 1px;
      display: flex;
      align-items: center;
    }
.contact-email, .contact-address {
    margin-left: -4px;
    font-size: 1.18em;
}
    /* Contact Form */
 .contact-form-col {
    padding: 34px 0 27px 39px;
    margin-top: 68px;
}
    .contact-form label {
      color: #fff;
      font-weight: normal;
      margin-bottom: 7px;
      font-size: 1.02em;

    }
.form-control {
    background: #ffffff;
    border: 1.8px solid #bcbcbc;
    border-radius: 10px;
    color: #000000;
    font-size: 1.15em;
    margin-bottom: 14px;
    box-shadow: none;
    height: 41px;
}
.form-control:focus {
    border: 2px solid #ffffff;
    outline: none;
    box-shadow: none;
    background: #ffffff;
    color: #000000;
}
 .contact-form .form-group {
    margin-bottom: 3px;
}
    .contact-form .form-row {
      margin-bottom: 3px;
    }
    .contact-form .btn-submit {
      background: #3ed1f7;
      color: #0a1621;
      border: none;
      border-radius: 28px;
      font-weight: bold;
      font-size: 1.23em;
padding: 14px 58px;
      letter-spacing: 1px;
      margin-top: 18px;
      transition: background 0.2s;
    }
    .contact-form .btn-submit:hover {
      background: #13b0dd;
      color: #fff;
    }
    @media (max-width: 1150px) {
      .contact-title { font-size: 2.16em; }
      .contact-card { padding: 33px 17px 21px 17px; }
   
    }
    @media (max-width: 970px) {
      .contact-title { font-size: 1.4em; }
      .contact-section { flex-direction: column; padding-top:38px; }
      .contact-card { margin: 0 auto 34px auto; }
  
    }
    @media (max-width: 700px) {
      .contact-section { flex-direction: column; padding: 0; }

      .contact-title {         font-size: 40px; margin-bottom: 20px; }
.contact-card, .contact-form {
        width: 100%;
        border-radius: 17px;
        margin-top: 37px;
    }
    }



.footer {
      background: #000;
      padding: 50px 0 15px 0;
      color: #fff;
      font-family: 'Arial', sans-serif;
    }
    .footer .logo-col {
      text-align: left;
    }
    .footer-logo-img {
      max-height: 170px;
      max-width: 330px;
      margin-bottom: 15px;
    }
.footer-nav-title, .footer-contact-title, .footer-social-title {
    font-size: 2.3em;
    text-transform: uppercase;
    margin-bottom: 20px;
    font-family: 'oswaldbold';
    color: #fff;
}
    .footer-nav-links {
      margin-left: 0;
      padding-left: 0;
      list-style: none;
    }
    .footer-nav-links li {
      font-size: 1.15em;
          font-family: 'oswaldmedium';
      margin-bottom: 8px;
    }
    .footer-nav-links a {
      color: #fff;
      text-decoration: none;
      transition: color .2s;
    }
    .footer-nav-links a:hover,
    .footer-nav-links .active {
      color: #22cdf4;
      text-decoration: underline;
    }
    .footer-contact {
      font-size: 1.2em;
          font-family: 'oswaldmedium';
      margin-bottom: 10px;
    }
    .footer-social-icons {
      margin-top: 30px;
    }
    .footer-social-icons a {
      display: inline-block;
      background: #fff;
      border-radius: 50%;
      color: #000;
      width: 56px;
      height: 56px;
      line-height: 56px;
      font-size: 2.1em;
      text-align: center;
      margin-right: 27px;
      margin-bottom: 10px;
      transition: background .2s, color .2s;
    }
    .footer-social-icons a:hover {
      background: #22cdf4;
      color: #fff;
    }
    .footer-copyright {
      color: #aaa;
      font-size: 1.06em;
      padding-top: 10px;
      text-align: left;
      padding-left: 12px;
      font-weight: normal;
    }
    @media (max-width: 1200px) {
      .footer .row > div { margin-bottom: 24px; }
      .footer-nav-title, .footer-contact-title, .footer-social-title { font-size: 2em; }
    }
    @media (max-width: 991px) {
      .footer-nav-title, .footer-contact-title, .footer-social-title { font-size: 1.4em; }
      .footer-logo-img { max-width: 220px; max-height: 95px; }
      .footer-social-icons a { font-size: 1.45em; width: 40px; height: 40px; line-height: 40px; }
    }
    @media (max-width: 700px) {
      .footer { text-align: center; }
      .footer .logo-col { text-align: center; }
      .footer-social-icons { margin-top: 12px; }
      .footer-social-icons a { margin-right: 9px; }
      .footer-copyright { text-align: center; padding-left: 0; }
    }


        @media (max-width: 991px) {
            
            
    .hero-content h1 {
    font-size: 58px;
}
            
            .footer-bg {
    background: url(../images/footer-bg.jpg) center top / cover no-repeat;
    height: auto;
}
            
 .quote-form-card {
   margin-right: 0px; 
}  
            
            
.footer-mar form-control {
    border: 1.8px solid #000000 !important;
}
        
      .contact-card-bg {
    border-radius: 15px;

}      
.hero-images .img-top {
    width: 47%;
    left: 11px;
    top: -24px;

}
            
            
            .contact-form-col{padding: 20px; margin-top: 5px;}
            
  .contact-email, .contact-address {
    margin-left: 0px;
    font-size: 1.18em;
}
            
    .contact-detail {
        display: flex;
        align-items: center;
        flex-direction: column;
    
}
            
.hero-images {
    margin-top: 68px;
}
            
            .section-title {
    font-size: 50px;
    margin-top: 10px;
}
            
        
            
        .estimate-btn {

    float: none;

}
            
            .welcome-block {
    padding-top: 62px;
    padding-bottom: 87px;
                margin-top: 40px;
}
            
            
            
    .hero-title {
        line-height: 57px;
        font-size: 50px;
    }
            
            .section-title01{font-size: 36px;}
            .form-section {
                margin-top: 36px;
                padding: 30px 16px;
            }
        }