/*
	Theme Name: Hello Elementor Child
	Theme URI: https://elementor.com/hello-theme/?utm_source=wp-themes&utm_campaign=theme-uri&utm_medium=wp-dash
	Description: Hello Elementor is a lightweight and minimalist WordPress theme that was built specifically to work seamlessly with the Elementor site builder plugin. The theme is free, open-source, and designed for users who want a flexible, easy-to-use, and customizable website. The theme, which is optimized for performance, provides a solid foundation for users to build their own unique designs using the Elementor drag-and-drop site builder. Its simplicity and flexibility make it a great choice for both beginners and experienced Web Creators.
	Author: Elementor Team
	Author URI: https://elementor.com/?utm_source=wp-themes&utm_campaign=author-uri&utm_medium=wp-dash
	Version: 1.0.0
	Requires at least: 6.0
	Tested up to: 6.8
	Requires PHP: 7.4
	License: GNU General Public License v3 or later.
	License URI: https://www.gnu.org/licenses/gpl-3.0.html
	Template: hello-elementor
	Text Domain: hello-elementor
	Tags: accessibility-ready, flexible-header, custom-colors, custom-menu, custom-logo, featured-images, rtl-language-support, threaded-comments, translation-ready,
*/

.banner-header h2{
	font-family: 'Zodiak', serif !important;
}
.banner-header h2 span{
	font-style: italic;
}
.banner-content{
	font-family: 'Bespoke Serif', serif !important;
}
body{
	background-color:#F6F2ED !important;
}
.rpv-inline-btn a.elementor-button{
	position: relative;
	padding-left: 20px !important;
	padding-right: 20px !important;
	display: inline-block;
	transition: all 0.4s;
	overflow: hidden;
}
.project-category-list h2 a{
    position: relative;
    padding-left: 30px;
	padding-right: 30px;
	transition: all 0.4s;
}
.project-category-list h2 a::before, .rpv-inline-btn a.elementor-button::before{
	content:"";
	position: absolute;
	left: 0;
	top: 0;		
	opacity: 1;
  transform: translateX(0);
  transition: all 0.4s ease;
	width: 15px;    /* set width */
  height: 15px;   /* set height */
  background: url('/wp-content/uploads/2025/09/rpv-left-arr-1.png') no-repeat center;
  background-size: auto 14px; /* scale proportionally */
}
.project-category-list h2 a::before{
    top: 50%;
    transform: translate(0,-50%);
}
.project-category-list h2 a::after, .rpv-inline-btn a.elementor-button::after{
	content:"";
	position: absolute;
	right: -20px;
	top: 0;	
	opacity: 0;
  transform: translateX(20px);
  transition: all 0.4s ease;
	height: 15px;
	width: 15px;    /* set width */
  height: 15px;   /* set height */
  background: url('/wp-content/uploads/2025/09/rpv-right-arr-1.png') no-repeat center;
  background-size: auto 14px; /* scale proportionally */
}
.project-category-list h2 a::after{
    top: 50%;
    transform: translate(20px,-50%);
}
.project-category-list h2 a:hover, .rpv-inline-btn a.elementor-button:hover{
	color: #E4681B !important;
	padding-left: 0 !important;
}
.rpv-inline-btn a.elementor-button:hover::before{
	left: -20px;
	opacity: 0;
  transform: translateX(-20px);
}
.project-category-list h2 a:hover::before{
   	left: -20px;
	opacity: 0;
	top:50%;
  transform: translate(-20px,-50%); 
}
.rpv-inline-btn a.elementor-button:hover::after{
	right: 0;
	opacity: 1;
  transform: translateX(0);
}
.project-category-list h2 a:hover::after{
	right: 0;
	opacity: 1;
	top:50%;
  transform: translate(0,-50%);
}
.rpv-btn a.elementor-button{
	position: relative;
	padding-left: 40px !important;
	padding-right: 60px !important;
	display: inline-block;
	transition: all 0.4s;
	overflow: hidden;
	width: 250px;
}
.rpv-btn a.elementor-button::before{
	content:"";
	position: absolute;
	left: 0px;
	top: 50%;		
	opacity: 1;
  transform: translate(20px,-50%);
  transition: all 0.4s ease;
	width: 15px;    /* set width */
  height: 15px;   /* set height */
  background: url('/wp-content/uploads/2025/09/rpv-left-arr-1.png') no-repeat center;
  background-size: auto 14px; /* scale proportionally */
}
.rpv-btn a.elementor-button::after{
	content:"";
	position: absolute;
	right: -20px;
	top: 50%;	
	opacity: 0;
  transform: translate(20px, -50%);
  transition: all 0.4s ease;
	height: 15px;
	width: 15px;    /* set width */
  height: 15px;   /* set height */
  background: url('/wp-content/uploads/2025/09/white-right-arr-1.png') no-repeat center;
  background-size: auto 14px; /* scale proportionally */
}
.rpv-btn a.elementor-button:hover{
	padding-left: 20px !important;
}
.rpv-btn a.elementor-button:hover::before{
	left: -20px;
	opacity: 0;
	top:50%;
  transform: translate(-20px,-50%);
}
.rpv-btn a.elementor-button:hover::after{
	right: 20px;
	top: 50%;
	opacity: 1;
  transform: translate(0px,-50%);
}
.top-slider {
  position: fixed;
  top: 102;
  left: 0;
  width: 100%;
  height: 100vh;
}
.next-section {
  margin-top: 100vh;
}
/* Home page Service Section style */

.service-list-sec{
    
}
.service-list-sec .single-service-sec:last-child{
    border-bottom: 0;
}
.single-service-sec{
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 60px;
    border-bottom: 1px solid #173851;
    padding-bottom: 30px;
    margin-bottom: 30px;    
    color: #74818B;
    font-size: 80px;
    font-family: 'Zodiak';
    font-weight: 700;
}
.service-details-container h2 , .service-details-container p, .home-project-category-list h2 , .home-project-category-list p{
    color: #173851;
    font-family: "Inter", sans-serif;
    line-height: 131.9%;
    display: block;
}
.home-project-category-list h2,
.service-details-container h2{
    margin-top: 0;
    
}
.service-details-container h2 , .home-project-category-list h2 {
    font-weight: 600;
    font-size: 22px;
}
.service-details-container p, .home-project-category-list p{
    font-weight: 400;
    font-size: 16px;
}
.service-number-container h2{
        color: #74818B;
    font-size: 60px;
    font-family: 'Zodiak';
    font-weight: 700;
    opacity: 15%;
    font-style: italic;
}
.home-project-category-list{
    padding-left: 0;
}
.home-project-category-list li{
    list-style:none;
    border-bottom: 1px solid #173851;
    padding-bottom: 20px;
    margin-bottom: 20px; 
}
.contact-row label{
    color: #000000;
    font-family: "Inter", sans-serif;
    line-height: 173%;
    margin-bottom: 10px;
    font-size: 16px;
}
.contact-row{
    display: flex;
    gap: 20px;
    margin-bottom: 10px;
}
.contact-row .contact-col{
    width: 100%;
}
.contact-row input[type="text"],
.contact-row input[type="email"],
.contact-row input[type="tel"],
.contact-row textarea{
    border: 1px solid #173851;
    border-radius: 8px;
    color: #000000;
    font-family: "Inter", sans-serif;
    line-height: 173%;
    font-size: 16px;
    padding: 6px 20px;
    background: transparent;
}
.contact-row textarea{
    height: 100px;
}
.contact-row button[type="submit"] {
  border: 1px solid #173851;
  border-radius: 12px;
  padding: 15px 60px 15px 40px;
  font-family: "Inter", Sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 100%;
  color: #000000;
  background: transparent;
    position: relative;
	display: inline-block;
	transition: all 0.4s;
	overflow: hidden;
	width: 240px;
}
.contact-row button[type="submit"]::before{
	content:"";
	position: absolute;
	left: 0px;
	top: 50%;		
	opacity: 1;
  transform: translate(20px,-50%);
  transition: all 0.4s ease;
	width: 15px;    /* set width */
  height: 15px;   /* set height */
  background: url('/wp-content/uploads/2025/09/rpv-left-arr-1.png') no-repeat center;
  background-size: auto 14px; /* scale proportionally */
}
.contact-row button[type="submit"]::after{
	content:"";
	position: absolute;
	right: -20px;
	top: 50%;	
	opacity: 0;
  transform: translate(20px, -50%);
  transition: all 0.4s ease;
	height: 15px;
	width: 15px;    /* set width */
  height: 15px;   /* set height */
  background: url('/wp-content/uploads/2025/09/white-right-arr-1.png') no-repeat center;
  background-size: auto 14px; /* scale proportionally */
}
.contact-row button[type="submit"]:hover{
	padding-left: 20px;
	background-color:#E4681B;
    border-color:#E4681B;
    color: #ffffff;
}
.contact-row button[type="submit"]:hover::before{
	left: -20px;
	opacity: 0;
	top:50%;
  transform: translate(-20px,-50%);
}
.contact-row button[type="submit"]:hover::after{
	right: 20px;
	top: 50%;
	opacity: 1;
  transform: translate(0px,-50%);
}

.project-category-list{
    list-style: none;
    padding-left: 0;
}
.project-category-list h2 a{
    font-family: "Inter", Sans-serif;
  font-size: 18px;
  font-weight: 600;
  line-height: 131.9%;
  color: #173851;
display: block;
}
.project-category-list li{
    border-bottom: 1px solid #173851;
    margin-bottom: 20px;
}
.project-category-block .project-details{
        background: #ffffff;
    padding: 30px;
    margin-top: -20px;
    z-index: 10;
    position: relative;
    max-width: 80%;
    margin-left: auto;
    margin-right: auto;
}
.project-category-block .project-item{
    margin-bottom: 60px;
}


/* Base two-column layout */
.services-section .e-con-inner {
  display: flex !important;
  align-items: flex-start !important;
  gap: 40px; /* space between columns */
}

.services-left {
  flex: 0 0 35% ;      /* left column takes 35% */
  max-width: 35%;
}

.services-right {
  flex: 0 0 65%;      /* right column takes 65% */
  max-width: 65%;
}
@media only screen and (min-width: 768px){
/* Sticky behavior for left column */
.services-left {
  position: sticky !important;
  top: 100px !important;   /* adjust to match your header height */
  align-self: flex-start !important;
}
}
/* Mobile responsive (stacked layout) */
@media (max-width: 1024px) {
  .services-section .e-con-inner {
    flex-direction: column;
  }

  .services-left,
  .services-right {
    flex: 0 0 100%;
    max-width: 100%;
  }

  .services-left {
    position: relative;
    top: auto;
  }
}

.home-project-section{
   transition: background-position 0.1s ease; 
}

/* Fixed while active */
.home-project-section.bg-fixed-active {
  background-attachment: fixed !important;
  background-size: cover !important;
  
}

/* After active is removed at bottom */
.home-project-section.bg-fixed-bottom {
  background-attachment: fixed !important;
  /*background-position: bottom left !important; *//* stick to bottom */
  background-size: cover !important;
}

.project-category-block .project-details h4{
    color: #173851;
    font-family: "Inter", Sans-serif;
  font-size: 16px;
    font-weight: 400;
  line-height: 131.9%;
  margin:0 0 5px 0;
}
.project-category-block .project-details h3{
    margin: 0 0 15px 0;
}
.project-category-block .project-details h3{
    color: #173851;
    font-family: "Inter", Sans-serif;
  font-size: 24px;
    font-weight: 600;
  line-height: 131.9%;
  display: block;
}
.project-category-block .project-details .project-content p{
    color: #173851;
    font-family: "Inter", Sans-serif;
  font-size: 16px;
    font-weight: 400;
  line-height: 131.9%;
  margin-bottom: 0;
}

@media only screen and (max-width: 768px){
    .service-details-container h2, .home-project-category-list h2{
        font-size: 18px;
    }
    .service-number-container h2{
        font-size: 30px;
    }
    .single-service-sec{
        gap: 30px;
        padding-bottom: 10px;
    margin-bottom: 20px;
    }
    .contact-row {
    display: block;
    }
}
