/* ==========================================================
   HOMEPAGE — Frontend Styles
   ========================================================== */

/* ----------------------------------------------------------
   Scoped Variables
   ---------------------------------------------------------- */
.hp-page {
	--hp-dark: #062539;
	--hp-navy: #062539;
	--hp-primary: #EF7E00;
	--hp-primary-h: #062539;
	--hp-secondary: #84BD3A;
	--hp-text: #062539;
	--hp-text-2: #5f6f7e;
	--hp-text-3: #97a3af;
	--hp-bg: #f2f3f5;
	--hp-bg-alt: #f8f9fa;
	--hp-white: #ffffff;
	--hp-border: #e2e8f0;
	--hp-shadow-s: 0 1px 3px rgba(0,0,0,.06);
	--hp-shadow: 0 4px 16px rgba(0,0,0,.07);
	--hp-shadow-l: 0 12px 48px rgba(0,0,0,.12);
	--hp-radius: 8px;
	--hp-radius-l: 12px;
	--hp-speed: .25s;
	color: var(--hp-text);
	line-height: 1.72;
	overflow-x: hidden;
}
body.hp-no-scroll { overflow: hidden; }

/* Anchor helper (for hash links like #featured-products) */
.hp-page .hp-anchor {
	display: block;
	height: 0;
	visibility: hidden;
	pointer-events: none;
	scroll-margin-top: calc(var(--hp-sticky-header-h, 0px) + 18px);
}

/* ----------------------------------------------------------
   Section Rhythm
   ---------------------------------------------------------- */
.hp-section { padding: clamp(56px, 6vw, 92px) 0; }
.hp-page .container { max-width: 1240px; }

/* Zoom-stable gutters */
.hp-page .container,
.hp-hero .container,
.hp-trust .container {
	padding-left: clamp(16px, 2vw, 28px);
	padding-right: clamp(16px, 2vw, 28px);
}

.hp-hdr { text-align: center; max-width: 740px; margin: 0 auto 52px; }
.hp-hdr__title {
	font-family: 'Barlow', sans-serif;
	font-size: clamp(1.65rem, 2.2vw, 2.45rem); font-weight: 700;
	color: var(--hp-dark); margin-bottom: 14px;
	letter-spacing: -.025em; line-height: 1.18;
}
.hp-hdr__intro {
	font-size: clamp(1rem, 1.05vw, 1.12rem); color: var(--hp-text-2);
	margin-bottom: 0; line-height: 1.7;
}
.hp-eyebrow {
	display: inline-block; font-size: .78rem; font-weight: 600;
	letter-spacing: .1em; text-transform: uppercase;
	color: rgba(255,255,255,.9); background: rgba(255,255,255,.12);
	padding: 5px 16px; border-radius: 20px; margin-bottom: 16px;
}
.hp-cta-row { text-align: center; margin-top: 36px; }

/* ----------------------------------------------------------
   Buttons
   ---------------------------------------------------------- */
.hp-btn {
	display: inline-flex; align-items: center; gap: 8px;
	padding: clamp(11px, 1.1vw, 13px) clamp(22px, 2.2vw, 34px);
	font-family: 'Barlow', sans-serif; font-size: clamp(.9rem, .9vw, .98rem); font-weight: 600;
	border-radius: 6px; text-decoration: none;
	transition: all var(--hp-speed); cursor: pointer;
	border: 2px solid transparent; line-height: 1.4;
}
.hp-btn--primary {
	background: var(--hp-primary); color: var(--hp-white);
	border-color: var(--hp-primary);
}
.hp-btn--primary:hover {
	background: var(--hp-primary-h); border-color: var(--hp-primary-h);
	color: var(--hp-white); text-decoration: none;
	transform: translateY(-1px); box-shadow: var(--hp-shadow);
}
.hp-btn--outline {
	background: var(--hp-secondary); color: var(--hp-white);
	border-color: var(--hp-secondary);
}
.hp-btn--outline:hover {
	background: var(--hp-primary-h); border-color: var(--hp-primary-h);
	color: var(--hp-white); text-decoration: none;
	transform: translateY(-1px);
}
.hp-btn--block { width: 100%; justify-content: center; }
.hp-btn--sm { padding: 8px 20px; font-size: .82rem; }

/* ----------------------------------------------------------
   1. Hero — full-bleed background
   ---------------------------------------------------------- */
.hp-hero {
	background: linear-gradient(135deg, var(--hp-dark) 0%, #0a3a5c 100%);
	padding: calc(clamp(72px, 7vw, 110px) + var(--hp-sticky-header-h, 0px)) 0 clamp(72px, 7vw, 120px);
	position: relative; overflow: hidden;
	background-size: cover;
	background-position: center 40%;
}
.hp-hero::before {
	content: ''; position: absolute; inset: 0;
	background: radial-gradient(ellipse at 80% 50%, transparent 0%, rgba(6,37,57,.3) 100%);
	pointer-events: none;
}
.hp-hero::after {
	content: '';
	position: absolute;
	inset: 0;
	pointer-events: none;
	/* Subtle highlight around welding action area on right */
	background:
		radial-gradient(ellipse at 82% 56%, rgba(80,190,255,.16) 0%, rgba(80,190,255,.08) 20%, rgba(80,190,255,0) 46%),
		radial-gradient(circle at 78% 58%, rgba(255,170,80,.18) 0%, rgba(255,170,80,.08) 10%, rgba(255,170,80,0) 26%);
}
.hp-hero__content {
	position: relative; z-index: 1;
	max-width: 44rem;
}
.hp-hero__heading {
	font-family: 'Barlow', sans-serif; font-size: clamp(2.05rem, 3.3vw, 3.35rem); font-weight: 700;
	color: var(--hp-white); line-height: 1.08; margin-bottom: 22px;
	letter-spacing: -.025em;
}
.hp-hero__sub {
	font-size: clamp(1rem, 1.2vw, 1.15rem); color: rgba(255,255,255,.78);
	line-height: 1.72; margin-bottom: 24px; max-width: 560px;
	text-indent: 0;
}
.hp-hero__bullets {
	/* Same column as .hp-hero__sub so checkmarks line up with body copy (e.g. “pricing”). */
	list-style: none;
	padding: 0;
	margin: 0 0 32px;
	margin-inline-start: 0;
	padding-inline-start: 0;
	max-width: 560px;
	width: 100%;
	box-sizing: border-box;
	/* Two columns; each cell is full width so row 2 lines up with row 1. */
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px clamp(16px, 3vw, 28px);
	align-items: start;
	justify-items: stretch;
}
.hp-hero__bullets li {
	font-size: clamp(.9rem, .9vw, .98rem); color: rgba(255,255,255,.85);
	/* Fixed icon column + text column — avoids wrapped rows shifting horizontally vs flex + raw text nodes. */
	display: grid;
	grid-template-columns: 1.15em minmax(0, 1fr);
	column-gap: 8px;
	align-items: start;
	width: 100%;
	min-width: 0;
	margin: 0;
	padding: 0;
	white-space: normal;
}
.hp-hero__bullets .hp-hero__bullet-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	padding-top: 0.32em;
}
.hp-hero__bullets .hp-hero__bullet-text {
	min-width: 0;
}
.hp-hero__bullets i {
	color: var(--hp-primary); font-size: .75rem;
	line-height: 1;
	display: block;
}
.hp-hero__ctas { display: flex; flex-wrap: wrap; gap: 12px; }
.hp-hero .hp-btn--outline {
	background: transparent;
	color: rgba(255,255,255,.88); border-color: rgba(255,255,255,.28);
}
.hp-hero .hp-btn--outline:hover {
	border-color: rgba(255,255,255,.6); color: var(--hp-white);
	background: rgba(255,255,255,.08);
}

/* ----------------------------------------------------------
   2. Trust Strip
   ---------------------------------------------------------- */
.hp-trust {
	padding: 36px 0;
	background: var(--hp-white);
	border-bottom: 1px solid var(--hp-border);
}
.hp-trust__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: clamp(12px, 2vw, 20px);
}
.hp-trust__item {
	display: flex; align-items: center; gap: 12px;
	text-align: left; flex: 1; min-width: 0;
}
.hp-trust__item > i {
	font-size: 1.2rem; color: var(--hp-primary);
	width: 42px; height: 42px;
	display: flex; align-items: center; justify-content: center;
	background: rgba(239,126,0,.07); border-radius: 50%;
	flex-shrink: 0;
}
.hp-trust__num {
	display: block; font-family: 'Barlow', sans-serif;
	font-size: .86rem; font-weight: 700; color: var(--hp-dark);
	line-height: 1.25;
}
.hp-trust__label {
	display: block; font-size: .76rem; color: var(--hp-text-2);
	line-height: 1.35;
}

/* ----------------------------------------------------------
   3. Who We Work With
   ---------------------------------------------------------- */
.hp-audiences { background: var(--hp-white); }
.hp-audiences__col { margin-bottom: 24px; }
.hp-aud-card {
	background: var(--hp-bg-alt); border-radius: var(--hp-radius);
	padding: 34px 28px; height: 100%;
	border: 1px solid var(--hp-border);
	transition: box-shadow var(--hp-speed), transform var(--hp-speed);
	display: flex; flex-direction: column;
}
.hp-aud-card:hover { box-shadow: var(--hp-shadow); transform: translateY(-3px); }
.hp-aud-card--primary {
	background: var(--hp-white);
	border-color: var(--hp-primary);
	border-width: 2px;
	box-shadow: var(--hp-shadow-s);
}
.hp-aud-card--primary .hp-aud-card__icon {
	background: var(--hp-primary); color: var(--hp-white);
	width: 54px; height: 54px; font-size: 1.25rem;
}
.hp-aud-card__icon {
	width: 48px; height: 48px;
	display: flex; align-items: center; justify-content: center;
	background: rgba(239,126,0,.08); border-radius: 50%;
	margin-bottom: 18px; font-size: 1.1rem; color: var(--hp-primary);
}
.hp-aud-card__title {
	font-family: 'Barlow', sans-serif;
	font-size: 1.2rem; font-weight: 700;
	color: var(--hp-dark); margin: 0 0 10px; line-height: 1.3;
}
.hp-aud-card--primary .hp-aud-card__title { font-size: 1.2rem; }
.hp-aud-card__text {
	font-size: .96rem; color: var(--hp-text-2);
	line-height: 1.7; margin: 0 0 18px; flex: 1;
}
.hp-aud-card__link {
	font-family: 'Barlow', sans-serif;
	font-size: .85rem; font-weight: 600;
	color: var(--hp-primary); text-decoration: none;
	display: inline-flex; align-items: center; gap: 6px;
	transition: gap var(--hp-speed);
}
.hp-aud-card__link:hover { gap: 10px; text-decoration: none; }

/* ----------------------------------------------------------
   4. Featured Products
   ---------------------------------------------------------- */
.hp-products { background: var(--hp-bg); }
.hp-products__col { margin-bottom: 24px; }
.hp-prod-card {
	background: var(--hp-white); border-radius: var(--hp-radius-l);
	overflow: hidden; height: 100%;
	display: flex; flex-direction: column;
	border: 1px solid var(--hp-border);
	transition: box-shadow var(--hp-speed), transform var(--hp-speed);
}
.hp-prod-card:hover { box-shadow: var(--hp-shadow); transform: translateY(-3px); }
.hp-prod-card__img {
	background: var(--hp-bg); padding: clamp(14px, 2vw, 24px);
	display: flex; align-items: center; justify-content: center;
}
.hp-prod-card__img-link {
	text-decoration: none; color: inherit;
	transition: background-color var(--hp-speed);
}
.hp-prod-card__img-link:hover,
.hp-prod-card__img-link:focus-visible {
	background: #eceef1;
}
.hp-prod-card__img-link:focus-visible {
	outline: 2px solid var(--hp-primary);
	outline-offset: 2px;
}
.hp-prod-card__img img {
	max-width: 100%; height: auto; max-height: 260px;
	object-fit: contain; display: block;
}
.hp-prod-card__body { padding: 28px; flex: 1; display: flex; flex-direction: column; }
.hp-prod-card__market {
	display: inline-flex; align-items: center; gap: 6px;
	font-family: 'Barlow', sans-serif;
	font-size: .72rem; font-weight: 600; text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--hp-secondary); margin-bottom: 8px;
}
.hp-prod-card__market i { font-size: .65rem; }
.hp-prod-card__title {
	font-family: 'Barlow', sans-serif;
	font-size: 1.35rem; font-weight: 700;
	color: var(--hp-dark); margin: 0 0 14px; line-height: 1.25;
}
.hp-prod-card__title-link {
	color: inherit;
	text-decoration: none;
	transition: color var(--hp-speed);
}
.hp-prod-card__title-link:hover {
	color: var(--hp-primary);
	text-decoration: underline;
	text-underline-offset: 3px;
}
.hp-prod-card__title-link:focus-visible {
	color: var(--hp-primary);
	outline: 2px solid var(--hp-primary);
	outline-offset: 3px;
	border-radius: 2px;
}
.hp-prod-card__specs {
	list-style: none; padding: 0; margin: 0 0 16px;
}
.hp-prod-card__specs li {
	font-size: .92rem; color: var(--hp-text-2);
	padding: 5px 0 5px 22px; position: relative; line-height: 1.55;
	border-bottom: 1px solid rgba(0,0,0,.04);
}
.hp-prod-card__specs li:last-child { border-bottom: none; }
.hp-prod-card__specs li::before {
	content: '\2713'; position: absolute; left: 0; top: 5px;
	color: var(--hp-secondary); font-weight: 700; font-size: .78rem;
}
.hp-prod-card__tag {
	font-size: .85rem; color: var(--hp-text-2);
	margin: 0 0 20px; flex: 1;
	line-height: 1.65; border-left: 3px solid var(--hp-primary);
	padding-left: 12px;
}
.hp-prod-card .hp-btn { align-self: flex-start; }

/* Secondary product categories */
.hp-products__more {
	margin-top: 52px; padding-top: 44px;
	border-top: 1px solid var(--hp-border);
}
.hp-products__more-label {
	text-align: center; font-family: 'Barlow', sans-serif;
	font-size: .82rem; font-weight: 600; text-transform: uppercase;
	letter-spacing: .08em; color: var(--hp-text-3);
	margin: 0 0 24px;
}
.hp-products__cats {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: clamp(12px, 1.6vw, 16px);
}
.hp-cat-card {
	display: flex; flex-direction: column;
	background: var(--hp-white); border: 1px solid var(--hp-border);
	border-radius: var(--hp-radius-l); overflow: hidden;
	text-decoration: none; color: var(--hp-text);
	transition: box-shadow var(--hp-speed), transform var(--hp-speed);
}
.hp-cat-card:hover {
	box-shadow: var(--hp-shadow); transform: translateY(-3px);
	text-decoration: none; color: var(--hp-text);
}
.hp-cat-card__thumb {
	display: block; overflow: hidden;
	line-height: 0;
}
.hp-cat-card__thumb img {
	width: 100%; height: auto; display: block;
	aspect-ratio: 400/260; object-fit: cover;
	transition: transform .4s ease;
}
.hp-cat-card:hover .hp-cat-card__thumb img { transform: scale(1.04); }
.hp-cat-card__info {
	padding: 14px 18px;
	display: flex; align-items: center; justify-content: space-between;
	gap: 8px;
}
.hp-cat-card__name {
	font-family: 'Barlow', sans-serif;
	font-size: .88rem; font-weight: 600; flex: 1;
}
.hp-cat-card__arrow { color: var(--hp-text-3); font-size: .7rem; }
.hp-cat-card:hover .hp-cat-card__arrow { color: var(--hp-primary); }
.hp-products__range-link { text-align: center; margin-top: 24px; }
.hp-link-subtle {
	font-family: 'Barlow', sans-serif;
	font-size: .85rem; font-weight: 600;
	color: var(--hp-primary); text-decoration: none;
	display: inline-flex; align-items: center; gap: 6px;
	transition: gap var(--hp-speed);
}
.hp-link-subtle:hover { gap: 10px; text-decoration: none; }

/* ----------------------------------------------------------
   5. Factory Proof
   ---------------------------------------------------------- */
.hp-factory { background: var(--hp-white); }
.hp-factory__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: clamp(10px, 1.6vw, 16px);
	margin-bottom: clamp(22px, 2.5vw, 36px);
}
.hp-factory__photo {
	border-radius: var(--hp-radius-l); overflow: hidden;
	position: relative; background: var(--hp-dark);
}
.hp-factory__photo img {
	width: 100%; aspect-ratio: 16/10; object-fit: cover; display: block;
	transition: transform .4s ease;
}
.hp-factory__photo:hover img { transform: scale(1.03); }
.hp-factory__photo--video { cursor: pointer; }
.hp-play {
	position: absolute; top: 50%; left: 50%;
	transform: translate(-50%,-50%);
	width: 60px; height: 60px;
	transition: transform var(--hp-speed), opacity var(--hp-speed);
	opacity: .9; filter: drop-shadow(0 2px 8px rgba(0,0,0,.3));
}
.hp-factory__photo--video:hover .hp-play {
	transform: translate(-50%,-50%) scale(1.1); opacity: 1;
}
.hp-factory__body {
	text-align: center; font-size: .97rem;
	color: var(--hp-text-2); line-height: 1.72;
	max-width: 740px; margin: 0 auto;
}

/* ----------------------------------------------------------
   6. Africa Evidence
   ---------------------------------------------------------- */
.hp-africa { background: var(--hp-bg); }
.hp-africa__locations { margin-bottom: 40px; }
.hp-loc-card {
	background: var(--hp-white); border-radius: var(--hp-radius-l);
	overflow: hidden; height: 100%;
	border: 1px solid var(--hp-border);
	transition: box-shadow var(--hp-speed);
}
.hp-loc-card:hover { box-shadow: var(--hp-shadow); }
.hp-loc-card__img { background: #1a2a3a; }
.hp-loc-card__img img {
	width: 100%; aspect-ratio: 16/10; object-fit: cover; display: block;
}
.hp-loc-card__title {
	font-family: 'Barlow', sans-serif;
	font-size: 1.08rem; font-weight: 700;
	color: var(--hp-dark); margin: 0;
	padding: 22px 24px 8px; line-height: 1.3;
}
.hp-loc-card__title i { color: var(--hp-primary); margin-right: 6px; font-size: .9rem; }
.hp-loc-card__text {
	font-size: .88rem; color: var(--hp-text-2);
	line-height: 1.7; padding: 0 24px 24px; margin: 0;
}
.hp-africa__evidence { text-align: center; }
.hp-africa__evidence-label {
	font-family: 'Barlow', sans-serif;
	font-size: .82rem; font-weight: 600;
	color: var(--hp-text-3); text-transform: uppercase;
	letter-spacing: .08em; margin-bottom: 18px;
}
.hp-africa__evidence-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
	gap: clamp(10px, 1.6vw, 14px);
}
.hp-africa__evidence-card {
	border-radius: var(--hp-radius-l); overflow: hidden;
	background: var(--hp-white);
	border: 1px solid var(--hp-border);
	transition: transform var(--hp-speed), box-shadow var(--hp-speed);
}
.hp-africa__evidence-card:hover {
	transform: translateY(-2px); box-shadow: var(--hp-shadow-s);
}
.hp-africa__evidence-img {
	overflow: hidden;
	background: #1a2a3a;
}
/* Match Factory “photo tile” look; 4:3 to match previous evidence grid. */
.hp-africa__evidence-img .hp-factory__photo img {
	aspect-ratio: 4/3;
}
.hp-africa__evidence-media--static img {
	width: 100%;
	aspect-ratio: 4/3;
	object-fit: cover;
	display: block;
	vertical-align: top;
}
.hp-africa__evidence-card__title {
	font-family: 'Barlow', sans-serif;
	font-size: .85rem;
	font-weight: 600;
	margin: 0;
	padding: 10px 12px 14px;
	text-align: center;
	line-height: 1.35;
}
.hp-africa__evidence-card__title a {
	color: var(--hp-text);
	text-decoration: none;
}
.hp-africa__evidence-card__title a:hover {
	color: var(--hp-primary);
}

/* ----------------------------------------------------------
   7. Compatibility & Certifications
   ---------------------------------------------------------- */
.hp-compat-certs { background: var(--hp-white); }
.hp-compat { margin-bottom: 56px; }
.hp-brands {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	gap: clamp(10px, 1.6vw, 14px);
	align-items: stretch;
}
.hp-brand {
	width: auto; height: auto;
	min-height: 68px;
	display: flex; align-items: center; justify-content: center;
	background: var(--hp-white); border: 1px solid var(--hp-border);
	border-radius: var(--hp-radius); padding: 8px 10px;
	transition: box-shadow var(--hp-speed), transform var(--hp-speed);
}
.hp-brand:hover {
	box-shadow: var(--hp-shadow);
	transform: translateY(-2px);
	border-color: var(--hp-primary);
}
.hp-brand img {
	max-width: 100%; max-height: 100%; object-fit: contain;
	transition: filter var(--hp-speed), opacity var(--hp-speed);
}
.hp-brand:hover img { opacity: 1; }
.hp-brand__name {
	font-family: 'Barlow', sans-serif;
	font-size: .85rem; font-weight: 700;
	color: var(--hp-text-2); text-align: center;
	letter-spacing: .02em;
}
.hp-brand:hover .hp-brand__name { color: var(--hp-dark); }
/* Full width like .hp-brands: columns share width; height follows each image (no crop). CTA right, vertically centered. */
.hp-certs__row {
	display: flex;
	align-items: center;
	flex-wrap: nowrap;
	gap: clamp(12px, 2vw, 20px);
	width: 100%;
	margin-bottom: 8px;
	min-width: 0;
}
.hp-certs__row .hp-certs__grid {
	flex: 1 1 0;
	display: flex;
	align-items: flex-start;
	gap: clamp(8px, 1.2vw, 12px);
	min-width: 0;
}
.hp-certs__img {
	flex: 1 1 0;
	min-width: 0;
	width: auto;
	box-sizing: border-box;
	background: var(--hp-bg-alt); border: 1px solid var(--hp-border);
	border-radius: var(--hp-radius); padding: 8px;
	transition: box-shadow var(--hp-speed);
}
.hp-certs__img:hover { box-shadow: var(--hp-shadow-s); }
.hp-certs__img img {
	display: block;
	width: 100%;
	height: auto;
	object-fit: contain;
}
.hp-certs__link {
	flex: 0 0 auto;
	margin: 0;
	align-self: center;
	text-align: left;
}
.hp-certs__link a {
	font-family: 'Barlow', sans-serif;
	font-size: .82rem; font-weight: 600;
	color: var(--hp-text-3); text-decoration: none;
	display: inline-flex; align-items: center; gap: 6px;
	transition: color var(--hp-speed);
}
.hp-certs__link a:hover { color: var(--hp-primary); }
@media (max-width: 767px) {
	.hp-certs__row {
		flex-direction: column;
		align-items: stretch;
		flex-wrap: wrap;
	}
	.hp-certs__row .hp-certs__grid {
		flex-wrap: wrap;
		justify-content: center;
	}
	.hp-certs__img {
		flex: 1 1 calc(50% - 8px);
		min-width: 100px;
		max-width: 160px;
	}
	.hp-certs__link {
		max-width: none;
		text-align: center;
		align-self: center;
	}
}

/* ----------------------------------------------------------
   8. FAQ Accordion
   ---------------------------------------------------------- */
.hp-faq { background: var(--hp-bg); }
.hp-accordion { max-width: 800px; margin: 0 auto; }
.hp-acc {
	border: 1px solid var(--hp-border); border-radius: var(--hp-radius);
	margin-bottom: 10px; overflow: hidden;
	transition: box-shadow var(--hp-speed);
	background: var(--hp-white);
}
.hp-acc--open { box-shadow: var(--hp-shadow-s); border-color: var(--hp-primary); }
.hp-acc__trigger {
	width: 100%; background: var(--hp-white); border: none;
	padding: clamp(16px, 2vw, 22px) clamp(18px, 2.2vw, 26px); display: flex; align-items: center;
	justify-content: space-between; gap: 16px;
	font-family: 'Barlow', sans-serif; font-size: clamp(.95rem, 1vw, 1.02rem); font-weight: 600;
	color: var(--hp-dark); text-align: left; cursor: pointer;
	transition: color var(--hp-speed); line-height: 1.45;
}
.hp-acc__trigger:hover { color: var(--hp-primary); }
.hp-acc__icon {
	width: 20px; height: 20px; flex-shrink: 0;
	transition: transform .3s; color: var(--hp-text-3);
}
.hp-acc--open .hp-acc__icon { transform: rotate(180deg); color: var(--hp-primary); }
.hp-acc__body {
	padding: 0 clamp(18px, 2.2vw, 26px) clamp(18px, 2.2vw, 24px);
	font-size: clamp(.92rem, .95vw, 1rem);
	color: var(--hp-text-2); line-height: 1.75;
}
.hp-acc__body p { margin: 0; }

/* ----------------------------------------------------------
   9. Inquiry
   ---------------------------------------------------------- */
.hp-inquiry {
	background: linear-gradient(135deg, var(--hp-dark) 0%, #0a3a5c 100%);
	padding: clamp(72px, 7vw, 92px) 0 clamp(80px, 8vw, 100px);
}
.hp-inquiry .hp-hdr__title { color: var(--hp-white); text-align: center; }
.hp-inquiry .hp-hdr__intro {
	color: rgba(255,255,255,.7); text-align: center; margin-bottom: 34px;
}
.hp-inquiry__inner { max-width: 680px; margin: 0 auto; }
.hp-form-area {
	background: var(--hp-white); border-radius: var(--hp-radius-l);
	padding: clamp(24px, 3vw, 40px); box-shadow: var(--hp-shadow-l);
}
.hp-form-area__editor-note {
	margin: 0;
	font-size: clamp(.9rem, .95vw, 1rem);
	color: var(--hp-text-2);
	line-height: 1.65;
}

/* Elementor Pro Form (inquiry) — match prior .hp-field look; no duplicate HTML form */
.hp-form-area--elementor .elementor-form { margin: 0; }
.hp-form-area--elementor .elementor-form-fields-wrapper {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	margin: 0;
}
.hp-form-area--elementor .elementor-field-group {
	margin-bottom: 18px;
	width: 100%;
	box-sizing: border-box;
}
.hp-form-area--elementor .elementor-field-group.elementor-col-50 {
	flex: 0 0 50%;
	max-width: 50%;
	width: 50%;
}
.hp-form-area--elementor .elementor-field-group.elementor-col-100 {
	flex: 0 0 100%;
	max-width: 100%;
	width: 100%;
}
@media (max-width: 767px) {
	.hp-form-area--elementor .elementor-field-group.elementor-col-50 {
		flex: 0 0 100%;
		max-width: 100%;
		width: 100%;
	}
}

.hp-form-area--elementor .elementor-field-label {
	display: block;
	font-family: 'Barlow', sans-serif;
	font-size: clamp(.84rem, .9vw, .92rem);
	font-weight: 600;
	color: var(--hp-dark);
	margin-bottom: 6px;
	line-height: 1.35;
}
.hp-form-area--elementor .elementor-field-label .elementor-mark-required,
.hp-form-area--elementor .elementor-field-label .elementor-required {
	color: #c0392b;
	border: 0;
	text-decoration: none;
}

.hp-form-area--elementor .elementor-field-group input:not([type="hidden"]):not([type="submit"]):not([type="button"]):not([type="checkbox"]):not([type="radio"]),
.hp-form-area--elementor .elementor-field-group select,
.hp-form-area--elementor .elementor-field-group textarea {
	width: 100%;
	box-sizing: border-box;
	padding: clamp(10px, 1.1vw, 12px) clamp(12px, 1.4vw, 14px);
	border: 1px solid var(--hp-border);
	border-radius: 6px;
	font-family: 'Roboto', sans-serif;
	font-size: clamp(.9rem, .95vw, 1rem);
	color: var(--hp-text);
	background: #fafbfc;
	transition: border-color var(--hp-speed), box-shadow var(--hp-speed);
	-webkit-appearance: none;
	appearance: none;
}
.hp-form-area--elementor .elementor-field-group textarea {
	min-height: 140px;
	resize: vertical;
	line-height: 1.5;
}
.hp-form-area--elementor .elementor-field-group input:focus,
.hp-form-area--elementor .elementor-field-group select:focus,
.hp-form-area--elementor .elementor-field-group textarea:focus {
	outline: none;
	border-color: var(--hp-primary);
	box-shadow: 0 0 0 3px rgba(239,126,0,.16);
}

/* reCAPTCHA: margin only; no clipping, overlay, or z-index games */
.hp-form-area--elementor .elementor-field-group[class*="elementor-field-type-recaptcha"] {
	width: 100%;
	margin-bottom: 18px;
	overflow: visible;
}

.hp-form-area--elementor .elementor-field-type-submit {
	width: 100%;
	margin-bottom: 0;
}
.hp-form-area--elementor .elementor-field-type-submit .elementor-button {
	width: 100%;
	justify-content: center;
	padding: clamp(11px, 1.1vw, 13px) clamp(22px, 2.2vw, 34px);
	font-family: 'Barlow', sans-serif;
	font-size: clamp(.9rem, .9vw, .98rem);
	font-weight: 600;
	border-radius: 6px;
	line-height: 1.4;
	border: 2px solid var(--hp-primary);
	background: var(--hp-primary);
	color: var(--hp-white);
	transition: all var(--hp-speed);
	cursor: pointer;
}
.hp-form-area--elementor .elementor-field-type-submit .elementor-button:hover,
.hp-form-area--elementor .elementor-field-type-submit .elementor-button:focus {
	background: var(--hp-primary-h);
	border-color: var(--hp-primary-h);
	color: var(--hp-white);
	transform: translateY(-1px);
	box-shadow: var(--hp-shadow);
}
.hp-form-note {
	text-align: center; font-size: .82rem;
	color: rgba(255,255,255,.55); margin: 16px 0 0;
}
.hp-form-note i { margin-right: 4px; }

/* ----------------------------------------------------------
   Video Modal
   ---------------------------------------------------------- */
.hp-modal {
	position: fixed; inset: 0; z-index: 99999;
	display: flex; align-items: center; justify-content: center;
}
.hp-modal__overlay {
	position: absolute; inset: 0;
	background: rgba(0,0,0,.82); backdrop-filter: blur(4px);
}
.hp-modal__wrap {
	position: relative; width: 90vw; max-width: 960px; z-index: 1;
}
.hp-modal__close {
	position: absolute; top: -44px; right: 0;
	background: none; border: none; color: var(--hp-white);
	font-size: 2rem; cursor: pointer; opacity: .8;
	transition: opacity .2s; line-height: 1;
}
.hp-modal__close:hover { opacity: 1; }
.hp-modal__player {
	position: relative; padding-bottom: 56.25%; height: 0;
	border-radius: var(--hp-radius); overflow: hidden; background: #000;
}
.hp-modal__player iframe,
.hp-modal__player video {
	position: absolute; top: 0; left: 0; width: 100%; height: 100%;
}

/* ----------------------------------------------------------
   Responsive
   ---------------------------------------------------------- */
@media (max-width: 991px) {
	.hp-hero { padding: calc(64px + var(--hp-sticky-header-h, 0px)) 0 72px; }
	.hp-hero__content { max-width: 100%; }
	.hp-hdr { margin-bottom: 38px; }
	.hp-trust__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.hp-products__cats { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
	.hp-hero { background-position: 78% 40% !important; }
	.hp-hero::before {
		background: linear-gradient(to bottom, rgba(6,37,57,.26) 0%, rgba(6,37,57,.14) 100%);
	}
	.hp-hero::after {
		background:
			radial-gradient(ellipse at 84% 58%, rgba(80,190,255,.20) 0%, rgba(80,190,255,.08) 24%, rgba(80,190,255,0) 50%),
			radial-gradient(circle at 80% 60%, rgba(255,170,80,.22) 0%, rgba(255,170,80,.08) 12%, rgba(255,170,80,0) 28%);
	}
	.hp-hero__content {
		background: rgba(4,26,43,.44);
		border: 1px solid rgba(255,255,255,.12);
		border-radius: 12px;
		padding: 14px;
	}
	.hp-hero__bullets {
		grid-template-columns: 1fr;
		gap: 8px;
	}
	.hp-hero__bullets li { white-space: normal; }
	.hp-hero__ctas { flex-direction: column; }
	.hp-hero__ctas .hp-btn { justify-content: center; }
	.hp-hdr { margin-bottom: 28px; }
	.hp-trust__grid { grid-template-columns: 1fr; }
	.hp-trust__item { gap: 10px; }
	.hp-trust__item > i { width: 38px; height: 38px; font-size: 1.1rem; }
	.hp-aud-card { padding: 24px 20px; }
	.hp-prod-card__body { padding: 22px 20px; }
	.hp-form-area { padding: 28px 22px; }
	.hp-products__cats { grid-template-columns: 1fr 1fr; }
	.hp-cat-card__info { padding: 12px 14px; }
}
@media (max-width: 480px) {
	.hp-hero { background-position: 82% 40% !important; }
	.hp-hero__content { padding: 12px; }
	.hp-products__cats { grid-template-columns: 1fr; }
	.hp-cat-card { flex-direction: row; align-items: stretch; }
	.hp-cat-card__thumb { width: 100px; flex-shrink: 0; }
	.hp-cat-card__thumb img { width: 100%; height: 100%; aspect-ratio: auto; object-fit: cover; }
	.hp-cat-card__info { flex: 1; }
}

/* ----------------------------------------------------------
   Parent theme overrides
   ---------------------------------------------------------- */
.hp-page img { max-width: 100%; height: auto; }
.hp-page a:focus { outline: 2px solid var(--hp-primary); outline-offset: 2px; }
