/*!
Theme Name: Fremantle Roofing Services
Theme URI: http://underscores.me/
Author: StarlitDevs
Author URI: https://starlitdevs.com/
Description: This is a custom theme
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: frs
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.

StarlitDevs is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/

:root{
    --color-white: #FFFFFF;
	--color-blue: #333259;
	--color-blue-light: #3E3D66;
	--color-cream: #FEF3EE;
	--color-cream-1: #FAE8E0;
	--color-cream-2: #FEF3EEF2;
	--color-cream-light: #FFF9F6;
	--color-orange: #EF611B;
	--primary-font: 'Poppins';
}
body{
	-webkit-font-smoothing: antialiased; /* Chrome, Safari */
	-moz-osx-font-smoothing: grayscale; /* Firefox */
	font-family: var(--primary-font);
	line-height: 2;
	font-size: 14px;
	font-weight: 400;
	color: var(--color-blue);
	padding-inline: 20px;
	padding-top: 15px;
}
h1, h2, h3, .h3, h4, .h4, h5, .h5, h6{
	line-height: 1.1;
	margin: 0;
	padding: 0;
	font-weight: 500;
	letter-spacing: -4%;
}
h1, .super-title p{
	font-size: 14px;
	font-weight: 400;
	letter-spacing: 25%;
	line-height: 1;
	text-transform: uppercase;
}
h2{
	font-size: 64px;
	list-style: 1;
}
h3, .h3{
	font-size: 48px;
}
h4, .h4{
	font-size: 36px;
}
h5, .h5{
	font-size: 24px;
	letter-spacing: 0%;
}
p{
	margin-bottom: 20px;
}
p:last-child, p:last-of-type {
	margin-bottom: 0;
}
img{
	max-width: 100%;
	width: 100%;
	object-fit: cover;
	object-position: center;
	height: auto;
	transition: all .6s ease;
}
ul{
	margin: 0;
	padding: 0;
}
a{
	text-decoration: none;
	transition: .4s;
}
a:focus{
	outline: none;
}
textarea, input, select{
	box-sizing: border-box;
	width: 100%;
	border: none;
	border-radius: 10px;
	padding: 17px 25px;
	background-color: var(--color-cream);
	font-size: 15px;
	color: var(--color-blue);
}
input, select{
	height: 50px;
}
textarea{
	height: 194px;
}
select {
	padding-block: 10px;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg width='16' height='8' viewBox='0 0 16 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 0.999999L8 7L15 1' stroke='%23333259' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A");
	background-repeat: no-repeat;
	background-position: calc(100% - 25px);
}
input:focus, textarea:focus{
	outline: none;
}
input::placeholder, textarea::placeholder, select {
    color: var(--color-blue);
	opacity: 1;
}
.btn{
	padding: 17px 50px;
	border-radius: 10px;
	font-size: 15px;
	line-height: 1;
	font-weight: 400;
	transition: .3s;
	display: inline-block;
	text-transform: uppercase;
	position: relative;
	height: 50px;
}
.btn-orange{
	background-color: var(--color-orange);
	color: var(--color-cream);
	padding-inline: 47px;
}
.btn-orange:hover{
	background-color: var(--color-blue);
	color: var(--color-white);
}
.btn-white{
	background-color: var(--color-white);
	color: var(--color-blue);
}
.btn-white:hover{
	background-color: var(--color-blue-light);
	color: var(--color-white);
}
.bg {
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
}
.bg-cream{
	background-color: var(--color-cream);
}
.bg-blue{
	background-color: var(--color-blue);
}
.bg-blue-light{
	background-color: var(--color-blue-light);
}
.bg-orange{
	background-color: var(--color-orange);
}
.gap-10{
	gap: 10px;
}
.radius-15{
	border-radius: 15px;
}
.radius-25{
	border-radius: 25px;
}
.p-15{
	padding: 15px;
}
.py-15{
	padding-block: 15px;
}
.px-15{
	padding-inline: 15px;
}
.px-20{
	padding-inline: 20px;
}
.py-38{
	padding-block: 38px;
}
.py-35{
	padding-block: 35px;
}
.pt-100{
	padding-top: 100px;
}
.pb-100{
	padding-bottom: 100px;
}
.pt-50{
	padding-top: 50px;
}
.pb-50{
	padding-bottom: 50px;
}
.p-50{
	padding: 50px;
}
.py-50{
	padding-block: 50px;
}
.px-50{
	padding-inline: 50px;
}
.pt-38{
	padding-top: 38px;
}
.pb-38{
	padding-bottom: 38px;
}
.m-minus-20{
	margin-inline: -20px;
}
.m-20{
	margin-inline: 20px;
}
.overflow-visible{
	overflow: visible;
}
.container{
	max-width: 1330px;
	padding-inline: 15px;
	margin-inline: auto;
}
.mx-1400{
	max-width: 1400px;
  	margin-inline: auto;
}
.flex-1 {
	flex: 1;
}



/* header */

/* mmenu */
.mm-page {
	min-height: unset;
}
.mm-menu {
	display: none;
}
.modal-backdrop.show {
	opacity: .92;
}
.menu-trigger {
	display: none;
}



body.admin-bar .site-header {
  top: 32px;
}
.header-logo {
  max-width: 240px;
}
.header-menu ul {
  list-style: none;
  display: flex;
  gap: 15px;
}
.header-menu ul li{
	position: relative;
}
.header-menu ul li.current-menu-item a{
	color: var(--color-soft-orange);
}
.header-menu ul li a {
	padding-inline: 26px;
	font-size: 14px;
	text-transform: uppercase;
	line-height: 1;
	padding-block: 10px;
	display: inline-block;
	color: var(--color-blue);
	letter-spacing: 25%;
}
.header-menu ul li a:hover{
	color: var(--color-orange);
}
.button-group {
  display: flex;
  gap: 10px;
  justify-content: start;
  flex-wrap: wrap;
}
.header-buttons .button-group {
  display: flex;
  gap: 10px;
  justify-content: end;
}
.header-buttons .btn-orange {
	max-width: 200px;
}
.site-header {
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  width: 100%;
  z-index: 99;
  transition: .3s;
  padding-inline: 20px;
  padding-top: 15px;
  padding-bottom: 10px;
  background-color: var(--color-white);
}
.header-menu ul li .sub-menu {
  flex-direction: column;
  position: absolute;
  background-color: var(--color-cream);
  border-radius: 10px;
  left: 0;
  top: 100%;
  padding-block: 10px;
  transition: .3s;
  opacity: 0;
  pointer-events: none;
  width: 290px;
  box-shadow: 0px 10px 15px -3px rgba(0,0,0,0.1);
}
.header-menu ul li .sub-menu li a {
  color: var(--color-text);
}
.header-menu ul li .sub-menu li a:hover{
  color: var(--color-orange);
}
.header-menu ul li .sub-menu .current-menu-item a{
	color: var(--color-orange);
}
.header-menu ul li:hover .sub-menu{
  pointer-events: auto;
  opacity: 1;
}
.header-menu ul li:has(.sub-menu)::before {
  content: '';
  position: absolute;
  left: 27px;
  bottom: 0;
  width: 20px;
  height: 2px;
  background-color: var(--color-blue);
}
.header-menu ul li.current-menu-item a{
	color: var(--color-orange);
}
.header-menu ul li.current-menu-item:has(.sub-menu)::before {
	background-color: var(--color-orange);
}



/* banner */
._banner-row {
	gap: 10px;
	display: grid;
	grid-template-columns: 1fr 491px;
	align-items: stretch;
}
.banner-row {
	gap: 10px;
	display: flex;
}

.banner-content{
	align-content: center;
	padding-inline: 50px;
	padding-block: 100px;
	position: relative;
	overflow: hidden;
	z-index: 1;
	width: clamp(900px, 100%, 900px);
	min-height: 452px;
}

._banner-content-inner{
	max-width: calc(50% + 400px);
  	margin-left: auto;
}
body.home .banner-content::before,
body.page-template-suburb .banner-content::before {
  content: '';
  position: absolute;
  bottom: 0;
  right: -80px;
  width: 300px;
  height: 185px;
  background-image: url('https://frs.harmonisedstaging.au/wp-content/uploads/2026/05/banner-svg.png');
  background-repeat: no-repeat;
  background-size: contain;
  z-index: -1;
}
.banner-title {
  margin-block: 25px;
}
body.home .banner-title p {
	margin-bottom: 10px;
	max-width: 400px;
}
.banner-title h2 {
  margin-bottom: 25px;
  max-width: 800px;
}

@media (min-width: 767.98px) {
	.banner-media {
		flex: 1;
	}	
	.banner-large, 
	.page-template-service-child .banner-content, 
	.page-template-suburb .banner-content {
		min-height: 742px;
	}	
	
}

.banner-media img, .banner-media video {
	height: 100%;
	object-fit: cover;
	object-position: center;
	position: absolute;
	inset: 0;
}

/* call out */
.call-out-sec{
	margin-top: 10px;
}
.call-out-heading {
  max-width: 244px;
  width: 100%;
  padding-left: 35px;
}
.call-out-heading h3 {
  font-size: 32px;
  color: var(--color-cream);
}
.call-out {
  gap: 62px;
}
.call-out-content {
  gap: 10px;
}
.call-out-item {
  padding-block: 31px;
  padding-inline: 44px;
  gap: 25px;
}
.call-out-text h4 {
  font-size: 20px;
  color: var(--color-cream);
}
.call-out-icon {
	max-width: 40px;
}

/* services */
.services-heading {
	max-width: 444px;
	margin-inline: auto;
}
.services-btn {
	position: absolute;
	bottom: 15px;
	left: 15px;
	right: 15px;
	overflow: hidden;
}
.services-btn::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 0;
	transition: .4s;
	background-color: var(--color-blue);
}
.services-item:hover .services-btn::before{
	width: 100%;
}
.services-item:hover .service-btn-text h5{
	color: var(--color-cream);
}
.services-link::after {
	content: '';
	position: absolute;
	inset: 0;
}
.service-btn-text {
  padding-left: 15px;
}
.service-btn-text h5{
	transition: .4s;
}
.service-btn-icon {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
}
.service-btn-icon svg {
	color: var(--color-cream);
	width: 9px;
  	height: 18px;
}
.services-item img {
	aspect-ratio: 1 / 1.16;
	max-height: 532px;
}
.services-item:hover img {
	transform: scale(1.07);
}
.carousel-navigation button {
  border: navajowhite;
  background-color: var(--color-cream);
  max-width: 50px;
  height: 50px;
  border-radius: 15px;
  display: grid;
  place-items: center;
  color: var(--color-orange);
  padding: 0;
  width: 100%;
  transition: .3s;
}
.carousel-navigation button:hover{
	background-color: var(--color-blue);
	color: var(--color-cream);
}
.carousel-navigation button svg {
  width: 10px;
}
.carousel-pagination {
  text-align: center;
}
.carousel-navigation .swiper-pagination-bullet {
  width: 11px;
  height: 11px;
  margin-inline: 11px !important;
  background-color: var(--color-orange);
}
.carousel-navigation .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background-color: var(--color-orange);
}


/* craftsmanship */
.craftsmanship-title {
  margin-bottom: 25px;
}
.craftsmanship-content {
	padding-inline: 20px;
}
.craftsmanship-title h3 {
  margin-bottom: 25px;
}
.craftsmanship-buttons .button-group {
  justify-content: center;
}
.before-after-group img {
	aspect-ratio: 1 / 1.04;
	min-height: 468px;
	height: 100%;
}
.before-after-slider {
	overflow: visible;
}
.before-image::after, .after-image::after {
  content: "Before";
  position: absolute;
  right: 10px;
  bottom: 10px;
  background-color: var(--color-cream);
  font-size: 24px;
  font-weight: 500;
  line-height: 1;
  color: var(--color-blue);
  padding: 28px 30px;
  border-radius: 15px;
  transition: .4s;
}
.after-image::after{
	content: "After";
}
.before-image:hover img, .after-image:hover img {
  transform: scale(1.07);
}
.before-image:hover::after, .after-image:hover::after {
  background-color: var(--color-blue);
  color: var(--color-cream);
}


/* Choice */
.choice-title {
  max-width: 728px;
  margin-inline: auto;
  text-align: center;
}
.choice-title h3 {
  margin-bottom: 25px;
}
.choice-slide-img img {
  aspect-ratio: 1 / 0.88;
  min-height: 372px;
}
.choice-slide-content ul {
  padding-left: 25px;
}
.choice-slide-content h4 {
  margin-bottom: 25px;
}
.choice-slide-content p {
	margin-bottom: 0;
}
.choice-slide-buttons {
  margin-top: 25px;
}

/* CTA */
.cta-content h3 {
  margin-bottom: 25px;
  color: var(--color-cream);
}
.cta-buttons {
  margin-top: 25px;
}
.cta-buttons .button-group {
  justify-content: center;
}
.cta-content p {
  max-width: 695px;
  margin-inline: auto;
  color: var(--color-cream);
}
.cta-inner::before {
  content: '';
  position: absolute;
  inset: 0;
  background-color: var(--color-blue);
  opacity: 0.9;
}

/* reviews */
.reviews-title {
  padding-top: 25px;
  padding-bottom: 75px;
  gap: 30px;
}
.reviews-heading {
  max-width: 510px;
}
.reviews-sub-heading {
  max-width: 390px;
  width: 100%;
}
.author-name {
	font-size: 15px;
	font-weight: 700;
}
.reviews-btn {
  background-color: var(--color-cream);
  color: var(--color-blue);
  padding: 17px 50px;
  display: inline-block;
  margin-top: 25px;
  border-radius: 10px;
  font-size: 15px;
  line-height: 1;
}
.reviews-btn:hover {
  color: var(--color-cream);
  background-color: var(--color-orange);
}
.reviews-carousel {
  padding-inline: 75px;
}
.reviews-slide {
  padding: 50px;
  gap: 60px;
}
.reviews-slider .swiper-slide{
	align-content: center;
}
.reviews-text p {
  margin-bottom: 20px;
}
.reviews-text p:last-child {
  margin-bottom: 0;
}
.reviews-navigation {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  border: 0;
  max-width: 50px;
  width: 100%;
  height: 50px;
  background-color: var(--color-orange);
  color: var(--color-cream);
  border-radius: 15px;
  transition: .4s;
}
.reviews-navigation:hover{
	background-color: var(--color-blue);
}
.reviews-navigation.reviews-next {
  right: 0;
  left: auto;
}
.reviews-nav button{
	background-color: var(--color-orange);
	color: var(--color-cream);
}

/* contact */
.contact-title {
  color: var(--color-cream);
}
.contact-title h3 {
  margin-bottom: 25px;
}
.contact-info-item {
  color: var(--color-white);
  font-size: 24px;
  font-weight: 500;
  padding: 27px 48px;
  display: inline-block;
  line-height: 1;
  max-width: max-content;
  width: 100%;
}
.contact-info-item.email {
  padding-inline: 25px;
  text-decoration: underline;
  text-underline-offset: 5px;
}
.contact-form .row {
  --bs-gutter-x: 10px;
}
.input-item {
  margin-bottom: 10px;
}
.input-item.submit {
  margin-bottom: 0;
}
.input-item.submit .wpcf7-spinner {
  display: none;
}
.input-item.submit .btn {
  max-width: 100%;
}
.input-item.submit .btn:hover {
  background-color: var(--color-blue-light);
}

/* Pre Footer img */
.pre-footer-img {
  max-height: 371px;
}
.pre-footer-img-logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  max-width: 181px;
  max-height: 181px;
	opacity: .86;
}
.pre-footer-img::before {
  content: '';
  position: absolute;
  inset: 0;
  background-color: #000;
  opacity: 0.2;
}


/* FAQs */
.faq-accordion {
  max-width: 684px;
  margin-inline: auto;
}
.faq-heading {
	max-width: 518px;
	margin-inline: auto;
	padding-bottom: 50px;
}
.faq-collapse-content {
  display: none;
}
.faq-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 11px 25px;
  cursor: pointer;
  gap: 25px;
  border-radius: 10px;
}
.faq-icon svg{
	transition: .4s;
}
.faq-item.active .faq-icon svg {
	transform: rotate(180deg);
}
.faq-item {
  border-radius: 10px;
  margin-bottom: 10px;
}
.faq-item:last-child {
  margin-bottom: 0;
}
.faq-header h4 {
	font-size: 15px;
	font-weight: 600;
	color: var(--color-blue);
}
.faq-collapse-content {
  padding: 35px;
  background-color: var(--color-cream-light);
  border-radius: 10px;
  margin-top: 10px;
}
.faq-buttons {
  padding-top: 25px;
}
.faq-content :is(h1, h2, h3, h4, h5, h6) {
  font-size: 24px;
  margin-block: 20px;
}
.faq-content ul, .img-accordion-content ul {
  padding-left: 30px;
  margin-bottom: 25px;
}




/* Footer */
.footer-logo-group {
  max-width: 265px;
  width: 100%;
}
.policy-links {
  display: flex;
  align-items: center;
  gap: 5px;
}
.policy-links a {
  color: var(--color-blue);
}
.policy-links a:hover{
	color: var(--color-orange);
}
.footer-menu-group {
  max-width: 517px;
  width: 100%;
  gap: 73px;
}
.footer-menu-heading {
	font-weight: 600;
	padding-bottom: 15px;
}
.footer-menu ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.footer-menu ul li a {
	color: var(--color-blue);
	display: block;
}
.footer-menu ul li a:hover, .footer-links a:hover{
	color: var(--color-orange);
}
.footer-links {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.footer-link-item {
  display: block;
  color: var(--color-blue);
}
.footer-link-item.email {
	text-decoration: underline;
	text-underline-offset: 2px;
}
.footer-copyright {
  padding-block: 20px;
  background-color: var(--color-btn-bg);
}
.footer-bottom {
  padding-block: 20px;
  color: var(--color-white);
  margin-top: 10px;
}
.credit-text a {
  font-weight: 600;
  color: var(--color-white);
}
.credit-text a:hover{
	color: var(--color-orange);
}


/* Page Banner */
.banner-breadcrumb {
  margin-bottom: 25px;
}
.breadcrumb {
  margin: 0;
}
.breadcrumb ol {
  display: flex;
  list-style: none;
  gap: 15px;
  margin: 0;
  padding: 0;
  flex-wrap: wrap;
  text-align: start;
  row-gap: 2px;
  background-color: #FAE8E0;
  padding-inline: 15px;
  border-radius: 6px;
}
.breadcrumb ol li a {
  color: var(--color-blue);
  opacity: 32%;
  font-size: 12px;
  line-height: 1;
  text-transform: uppercase;
  padding-right: 15px;
  display: inline-block;
}
.breadcrumb ol li a:hover {
	opacity: 1;
}
.breadcrumb ol li span {
  color: var(--color-blue);
  text-transform: uppercase;
  font-size: 12px;
  line-height: 1;
  display: inline-block;
  letter-spacing: 25%;
}
.separator svg {
	width: 6px;
	height: 6px;
}

/* About Template */
.quality-bg {
  background-color: var(--color-cream-2);
  padding-block: 92px;
}
.quality-wrapper{
	gap: 40px;
}
.quality-content {
  max-width: 715px;
}
.quality-heading {
  max-width: 524px;
  width: 100%;
}

/* about slide */
.about-us-img {
  max-width: 275px;
  width: 100%;
}
.about-us-content {
  flex: 1;
  padding-inline: 35px;
  padding-top: 30px;
  padding-bottom: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 25px;
}
.about-us-img img {
  aspect-ratio: 1 / 1.68;
  border-radius: 15px;
	object-position: top center;
}
.about-heading {
  margin-bottom: 10px;
}
.about-position {
  margin-bottom: 20px;
  padding: 6px 15px;
  border-radius: 6px;
  background-color: var(--color-white);
  max-width: max-content;
}
.about-us-button {
  text-align: end;
}
.about-btn {
  display: inline-flex;
  align-items: center;
  gap: 25px;
  color: var(--color-blue);
  font-size: 15px;
  text-transform: uppercase;
}
.about-btn-icon {
  width: 50px;
  height: 50px;
  background-color: var(--color-orange);
  border-radius: 15px;
  display: grid;
  place-items: center;
  transition: .4s;
}
.about-btn:hover {
  color: var(--color-orange);
}
.about-btn:hover .about-btn-icon {
  background-color: var(--color-blue);
}
.about-btn-icon svg {
  width: 9px;
}

/* contact-us slider */
.contact-slider-heading {
	max-width: 914px;
	margin-inline: auto;
}
.contact-slider-heading h3 + p {
    margin-top: 25px;
}
.contact-slide-text {
  position: absolute;
  bottom: 15px;
  left: 15px;
  right: 15px;
  height: 80px;
}
.contact-slide-text p {
  text-align: center;
  width: 100%;
  line-height: 1.2;
  font-size: 20px;
  font-weight: 500;
  padding-inline: 10px;
}
.contact-slide-item img {
  height: 100%;
  aspect-ratio: 1 / 1.06;
  min-height: 315px;
}
.contact-slide-item:hover img{
	transform: scale(1.07);
}


/* Profile Template */
.profile-banner-grid {
  display: grid;
  grid-template-columns: 350px 1fr;
  gap: 10px;
  align-items: stretch;
}
.profile-banner-img img {
	max-height: 492px;
	height: 100%;
}
.profile-banner-content {
  align-content: center;
  padding: 50px;
  position: relative;
  overflow: hidden;
}
.profile-title {
  margin-top: 25px;
}
.profile-banner-buttons {
  margin-top: 25px;
}
.position {
  padding: 6px 15px;
  background-color: #FAE8E0;
  border-radius: 6px;
}
.profile-heading {
  gap: 25px;
}
.profile-banner-content::before {
	content: '';
	position: absolute;
	bottom: 0;
	right: -80px;
	width: 300px;
	height: 185px;
	background-image: url('https://frs.harmonisedstaging.au/wp-content/uploads/2026/05/banner-svg.png');
	background-repeat: no-repeat;
	background-size: contain;
}

/* profile content */
.profile-content :is(h1, h2, h3, h4, h5, h6) {
  font-size: 24px;
  margin-bottom: 25px;
  margin-top: 25px;
}
.profile-content :is(h1, h2, h3, h4, h5, h6):last-child{
  margin-bottom: 0;
}
.profile-content ul {
  padding-left: 25px;
  margin-bottom: 20px;
}

/* service template */
.services-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 10px;
}
.service-item-1, .service-item-2, .service-item-3 {
  grid-column: span 2;
}
.service-item-4, .service-item-5 {
  grid-column: span 3;
}

/* service child */
.child-cta {
  max-width: 672px;
  margin-inline: auto;
}
.child-cta-content {
  margin-bottom: 25px;
}
.child-cta-buttons .button-group {
  justify-content: center;
}
.child-cta-content h3 {
  margin-bottom: 25px;
}

/* image with text */
.img-with-text-img img {
  aspect-ratio: 1 / 1.15;
}
.img-with-text-row {
	--bs-gutter-x: 0;
}
.img-with-text-content {
  margin-bottom: 25px;
}
.img-with-text-content h4, .img-with-text-content h3 {
  margin-bottom: 25px;
}

/* child before after */
.child-before-after-heading {
  max-width: 518px;
  width: 100%;
}
.child-before-after-subheading {
  max-width: 728px;
  width: 100%;
}
.child-before-after-button .button-group {
  justify-content: end;
}
.child-before-after-button {
  margin-top: 25px;
}
.child-before-after-button .btn-white {
  background-color: var(--color-cream);
}
.child-before-after-button .btn-white:hover {
  background-color: var(--color-blue-light);
}
.child-before-after-title {
  padding-top: 35px;
}
.child-before-after-carousel {
  padding-inline: 75px;
}
.before-after-navigate {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  border: none;
  background-color: var(--color-orange);
  color: var(--color-cream);
  width: 50px;
  height: 50px;
  border-radius: 15px;
}
.child-beforeAfter-next.before-after-navigate {
  left: auto;
  right: 0;
}

/* contact template */
.marquee-title {
  max-width: 702px;
  margin-inline: auto;
  margin-top: 35px;
  margin-bottom: 25px;
}
.marquee-title h3 {
  margin-bottom: 25px;
}
.marquee-wrapper {
  background-color: var(--color-white);
  padding-block: 50px;
  border-radius: 15px;
}
.marquee-track {
   display: flex;
   width: max-content;
   animation: marquee-scroll 40s linear infinite;
}
.marquee-wrapper:hover .marquee-track {
   animation-play-state: paused;
}
.marquee-item {
   flex-shrink: 0;
   padding: 0 36px;
   display: flex;
   align-items: center;
}
@keyframes marquee-scroll {
   from {
      transform: translateX(0);
   }
   to {
      transform: translateX(-50%);
   }
}


/* blog */
body.page-template-blog .page-banner-buttons {
	display: none;
}
.blog-image {
  max-width: 482px;
  width: 100%;
}
.blog-content {
  flex: 1;
}
.blog-image img {
  aspect-ratio: 1 / 0.82;
}
.blog-item:hover .blog-image img{
	transform: scale(1.06);
}
.blog-item {
  margin-bottom: 10px;
}
.blog-item:last-child{
	margin-bottom: 0;
}
.blog-content h4 {
  margin-bottom: 25px;
  color: var(--color-blue);
}
.blog-excerpt {
  margin-block: 25px;
}
.blog-read-more {
  text-align: end;
}
.blog-info {
  gap: 10px;
}
.blog-read {
	display: inline-flex;
	gap: 25px;
	align-items: center;
	color: var(--color-blue);
	font-weight: 400;
	text-transform: uppercase;
	font-size: 15px;
}
.blog-read:hover{
	color: var(--color-orange);
}
.blog-read-icon {
	width: 50px;
	height: 50px;
	background-color: var(--color-orange);
	border-radius: 15px;
	display: grid;
	place-items: center;
	transition: .4s;
}
.blog-read:hover .blog-read-icon{
	background-color: var(--color-blue-light);
}
.blog-read svg {
  width: 10px;
}
.blog-super-title, .blog-category a {
	padding: 10px 15px;
	line-height: 1;
	color: var(--color-blue);
	text-transform: uppercase;
	letter-spacing: 5%;
	font-size: 12px;
	background-color: var(--color-cream-1);
	border-radius: 6px;
	display: block;
}
.page-banner-title.single, .page-banner-title.single h2 {
	margin-bottom: 0;
}
.pagination-numbers {
  display: flex;
  align-items: center;
  gap: 4px;
}
.pagination-number {
  width: 50px;
  height: 50px;
  border-radius: 15px;
  color: var(--color-blue);
  font-size: 15px;
  font-weight: 400;
  line-height: 1;
  display: grid;
  place-items: center;
}
.pagination-number.active, .pagination-number:hover {
  background-color: var(--color-orange);
  color: var(--color-cream);
}
.pagination-arrow {
  color: var(--color-orange);
  border-radius: 15px;
  background-color: var(--color-cream);
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
}
.pagination-arrow svg {
  width: 10px;
}
.pagination-arrow:hover:not(.pagination-arrow.disabled) {
  color: var(--color-cream);
  background-color: var(--color-orange);
}
.pagination-arrow.disabled {
  opacity: 0.5;
}


/* single page */
.post-content {
  margin-top: 25px;
}
.post-content .wp-block-columns {
  margin-top: 45px;
  gap: 35px;
}
.post-content .wp-block-image img {
  border-radius: 25px;
  aspect-ratio: 4 / 2;
}
.post-content h1, .post-content h2 {
  color: var(--color-heading);
}
.post-content h1{
	font-size: 50px;
}
.post-content h2 {
  font-size: 48px;
}
.post-content h1, .post-content h2, .post-content h3, .post-content h4, .post-content h5, .post-content h6 {
  margin-bottom: 25px;
  margin-top: 45px;
}


/* popular posts */
.row.popular-post-row {
  --bs-gutter-x: 10px;
  margin-top: 45px;
  row-gap: 10px;
}
.popular-post-img img {
  aspect-ratio: 1 / 0.92;
}
.popular-post-text {
  padding-inline: 15px;
  padding-block: 30px;
  display: flex;
  flex-direction: column;
  gap: 25px;
}
.popular-post-text h4 {
  font-size: 24px;
}
.pp-button a {
  max-width: 100%;
}
.popular-post-card {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.popular-post-card:hover .popular-post-img img{
	transform: scale(1.06);
}

/* 404 */
.not-found {
  text-align: center;
}
.not-found h1 {
  font-size: 52px;
  font-family: var(--secondary-font);
  color: var(--color-heading);
  letter-spacing: normal;
  text-transform: capitalize;
  margin-bottom: 25px;
}
.not-found .btn {
  margin-top: 25px;
}
.not-found p {
  font-weight: 400;
  font-size: 16px;
}

/* Thank you */
body.page-id-372 .banner {
	display: none;
}
.thank-you h3.wp-block-heading {
  font-size: 48px;
}
.thank-you p {
  font-size: 16px;
  line-height: 1.5;
}
.entry-content h1{
	font-size: 52px;
	letter-spacing: normal;
	font-family: var(--secondary-font);
	text-transform: capitalize;
}
.entry-content :is(h1, h2, h3, h4, h5, h6) {
  color: var(--color-heading);
  margin-bottom: 25px;
}
.entry-content :is(h1, h2, h3, h4, h5, h6):not(:first-child) {
  margin-top: 45px;
}
.entry-content :is(h1, h2, h3, h4) {
  font-size: 32px;
}




/* Responsive */


@media (max-width: 1299.98px){
	.header-menu ul li a{
		padding-inline: 8px;
	}
	
	.banner-content {
		max-width: 700px;
	}	

	/* call out */
	.banner-content-inner{
		max-width: 100%;
	}
	.call-out {
		gap: 40px;
	}
	.call-out-item {
		padding-block: 28px;
		padding-inline: 35px;
	}
	.call-out-text h4 {
		font-size: 18px;
	}
	.contact-slide-text p{
		font-size: 16px;
	}
	.about-us-img {
		max-width: 232px;
	}
}
@media (max-width: 1199.98px){

	/* m-menu */
	.mm-panel ul li a {
		font-size: 14px;
		color: var(--color-blue) !important;
		text-transform: uppercase;
		font-weight: 400;
		letter-spacing: 25%;
	}
	.mm-panel ul li a:hover{
		color: var(--color-orange) !important;
	}
	.mm-menu {
		z-index: 100;
		display: block;
	}
	.mm-wrapper__blocker.mm-blocker.mm-slideout{
		z-index: 99;
	}
	.mm-panels {
		background: var(--color-white);
	}
	.mm-menu {
		--mm-size: 100%;
		--mm-color-background: var(--color-white);
	}
	body.admin-bar .mm-menu {
		top: 32px;
	}
	.menu-close-btn {
		position: absolute;
		right: 20px;
		z-index: 9;
		font-size: 18px !important;
		color: var(--color-text) !important;
		top: 15px;
		font-size: 16px;
	}
	.mm-navbar__title span {
		display: none;
	}
	.mm-panel--opened .mm-navbar__title span {
		display: block;
		font-size: 0;
	}
	#menu .mm-navbar .mm-navbar__title span {
		display: none;
	}
	.mm-panel .mega-menu {
		position: relative !important;
	}
	.mm-panels .sub-menu li a {
		padding: 15px 20px !important;
	}
	.menu-trigger{
		display: block;
	}
	.menu-trigger a {
		flex-direction: column;
		row-gap: 8px;
		position: relative;
		z-index: 999;
		cursor: pointer;
		border-radius: 100px;
		height: 35px;
		width:35px;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	.menu-trigger span {
		display: block;
		height: 2px;
		width: 24px;
		background-color: var(--color-blue);
		border-radius: 100px;
	}
	
	/* menu-end */
	
	/* 	mbl menu btn */
	.mbl-menu-btn::after {
	  display: none;
	}
	.mbl-menu-btn {
	  margin-top: 10px;
	  text-align: center;
	}
	.mbl-menu-btn a.mm-listitem__text {
		background-color: var(--color-orange);
		margin-inline: 15px;
		border-radius: 10px;
		color: var(--color-cream) !important;
		transition: .3s;
		font-size: 15px;
   		letter-spacing: 0%;
	}
	.mbl-menu-btn a.mm-listitem__text:hover{
		background-color: var(--color-blue);
		color: var(--color-cream) !important;
	}
	.mbl-menu-quote a.mm-listitem__text {
	  background-color: var(--color-cream-1);
	  color: var(--color-blue) !important;
	}
	
	.px-50 {
		padding-inline: 30px;
	}

	.header-menu {
		display: none;
	}
	.banner-content {
		padding-block: 100px;
	}
	h2 {
		font-size: 48px;
	}
	.header-buttons {
		max-width: 460px;
		display: flex;
		gap: 10px;
		align-items: center;
	}
	.header-buttons .button-group {
		width: 100%;
	}
	

	/* Banner */
	.banner-row {
		grid-template-columns: 1fr 390px;
	}

	/* call out */
	.call-out {
		gap: 20px;
	}
	.call-out-heading {
		max-width: 215px;
	}
	.call-out-item {
		padding-block: 18px;
		padding-inline: 30px;
		gap: 20px;
	}
	.call-out-text h4 {
		font-size: 16px;
	}
	.call-out-heading h3 {
		font-size: 28px;
	}

	/* services */
	.service-btn-text h5 {
		font-size: 20px;
	}

	/* Contact */
	.contact-info-item.email {
		font-size: 18px;
	}

	
}
@media (max-width: 991.98px){
	h3, .h3 {
		font-size: 44px;
	}
	.pt-100{
		padding-top: 80px;
	}
	.pb-100{
		padding-bottom: 80px;
	}
	.trust-bar {
		padding-block: 30px;
	}

	/* Banner */
	.banner-content {
		padding-block: 80px;
		padding-inline: 30px;
	}
	.banner-content {
		max-width: 500px;
	}	
	
	.banner-row {
		grid-template-columns: 1fr 300px;
	}
	.banner-title h2 br, .banner-title p br {
		display: none;
	}

	/* call out */
	.call-out-heading {
		max-width: 100%;
		padding-left: 0;
		padding-top: 10px;
	}
	.call-out-content {
		width: 100%;
	}
	.call-out-icon {
		width: 37px;
	}

	/* reviews */
	.reviews-btn{
		padding-inline: 35px;
	}

	/* contact */
	.contact-info {
		margin-top: 33px;
		margin-bottom: 70px;
	}


	/* Footer */
	.footer-menu-group{
		display: grid !important;
		grid-template-columns: repeat(2, 1fr);
		gap: 35px;
		max-width: 100%;
		margin-block: 36px;
	}

	/* About Template */
	.quality-bg{
		padding-block: 50px;
	}
	.quality-content, .quality-heading {
		max-width: 100%;
	}
	.quality-wrapper{
		gap: 35px;
	}

	/* profile template */
	.profile-banner-content::before {
		display: none;
	}
	.profile-banner-content {
		padding-inline: 30px;
	}
	.profile-banner-grid{
		grid-template-columns: 250px 1fr;
	}

	/* service template */
	.service-item-1, .service-item-2 {
		grid-column: span 3;
	}
	.service-item-3 {
		grid-column: span 6;
	}

	/* image with text */
	.img-with-text-img img {
		aspect-ratio: auto;
	}
	.img-with-text-text{
		padding-top: 35px;
		padding-bottom: 20px;
	}

	/* child before after */
	.child-before-after-carousel {
		padding-inline: 0;
	}

	/* Blog */
	.blog-image img {
		aspect-ratio: 4 / 2;
	}
	.blog-image, .blog-content {
		max-width: 100%;
	}

}
@media (max-width: 782.98px){
	body.admin-bar .site-header, body.admin-bar .mm-menu{
		top: 46px;
	}
}
@media (max-width: 767.98px){
	.px-50 {
		padding-inline: 20px;
	}
	.pt-100{
		padding-top: 60px;
	}
	.pb-100{
		padding-bottom: 60px;
	}
	.pt-50{
		padding-top: 35px;
	}
	.pb-50{
		padding-bottom: 35px;
	}
	.md-m-0{
		margin-inline: 0;
	}
	.overflow-md-hidden{
		overflow: hidden;
	}
	.site-header {
		padding: 10px;
	}
	.header-logo {
		max-width: 186px;
	}
	.header-buttons .button-group {
		display: none;
	}
	.header-buttons {
		max-width: max-content;
	}
	body{
		padding: 10px;
	}
	h3, .h3 {
		font-size: 40px;
	}
	h4, .h4{
		font-size: 26px;
	}
	.banner-row {
		grid-template-columns: repeat(1, 1fr);
	}
	.banner-row {
		flex-direction: column;
	}	
	.banner-content {
		max-width: 100%;
	}	
	
	.banner-title{
		margin-block: 20px;
	}
	.banner-title h2 {
		margin-bottom: 20px;
	}
	.banner-content {
		padding-block: 50px;
		padding-inline: 35px;
	}
	.banner-content::before{
		display: none;
	}
	.banner-media {
		aspect-ratio: 1 / 1.38;
	}

	/* call out */
	.call-out-heading h3 {
		font-size: 24px;
	}
	.call-out-text h4 {
		font-size: 20px;
	}
	.call-out-item {
		padding: 30px 44px;
	}

	/* Before After */
	.before-image::after, .after-image::after {
		padding-block: 15px;
		font-size: 20px;
	}
	.before-after-slider {
		overflow: hidden;
	}

	/* choice */
	.choice-slide-content{
		padding-top: 25px;
		padding-bottom: 20px;
	}

	/* reviews */
	.reviews-carousel {
		padding-inline: 10px;
	}
	.reviews-title {
		padding-inline: 20px;
		padding-bottom: 50px;
		padding-top: 10px;
	}
	.reviews-slide{
		padding-inline: 35px;
		gap: 40px;
	}
	.reviews-slider .swiper-slide {
		align-content: start;
	}	
	

	/* Faqs */
	.faq-collapse-content {
		padding: 35px;
	}
	.faq-header{
		padding-block: 15px;
	}

	/* FAQs */
	.faq-content :is(h1, h2, h3, h4, h5, h6){
		font-size: 18px;
		margin-top: 25px;
	}
	.faq-content ul {
		padding-left: 25px;
	}

	/* Profile Banner */
	.profile-banner-grid{
		grid-template-columns: repeat(1, 1fr)
	}
	.profile-banner-content {
		order: 1;
	}
	.profile-banner-img {
		order: 2;
	}
	.profile-banner-img img {
		max-height: 100%;
	}

	/* contact slider */
	.contact-slider-heading h3 br {
		display: none;
	}

	/* marquee */
	.marquee-wrapper {
		padding-block: 30px;
	}

	/* single page */
	.post-content h1{
		font-size: 42px;
	}
	.post-content h2 {
		font-size: 38px;
	}

	/* blog */
	.pagination-number{
		width: 32px;
		height: 32px;
		border-radius: 8px;
	}
	.pagination-arrow svg {
		width: 32px;
		height: 32px;
	}

	/* 404 */
	.not-found h1 {
		font-size: 40px;
	}
}
@media (max-width: 600.98px){
	body.admin-bar .site-header, body.admin-bar .mm-menu{
		top: 92px;
	}
	body.admin-bar .site-header.sticky-active{
		top: 0;
	}
	body.admin-bar.header-sticky .mm-menu {
		top: 0;
	}
}
@media (max-width: 575.98px){
	.p-x-0{
		padding-inline: 0;
	}
	.padding-top-0{
		padding-top: 0;
	}
	.button-group{
		justify-content: center;
	}
	.button-group .btn{
		width: 100%;
	}

	/* banner */
	.super-title {
		margin-inline: auto;
	}

	/* call out */
	.call-out-heading {
		max-width: 230px;
		padding-top: 35px;
		padding-bottom: 20px;
	}

	
	/* services */
	.service-btn-text h5 {
		font-size: 24px;
	}
	.services-item img{
		height: 532px;
	}
	.services-navigation {
		padding-top: 35px;
	}
	.services-grid {
		grid-template-columns: repeat(1, 1fr);
	}
	.services-item {
		grid-column: auto;
	}

	/* Before After Carousel */
	.before-after-group {
		padding: 0;
		background-color: transparent;
	}

	/* Reviews */
	.reviews-slide{
		gap: 25px;
	}

	/* contact */
	.contact-title, .contact-info {
		width: 100%;
	}
	.contact-info-item {
		max-width: 100%;
		padding-inline: 0;
		text-align: center;
	}
	.contact-info-item.email {
		padding-inline: 0;
		font-size: 15px;
	}
	.contact-row {
		--bs-gutter-x: 15px;
	}

	/* Footer */
	.site-footer {
		padding-block: 0;
	}
	.footer-logo-group {
		max-width: 100%;
	}
	.footer-logo {
		margin-inline: auto;
		max-width: 191px;
	}
	.footer-menu-group {
		grid-template-columns: repeat(1, 1fr);
	}

	/* about us slider */
	.about-us-img {
		max-width: 100%;
	}
	.about-us-slide {
		padding-bottom: 35px;
	}
	.about-us-content {
		padding-inline: 0;
		text-align: center;
	}
	.about-position {
		margin-inline: auto;
	}
	.about-us-button {
		text-align: center;
	}
	.about-us-img img {
		aspect-ratio: 1 / 1.3;
	}

	/* image with text */
	.img-with-text-img img {
		aspect-ratio: 1;
	}
	.img-with-text-text{
		padding-inline: 15px;
	}

	/* marquee */
	.marquee-item {
		padding-inline: 20px;
	}

	/* blog */
	.blog-image img {
		aspect-ratio: 1 / 1;
	}
	.blog-content {
		padding-inline: 5px;
		text-align: center;
	}
	.blog-read {
		max-width: 100%;
	}
	.blog-info .super-title {
		margin-inline: 0;
	}
	.blog-banner img {
		max-height: 100%;
	}
	.post-content .wp-block-image img {
		aspect-ratio: 4 / 3;
	}

	.banner-breadcrumb ol {
		margin-inline: auto;
		justify-content: center;
	}
}