/* =============================================================
   Masters EHS Consultants – Custom Header & Hero Styles
   File: assets/css/header-hero.css
   ============================================================= */


/* -------------------------------------------------------------
   1. HEADER — ABSOLUTE OVERLAY (sits on top of hero image)
   Royal Elementor renders the header as .elementor-1663 wrapper
   ABOVE the page content. We make both the outer wrapper AND
   the inner section absolutely positioned so they float over
   the hero section instead of pushing it down.
   ------------------------------------------------------------- */

/* ── OUTER Royal Elementor template wrapper ── */
.elementor-1663 {
	position: absolute !important;
	top: 0 !important;
	left: 0 !important;
	width: 100% !important;
	z-index: 999 !important;
	pointer-events: none;   /* let clicks pass through empty areas */
}
.elementor-1663 * {
	pointer-events: auto;   /* but widgets stay clickable */
}

/* Admin bar offsets for outer wrapper */
.admin-bar .elementor-1663 {
	top: 32px !important;
}
@media screen and (max-width: 782px) {
	.admin-bar .elementor-1663 {
		top: 46px !important;
	}
}

/* ── INNER section / container (has CSS ID masters-ehs-header when set) ── */
#masters-ehs-header.elementor-section,
#masters-ehs-header.e-con,
.elementor-1663 .elementor-section,
.elementor-1663 .e-con {
	position: relative !important;   /* inside already-absolute wrapper */
	background-color: transparent !important;
	transition: background-color 0.35s ease, box-shadow 0.35s ease;
	padding-top: 0 !important;       /* remove the 18px gap inside header */
	margin-top: 0 !important;
}

/* Sticky / scroll state — becomes solid dark background */
.elementor-1663.masters-is-sticky,
#masters-ehs-header.masters-is-sticky {
	position: fixed !important;
	top: 0 !important;
	left: 0 !important;
	width: 100% !important;
	background-color: rgba(10, 38, 71, 0.97) !important;
	box-shadow: 0 3px 24px rgba(0, 0, 0, 0.28) !important;
	z-index: 9999 !important;
}

.admin-bar .elementor-1663.masters-is-sticky,
.admin-bar #masters-ehs-header.masters-is-sticky {
	top: 32px !important;
}

@media screen and (max-width: 782px) {
	.admin-bar .elementor-1663.masters-is-sticky,
	.admin-bar #masters-ehs-header.masters-is-sticky {
		top: 46px !important;
	}
}


/* -------------------------------------------------------------
   2. HEADER SECTION LAYOUT
   ------------------------------------------------------------- */

#masters-ehs-header .elementor-container,
#masters-ehs-header .e-con-inner {
	align-items: center;
}

/* Company name — always white */
#masters-ehs-header .elementor-widget-heading .elementor-heading-title {
	color: #ffffff !important;
	text-shadow: 0 1px 5px rgba(0, 0, 0, 0.55);
	white-space: nowrap;
}


/* -------------------------------------------------------------
   3. HAMBURGER ICON (three bars)
   ------------------------------------------------------------- */

.masters-hamburger-wrapper {
	position: relative;
	display: flex;
	justify-content: flex-end;
	align-items: center;
	height: 100%;
}

.masters-hamburger-icon {
	appearance: none;
	-webkit-appearance: none;
	background: transparent;
	border: none;
	cursor: pointer;
	padding: 4px 2px;
	outline: none;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: 30px;
	height: 20px;
	z-index: 1001;
}

.masters-hamburger-icon span {
	display: block;
	height: 2px;
	width: 100%;
	background-color: #ffffff;
	border-radius: 3px;
	transition: transform 0.35s cubic-bezier(0.23, 1, 0.32, 1),
	            opacity   0.25s ease,
	            width     0.25s ease;
	transform-origin: center;
}

/* Animated X when open */
.masters-hamburger-icon[aria-expanded="true"] span:nth-child(1) {
	transform: translateY(9px) rotate(45deg);
}
.masters-hamburger-icon[aria-expanded="true"] span:nth-child(2) {
	opacity: 0;
	width: 0;
}
.masters-hamburger-icon[aria-expanded="true"] span:nth-child(3) {
	transform: translateY(-9px) rotate(-45deg);
}

.masters-hamburger-icon:focus-visible {
	outline: 2px solid rgba(255, 255, 255, 0.8);
	outline-offset: 4px;
	border-radius: 3px;
}


/* -------------------------------------------------------------
   4. DROPDOWN NAVIGATION MENU
   ------------------------------------------------------------- */

.masters-hamburger-nav {
	display: none;
	position: absolute;
	top: calc(100% + 18px);
	right: -8px;
	min-width: 230px;
	background: #ffffff;
	border-radius: 8px;
	box-shadow: 0 12px 48px rgba(0, 0, 0, 0.18);
	border-top: 3px solid #003366;
	z-index: 9999;
	overflow: hidden;
}

.masters-hamburger-nav.is-open {
	display: block;
	animation: mastersNavFadeIn 0.22s ease-out forwards;
}

@keyframes mastersNavFadeIn {
	from { opacity: 0; transform: translateY(-6px); }
	to   { opacity: 1; transform: translateY(0);    }
}

.masters-hamburger-nav #masters-primary-menu,
.masters-hamburger-nav ul {
	list-style: none;
	margin: 0;
	padding: 6px 0;
}

.masters-hamburger-nav ul li {
	margin: 0;
	border-bottom: 1px solid #f0f3f8;
}

.masters-hamburger-nav ul li:last-child {
	border-bottom: none;
}

.masters-hamburger-nav ul li a {
	display: block;
	padding: 13px 22px;
	color: #2d3748;
	font-size: 14px;
	font-weight: 500;
	text-decoration: none;
	transition: background-color 0.18s, color 0.18s, padding-left 0.18s;
}

.masters-hamburger-nav ul li a:hover,
.masters-hamburger-nav ul li.current-menu-item > a {
	background-color: #eef2ff;
	color: #003366;
	padding-left: 28px;
}

/* ── Level 1 sub-menu (immediate children) ── */
.masters-hamburger-nav .sub-menu {
	display: none;
	background-color: #f7f9fc;
	padding: 4px 0 !important;
}

.masters-hamburger-nav .sub-menu.is-open {
	display: block;
	animation: mastersNavFadeIn 0.18s ease-out forwards;
}

.masters-hamburger-nav .sub-menu li a {
	padding-left: 34px;
	font-size: 13px;
	color: #4a5568;
}

.masters-hamburger-nav .sub-menu li a:hover {
	padding-left: 40px;
	color: #003366;
}

/* ── Level 2 sub-menu (sub-sub items) ── */
.masters-hamburger-nav .sub-menu .sub-menu {
	display: none;
	background-color: #edf0f7;
	padding: 2px 0 !important;
}

.masters-hamburger-nav .sub-menu .sub-menu.is-open {
	display: block;
}

.masters-hamburger-nav .sub-menu .sub-menu li a {
	padding-left: 50px;
	font-size: 12px;
	color: #5a6578;
}

.masters-hamburger-nav .sub-menu .sub-menu li a:hover {
	padding-left: 56px;
	color: #003366;
}

/* ── Arrow indicator for items that have children ── */
.masters-hamburger-nav li.menu-item-has-children > a {
	display: flex !important;
	align-items: center;
	justify-content: space-between;
}

.masters-hamburger-nav li.menu-item-has-children > a::after {
	content: '›';
	font-size: 18px;
	line-height: 1;
	margin-left: 8px;
	transition: transform 0.25s ease;
	color: #a0aec0;
	flex-shrink: 0;
}

.masters-hamburger-nav li.menu-item-has-children.is-open > a::after {
	transform: rotate(90deg);
	color: #003366;
}


/* -------------------------------------------------------------
   5. HERO SECTION — Full screen, starts from top 0
   Header is absolute so hero does NOT need padding-top.
   Remove any negative margin from Elementor — not needed.
   ------------------------------------------------------------- */

.masters-hero-section.elementor-section,
.masters-hero-section.e-con {
	min-height: 100vh !important;
	padding-top: 0 !important;
	margin-top: 0 !important;    /* Remove negative margin completely */
	display: flex;
	align-items: center;
	position: relative;
}

/* Hero content sits above the background overlay */
.masters-hero-section .elementor-container,
.masters-hero-section .e-con-inner {
	position: relative;
	z-index: 2;
}

/* Hero heading */
.masters-hero-section .elementor-heading-title {
	color: #ffffff !important;
	text-shadow: 0 3px 12px rgba(0, 0, 0, 0.45);
}

/* Hero sub-text */
.masters-hero-section .elementor-widget-text-editor p {
	color: rgba(255, 255, 255, 0.88) !important;
}


/* -------------------------------------------------------------
   6. RESPONSIVE — DESKTOP / TABLET heading size
   ------------------------------------------------------------- */

@media (max-width: 1024px) {
	#masters-ehs-header .elementor-heading-title,
	.elementor-1663 .elementor-heading-title {
		font-size: 18px !important;
		letter-spacing: 1.5px;
	}
}


/* -------------------------------------------------------------
   6B. MOBILE HEADER LAYOUT  (≤ 767px)
   Force: Logo LEFT | Company Name CENTER | Hamburger RIGHT
   Uses element IDs read directly from the live DOM so the rules
   are precise even though Elementor doesn't expose them in the
   visual editor easily.
   ------------------------------------------------------------- */

@media (max-width: 767px) {

	/* ── Outer e-con container AND its inner flex wrapper ── */
	.elementor-1663 .elementor-element-9c94838,
	.elementor-1663 .elementor-element-9c94838 > .e-con-inner {
		display: flex !important;
		flex-direction: row !important;
		align-items: center !important;
		justify-content: space-between !important;
		flex-wrap: nowrap !important;
		width: 100% !important;
		padding: 8px 14px !important;
		box-sizing: border-box !important;
		overflow: visible !important;
	}

	/* ── All 3 inner containers: reset widths ── */
	.elementor-1663 .elementor-element-9c94838 > .e-con-inner > .elementor-element,
	.elementor-1663 .elementor-element-9c94838 > .elementor-element {
		width: auto !important;
		min-width: 0 !important;
		padding: 0 !important;
		flex-shrink: 0 !important;
		align-self: center !important;
	}

	/* ── Container 1 — Logo (left, fixed size) ── */
	.elementor-1663 .elementor-element-59655e0 {
		flex: 0 0 auto !important;
		width: auto !important;
		display: flex !important;
		align-items: center !important;
		justify-content: flex-start !important;
		align-self: center !important;
	}
	.elementor-1663 .elementor-element-59655e0 > .e-con-inner {
		display: flex !important;
		align-items: center !important;
		justify-content: flex-start !important;
	}
	.elementor-1663 .elementor-element-59655e0 img {
		max-height: 52px !important;
		width: auto !important;
		display: block !important;
	}

	/* ── Container 2 — Heading (centre, expands, vertically centred in row) ── */
	.elementor-1663 .elementor-element-fa1f584 {
		flex: 1 1 auto !important;
		width: auto !important;
		min-height: 0 !important;
		display: flex !important;
		flex-direction: column !important;
		align-items: center !important;
		justify-content: center !important;
		align-self: center !important;
		text-align: center !important;
	}

	/* Hide all spacers inside heading column */
	.elementor-1663 .elementor-element-3feee5c,
	.elementor-1663 .elementor-element-fa1f584 .elementor-widget-spacer {
		display: none !important;
	}

	/* Heading widget — centred, two-line text */
	.elementor-1663 .elementor-element-ba7ef8f {
		display: flex !important;
		align-items: center !important;
		justify-content: center !important;
		align-self: center !important;
		width: auto !important;
		max-width: 100% !important;
		text-align: center !important;
		margin: 0 !important;
		padding: 0 !important;
	}
	.elementor-1663 .elementor-element-ba7ef8f .elementor-widget-container {
		text-align: center !important;
		width: auto !important;
		display: flex !important;
		justify-content: center !important;
	}
	/* Two-line: MASTERS EHS / CONSULTANTS — heading has <br> from PHP fix */
	.elementor-1663 .elementor-element-ba7ef8f .elementor-heading-title {
		font-size: 11px !important;
		letter-spacing: 0.8px !important;
		white-space: normal !important;
		word-break: break-word !important;
		overflow-wrap: break-word !important;
		text-align: center !important;
		line-height: 1.4 !important;
		margin: 0 auto !important;
		padding: 0 !important;
		width: auto !important;
	}

	/* ── Container 3 — Hamburger (right, fixed size) ── */
	.elementor-1663 .elementor-element-49213ec {
		flex: 0 0 auto !important;
		display: flex !important;
		align-items: center !important;
		justify-content: flex-end !important;
		height: 100% !important;
	}
	.elementor-1663 .elementor-element-49213ec > .e-con-inner {
		display: flex !important;
		align-items: center !important;
		justify-content: flex-end !important;
	}

	/* Hide all spacers in hamburger column */
	.elementor-1663 .elementor-element-c2afdc8,
	.elementor-1663 .elementor-element-49213ec .elementor-widget-spacer {
		display: none !important;
	}

	/* Hamburger wrapper vertically centred */
	.masters-hamburger-wrapper {
		display: flex !important;
		align-items: center !important;
		height: 100% !important;
	}

	/* Hamburger menu dropdown — keep it within screen */
	.masters-hamburger-nav {
		right: 0 !important;
		left: auto !important;
		min-width: 200px !important;
		max-width: 90vw !important;
	}
}


/* -------------------------------------------------------------
   7. WHITE SPACE FIX — Remove top gap between browser edge
      and the hero/header area
   Astra sometimes adds padding-top on .site-content or keeps
   a zero-height header wrapper that still creates a gap.
   ------------------------------------------------------------- */

/* Astra's header markup — collapse to zero so it doesn't push content */
body.masters-transparent-header .ast-above-header-wrap,
body.masters-transparent-header .ast-header-wrap,
body.masters-transparent-header header.site-header,
body.masters-transparent-header #masthead {
	height: 0 !important;
	min-height: 0 !important;
	padding: 0 !important;
	margin: 0 !important;
	border: none !important;
	overflow: visible !important;  /* keep absolute header visible */
}

/* Astra site-content / page wrapper — remove any top offset */
body.masters-transparent-header #page,
body.masters-transparent-header .hfeed,
body.masters-transparent-header .site-content,
body.masters-transparent-header #content,
body.masters-transparent-header .ast-container {
	padding-top: 0 !important;
	margin-top: 0 !important;
}

/* Astra #primary content area — main cause of white gap */
body.masters-transparent-header #primary,
body.masters-transparent-header .ast-primary-content-area,
body.masters-transparent-header #main {
	margin-top: 0 !important;
	padding-top: 0 !important;
}

/* Astra's ast-separate-container adds padding-top:5.34em on article — kills white gap on new pages */
body.masters-transparent-header .ast-separate-container .ast-article-single,
body.masters-transparent-header .ast-separate-container .ast-article-post,
body.masters-transparent-header article.ast-article-single,
body.masters-transparent-header article.ast-article-post {
	padding-top: 0 !important;
	margin-top: 0 !important;
}

/* First Elementor section/container on the page — pull it flush to top */
body.masters-transparent-header .elementor-section-wrap > .elementor-section:first-child,
body.masters-transparent-header .elementor-section-wrap > .e-con:first-child,
body.masters-transparent-header .elementor > .elementor-section-wrap > .elementor-section:first-child,
body.masters-transparent-header .elementor > .elementor-section-wrap > .e-con:first-child {
	margin-top: 0 !important;
}


/* -------------------------------------------------------------
   8. HEADER HORIZONTAL ALIGNMENT
   Force all three columns (logo | name | hamburger) to sit in
   a single row, vertically centred, regardless of how the
   Elementor container inherits flex settings from Royal theme.
   ------------------------------------------------------------- */

/* Outer container: row, centred */
#masters-ehs-header .elementor-container,
#masters-ehs-header .e-con-inner {
	display: flex !important;
	flex-direction: row !important;
	flex-wrap: nowrap !important;
	align-items: center !important;
	justify-content: space-between !important;
}

/* Each column: flex child, centred vertically */
#masters-ehs-header .elementor-column,
#masters-ehs-header .elementor-col-25,
#masters-ehs-header .elementor-col-50 {
	display: flex !important;
	flex-direction: column !important;
	justify-content: center !important;
	align-self: center !important;
}

/* Widget wrappers inside columns — no unexpected margins */
#masters-ehs-header .elementor-widget-wrap,
#masters-ehs-header .elementor-element {
	display: flex !important;
	align-items: center !important;
}

/* Logo image: no bottom gap (inline image default) */
#masters-ehs-header .elementor-widget-image img {
	display: block;
	vertical-align: middle;
}

/* Hamburger wrapper fills right column and pushes icon to the right */
#masters-ehs-header .masters-hamburger-wrapper {
	width: 100%;
	justify-content: flex-end;
}
