.elementor-kit-3{--e-global-color-primary:#2e518b;--e-global-color-secondary:#1f3d6f;--e-global-color-text:#0B0F14;--e-global-color-accent:#3366ff;--e-global-color-d302e97:#F7F4EE;--e-global-color-0a4e1e6:#4B5563;--e-global-color-2de42fb:#E6DFD4;--e-global-typography-primary-font-family:"Archivo";--e-global-typography-primary-font-weight:800;--e-global-typography-primary-letter-spacing:-0.5px;--e-global-typography-secondary-font-family:"Archivo";--e-global-typography-secondary-font-weight:700;--e-global-typography-text-font-family:"Inter";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Inter";--e-global-typography-accent-font-weight:600;font-family:"Inter", Sans-serif;font-size:17px;line-height:1.6em;}.elementor-kit-3 e-page-transition{background-color:#FFBC7D;}.elementor-kit-3 h1{font-family:"Archivo", Sans-serif;font-size:64px;font-weight:800;line-height:1.05em;}.elementor-kit-3 h2{font-family:"Archivo", Sans-serif;font-size:44px;font-weight:800;line-height:1.1em;}.elementor-kit-3 h3{font-family:"Archivo", Sans-serif;font-size:28px;font-weight:700;line-height:1.2em;}.elementor-kit-3 h4{font-family:"Archivo", Sans-serif;font-size:22px;font-weight:700;}.elementor-kit-3 button,.elementor-kit-3 input[type="button"],.elementor-kit-3 input[type="submit"],.elementor-kit-3 .elementor-button{font-family:"Inter", Sans-serif;font-weight:700;letter-spacing:0.5px;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1240px;}.e-con{--container-max-width:1240px;}.elementor-widget:not(:last-child){margin-block-end:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}.site-header .site-branding{flex-direction:column;align-items:stretch;}.site-header{padding-inline-end:0px;padding-inline-start:0px;}.site-footer .site-branding{flex-direction:column;align-items:stretch;}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-kit-3 h1{font-size:38px;}.elementor-kit-3 h2{font-size:30px;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}/* Start custom CSS *//* ============================================================
   TRE Construction kit-wide custom CSS
   Lives in the kit's custom_css; emitted on every page.
   ============================================================ */

:root {
	--tre-primary:    #2e518b;
	--tre-primary-dk: #1f3d6f;
	--tre-accent:     #3366ff;
	--tre-ink:        #0B0F14;
	--tre-surface:    #F7F4EE;
	--tre-muted:      #4B5563;
	--tre-border:     #E6DFD4;
	--tre-header-h:   72px;
}
@media (max-width: 900px) { :root { --tre-header-h: 64px; } }
@media (max-width: 600px) { :root { --tre-header-h: 60px; } }

body { background: #fff; color: var(--tre-ink); }

/* Eyebrow label */
.tre-eyebrow .elementor-heading-title {
	font-size: 13px !important;
	font-weight: 800 !important;
	text-transform: uppercase;
	letter-spacing: 2px;
	line-height: 1.2;
	color: var(--tre-primary);
}

/* ----- Theme Builder header (#site-header) — fixed height = --tre-header-h ----- */
#site-header {
	display: flex !important;
	flex-direction: row !important;
	flex-wrap: nowrap !important;
	align-items: center !important;
	justify-content: flex-start !important;
	gap: 24px;
	padding: 0 28px !important;
	height: var(--tre-header-h);
	min-height: var(--tre-header-h);
	max-width: 100% !important;
	width: 100% !important;
}
@media (max-width: 900px) {
	#site-header { padding: 0 16px !important; }
}
#site-header > * {
	flex: 0 0 auto !important;
	max-width: none !important;
	min-width: 0;
}
/* Logo: capped to header height; SVG natural size doesn't blow out the row */
#site-header > .tre-header-logo,
#site-header .tre-header-logo {
	width: 150px !important;
	max-width: 150px !important;
	max-height: calc(var(--tre-header-h) - 16px);
	overflow: hidden;
}
#site-header .tre-header-logo .elementor-widget-container,
#site-header .tre-header-logo img {
	width: 100% !important;
	max-width: 150px !important;
	max-height: calc(var(--tre-header-h) - 16px) !important;
	height: auto !important;
	object-fit: contain;
	display: block;
}
/* Nav menu: shrink-to-fit content, no wrap, push the right CTA (desktop only) */
#site-header > .elementor-widget-nav-menu { flex: 0 1 auto !important; }
@media (min-width: 901px) {
	#site-header .elementor-nav-menu--main {
		display: flex !important;
		flex-direction: row !important;
		flex-wrap: nowrap !important;
	}
	#site-header .elementor-nav-menu--main ul.elementor-nav-menu {
		display: flex !important;
		flex-wrap: nowrap !important;
		white-space: nowrap !important;
		gap: 2px;
	}
	#site-header .elementor-nav-menu--main a.elementor-item {
		padding: 8px 10px !important;
		white-space: nowrap;
	}
}
/* Hide the inline phone number in the header CTA group on narrower desktops
   to keep the 6-item nav from colliding with the right-side controls. The
   "Get a quote" button stays. Phone is still in the footer, and a tappable
   phone glyph is injected on mobile via the hero JS. */
@media (max-width: 1279px) and (min-width: 901px) {
	#site-header > .tre-header-cta .elementor-widget-text-editor { display: none !important; }
}
#site-header > .tre-header-cta {
	margin-left: auto !important;
	width: auto !important;
	max-width: max-content !important;
	flex: 0 0 auto !important;
	flex-direction: row !important;
	align-items: center !important;
	gap: 14px !important;
}
@media (max-width: 900px) {
	#site-header { padding: 10px 16px !important; gap: 12px; }
	#site-header > .tre-header-cta { gap: 8px !important; }
	#site-header > .tre-header-cta .elementor-widget-text-editor { display: none !important; }
}
@media (max-width: 600px) {
	#site-header > .tre-header-logo { width: 130px !important; max-width: 130px !important; }
}

/* ============================================================
   HERO (re-creation of original tc-carousel as native widgets)
   The hero is built from a Container with .tre-hero class containing:
     - .tre-hero-bg-stack (six containers, each with one slide bg-image)
     - .tre-hero-branding (logo + nav-menu + Contact button)
     - .tre-hero-content (heading + body for the active slide, x6 stacked)
     - .tre-hero-stats (5 counters)
     - .tre-hero-tabs (6 tab labels at bottom)
   The Custom-Code JS rotates which children of .tre-hero-bg-stack and
   .tre-hero-content carry the .is-active class.
   ============================================================ */
.tre-hero {
	position: relative;
	width: 100%;
	height: calc(100vh - var(--tre-header-h));
	min-height: calc(100vh - var(--tre-header-h));
	overflow: hidden;
	color: #fff;
	background: #000;
}
/* On the home page the TB header is hidden, hero takes full viewport.
   The hero carries its own branding card. */
body.home .elementor-location-header { display: none !important; }
body.home .tre-hero,
.tre-hero--home {
	height: 100vh !important;
	min-height: 100vh !important;
}
.tre-hero .tre-hero-bg-stack > .e-con,
.tre-hero .tre-hero-bg-stack > .e-con-inner,
.tre-hero .tre-hero-bg-stack {
	position: absolute;
	inset: 0;
	z-index: 1;
}
.tre-hero .tre-hero-bg-slide {
	position: absolute !important;
	inset: 0 !important;
	width: 100% !important;
	height: 100% !important;
	opacity: 0;
	transition: opacity 1s ease-in-out;
	background-size: cover;
	background-position: center;
}
.tre-hero .tre-hero-bg-slide::after {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,0.18);
	z-index: 2;
}
.tre-hero .tre-hero-bg-slide::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0,0,0,0.72), transparent 60%);
	z-index: 3;
}
.tre-hero .tre-hero-bg-slide.is-active {
	opacity: 1;
	z-index: 4;
}

/* Hero branding card — prominent logo plus inline nav, top-left.
   Desktop / large tablet: floating dark card pinned top-left.
   Mobile: see the slim header bar override further down. */
.tre-hero .tre-hero-branding {
	position: absolute !important;
	top: 32px !important;
	left: 32px !important;
	z-index: 6;
	background: rgba(0,0,0,0.55);
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
	padding: 14px 22px !important;
	border-radius: 12px;
	flex-direction: row !important;
	align-items: center !important;
	gap: 24px !important;
	width: auto !important;
	max-width: calc(100% - 64px);
	border: 1px solid rgba(255,255,255,0.08);
}
.tre-hero .tre-hero-branding .tre-hero-logo {
	flex: 0 0 auto !important;
	width: auto !important;
	max-width: none !important;
}
.tre-hero .tre-hero-branding .tre-hero-logo .elementor-widget-container,
.tre-hero .tre-hero-branding .tre-hero-logo img {
	display: block !important;
	height: 130px !important;
	max-height: 130px !important;
	width: auto !important;
	max-width: none !important;
}
.tre-hero .tre-hero-branding .tre-hero-nav-row {
	flex-direction: row !important;
	gap: 4px !important;
	align-items: center !important;
}
.tre-hero .tre-hero-branding .tre-hero-nav-link {
	color: #fff !important;
	font-size: 15px !important;
	font-weight: 600 !important;
	letter-spacing: 0.4px;
	text-decoration: none !important;
	padding: 10px 14px;
	border-radius: 6px;
	transition: background 0.2s, color 0.2s;
	white-space: nowrap;
	display: inline-block;
}
.tre-hero .tre-hero-branding .tre-hero-nav-link:hover {
	background: rgba(255,255,255,0.12);
	color: #fff !important;
}
.tre-hero .tre-hero-branding .tre-hero-nav-cta {
	background: var(--tre-primary) !important;
	color: #fff !important;
	font-weight: 700 !important;
	letter-spacing: 0.5px;
	margin-left: 4px;
}
.tre-hero .tre-hero-branding .tre-hero-nav-cta:hover {
	background: var(--tre-primary-dk) !important;
}

/* Mobile header utility buttons (call + hamburger) — injected by JS,
   shown only on mobile. Both are 44×44 to meet touch-target guidance. */
.tre-hero-hamburger,
.tre-hero-callbtn {
	display: none;
	background: transparent;
	border: 0;
	width: 44px;
	height: 44px;
	padding: 0;
	margin: 0;
	cursor: pointer;
	color: #fff;
	align-items: center;
	justify-content: center;
	border-radius: 6px;
	flex: 0 0 auto;
}
.tre-hero-hamburger:focus-visible,
.tre-hero-callbtn:focus-visible {
	outline: 2px solid #fff;
	outline-offset: 2px;
}
/* Call button — phone glyph in a brand-blue rounded square so it reads
   as a primary action distinct from the hamburger. */
.tre-hero-callbtn {
	background: var(--tre-primary);
	color: #fff;
	transition: background 0.18s ease, transform 0.18s ease;
	text-decoration: none;
}
.tre-hero-callbtn:hover { background: var(--tre-primary-dk); }
.tre-hero-callbtn:active { transform: scale(0.94); }
.tre-hero-callbtn svg {
	width: 20px;
	height: 20px;
	fill: currentColor;
}
.tre-hero-mobile-utils {
	display: none;
	align-items: center;
	gap: 8px;
	flex: 0 0 auto;
}
.tre-hero-hamburger span {
	display: block;
	width: 22px;
	height: 2px;
	background: #fff;
	position: relative;
	transition: transform 0.25s ease, opacity 0.25s ease, top 0.25s ease;
}
.tre-hero-hamburger span::before,
.tre-hero-hamburger span::after {
	content: "";
	position: absolute;
	left: 0;
	width: 22px;
	height: 2px;
	background: #fff;
	transition: transform 0.25s ease, top 0.25s ease;
}
.tre-hero-hamburger span::before { top: -7px; }
.tre-hero-hamburger span::after  { top:  7px; }
.tre-hero-hamburger.is-open span { background: transparent; }
.tre-hero-hamburger.is-open span::before { top: 0; transform: rotate(45deg); }
.tre-hero-hamburger.is-open span::after  { top: 0; transform: rotate(-45deg); }

/* Mobile nav — injected by JS. A compact dropdown sheet that slides down
   from the slim header, NOT a fullscreen takeover. Tap outside (the
   transparent backdrop) closes it. */
.tre-hero-mobilenav-backdrop {
	position: fixed;
	inset: 0;
	z-index: 99;
	background: rgba(0, 0, 0, 0.35);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.2s ease, visibility 0.2s ease;
}
.tre-hero-mobilenav-backdrop.is-open {
	opacity: 1;
	visibility: visible;
}
.tre-hero-mobilenav {
	position: fixed;
	top: 60px;
	right: 8px;
	z-index: 101;
	min-width: 220px;
	max-width: calc(100vw - 16px);
	background: rgba(11, 15, 20, 0.97);
	-webkit-backdrop-filter: blur(12px);
	backdrop-filter: blur(12px);
	border: 1px solid rgba(255,255,255,0.08);
	border-radius: 10px;
	box-shadow: 0 12px 32px rgba(0,0,0,0.45);
	display: flex;
	flex-direction: column;
	padding: 6px;
	gap: 2px;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-6px) scale(0.98);
	transform-origin: top right;
	transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease;
}
.tre-hero-mobilenav.is-open {
	opacity: 1;
	visibility: visible;
	transform: translateY(6px) scale(1);
}
.tre-hero-mobilenav a {
	display: block;
	color: #fff;
	font-size: 16px;
	font-weight: 600;
	letter-spacing: 0.2px;
	text-decoration: none;
	padding: 12px 16px;
	border-radius: 6px;
	text-align: left;
	transition: background 0.15s ease;
}
.tre-hero-mobilenav a:hover,
.tre-hero-mobilenav a:focus-visible {
	background: rgba(255,255,255,0.08);
}
.tre-hero-mobilenav a:last-child {
	margin-top: 4px;
	background: var(--tre-primary);
	color: #fff;
	font-weight: 700;
	text-align: center;
}
.tre-hero-mobilenav a:last-child:hover { background: var(--tre-primary-dk); }

/* Big logo card — visible on mobile only, anchored beneath the slim
   header, centered, prominent enough that the company name is the first
   thing you see. */
.tre-hero-mobilelogo {
	display: none;
}
@media (max-width: 767px) {
	.tre-hero-mobilelogo {
		display: flex;
		position: absolute;
		left: 16px;
		top: 76px;
		z-index: 5;
		padding: 0;
		background: transparent;
		border: 0;
		border-radius: 0;
		box-shadow: none;
		max-width: calc(100% - 96px); /* leave room for the hamburger */
		justify-content: flex-start;
		align-items: center;
		text-decoration: none;
	}
	/* Recolor the logo to white silhouette via filter (the source SVG uses
	   dark-navy + blue gradient fills which are invisible on dark slides);
	   add a soft drop shadow so it stays legible on bright slide images. */
	.tre-hero-mobilelogo img {
		display: block;
		height: 116px;
		max-height: 116px;
		width: auto;
		max-width: 280px;
		filter: brightness(0) invert(1) drop-shadow(0 2px 6px rgba(0,0,0,0.55));
	}
}
@media (max-width: 360px) {
	.tre-hero-mobilelogo { left: 12px; top: 68px; max-width: calc(100% - 80px); }
	.tre-hero-mobilelogo img { height: 92px; max-height: 92px; max-width: 220px; }
}

@media (max-width: 1024px) {
	.tre-hero .tre-hero-branding {
		top: 20px !important;
		left: 20px !important;
		right: 20px;
		padding: 10px 14px !important;
		gap: 14px !important;
		max-width: calc(100% - 40px);
		border-radius: 10px;
	}
	.tre-hero .tre-hero-branding .tre-hero-logo .elementor-widget-container,
	.tre-hero .tre-hero-branding .tre-hero-logo img {
		height: 80px !important;
		max-height: 80px !important;
	}
	.tre-hero .tre-hero-branding .tre-hero-nav-link {
		font-size: 13px !important;
		padding: 8px 10px;
	}
}

/* Mobile header: slim full-width bar, logo left, hamburger right.
   The inline nav links are hidden — JS injects an overlay menu instead. */
@media (max-width: 767px) {
	.tre-hero .tre-hero-branding {
		position: absolute !important;
		top: 0 !important;
		left: 0 !important;
		right: 0 !important;
		bottom: auto !important;
		max-width: 100% !important;
		width: 100% !important;
		border-radius: 0 !important;
		border-left: 0;
		border-right: 0;
		border-top: 0;
		border-bottom: 1px solid rgba(255,255,255,0.08);
		padding: 8px 14px !important;
		flex-direction: row !important;
		align-items: center !important;
		justify-content: space-between !important;
		gap: 8px !important;
		background: rgba(11, 15, 20, 0.78);
	}
	.tre-hero .tre-hero-branding .tre-hero-logo {
		flex: 0 1 auto !important;
		min-width: 0;
	}
	.tre-hero .tre-hero-branding .tre-hero-logo .elementor-widget-container,
	.tre-hero .tre-hero-branding .tre-hero-logo img {
		height: 44px !important;
		max-height: 44px !important;
		max-width: 60vw !important;
	}
	/* Hide the inline nav row on mobile — overlay handles it. */
	.tre-hero .tre-hero-branding .tre-hero-nav-row { display: none !important; }
	.tre-hero-hamburger,
	.tre-hero-callbtn {
		display: inline-flex;
	}
	.tre-hero-mobile-utils { display: inline-flex; }
}

.tre-hero .tre-hero-content {
	position: absolute !important;
	bottom: 110px !important;
	left: 28px !important;
	z-index: 5;
	max-width: 540px;
	background: rgba(0,0,0,0.6);
	padding: 22px 24px !important;
	border-radius: 6px;
	flex-direction: column !important;
}
.tre-hero .tre-hero-slide {
	display: none;
}
.tre-hero .tre-hero-slide.is-active {
	display: block;
	animation: treHeroFadeIn 0.7s ease-out both;
}
.tre-hero .tre-hero-slide h1,
.tre-hero .tre-hero-slide h2,
.tre-hero .tre-hero-slide h3,
.tre-hero .tre-hero-slide .elementor-heading-title {
	color: #fff !important;
	font-size: 44px !important;
	line-height: 1.1 !important;
	font-weight: 800 !important;
	margin: 0 0 12px 0 !important;
}
@media (max-width: 767px) {
	.tre-hero .tre-hero-slide h1,
	.tre-hero .tre-hero-slide h2,
	.tre-hero .tre-hero-slide h3,
	.tre-hero .tre-hero-slide .elementor-heading-title { font-size: 28px !important; }
}
.tre-hero .tre-hero-slide p,
.tre-hero .tre-hero-slide .elementor-text-editor {
	color: #fff !important;
	font-size: 18px !important;
	line-height: 1.45 !important;
	margin: 0 !important;
}
.tre-hero .tre-hero-slide .tre-hero-slide-cta {
	display: inline-block;
	margin-top: 14px;
	color: #ffffff !important;
	font-weight: 700;
	font-size: 16px;
	text-decoration: none;
	border-bottom: 2px solid var(--tre-accent);
	padding-bottom: 2px;
	transition: color 0.2s ease, border-color 0.2s ease;
}
.tre-hero .tre-hero-slide .tre-hero-slide-cta:hover {
	color: var(--tre-accent) !important;
}

/* STATS — three layouts.
   1280+ : vertical column on the right (original design)
   768–1279: horizontal row pinned just above the tabs strip (no clipping)
   <768  : hidden (handled in mobile section)
*/
.tre-hero .tre-hero-stats {
	position: absolute !important;
	top: 130px !important;
	right: 28px !important;
	z-index: 5;
	display: grid !important;
	grid-template-columns: 1fr;
	gap: 14px !important;
	align-items: stretch !important;
	width: auto !important;
}
.tre-hero .tre-hero-stats .elementor-counter,
.tre-hero .tre-hero-stats > .e-con,
.tre-hero .tre-hero-stats .elementor-widget {
	background: rgba(0,0,0,0.6);
	padding: 14px 22px !important;
	border-radius: 6px;
	text-align: center !important;
	min-width: 200px;
}
.tre-hero .tre-hero-stats .elementor-counter-number-wrapper {
	color: #fff !important;
	font-size: 38px !important;
	font-weight: 800 !important;
	line-height: 1 !important;
}
.tre-hero .tre-hero-stats .elementor-counter-title {
	color: rgba(255,255,255,0.9) !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	margin-top: 6px !important;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

/* Short-viewport safety net: when desktop layout (column-on-right) doesn't
   have enough vertical room, compress vertical padding/gap so the 5 stats
   still fit between branding and tabs without clipping. */
@media (min-width: 1280px) and (max-height: 820px) {
	.tre-hero .tre-hero-stats { gap: 8px !important; top: 110px !important; }
	.tre-hero .tre-hero-stats .elementor-counter,
	.tre-hero .tre-hero-stats > .e-con,
	.tre-hero .tre-hero-stats .elementor-widget {
		padding: 9px 18px !important;
		min-width: 180px;
	}
	.tre-hero .tre-hero-stats .elementor-counter-number-wrapper { font-size: 28px !important; }
	.tre-hero .tre-hero-stats .elementor-counter-title { font-size: 12px !important; margin-top: 2px !important; }
}

/* Tablet 768–1279: stats become a horizontal row pinned to bottom-left,
   above the (hidden-at-this-size) tabs strip. */
@media (min-width: 768px) and (max-width: 1279px) {
	.tre-hero .tre-hero-stats {
		top: auto !important;
		right: 16px !important;
		left: 16px !important;
		bottom: 20px !important;
		grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
		gap: 8px !important;
	}
	.tre-hero .tre-hero-stats .elementor-counter,
	.tre-hero .tre-hero-stats > .e-con,
	.tre-hero .tre-hero-stats .elementor-widget {
		min-width: 0 !important;
		padding: 10px 8px !important;
	}
	.tre-hero .tre-hero-stats .elementor-counter-number-wrapper { font-size: 24px !important; }
	.tre-hero .tre-hero-stats .elementor-counter-title { font-size: 11px !important; letter-spacing: 0.3px; margin-top: 3px !important; }
	/* Content card needs to clear the new bottom stats band on tablet. */
	.tre-hero .tre-hero-content { bottom: 130px !important; }
}

/* TABS — visible only at desktop widths; they wrap to two rows below 1280
   which wastes vertical space and pushes stats out of bounds. */
.tre-hero .tre-hero-tabs {
	position: absolute !important;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 6;
	background: rgba(0,0,0,0.55);
	border-top: 2px solid var(--tre-primary);
	display: flex !important;
	flex-direction: row !important;
	justify-content: center !important;
	flex-wrap: nowrap;
	width: 100% !important;
	padding: 0 !important;
}
.tre-hero .tre-hero-tabs .tre-hero-tab {
	padding: 14px 22px;
	font-size: 15px;
	font-weight: 700;
	color: #fff;
	cursor: pointer;
	opacity: 0.6;
	transition: opacity 0.25s, border-top-color 0.25s;
	border-top: 4px solid transparent;
	white-space: nowrap;
	user-select: none;
}
.tre-hero .tre-hero-tabs .tre-hero-tab.is-active {
	opacity: 1;
	border-top-color: var(--tre-primary);
}
@media (max-width: 1279px) {
	.tre-hero .tre-hero-tabs { display: none !important; }
}

/* Pagination affordance — dots + prev/next arrows. Injected by JS so it's
   only present when the slideshow is wired up. Visible only at viewports
   where the tab strip isn't shown. */
.tre-hero-pagination {
	display: none;
}
@media (max-width: 1279px) {
	.tre-hero-pagination {
		display: flex;
		position: absolute;
		left: 0;
		right: 0;
		bottom: 12px;
		z-index: 7;
		align-items: center;
		justify-content: center;
		gap: 14px;
		pointer-events: none; /* let the dots/arrows opt back in */
	}
	.tre-hero-pagination .tre-hero-arrow,
	.tre-hero-pagination .tre-hero-dots {
		pointer-events: auto;
	}
	.tre-hero-pagination .tre-hero-arrow {
		width: 38px;
		height: 38px;
		border-radius: 50%;
		border: 1px solid rgba(255,255,255,0.35);
		background: rgba(0, 0, 0, 0.45);
		-webkit-backdrop-filter: blur(8px);
		backdrop-filter: blur(8px);
		color: #fff;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		cursor: pointer;
		padding: 0;
		transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
	}
	.tre-hero-pagination .tre-hero-arrow:hover,
	.tre-hero-pagination .tre-hero-arrow:focus-visible {
		background: rgba(0, 0, 0, 0.7);
		border-color: rgba(255,255,255,0.7);
		outline: none;
	}
	.tre-hero-pagination .tre-hero-arrow:active { transform: scale(0.94); }
	.tre-hero-pagination .tre-hero-arrow svg { width: 16px; height: 16px; fill: none; stroke: currentColor; stroke-width: 2.4; stroke-linecap: round; stroke-linejoin: round; }
	.tre-hero-pagination .tre-hero-dots {
		display: inline-flex;
		gap: 8px;
		padding: 8px 12px;
		background: rgba(0, 0, 0, 0.45);
		-webkit-backdrop-filter: blur(8px);
		backdrop-filter: blur(8px);
		border: 1px solid rgba(255,255,255,0.18);
		border-radius: 999px;
		align-items: center;
	}
	.tre-hero-pagination .tre-hero-dot {
		width: 8px;
		height: 8px;
		border-radius: 50%;
		background: rgba(255,255,255,0.45);
		border: 0;
		padding: 0;
		cursor: pointer;
		transition: background 0.2s ease, transform 0.2s ease, width 0.2s ease;
	}
	.tre-hero-pagination .tre-hero-dot:hover { background: rgba(255,255,255,0.85); }
	.tre-hero-pagination .tre-hero-dot.is-active {
		background: #fff;
		width: 22px;
		border-radius: 999px;
	}
}
/* Tablet (768–1279): pagination tucks right of the content card, above
   the horizontal stats band. The content card sits left:28, max-width:540
   so we position pagination on the right edge to avoid overlap. */
@media (min-width: 768px) and (max-width: 1279px) {
	.tre-hero-pagination {
		bottom: 180px;
		left: auto;
		right: 24px;
		justify-content: flex-end;
	}
}
/* On mobile the pagination needs to clear the bottom content card
   (which sits at bottom: 24px with ~180px height). */
@media (max-width: 767px) {
	.tre-hero-pagination { bottom: 230px; }
}
@media (max-width: 360px) {
	.tre-hero-pagination { bottom: 200px; }
}

@keyframes treHeroFadeIn {
	from { opacity: 0; transform: translateY(8px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* Mobile hero polish (≤767px) — stats + tabs hidden; content card sits
   in the lower 40% of the viewport with a translucent dark backdrop;
   slim header bar handled in the branding override above. */
@media (max-width: 767px) {
	.tre-hero .tre-hero-stats,
	.tre-hero .tre-hero-tabs { display: none !important; }
	.tre-hero .tre-hero-content {
		left: 12px !important;
		right: 12px !important;
		bottom: 24px !important;
		max-width: calc(100% - 24px) !important;
		border-radius: 10px;
		padding: 18px 18px !important;
		background: rgba(0,0,0,0.65);
	}
	.tre-hero .tre-hero-slide h2,
	.tre-hero .tre-hero-slide .elementor-heading-title { font-size: 26px !important; line-height: 1.15 !important; margin-bottom: 8px !important; }
	.tre-hero .tre-hero-slide p,
	.tre-hero .tre-hero-slide .elementor-text-editor { font-size: 15px !important; line-height: 1.45 !important; }
	/* Strengthen the bottom gradient so the content card has more contrast. */
	.tre-hero .tre-hero-bg-slide::before {
		background: linear-gradient(to top, rgba(0,0,0,0.85), rgba(0,0,0,0.3) 35%, transparent 60%);
	}
}
/* Very narrow phones (iPhone SE class) — tighten everything one more notch. */
@media (max-width: 360px) {
	.tre-hero .tre-hero-branding { padding: 6px 10px !important; }
	.tre-hero .tre-hero-branding .tre-hero-logo .elementor-widget-container,
	.tre-hero .tre-hero-branding .tre-hero-logo img { height: 40px !important; max-height: 40px !important; }
	.tre-hero .tre-hero-content { padding: 14px !important; bottom: 16px !important; left: 8px !important; right: 8px !important; max-width: calc(100% - 16px) !important; }
	.tre-hero .tre-hero-slide h2,
	.tre-hero .tre-hero-slide .elementor-heading-title { font-size: 22px !important; }
	.tre-hero .tre-hero-slide p,
	.tre-hero .tre-hero-slide .elementor-text-editor { font-size: 14px !important; }
}

/* ============================================================
   Projects grid (replaces the custom-HTML projects block)
   Each .tre-project tile is built from a flex container with bg image
   + heading + caption (city/state) overlay.
   ============================================================ */
.tre-projects-grid {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important;
	gap: 20px !important;
	max-width: 1240px;
	margin: 0 auto;
	width: 100% !important;
}
.tre-projects-grid .tre-project-tile {
	position: relative;
	overflow: hidden;
	border-radius: 10px;
	background: #0a0d11;
	aspect-ratio: 3 / 2;
	transition: transform 0.3s;
	padding: 0 !important;
	width: 100% !important;
	min-width: 0 !important;
}
.tre-projects-grid .tre-project-tile .tre-project-img,
.tre-projects-grid .tre-project-tile .tre-project-img .elementor-widget-container,
.tre-projects-grid .tre-project-tile .tre-project-img img {
	position: absolute !important;
	inset: 0 !important;
	width: 100% !important;
	height: 100% !important;
	max-width: none !important;
	max-height: none !important;
	object-fit: cover;
	object-position: center;
	z-index: 1;
	filter: brightness(0.93) contrast(1.02);
	transition: transform 0.4s ease;
}
.tre-projects-grid .tre-project-tile:hover .tre-project-img img { transform: scale(1.05); }
.tre-projects-grid .tre-project-tile::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0,0,0,0.78) 0%, rgba(0,0,0,0) 60%);
	pointer-events: none;
	z-index: 2;
}
.tre-projects-grid .tre-project-info {
	position: absolute !important;
	left: 16px !important;
	bottom: 16px !important;
	right: 16px;
	/* Must sit above the tile's ::after gradient (also z-index 2) so the
	   white text isn't dimmed by the dark overlay painting on top of it. */
	z-index: 3;
}
.tre-projects-grid .tre-project-info h3,
.tre-projects-grid .tre-project-info .elementor-heading-title {
	color: #fff !important;
	font-size: 20px !important;
	font-weight: 700 !important;
	line-height: 1.2 !important;
	margin: 0 0 4px 0 !important;
}
.tre-projects-grid .tre-project-info p {
	color: rgba(255,255,255,0.92) !important;
	font-size: 14px !important;
	margin: 0 !important;
}
/* Collapsed default: only show the first 6 tiles (2 rows of 3 desktop, 3 rows of 2 tablet) */
.tre-projects-grid.is-collapsed .tre-project-tile:nth-child(n+7) {
	display: none;
}
@media (max-width: 1024px) {
	.tre-projects-grid { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 640px) {
	/* Two columns on mobile, smaller gap. */
	.tre-projects-grid {
		display: grid !important;
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 10px !important;
	}
	.tre-projects-grid .tre-project-tile { aspect-ratio: 4 / 3; }
	/* Solid dark band along the bottom of every tile — guarantees the
	   title is always legible regardless of the image behind it. */
	.tre-projects-grid .tre-project-tile::after {
		background: linear-gradient(to top, rgba(0,0,0,0.88) 0%, rgba(0,0,0,0.78) 30%, rgba(0,0,0,0) 60%) !important;
	}
	.tre-projects-grid .tre-project-info {
		left: 0 !important;
		right: 0 !important;
		bottom: 0 !important;
		padding: 12px 14px !important;
		/* Explicit dark band guarantees contrast regardless of underlying
		   image content — gradients alone can wash out on busy tiles. */
		background: linear-gradient(to top, rgba(0,0,0,0.92), rgba(0,0,0,0.78));
	}
	.tre-projects-grid .tre-project-info h3,
	.tre-projects-grid .tre-project-info .elementor-heading-title {
		font-size: 14px !important;
		font-weight: 800 !important;
		line-height: 1.2 !important;
		margin: 0 !important;
		color: #fff !important;
		text-shadow: 0 1px 3px rgba(0,0,0,0.7);
		/* Hard cap at 2 lines so the longest names truncate cleanly
		   instead of overflowing or stealing the entire tile. */
		display: -webkit-box;
		-webkit-line-clamp: 2;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}
	/* Drop the city/state caption on mobile — title alone keeps the small
	   tiles uncluttered and consistent. */
	.tre-projects-grid .tre-project-info p { display: none !important; }
	/* Collapsed default on mobile: show 4 tiles (2x2 grid). */
	.tre-projects-grid.is-collapsed .tre-project-tile:nth-child(n+5) { display: none; }
	.tre-projects-grid.is-collapsed .tre-project-tile:nth-child(n+7) { display: none; }
}
.tre-projects-toggle { text-align: center; margin: 28px 0; }
.tre-projects-toggle button {
	background: var(--tre-primary);
	color: #fff;
	border: 0;
	padding: 12px 28px;
	border-radius: 6px;
	font-size: 15px;
	font-weight: 700;
	cursor: pointer;
	transition: background 0.2s;
}
.tre-projects-toggle button:hover { background: var(--tre-primary-dk); }

/* ============================================================
   Members marquee — single track of linked logo+name chips.
   Each chip is one container so logo and label move as one unit.
   The whole chip is a link to the org's official site.
   ============================================================ */
.tre-members {
	max-width: 100%;
	overflow: hidden;
	mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
	-webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.tre-members-track {
	display: flex !important;
	flex-wrap: nowrap !important;
	align-items: stretch !important;
	gap: 24px !important;
	width: max-content !important;
	animation: treMembersScroll 60s linear infinite;
}
.tre-members:hover .tre-members-track { animation-play-state: paused; }
.tre-members-track > * { flex: 0 0 auto !important; }

/* The chip container. Position relative so the stretched logo link can cover it. */
.tre-members-track > .tre-members-chip {
	position: relative;
	flex: 0 0 auto !important;
	width: 220px !important;
	min-height: 160px;
	padding: 16px 18px !important;
	background: #fff;
	border: 1px solid var(--tre-border);
	border-radius: 12px;
	transition: transform 200ms ease, box-shadow 200ms ease, border-color 200ms ease;
}
.tre-members-track > .tre-members-chip:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(11, 15, 20, 0.08);
	border-color: var(--tre-primary);
}

/* Stretched-link pattern: a dedicated link widget sibling, absolutely
   positioned to cover the entire chip. Image + caption stay in normal flow
   above it. The wrapper widget AND the inner <a> both stretch so the click
   target fills the chip regardless of internal padding. */
.tre-members-chip-link-w {
	position: absolute !important;
	inset: 0 !important;
	z-index: 1 !important;
	margin: 0 !important;
	padding: 0 !important;
	width: 100% !important;
	height: 100% !important;
}
.tre-members-chip-link-w .elementor-widget-container,
.tre-members-chip-link-w .elementor-widget-container > p {
	position: absolute;
	inset: 0;
	margin: 0;
	padding: 0;
	width: 100%;
	height: 100%;
}
.tre-members-chip-link {
	position: absolute;
	inset: 0;
	display: block;
	width: 100%;
	height: 100%;
	border-radius: 12px;
	text-decoration: none;
	background: transparent;
}
.tre-members-chip-link:focus-visible {
	outline: 2px solid var(--tre-primary);
	outline-offset: 2px;
}

/* Logo image — visible in normal flow, ignores clicks so they fall through. */
.tre-members-chip-logo {
	flex: 0 0 auto !important;
	width: auto !important;
	max-width: 100% !important;
	position: relative;
	z-index: 2;
	pointer-events: none;
}
.tre-members-chip-logo .elementor-widget-container {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 80px;
}
.tre-members-chip-logo img {
	height: 64px !important;
	max-height: 64px !important;
	width: auto !important;
	max-width: 180px !important;
	object-fit: contain !important;
	display: block;
}

/* Org name caption — visible above the stretched link, clicks pass through. */
.tre-members-chip-name {
	display: block;
	text-align: center;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.3px;
	color: var(--tre-ink);
	line-height: 1.3;
	position: relative;
	z-index: 2;
	pointer-events: none;
}
.tre-members-chip-name-w {
	position: relative;
	z-index: 2;
	pointer-events: none;
}
.tre-members-track > .tre-members-chip:hover .tre-members-chip-name {
	color: var(--tre-primary);
}

@keyframes treMembersScroll {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}

/* Mobile: smaller chips, faster motion is fine since we shrunk the set. */
@media (max-width: 600px) {
	.tre-members-track > .tre-members-chip,
	.tre-members-track > a.tre-members-chip {
		width: 180px !important;
		min-height: 140px;
		padding: 12px 14px !important;
	}
	.tre-members-chip-logo .elementor-widget-container { height: 64px; }
	.tre-members-chip-logo img { height: 52px !important; max-height: 52px !important; max-width: 150px !important; }
	.tre-members-chip-name { font-size: 13px; }
}

/* ============================================================
   Stat strip used on Home + CRE
   ============================================================ */
.tre-stat-strip {
	display: grid !important;
	grid-template-columns: repeat(5, 1fr) !important;
	gap: 24px;
	max-width: 1240px;
	margin: 0 auto;
}
.tre-stat-strip .elementor-counter {
	text-align: center;
}
.tre-stat-strip .elementor-counter-number-wrapper {
	font-size: 48px !important;
	font-weight: 800 !important;
	color: var(--tre-primary) !important;
	line-height: 1 !important;
}
.tre-stat-strip .elementor-counter-title {
	color: var(--tre-muted) !important;
	font-size: 13px !important;
	font-weight: 700 !important;
	letter-spacing: 1px !important;
	text-transform: uppercase;
	margin-top: 10px !important;
}
@media (max-width: 1024px) { .tre-stat-strip { grid-template-columns: repeat(3, 1fr) !important; } }
@media (max-width: 540px)  { .tre-stat-strip { grid-template-columns: repeat(2, 1fr) !important; } }

/* ============================================================
   Final CTA band
   ============================================================ */
.tre-final-cta { text-align: center; }
/* The default accent (#3366ff) is too close to the band background
   (TRE_BRAND_PRIMARY #2e518b). Force the highlighted phrase to a
   warm, high-contrast color so it pops off the dark blue band. */
.tre-final-cta h1 span,
.tre-final-cta h2 span,
.tre-final-cta .elementor-heading-title span {
	color: #FFD66B !important;
}

/* ============================================================
   Grid utilities (override Elementor flex with CSS Grid where rows of cards are needed)
   ============================================================ */
.tre-grid-2,
.tre-grid-3,
.tre-grid-4 {
	display: grid !important;
	gap: 24px !important;
	max-width: 1240px;
	margin-left: auto;
	margin-right: auto;
}
.tre-grid-2 { grid-template-columns: repeat(2, 1fr) !important; }
.tre-grid-3 { grid-template-columns: repeat(3, 1fr) !important; }
.tre-grid-4 { grid-template-columns: repeat(4, 1fr) !important; }
@media (max-width: 767px) {
	.tre-grid-2,
	.tre-grid-3,
	.tre-grid-4 { grid-template-columns: 1fr !important; }
}

/* ============================================================
   Leadership team page
   ============================================================ */
.tre-leadership-banner h1,
.tre-leadership-banner .elementor-heading-title {
	text-shadow: 0 2px 18px rgba(0,0,0,0.55);
}
/* portfolio cards (who runs what) */
.tre-portfolio-grid { max-width: 1040px !important; gap: 24px !important; }
.tre-portfolio-card {
	border-radius: 14px !important;
	border: 1px solid rgba(255,255,255,0.08);
	transition: transform 0.2s ease, border-color 0.2s ease;
}
.tre-portfolio-card:hover {
	transform: translateY(-2px);
	border-color: rgba(51,102,255,0.4);
}
.tre-portfolio-card .elementor-icon-list-text {
	color: #ffffff !important;
}
/* stat cards on the by-the-numbers strip */
.tre-stat-card {
	background: #ffffff !important;
	border-radius: 12px !important;
	box-shadow: 0 4px 14px rgba(11,15,20,0.06);
	border: 1px solid var(--tre-border);
}
/* certification cards */
.tre-cert-grid { max-width: 1120px !important; gap: 16px !important; }
.tre-cert-card {
	border-radius: 12px !important;
	border: 1px solid rgba(255,255,255,0.08);
	transition: transform 0.2s ease, border-color 0.2s ease;
}
.tre-cert-card:hover {
	transform: translateY(-2px);
	border-color: rgba(51,102,255,0.45);
}
/* step cards on the how-a-job-runs band */
.tre-step-grid { max-width: 1120px !important; }
.tre-step-card {
	background: #ffffff !important;
	border-radius: 14px !important;
	border: 1px solid var(--tre-border);
	box-shadow: 0 6px 18px rgba(11,15,20,0.05);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.tre-step-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 12px 26px rgba(11,15,20,0.10);
}
.tre-leader-grid { max-width: 1040px !important; gap: 32px !important; }
.tre-leader-card {
	background: #ffffff !important;
	border-radius: 14px !important;
	overflow: hidden !important;
	box-shadow: 0 12px 32px rgba(11,15,20,0.10);
	padding: 0 !important;
}
.tre-leader-photo-wrap {
	width: 100% !important;
	aspect-ratio: 3 / 4;
	overflow: hidden !important;
	padding: 0 !important;
	margin: 0 !important;
	background: #1a1a1a;
}
.tre-leader-photo-wrap img,
.tre-leader-photo img {
	display: block !important;
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	object-position: center top !important;
}
.tre-leader-body {
	padding: 28px 28px 32px !important;
}
@media (max-width: 767px) {
	.tre-leader-grid { gap: 24px !important; }
	.tre-leader-photo-wrap { aspect-ratio: 4 / 5; }
}
.tre-grid-2 > *,
.tre-grid-3 > *,
.tre-grid-4 > * {
	width: 100% !important;
	min-width: 0 !important;
	max-width: 100% !important;
	flex: 1 1 auto !important;
}

/* CRE vertical row — 30 / 70 split, stacks on mobile */
.tre-vertical-row {
	display: grid !important;
	grid-template-columns: 30% 1fr !important;
	gap: 16px !important;
	align-items: baseline !important;
	border-bottom: 1px solid var(--tre-border);
	padding: 18px 0 !important;
	width: 100% !important;
}
.tre-vertical-row > * {
	width: 100% !important;
	min-width: 0 !important;
}
@media (max-width: 640px) {
	.tre-vertical-row { grid-template-columns: 1fr !important; }
}

/* States row used on home about — chips wrap on mobile */
.tre-states-row {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 12px !important;
	justify-content: center !important;
}
.tre-states-row > * { flex: 0 0 auto !important; }
@media (max-width: 1024px) {
	.tre-grid-3,
	.tre-grid-4 { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 640px) {
	.tre-grid-2,
	.tre-grid-3,
	.tre-grid-4 { grid-template-columns: 1fr !important; }
}

/* ============================================================
   Cards (services, verticals, certifications)
   ============================================================ */
.tre-card {
	background: #fff;
	border: 1px solid var(--tre-border);
	border-radius: 12px;
	padding: 28px;
	transition: transform 0.2s, box-shadow 0.2s;
}
.tre-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 12px 30px rgba(0,0,0,0.08);
}
.tre-card.tre-card-dark {
	background: var(--tre-ink);
	color: #fff;
	border-color: rgba(255,255,255,0.12);
}
.tre-card.tre-card-dark .elementor-heading-title { color: #fff !important; }
.tre-card.tre-card-dark p { color: rgba(255,255,255,0.85); }

/* ============================================================
   Steel buildings section — content sits in a black rounded card
   so the blue accents read against the bg photo.
   ============================================================ */
.tre-steel-section {
	padding: 64px 24px !important;
}
.tre-steel-card {
	background: rgba(0,0,0,0.72) !important;
	-webkit-backdrop-filter: blur(10px);
	backdrop-filter: blur(10px);
	border-radius: 18px !important;
	border: 1px solid rgba(255,255,255,0.08);
	padding: 56px 56px !important;
	max-width: 920px !important;
	margin: 0 auto !important;
	width: 100% !important;
	box-shadow: 0 18px 60px rgba(0,0,0,0.35);
}
.tre-steel-partner-logo {
	margin: 8px auto 16px !important;
}
.tre-steel-partner-logo .elementor-widget-container,
.tre-steel-partner-logo img {
	display: block;
	margin: 0 auto;
}
.tre-steel-bullets .elementor-icon-list-item {
	background: rgba(255,255,255,0.04);
	border-radius: 8px;
	padding: 10px 14px !important;
}
.tre-steel-cta-row { flex-wrap: wrap !important; }
@media (max-width: 768px) {
	.tre-steel-card { padding: 32px 22px !important; border-radius: 14px !important; }
	.tre-steel-cta-row > * { width: 100%; }
}

/* ============================================================
   Contact section — 2-column grid (side content + form)
   ============================================================ */
.tre-contact-section { padding: 80px 24px !important; }
.tre-contact-grid {
	display: grid !important;
	grid-template-columns: 1.1fr 1fr !important;
	gap: 64px !important;
	max-width: 1180px !important;
	margin: 0 auto !important;
	align-items: start !important;
	width: 100% !important;
}
.tre-contact-grid > * {
	width: 100% !important;
	min-width: 0 !important;
}
.tre-contact-form-wrap {
	background: rgba(255,255,255,0.04);
	border: 1px solid rgba(255,255,255,0.10);
	border-radius: 14px;
	padding: 32px !important;
}
.tre-contact-form-wrap .elementor-field-textual {
	background: rgba(255,255,255,0.06) !important;
	border: 1px solid rgba(255,255,255,0.14) !important;
	color: #fff !important;
}
.tre-contact-form-wrap .elementor-field-textual::placeholder { color: rgba(255,255,255,0.55) !important; }
.tre-contact-form-wrap .elementor-field-textual:focus {
	border-color: var(--tre-primary) !important;
	background: rgba(255,255,255,0.10) !important;
	outline: none !important;
}
@media (max-width: 900px) {
	.tre-contact-grid { grid-template-columns: 1fr !important; gap: 32px !important; }
	.tre-contact-section { padding: 56px 16px !important; }
	.tre-contact-form-wrap { padding: 22px !important; }
}

/* Util: section padding (override Elementor inline padding to a calmer scale) */
.tre-section { padding: 48px 24px !important; }
.tre-section--dark { background: var(--tre-ink); color: #fff; }
.tre-section--dark .elementor-heading-title,
.tre-section--dark p,
.tre-section--dark li { color: #fff !important; }
.tre-section--surface { background: var(--tre-surface); }
@media (max-width: 768px) { .tre-section { padding: 32px 16px !important; } }
/* Force consistent spacing between sections */
.tre-section + .tre-section { margin-top: 0 !important; }

/* Trim default Elementor widget vertical margin so sections don't bloat */
.tre-section > .e-con-inner > .elementor-widget,
.tre-section > .elementor-widget {
	margin-block: 0 !important;
}
.tre-section .elementor-widget-text-editor:not(:last-child) { margin-bottom: 0 !important; }
.tre-section .elementor-widget-heading + .elementor-widget-text-editor { margin-top: 4px; }
.tre-section .elementor-widget-heading + .elementor-widget-heading { margin-top: 4px; }

/* Stats section: tighter, eyebrow → heading → strip with no extra body */
.tre-stats-section { padding: 36px 24px !important; }
.tre-services-section { padding: 48px 24px !important; }
@media (max-width: 768px) {
	.tre-stats-section { padding: 28px 16px !important; }
	.tre-services-section { padding: 32px 16px !important; }
}/* End custom CSS */