/*
Theme Name: Jays Landscape
Theme URI: https://ramblinjackson.com
Version: 1.1.1
Description: A Beaver Builder child theme for Jays Landscape.
Author: The Ramblin Jackson Team
Author URI: https://ramblinjackson.com
template: bb-theme
*/

/* =============================================================================
   TABLE OF CONTENTS
   1.  Common / Base
   2.  Header
   3.  Hero Banner
   4.  Custom Slider
   5.  Services
   6.  Portfolio
   7.  Reviews
   8.  Career
   9.  Gallery / Projects Loop
   10. Blog / Single Post
   11. Pagination
   12. Accordion
   13. Service Area
   14. Forms (Gravity Forms)
   15. Footer
   16. Responsive — min-width: 1660px
   17. Responsive — min-width: 1200px
   18. Responsive — max-width: 1500px
   19. Responsive — max-width: 1300px
   20. Responsive — max-width: 1260px
   21. Responsive — max-width: 1199px
   22. Responsive — max-width: 991px
   23. Responsive — max-width: 767px
   24. Responsive — max-width: 568px
   ============================================================================= */


/* =============================================================================
   1. Common / Base
   ============================================================================= */

body {
  font-family: "Messina Sans";
}

p {
  /* Desktop override in @media (min-width: 1200px) */
}

body .revwid-container {
  font-family: "Messina Sans" !important;
}

body .fl-button:is(a, button) {
  text-decoration: none !important;
}

body .fl-page .fl-builder-content .fl-button:is(a, button):focus,
body .fl-page .fl-builder-content .fl-button:is(a, button):focus-visible,
body .fl-button:is(a, button):focus,
.fl-button:is(a, button):focus-visible {
  background-color: var(--fl-global-accent) !important;
  border-color: var(--fl-global-accent) !important;
  color: var(--fl-global-accent-alt) !important;
  outline: 0 !important;
}

body #fl-to-top {
  background-color: currentColor;
  bottom: 68px;
}

body #fl-to-top:hover {
  background-color: var(--fl-global-accent);
}

body #fl-to-top i {
  top: 14px;
  left: 12px;
  font-size: 22px;
}

.mix-blend-bg > .fl-row-content-wrap::after,
.mix-blend-bg > .fl-row-content-wrap {
  mix-blend-mode: multiply;
}

.padding-right-container > .fl-row-content-wrap {
  padding-right: calc(50% - 1220px / 2);
}

.padding-left-container > .fl-row-content-wrap,
body .box-padding-left-container,
body .service-padding-left-container {
  padding-left: calc(50% - 1220px / 2);
}

/* Image Borders */
.inner-border .fl-photo-img {
  outline: 1px solid white;
  outline-offset: -25px;
}

/* List Styles */
.list-blue ul li {
  list-style-type: square;
}

.list-blue ul li::marker {
  color: var(--fl-global-base-200);
}

.list-blue ul li strong,
.list-blue ul li b {
  color: var(--fl-global-base-200);
}

/* Blur Button */
body .btn-blur .fl-button {
  backdrop-filter: blur(4px);
  --webkit-backdrop-filter: blur(4px);
  --moz-backdrop-filter: blur(4px);
}


/* =============================================================================
   2. Header
   ============================================================================= */

body header::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  height: 146%;
  width: 100%;
  background: linear-gradient(180deg, #2a2824 -10%, rgba(42, 40, 36, 0) 85.71%);
  /* mix-blend-mode: multiply; */
}

body header.fl-theme-builder-header-sticky::before {
  height: 100%;
}

body header:not(.fl-theme-builder-header-sticky) .header-top > .fl-row-content-wrap {
  background-color: rgba(42, 40, 36, 0.25) !important;
  backdrop-filter: blur(5px);
}

body header.fl-theme-builder-header-sticky .header-top > .fl-row-content-wrap {
  border-bottom: 1px solid rgb(240, 241, 234, 0.35);
}

body .fl-theme-builder-header-shrink-row-top.fl-row-content-wrap {
  padding-block: 15px;
}

.header-desktop-menu .fl-module-menu {
  width: 100%;
}

.header-desktop-menu .fl-module-menu .menu > li:first-child > a {
  padding-left: 0;
}

.header-desktop-menu .fl-module-menu .menu > li:last-child > a {
  padding-right: 0;
}

.header-desktop-menu .fl-module-menu nav > .menu {
  width: 100%;
  justify-content: space-between;
  align-items: end;
}

.header-desktop-menu .fl-module-menu .menu .fl-menu-logo a {
  padding-inline: 87px;
}

.fl-builder-content[data-type="header"].fl-theme-builder-header-shrink img {
  max-height: 100px !important;
}

body .heder-top-number a:hover {
  color: var(--fl-global-accent) !important;
}

/* Single Post — header override */
body.single-post header .fl-row-content-wrap,
body.single-post header:not(.fl-theme-builder-header-sticky) .header-top > .fl-row-content-wrap {
  background-color: var(--fl-global-base-400) !important;
}

body.single-post header:not(.fl-theme-builder-header-sticky) .header-top > .fl-row-content-wrap {
  border-bottom: 1px solid rgb(240, 241, 234, 0.35);
}


/* =============================================================================
   3. Hero Banner
   ============================================================================= */

.hero-slider-section .pp-image-carousel-wrapper::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  background: #aeaeae;
  mix-blend-mode: multiply;
  height: 100%;
  width: 100%;
  z-index: 2;
}

body .hero-text-box {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  z-index: 2;
}

.hero-slider-section .pp-image-carousel-wrapper .pp-swiper-button {
  z-index: 5;
  top: 45.5%;
  border: 0 !important;
}

.hero-slider-section .pp-image-carousel-wrapper .pp-swiper-button.swiper-button-prev {
  left: calc(50% - 1220px / 2);
}

.hero-slider-section .pp-image-carousel-wrapper .pp-swiper-button.swiper-button-next {
  right: calc(49% - 1225px / 2);
}

.hero-slider-section
  .pp-image-carousel-wrapper
  .pp-swiper-button.swiper-button-next
  span {
  margin-right: -5px;
}

.hero-title .pp-heading-content,
.inner-hero-title .pp-heading-content {
  overflow: visible;
}

body .inner-hero-title .pp-heading-content .pp-heading .heading-title span.pp-secondary-title {
  position: absolute;
  top: calc(100% + 30px);
  left: 0;
  right: 0;
  margin: auto;
  max-width: 1200px;
  padding-inline: 15px;
}

.inner-page-hero-section {
  position: relative;
  z-index: 2;
}


/* =============================================================================
   4. Custom Slider
   ============================================================================= */

/* Navigation arrow images */
body .custom-slider .fl-content-slider-navigation .slider-next {
  background-image: url(assets/images/next-arrow.svg);
}

body .custom-slider .fl-content-slider-navigation .slider-prev {
  background-image: url(assets/images/prev-arrow.svg);
}

/* Navigation container */
body .custom-slider .fl-content-slider-navigation {
  position: absolute;
  top: inherit;
  bottom: -75px;
  left: 0;
  right: 0;
  z-index: 1;
  margin-top: -16px;
  height: 115px;
  width: 115px;
  margin: auto;
  border-radius: 115px;
  background: #f0f1ea;
  box-shadow: 0 0 25px 0 rgba(0, 0, 0, 0.15);
}

body .custom-slider .fl-content-slider-navigation .slider-prev,
body .custom-slider .fl-content-slider-navigation .slider-next {
  position: absolute;
  display: inline-block;
  opacity: 1;
  top: 0;
  bottom: 0;
  background-repeat: no-repeat;
  background-size: 14px;
  background-position: center;
  height: 28px;
  width: 28px;
  margin: auto;
  outline: 0;
}

body .custom-slider .fl-content-slider-navigation .slider-next {
  right: 15px;
}

body .custom-slider .fl-content-slider-navigation .slider-prev {
  left: 15px;
}

body .custom-slider .fl-content-slider-navigation .fl-content-slider-svg-container {
  display: none;
}

body .custom-slider .fl-content-slider-navigation::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 1px;
  height: 34px;
  left: 0;
  right: 0;
  margin: auto;
  background: #97a498;
}

/* Pager */
body .custom-slider .bx-wrapper .bx-pager {
  bottom: 60px;
  text-align: left !important;
}

body .custom-slider .bx-wrapper .bx-pager-item {
  font-size: 20px;
}

/* Pagination display */
body .slider-pagination {
  color: #97a498;
  font-family: "SuperBlue";
  font-weight: 300;
  position: relative;
  display: flex;
  align-items: center;
  font-size: 20px;
}

body .slider-pagination .pagination-slide {
  color: #1b5697;
  font-weight: 900;
}

body .slider-pagination .pagination-total-slide {
  position: relative;
  padding-left: 20px;
}

body .slider-pagination .pagination-total-slide::before {
  content: "/";
  position: absolute;
  left: 6px;
  top: -1px;
  color: #97a498;
  font-weight: 300;
}

/* Reason Slider */
body .reason-slider .fl-content-slider .fl-slide .fl-slide-text {
  max-width: 94%;
}

body .reason-slider .fl-content-slider .fl-slide .fl-slide-title {
  margin-bottom: 33px !important;
}


/* =============================================================================
   5. Services
   ============================================================================= */

.service-title .pp-primary-title {
  margin-bottom: 10px;
}

body .service-slider {
  max-width: 420px;
}

body .custom-slider.service-slider .fl-content-slider-navigation {
  left: inherit;
  right: -155px;
  bottom: 0;
  background: rgba(240, 241, 234, 0.05);
  border: 1px solid #f0f1ea;
  filter: brightness(0) saturate(100%) invert(99%) sepia(2%) saturate(611%)
    hue-rotate(24deg) brightness(101%) contrast(89%);
  --webkit-filter: brightness(0) saturate(100%) invert(99%) sepia(2%)
    saturate(611%) hue-rotate(24deg) brightness(101%) contrast(89%);
  --moz-filter: brightness(0) saturate(100%) invert(99%) sepia(2%)
    saturate(611%) hue-rotate(24deg) brightness(101%) contrast(89%);
  box-shadow: none;
}

body .custom-slider.service-slider .fl-content-slider-navigation::after {
  background: #f0f1ea;
}

body .border-box-container {
  max-width: calc(50% - -1140px / 2) !important;
}

body .service-slider-pagination .slider-pagination,
body .service-slider-pagination .pagination-total-slide::before {
  color: #83b8db;
}

body .service-slider-pagination .pagination-slide {
  color: #f0f1ea;
}

body .service-slider .fl-button:hover {
  border-color: var(--fl-global-accent) !important;
}

body .service-slider .fl-button-wrap {
  margin-top: 10px;
}

body .service-slider .fl-slide-title {
  margin-bottom: 12px;
}


/* =============================================================================
   6. Portfolio
   ============================================================================= */

.portfolio-section .fl-content-slider::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  background: rgba(53, 61, 68, 0.45);
  mix-blend-mode: multiply;
  height: 100%;
  width: 100%;
  z-index: 2;
}

.portfolio-section .fl-content-slider::after {
  content: "";
  position: absolute;
  bottom: -57px;
  right: 0;
  left: 0;
  background: linear-gradient(
    180deg,
    rgba(53, 61, 68, 0.25) -31.58%,
    rgba(53, 61, 68, 0) 85.96%
  );
  mix-blend-mode: multiply;
  height: 57px;
  width: 100%;
  z-index: 2;
}

body .portfolio-text-box {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  z-index: 2;
  height: 80%;
}

body .portfolio-section .custom-slider .fl-content-slider-navigation {
  bottom: -57px;
  z-index: 3;
}


/* =============================================================================
   7. Reviews
   ============================================================================= */

body .revwid-is-horizontal-widget.revwid-container .revwid-ctas .revwid-button {
  background-color: transparent !important;
}

body .revwid-is-horizontal-widget.revwid-container .revwid-ctas .revwid-button:hover {
  background-color: var(--fl-global-accent) !important;
}

body
  .revwid-is-horizontal-widget.revwid-container
  .revwid-ctas
  .revwid-button.revwid-is-leave-feedback-button {
  background-color: var(--fl-global-accent) !important;
}

body
  .revwid-is-horizontal-widget.revwid-container
  .revwid-ctas
  .revwid-button.revwid-is-leave-feedback-button:hover {
  background-color: transparent !important;
  border: 1px solid var(--fl-global-base-100) !important;
}

body .revwid-container .revwid-is-filter-button > .revwid-is-arrow-icon,
body .revwid-container .revwid-pagination .revwid-pagination-link {
  color: var(--fl-global-base-100) !important;
}

body .revwid-container .revwid-pagination .revwid-pagination-link.revwid-is-active {
  font-weight: 900 !important;
}

body .revwid-container .revwid-is-close-icon {
  top: -2px !important;
  margin-right: 3px !important;
  font-size: 17px !important;
}

body .revwid-container .revwid-has-content-color,
body .revwid-container .revwid-pagination .revwid-pagination-link.revwid-is-active {
  color: var(--fl-global-base-100) !important;
}


/* =============================================================================
   8. Career
   ============================================================================= */

.career-section > .fl-row-content-wrap:after {
  background-image: linear-gradient(
    0deg,
    #1b5697 -4.1%,
    rgba(27, 86, 151, 0) 58%
  );
}

.career-section {
  position: relative;
  z-index: 1;
}

.career-section::before {
  content: "" !important;
  position: absolute;
  top: 0;
  /* bottom: 0; */
  left: 0;
  right: 0;
  background: #f0f1ea;
  height: calc(var(--career-height) + 30px);
  width: 100%;
  z-index: 1;
}

body:not(.home) .career-section::before {
  height: calc(var(--career-height) + 65px);
}


/* =============================================================================
   9. Gallery / Projects Loop
   ============================================================================= */

.projects_loop ul li {
  list-style-type: none;
  position: relative;
  /* border-radius: 12px; */
  overflow: hidden;
}

.projects_loop .fl-photo {
  height: 100%;
}

.projects_loop ul li .fl-module.project_headline {
  position: absolute;
  bottom: 0px;
  width: 100%;
  display: inline-block;
  padding: 8px 15px 12px !important;
  background-color: rgb(27 56 88 / 85%);
}

.projects_loop .fl-photo-content,
.project_gallery .fl-photo-content {
  overflow: hidden;
}

.projects_loop .fl-loop-item img,
.project_gallery .fl-photo-content a img {
  transition: all 0.3s ease-in-out;
}

.projects_loop .fl-loop-item:hover img,
.project_gallery .fl-photo-content a:hover img {
  transform: scale(1.1);
  will-change: transform;
}


/* =============================================================================
   10. Blog / Single Post
   ============================================================================= */

.blog-post-grid .fl-post-grid-image img {
  height: 273px !important;
  object-fit: cover;
}

.blog-post-grid .fl-post-grid-image a:focus {
  outline: 0 !important;
  outline-offset: 0 !important;
}

.single-post .fl-module-fl-post-content ul,
.single-post .fl-module-fl-post-content ol {
  padding-left: 40px;
}

.single-post .fl-module-fl-post-content ul li {
  list-style-type: disc;
}

.single-post .fl-module-fl-post-content ol li {
  list-style-type: auto;
}

.single-post .fl-module-fl-post-content ol + p,
.single-post .fl-module-fl-post-content ul + p {
  margin-top: 15px;
}

body .back-gallery-brn .fl-button {
  /* Mobile override in @media (max-width: 767px) */
}


/* =============================================================================
   11. Pagination
   ============================================================================= */

body .fl-builder-pagination {
  padding-bottom: 0 !important;
}

body .fl-builder-pagination ul.page-numbers {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

body .fl-builder-pagination li {
  border-radius: 0;
  overflow: inherit;
}

body .fl-builder-pagination li a,
.fl-builder-pagination li span {
  text-decoration: none !important;
  height: 35px;
  width: 35px !important;
  border-radius: 0;
  display: flex !important;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  padding: 5px !important;
  margin: 0 !important;
  border: 1px solid var(--fl-global-accent-alt) !important;
  background-color: transparent;
}

body .fl-builder-pagination li a.page-numbers:hover,
body .fl-builder-pagination li span.current {
  background: var(--fl-global-accent-alt) !important;
  text-decoration: none !important;
  color: var(--fl-global-base-100) !important;
}

body .fl-builder-pagination li .next.page-numbers,
body .fl-builder-pagination li .prev.page-numbers {
  width: auto !important;
}


/* =============================================================================
   12. Accordion
   ============================================================================= */

body .pp-accordion-item .pp-accordion-content p:last-child {
  margin-bottom: 0;
}

body .process-accordion .pp-accordion-button-label a {
  color: var(--fl-global-base-300);
}

body .process-accordion .pp-accordion-button-label a:hover {
  color: var(--fl-global-accent-alt);
}


/* =============================================================================
   13. Service Area
   ============================================================================= */

.service-area-list ul {
  display: flex;
  flex-wrap: wrap;
  gap: 0 10px;
}

.service-area-list ul li {
  flex: 0 0 calc(50% - 10px);
}

.service-area-list ul li a {
  color: var(--fl-global-accent-alt) !important;
}

.service-area-list ul li a:hover {
  color: var(--fl-global-accent) !important;
}


/* =============================================================================
   14. Forms (Gravity Forms)
   ============================================================================= */

body .gform_wrapper.gravity-theme select {
  cursor: pointer;
  padding-right: 30px !important;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-image: url(assets/images/select-arrow.svg);
  background-position: right 15px center;
  background-repeat: no-repeat;
  background-size: 12px;
  background-color: transparent;
}

body .gform_wrapper .gfield_error .validation_message {
  padding: 5px 10px !important;
}

body .gform_wrapper.gravity-theme .gfield textarea {
  height: 150px !important;
  min-height: inherit !important;
}

body .gform_wrapper.gravity-theme input,
body .gform_wrapper.gravity-theme select,
body .gform_wrapper.gravity-theme textarea {
  line-height: 1.4 !important;
  min-height: auto !important;
}

body .gform_wrapper .gfield .ginput_complex.ginput_container label,
body .gform_wrapper.gravity-theme .gfield-choice-input + label {
  font-weight: 400 !important;
}

body .gform_wrapper.gravity-theme .gfield-choice-input + label {
  vertical-align: top;
}

body .gform_wrapper.gravity-theme .gform_footer,
.gform_wrapper.gravity-theme .gform_page_footer {
  margin-top: 20px !important;
}

body .gform_wrapper.gravity-theme .gfield-choice-input {
  vertical-align: top;
  margin-top: 7px;
  accent-color: #000;
  cursor: pointer;
}


/* =============================================================================
   15. Footer
   ============================================================================= */

.copyright-footer .fl-rich-text p {
  margin-bottom: 10px !important;
}

body .copyright-footer a:hover {
  text-decoration: none !important;
}

.footer-row a:hover,
.footer-menu-col .menu a:hover {
  color: var(--fl-global-base-100) !important;
  text-decoration: underline !important;
}


/* =============================================================================
   16. Responsive — min-width: 1660px
   ============================================================================= */

@media (min-width: 1660px) {
  body .left-gradient-image-position > .fl-row-content-wrap {
    background-position: calc(49% - 590px / 2) 0;
  }

  body .right-gradient-image-position > .fl-row-content-wrap {
    background-size: cover;
  }

  .padding-right-container > .fl-row-content-wrap {
    padding-left: calc(50% - 1600px / 2);
  }

  .padding-left-container > .fl-row-content-wrap,
  body .service-padding-left-container {
    padding-right: calc(50% - 1600px / 2);
  }

  .service-area-section > .fl-row-content-wrap {
    background-position: calc(50% - -720px / 2) top;
  }

  body .service-section > .fl-row-content-wrap {
    background-size: calc(50% - -1220px / 2) 100%;
  }
}


/* =============================================================================
   17. Responsive — min-width: 1200px
   ============================================================================= */

@media (min-width: 1200px) {
  p {
    margin: 0 0 24px;
  }

  body header .fl-menu .sub-menu {
    width: 240px;
  }

  body header .fl-menu .menu > li:not(.fl-menu-logo) {
    margin-bottom: 18px;
  }

  body .menu > li > .fl-has-submenu-container > a {
    padding-right: 0 !important;
  }

  body .fl-menu button.fl-menu-toggle {
    width: 25px;
  }

  body .right-gradient-image-position > .fl-row-content-wrap::before {
    content: "";
    position: absolute;
    bottom: 0px;
    width: 50%;
    right: 0;
    height: 100px;
    background-image: linear-gradient(
      0deg,
      #f0f1ea 8%,
      rgba(240, 241, 234, 0.01) 99.51%
    );
  }

  /* Process */
  .service-area-process .process-accordion > .fl-module-content {
    margin-right: 0 !important;
    margin-left: 90px !important;
  }
}

/* =============================================================================
   17. Responsive — min-width: 1025px
   ============================================================================= */

@media (min-width: 1025px) {
	.process-accordion {
		min-height:706px !important;
		max-height:706px !important; 
	}
	.process-accordion .pp-accordion-item.pp-accordion-item-active{
		min-height: 210px !important;
	}
	.service-slider{
		min-height: 217px !important;
	}
	.service-slder .fl-slide {
		min-height: 220px;
	}
	body .custom-slider.service-slider .fl-content-slider-navigation {
		top: 100px !important;
		bottom: auto !important;
	}

}


/* =============================================================================
   18. Responsive — max-width: 1500px
   ============================================================================= */

@media (max-width: 1500px) {
  body .custom-slider.service-slider .fl-content-slider-navigation {
    right: -115px;
  }

  body .reason-slider .fl-content-slider,
  body .reason-slider .fl-content-slider .bx-wrapper .bx-viewport,
  body .reason-slider .fl-content-slider .fl-slide {
    height: auto !important;
    min-height: 480px !important;
  }

  body .reason-slider .fl-content-slider .fl-slide .fl-slide-text {
    max-width: 100%;
  }

  body .reason-slider .fl-content-slider .fl-slide .fl-slide-title {
    margin-bottom: 20px !important;
  }
}


/* =============================================================================
   19. Responsive — max-width: 1300px
   ============================================================================= */

@media (max-width: 1300px) {
  .header-desktop-menu .fl-module-menu .menu .fl-menu-logo a {
    padding-inline: 57px;
  }
}


/* =============================================================================
   20. Responsive — max-width: 1260px
   ============================================================================= */

@media (max-width: 1260px) {
  .hero-slider-section .pp-image-carousel-wrapper .pp-swiper-button.swiper-button-prev {
    left: 15px;
  }

  .hero-slider-section .pp-image-carousel-wrapper .pp-swiper-button.swiper-button-next {
    right: 15px;
  }
}


/* =============================================================================
   21. Responsive — max-width: 1199px
   ============================================================================= */

@media (max-width: 1199px) {
  /* Common */
  body .large-device-bg-none > .fl-row-content-wrap {
    background-image: none !important;
  }

  body .custom-slider .fl-content-slider-navigation {
    bottom: -50px;
  }

  /* Header */
  body header {
    position: relative !important;
  }

  body header .header-top > .fl-row-content-wrap {
    border-bottom: 1px solid rgb(240, 241, 234, 0.35);
  }

  body header:not(.fl-theme-builder-header-shrink) .header-top > .fl-row-content-wrap,
  body header:not(.fl-theme-builder-header-shrink) .header-bottom > .fl-row-content-wrap {
    background-color: rgba(42, 40, 36, 1) !important;
  }

  /* Hamburger Menu */
  body .fl-menu-mobile-toggle.fl-active .fl-hamburger-menu-top {
    transform: rotateZ(45deg) translateY(-30px) translateX(100px);
  }

  body .fl-menu-mobile-toggle.fl-active .fl-hamburger-menu-middle {
    opacity: 0;
  }

  body .fl-menu-mobile-toggle.fl-active .fl-hamburger-menu-bottom {
    transform: rotateZ(-45deg) translateY(-100px) translateX(-270px);
  }

  /* Portfolio */
  body .portfolio-section .fl-content-slider {
    min-height: 700px !important;
    height: 700px;
  }

  body .portfolio-section .fl-content-slider .bx-wrapper .bx-viewport {
    height: 700px !important;
  }

  /* Services */
  body .service-slider {
    max-width: 100%;
  }

  body .service-slider .fl-slide {
    margin-inline: 1px !important;
  }

  body .custom-slider.service-slider .fl-content-slider-navigation {
    right: 115px;
    bottom: -80px;
    height: 100px;
    width: 100px;
  }
}


/* =============================================================================
   22. Responsive — max-width: 1024px
   ============================================================================= */

@media (max-width: 1024px) {
  /* Common */
  .medium-device-bg-none > .fl-row-content-wrap {
    background-image: none !important;
  }

  /* Image Width */
  .fl-photo-content:not(.fl-photo-img-svg), 
  .fl-photo-img:not(.wp-image-383) {
	width: 100% !important;
  }

  /* Slider */
  body .slider-pagination {
    justify-content: center;
  }

  body .custom-slider .fl-content-slider-navigation {
    height: 90px;
    width: 90px;
    bottom: -140px;
  }

  body .custom-slider .fl-content-slider-navigation .slider-prev {
    left: 10px;
  }

  body .custom-slider .fl-content-slider-navigation .slider-next {
    right: 10px;
  }

  body .custom-slider .bx-wrapper .bx-pager.bx-default-pager button::before {
    top: 0;
  }

  body .custom-slider.service-slider .fl-content-slider-navigation {
    right: 0;
    left: 0;
    bottom: -100px;
    height: 90px;
    width: 90px;
  }

  /* Portfolio */
  body .portfolio-section .custom-slider .fl-content-slider-navigation {
    bottom: -44px;
  }

  /* Reason Slider */
  body .reason-slider .fl-content-slider,
  body .reason-slider .fl-content-slider .bx-wrapper .bx-viewport,
  body .reason-slider .fl-content-slider .fl-slide {
    height: auto !important;
    min-height: auto !important;
  }

  body .reason-slider .fl-content-slider {
    padding-bottom: 10px;
  }

  body .reason-slider .bx-wrapper .bx-pager {
    bottom: -29px;
  }

  /* Footer */
  body footer .footer-row .fl-col-group {
    display: flex;
    flex-wrap: wrap;
  }

  body footer .footer-logo-col {
    order: -1;
  }
}


/* =============================================================================
   23. Responsive — max-width: 767px
   ============================================================================= */

@media (max-width: 767px) {
  /* Header */
  body header .header-top .fl-col-group {
    display: flex;
    flex-wrap: nowrap;
  }

  /* Hero Banner */
  .hero-title .pp-heading-content .pp-heading-separator .pp-separator-line {
    border-bottom-width: 50px !important;
  }

  .hero-title .pp-heading-content .pp-heading .heading-title span.pp-primary-title {
    margin-bottom: 10px;
  }

  .hero-slider-section .pp-image-carousel-wrapper .pp-swiper-button {
    height: 45px;
    width: 45px;
    top: 40%;
  }

  /* Portfolio */
  body .portfolio-section .fl-content-slider {
    min-height: 470px !important;
    height: 470px;
  }

  body .portfolio-section .fl-content-slider .bx-wrapper .bx-viewport {
    height: 470px !important;
  }

  body .portfolio-section .fl-content-slider .fl-slide-mobile-photo-img {
    height: 470px !important;
    object-fit: cover;
  }

  /* Gallery */
  body .back-gallery-brn .fl-button {
    margin-bottom: 30px !important;
  }
}


/* =============================================================================
   24. Responsive — max-width: 568px
   ============================================================================= */

@media (max-width: 568px) {
  /* Header */
  body header .header-top .fl-button {
    font-size: 11px !important;
    padding: 8px 8px !important;
  }

  /* Buttons */
  body .fl-builder-content .fl-button:is(a, button),
  body .fl-builder-content a.fl-button:visited {
    padding-inline: 16px !important;
    font-size: 13px !important;
  }

  /* Service Area */
  .service-area-list ul li {
    flex: 0 0 100%;
  }
}