/* 
Theme Name: Hello Elementor Child
Theme URI: https://github.com/elementor/hello-theme-child/
Description: Hello Elementor Child is a child theme of Hello Elementor, created by Elementor team
Author: Elementor Team
Author URI: https://elementor.com/
Template: hello-elementor
Version: 2.0.0
Text Domain: hello-elementor-child
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: flexible-header, custom-colors, custom-menu, custom-logo, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready
*/

/* Add your custom styles here */

html, body { overflow-x: hidden; }
@media only screen and (max-width: 767px) {
	h1 {
		font-size: 36px !important;
		line-height: 1.2 !important;
	}
	p {
		font-size: 14px !important;
		
	}
}
a {
	color: initial;
}
.tm { 
	font-size: .8em; 
	vertical-align: super; 
	line-height: 1; 
}
.blog-style *,
.dark-font *,
.wp-block-heading {
	color: #373737 !important;
}
.blog-style h1 {
	font-size: 50px !important;
	margin-top: 75px !important;
	margin-bottom: 50px !important;
}
.blog-style h2,
.blog-style h3 {
	font-size: 18px !important;
}
.post-tags {
	padding: 25px !important;
}
.post-tags * {
	color: #373737 !important;
}
h5.elementor-heading-title {
	margin-top: 20px;
}
.pdp-read-more-white,
.pdp-read-more-white visited{
	color: #fff !important;
	text-decoration: underline !important;
	font-weight: bold !important;
}
.pdp-read-more-dark,
.pdp-read-more-dark visited {
	color: #373737 !important;
	text-decoration: underline !important;
	font-weight: bold !important;
}
/* .anchor-offset {
  scroll-margin-top: -150px; /* Adjust this to match your header height */
} */
/* Add black gradient fade at the top of hero sections */
#content::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 120px; /* adjust as needed */
  background: linear-gradient(to bottom, rgba(0,0,0,0.8), rgba(0,0,0,0));
  z-index: 1;
  pointer-events: none;
}
.home .breadcrumb_last {
	display: none;
}
.page-content > div > .elementor-element {
	padding-left: 1em !important;
	padding-right: 1em !important;
}
@media only screen and (min-width: 1050px) {
	.elementor-nav-menu--main li a {
		margin-inline-end: 0 !important;
	}
}
@media only screen and (min-width: 1200px) {
	.elementor-nav-menu--main li a {
		margin-inline-end: 24px !important;
	}
}
@media only screen and (min-width: 1400px) {
	.elementor-nav-menu--main li a {
		margin-inline-end: 40px !important;
	}
}
@media only screen and (min-width: 1700px) {
	.elementor-nav-menu--main li a {
		margin-inline-end: 70px !important;
	}
}


.elementor-menu-toggle,
.transparent-header div.elementor-menu-toggle svg,
.black-header div.elementor-menu-toggle svg {
	color: #fff !important;
	fill: #fff !important;
}
.elementor-post__title a {
	color: #1A1A1A !important;
}
a.elementor-post__read-more {
	font-family: Inter !important;
	color: #1A1A1A !important;
    font-style: initial !important;
}
.search header {
	background: #000;
}
.single-post header {
	background: #fff;
}
header.white-header {
	background: #fff;
}
header.black-header {
	background: #000;
}
.white-header .elementor-menu-toggle svg {
	fill: #000 !important;
}
.transparent-header .elementor-shortcode a,
.black-header .elementor-shortcode a,
.black-header .elementor-shortcode * {
	color: #fff !important;
}
.transparent-header.scrolled {
  background-color: #000 !important;
}
.yoast-breadcrumbs * {
	font-weight: 400 !important;
	font-family: Inter !important;
}
.white-header .yoast-breadcrumbs * {
	color: #000 !important;
}
.elementor-nav-menu--main .elementor-item {
    color: #fff !important;
}
.white-header .elementor-nav-menu--main .elementor-item {
    color: #1A1A1A !important;
}
.white-header .elementor-nav-menu--main .elementor-item:hover {
    color: #1A1A1A !important;
}

header.white-header .elementor-button {
	color: #fff !important;
}
@media only screen and (max-width: 767px) {
	footer .elementor-element div.elementor-menu-toggle svg {
		fill: #FFF !important;
		margin-left: -10px;
	}
}
/* buttons */
.white-outline-button a {
	background-color: transparent !important;
    color: #fff !important;
    border-color: #fff !important;
	padding: 20px 32px !important;
}
.grey-outline-button a {
	background-color: transparent !important;
    color: #373737 !important;
    border-color: rgba(0, 0, 0, 0.20) !important;
	padding: 20px 32px !important;
}
.asset-button a {
  display: inline-flex;
  align-items: center;
  gap: 8px; /* Space between image and text */
  padding: 8px 18px 8px 12px !important;
  background-color: #4F616E !important;
  color: #fff !important;
  border: 1px solid #4F616E !important;
  border-radius: 8px !important;
  text-decoration: none;
  font-weight: 500;
  font-size: 16px;
  position: relative;
}

.asset-button.grey a {
  background-color: #4F616E !important;
  color: #fff !important;
  border: 1px solid #4F616E !important;
}
.asset-button.blue a {
  background-color: #D7EFFF !important;
  color: #373737 !important;
  border: 1px solid #D7EFFF !important;
}
.asset-button.yellow a {
  background-color: #FFE4C3 !important;
  color: #1A1A1A !important;
  border: 1px solid #FFE4C3 !important;
}

.asset-button a::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.asset-button.grey.catalog a::before {
  background-image: url('/wp-content/uploads/2025/04/v6-icon.png');
}
.asset-button.grey.brochure a::before {
  background-image: url('/wp-content/uploads/2025/04/v6-icon.png');
}
.asset-button.blue.catalog a::before {
  background-image: url('/wp-content/uploads/2025/04/v6-icon-blue.png');
}
.asset-button.blue.brochure a::before {
  background-image: url('/wp-content/uploads/2025/04/v6-icon-blue.png');
}
.asset-button.yellow.catalog a::before {
  background-image: url('/wp-content/uploads/2025/04/v6-icon-yellow_2x.png');
}
.asset-button.yellow.brochure a::before {
  background-image: url('/wp-content/uploads/2025/04/v6-icon-yellow_2x.png');
}
@media only screen and (max-width: 767px) {
	.category-lp-hero .elementor-element {
		border: none !important;
	}
	.industry-leading .elementor-swiper-button-prev {
		left: -28px !important;
		top: -5% !important;
	}
	.industry-leading .elementor-swiper-button-next {
		right: -28px !important;
		top: -5% !important;
	}
}
/* Resource Page Buttons */
.resource-asset-button a {
  display: flex;
  align-items: center;
  background-color: #fff !important;
  color: #373737 !important;
  border: 1px solid #fff !important;
  padding: 16px 24px !important; /* Adjusted for better alignment */
  height: auto !important;
  border-radius: 9999px; /* Optional: for pill shape */
  font-weight: 500;
  gap: 12px; /* Space between icon and text */
  text-decoration: none;
  white-space: nowrap;
}
.resource-asset-button.border a {
  border: 1px solid #AFC5D4 !important;
}

.resource-asset-button a::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  flex-shrink: 0;
}

.resource-asset-button.blue a::before {
  background-image: url('/wp-content/uploads/2025/04/v6-icon-blue.png');
}
.resource-asset-button.red a::before {
  background-image: url('/wp-content/uploads/2025/04/v6-icon_red.png');
}
.resource-asset-button.green a::before {
  background-image: url('/wp-content/uploads/2025/04/v6-icon_green.png');
}

.menu-item a {
	font-family: Inter !important;
	font-size: 16px !important;
	line-height: 19px !important;
	font-weight: 600 !important;
/* 	color: #fff !important; */
	text-transform: none !important;
    letter-spacing: 0 !important;
}
.menu-item a:hover {
	color: #eee !important;
}
/* Reset default underline */
.elementor-nav-menu > .menu-item > a {
  position: relative;
  text-decoration: none;
}

/* Hover underline effect for top-level items only */
.elementor-nav-menu > .menu-item > a::after {
  content: '';
  position: absolute;
  bottom: 4px;
  left: 0;
  width: 0;
  height: 2px !important;
  background-color: #2b9adf !important;
  transition: width 0.3s ease;
}

.elementor-nav-menu > .menu-item > a:hover::after {
  width: 100%;
}
.sub-menu {
	background-color: #EBF4FB !important;
	border-radius: 8px;
	width: 270px !important;
	padding-top: 10px !important;
	padding-bottom: 15px !important;
}
.elementor-nav-menu .sub-arrow {
	display: none !important;
}
.elementor-nav-menu .menu-item .sub-menu a {
	color: #27333B !important;
	font-family: Barlow Semi Condensed !important;
	font-size: 16px !important;
	line-height: 120% !important;
}
.elementor-nav-menu--dropdown .menu-item {
  display: block;
  position: relative;
}
.elementor-nav-menu--dropdown .menu-item > a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  box-sizing: border-box;
}
.elementor-nav-menu--dropdown .menu-item > a:hover {
  background-color: #c1e1f9 !important;
  color: #27333B !important;
  border-radius: 0 !important;
}
.elementor-nav-menu--dropdown .menu-item > a::after {
  content: '';
  display: inline-block;
  background-image: url('/wp-content/uploads/2025/04/Arrow.png');
  background-size: contain;
  background-repeat: no-repeat;
  width: 12px;
  height: 12px;
  margin-left: 10px;
}
.page-header {
	display: none;
}
.header-search form {
	width: 120px !important;
	height: 36px !important;
	min-height: 36px !important;
}
.header-search input.e-search-input {
	width: 160px !important;
	height: 48px !important;
	min-height: 48px !important;
	line-height: 48px !important;               
	padding: 0 40px 0 15px !important;          
	color: #fff !important;
	background-color: transparent !important;
	border: 1px solid #525252 !important;
	border-radius: 999px !important;
	background-image: url('/wp-content/uploads/2025/04/search_icon.svg');
	background-repeat: no-repeat;
	background-position: right 12px center;
	background-size: 20px 20px;
	box-sizing: border-box;
	font-size: 14px !important;
	font-family: Inter !important;
	font-weight: 600;
}
.header-search input::placeholder {
	color: #fff !important;
	font-family: Inter !important;
	font-size: 14px !important;
	font-weight: 600;
}
.white-header .header-search input::placeholder {
	color: #1a1a1a !important;
}
.white-header .header-search input.e-search-input {
	background-image: url('/wp-content/uploads/2025/04/dark_search_icon.svg');
	color: #1a1a1a !important;
}
.large-number {
	font-family: "Barlow Semi Condensed";
	font-size: 50px !important;
	line-height: 120% !important;
	color: #FFAE46 !important;
	font-weight: 600 !important;
}
.less-padding-button a {
	padding: 16px 24px 16px 24px !important;
}
.get-in-touch a {
	width: 136px !important;
}
.learn-more-link {
  display: inline-flex;
  align-items: center;
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: #27333B;
  text-decoration: none;
  gap: 8px;
  line-height: 1;
}
.learn-more-link .arrow-icon {
  width: 24px;
  height: auto;
  position: relative;
  top: 2px; 
  transition: transform 0.2s ease;
}

.learn-more-link:hover .arrow-icon {
  transform: translateX(4px);
}
.swiper-pagination {
	margin-top: 32px;
}
.elementor-widget-n-carousel.elementor-pagination-position-outside>.elementor-widget-container .swiper-pagination-bullet {
	height: 10px;
	width: 10px;
}
.swiper-pagination-bullet {
	height: 10px !important;
	width: 10px !important;
}
.elementor-swiper-button.elementor-swiper-button-next svg, 
.elementor-swiper-button.elementor-swiper-button-prev svg {
	fill: #000 !important;
	width: 95px !important;
	height: 95px !important;
}
.elementor-swiper-button svg path {
  fill: #000 !important;
}
.elementor-swiper-button svg g,
.elementor-swiper-button svg circle {
  filter: none !important;
}
/* Homepage accordion */
.home .e-n-accordion-item {
	height: 220px !important;
	border-bottom: 1px solid #DADADA;
	justify-content: center !important;
}
@media only screen and (max-width: 767px) {
	.home .e-n-accordion-item {
		height: 265px !important;
	}
}
.home .e-n-accordion-item-title {
	display: flex !important;
	align-items: center !important;
	border: none !important;
}
.home .e-n-accordion-item-title-header {
  flex: 1; /* This makes the text take up remaining space */
}
.home .e-n-accordion-item-title-icon {
  margin-left: auto; /* Pushes the icon to the far right */
  display: flex;
  align-items: center;
}
.home .e-n-accordion-item-title-text {
	font-family: "Barlow Semi Condensed", Inter !important;
	font-size: 30px !important;
	line-height: 120% !important;
	color: #27333B !important;
	font-weight: 600;
}
.home .e-n-accordion-item-title-icon {
	font-weight: 400 !important;
	color: #27333B !important;
}
.e-n-accordion-item svg {
	height: 30px !important;
}

.tech-link {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%; /* or a fixed width if you prefer */
  max-width: 600px; /* optional max-width */
  padding: 10px 0;
  text-decoration: none;
  color: #1A1A1A;
}
.tech-link .arrow-icon-grey {
  width: 24px;
  height: auto;
  position: relative;
  top: 1px; 
  transition: transform 0.2s ease;
}

.tech-link:hover .arrow-icon-grey {
  transform: translateX(4px);
}
.arrow-icon-grey {
  height: 12px; /* or whatever height you need */
  width: auto;
  margin-left: 8px;
}
/* back to top */
html {
  scroll-behavior: smooth;
}
.back-to-top {
  display: inline-block;
  margin-top: 2rem;
  font-size: 0.9rem;
  text-decoration: none;
  transition: color 1s ease;
}
footer .elementor-nav-menu > .menu-item > a::after {
  bottom: -6px;
}
/* PDP button */
.pdp-button a {
  display: flex;
  align-items: center;
  height: 74px;
  padding: 24px 32px !important;
  padding-left: 60px !important; /* sets text approx. 60px from left edge */
  gap: 12px;
  border: 1px solid #27333B !important;
  background-color: transparent !important;
  color: #1a1a1a !important;
  text-align: left;
  line-height: 1;
  position: relative;
}

/* Left icon */
.pdp-button a::before {
  content: "";
  position: absolute;
  left: 24px;
  top: 50%;
  transform: translateY(-50%);
  background-image: url('/wp-content/uploads/2025/04/pdf_icon.png');
  background-size: contain;
  background-repeat: no-repeat;
  width: 28px;
  height: 28px;
}
.pdp-button.bim a::before {
  background-image: url('/wp-content/uploads/2025/08/bim.png');
}
.pdp-button.cad a::before {
  background-image: url('/wp-content/uploads/2025/08/dwg.png');
}
.pdp-button.sketch-up a::before {
  background-image: url('/wp-content/uploads/2025/08/skp.png');
}
.pdp-button.contact-us a::before {
  background-image: none;
}

/* Right icon */
.pdp-button a::after {
  content: "";
  position: absolute;
  right: 24px;
  top: 50%;
  transform: translateY(-50%);
  background-image: url('/wp-content/uploads/2025/04/download_icon_2x.png');
  background-size: contain;
  background-repeat: no-repeat;
  width: 28px;
  height: 28px;
}
.e-n-tabs-heading {
	border-top: 1px solid rgba(0, 0, 0, 0.10);
	border-bottom: 1px solid rgba(0, 0, 0, 0.10);
}
.case-study-tabs .e-n-tabs-heading {
	border: none;
}
/* Container */
.e-n-tab-title {
  position: relative;
  display: inline-block;
  font-weight: bold;
  color: #1a1a1a;
}

/* Animated underline */
.e-n-tab-title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 0;
  height: 2px;
  background-color: #000;
  transition: width 0.3s ease;
}

/* On hover - underline grows */
.e-n-tab-title:hover::after {
  width: 100%;
}
.comments-area {
	display: none;
}
/* Document Library Pro */
.dataTables_filter label {
	color: #000;
}
.col-date_modified,
.col-file_type,
.dataTables_filter {
	color: #000;
}
.dataTables_filter label {
	font-weight: 700 !important;
}
.select2-dropdown.posts-table-dropdown .select2-results__option {
	background-color: #fff !important;
	color: #000 !important;
	
}
.select2-container--default .select2-results__option--highlighted[aria-selected] {
	background-color: #5897fb !important;
	color: #fff !important;
}
.posts-table-controls * {
	color: #000 !important;
}
.posts-table-controls input[type=search] {
	background-color: #fff !important;
	border: 1px solid #B9B9B9 !important;
	border-radius: 99999px !important;
}
.posts-table-select-filters {
	z-index: 1;
}
table.dataTable thead>tr>th {
	border: 0 !important;
}
.posts-data-table td {
	vertical-align: middle !important;
}
.dlp-single-wrap .dlp-single-left {
	display: none;
}
.dlp-single-wrap .dlp-single-right {
	border: 1px solid #B9B9B9 !important;
	padding: 20px;
	color: #373737 !important;
	border-radius: 8px;
	margin-top: 60px;
	margin-bottom: 60px;
	width: 50% !important;
}
#dlp-document-info-list > div {
	line-height: 30px;
}
/* Elementor form */
.elementor-form textarea::placeholder {
	color: #373737 !important;
}
.elementor-form textarea,
.elementor-form input,
.elementor-form select {
	border-radius: 8px !important;
	border: 1px solid #B9B9B9 !important;
	color: #000 !important;
}
.elementor-field-type-submit {
	width: 25% !important;
	margin-top: 35px !important;
}
.elementor-form .elementor-button[type="submit"]  {
	background-color: transparent !important;
    color: #373737 !important;
    border-color: #1A1A1A;
	padding: 24px 48px !important;
	border-width: 2px !important;
}
.elementor-social-icons-wrapper {
	margin-left: -10px;
    margin-top: -10px;

}
.elementor-social-icons-wrapper .elementor-grid-item {
	margin-right: -10px;
}
.elementor-message {
	color: #000 !important;
}
/* FAQ accordion */
.faq-accordion .e-n-accordion-item {
	border-bottom: 1px solid #DADADA;
	justify-content: center !important;
}
.faq-accordion .e-n-accordion-item-title {
	display: flex !important;
	align-items: center !important;
	border: none !important;
}
.faq-accordion .e-n-accordion-item-title-header {
  flex: 1; /* This makes the text take up remaining space */
}
.faq-accordion .e-n-accordion-item-title-icon {
  margin-left: auto; /* Pushes the icon to the far right */
  display: flex;
  align-items: center;
}
.faq-accordion .e-n-accordion-item-title-text {
	font-family: "Barlow Semi Condensed", Inter !important;
	font-size: 30px !important;
	line-height: 120% !important;
	color: #27333B !important;
	font-weight: 600;
	padding-bottom: 10px;
}
.faq-accordion .e-n-accordion-item-title-icon {
	font-weight: 400 !important;
	color: #27333B !important;
}
.faq-posts .elementor-post__title {
	line-height: 1px !important;
}
.faq-posts .elementor-post__title a {
	font-size: 30px !important;
}
.faq-posts .elementor-post__meta-data span + span:before {
	display: none !important;
}
.faq-posts .elementor-post-date {
	font-family: Inter !important;
	color: #BB7821;
	font-size: 14px !important;
}
.faq-posts .elementor-post__meta-data {
	line-height: 1px;
}

@media only screen and (max-width: 767px) {
	.category-lp-subheader .elementor-element {
		border: none !important;
		margin-bottom: 5px;
		margin-top: 5px;
	}
	.category-lp-subheader .elementor-element:first-child {
		margin-top: 10px;
	}
	.category-lp-subheader .elementor-element:last-child {
		margin-bottom: 10px;
	}
}
@media only screen and (min-width: 768px) and (max-width: 1049px) {
	.category-lp-subheader .elementor-element {
		border: none !important;
	}
}
@media only screen and (min-width: 1050px) {
	.category-lp-subheader > .e-con-inner {
	  margin-left: auto !important;
	  margin-right: auto !important;
	  display: flex !important;
	  flex-wrap: nowrap !important;
	  justify-content: center !important;
	  align-items: center !important;
	  width: 100% !important;
	  gap: 0 !important;
	}
	.category-lp-subheader > .e-con-inner > .e-child {
		flex: 0 0 auto !important;
		width: auto !important;
		padding-right: 0;
	}
}
@media only screen and (min-width: 1050px) {
	.category-lp-subheader > .e-con-inner {
	  gap: 20px !important;
	}
	.category-lp-subheader > .e-con-inner > .e-child {
		padding-right: 10px;
	}
}
@media only screen and (min-width: 1250px) {
	.category-lp-subheader > .e-con-inner {
	  gap: 50px !important;
	}
	.category-lp-subheader > .e-con-inner > .e-child {
		padding-right: 40px;
	}
}
.bottom-gradient {
  position: relative;
  overflow: hidden;
}

.bottom-gradient::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  top: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0) 50%);
  z-index: 1;
  pointer-events: none;
}
.bottom-gradient > .elementor-element {
  position: relative;
  z-index: 2;
}
.products-used a {
	color: #C5DAF4 !important;
}
.products-used > div {
	border-bottom: 1px solid #657A87;
}

/* Base layout: 3 equal columns with gap-safe widths */
.tech-resources-module > .e-con-inner > .e-con-full {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 2rem;
}

.tech-resources-module > .e-con-inner > .e-con-full > .e-con-full {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  flex: 1 1 calc(33.333% - 1.4rem); /* subtract approx half the gap */
  height: 460px;
  box-sizing: border-box;
}

/* Between 1200px and 768px: fix column height, prevent wrapping */
@media (max-width: 1200px) and (min-width: 768px) {
  .tech-resources-module > .e-con-inner > .e-con-full {
    flex-wrap: nowrap;
  }

  .tech-resources-module > .e-con-inner > .e-con-full > .e-con-full {
    flex: 1 1 calc(33.333% - 1.4rem);
    height: 550px;
  }
}

/* Below 768px: stack vertically */
@media (max-width: 767px) {
  .tech-resources-module > .e-con-inner > .e-con-full {
    flex-direction: column !important;
    flex-wrap: nowrap !important;
  }

  .tech-resources-module > .e-con-inner > .e-con-full > .e-con-full {
    width: 100% !important;
    max-width: 100% !important;
    height: 350px !important;
	min-height: 350px !important;
  }
}

/* Ensure the "See all" buttons stick to bottom */
.tech-resources-module .elementor-widget-button {
  margin-top: auto;
  margin-bottom: 100px;
}
.col-custom_file_type,
.dataTables_empty {
	color: #000 !important;
}
.dlp-document-info .dlp-download-link::after {
  content: "Click here to download";
  display: block;
  font-size: 14px;
  color: #333;
  margin-top: 6px;
  text-align: center; /* optional */
}
.category-lp-subheader .elementor-widget-heading {
	height: 45px !important;
}
.category-lp-subheader h5 {
	margin-top: 10px !important;
}