/* ================================================================
   FGPS Solar Blocks — Frontend Styles
   All sections scoped with .fgps- prefix
   ================================================================ */

/* ── CSS Variables ── */
:root {
	--fgps-primary:    #315efb;
	--fgps-primary-lt: #7fb2ff;
	--fgps-primary-dk: #1835c4;
	--fgps-bg:         #f4f8ff;
	--fgps-txt:        #0e1b30;
	--fgps-muted:      #64748b;
	--fgps-border:     #e2e8f0;
	--fgps-rx:         28px;
	--fgps-rl:         20px;
	--fgps-rm:         14px;
	--fgps-shadow-sm:  0 1px 3px rgba(0,0,0,0.08);
	--fgps-shadow-md:  0 4px 20px rgba(49,94,251,0.12);
	--fgps-shadow-lg:  0 20px 60px rgba(0,0,0,0.12);
}

[data-mode="commercial"] {
	--fgps-primary:    #1b3d8f;
	--fgps-primary-lt: #4a7cc9;
	--fgps-primary-dk: #0f2760;
}

/* ── Fonts ── (loaded via wp_enqueue_style in class-plugin.php — no @import here) */

/* ── Utility ── */
.wrap { max-width: 1280px; margin: 0 auto; padding: 0 24px; }

/* ── Section Header shared ── */
.fgps-section-head {
	text-align: center;
	margin-bottom: 48px;
}

.fgps-section-title {
	font-family: 'Poppins', sans-serif;
	font-size: clamp(26px, 4vw, 38px);
	font-weight: 700;
	color: var(--fgps-txt);
	margin: 0 0 12px;
	line-height: 1.2;
}

.fgps-section-copy {
	font-family: 'Inter', sans-serif;
	font-size: 16px;
	color: var(--fgps-muted);
	max-width: 560px;
	margin: 0 auto;
	line-height: 1.7;
}

/* ── Shared Buttons ── */
.fgps-btn-primary {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: var(--fgps-primary);
	color: #fff;
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	font-weight: 600;
	padding: 14px 28px;
	border-radius: 100px;
	text-decoration: none;
	border: none;
	cursor: pointer;
	transition: background 0.2s, transform 0.2s, box-shadow 0.2s;
	box-shadow: 0 4px 16px rgba(49,94,251,0.3);
}

.fgps-btn-primary:hover {
	background: var(--fgps-primary-dk);
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(49,94,251,0.4);
	color: #fff;
}

.fgps-btn-primary--lg { padding: 16px 36px; font-size: 16px; }

.fgps-btn-ghost {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: transparent;
	color: rgba(255,255,255,0.85);
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	font-weight: 600;
	padding: 14px 28px;
	border-radius: 100px;
	text-decoration: none;
	border: 1.5px solid rgba(255,255,255,0.35);
	cursor: pointer;
	transition: background 0.2s, border-color 0.2s, color 0.2s;
}

.fgps-btn-ghost:hover {
	background: rgba(255,255,255,0.12);
	border-color: rgba(255,255,255,0.6);
	color: #fff;
}

.fgps-btn-ghost--lg { padding: 16px 36px; font-size: 16px; }

/* ── Scroll reveal ── */
/* Elements start invisible; .vis added by IntersectionObserver in JS */
[data-r] {
	opacity: 0;
	transform: translateY(24px);
}

[data-r].vis {
	opacity: 1;
	transform: translateY(0);
	transition: opacity 0.55s ease, transform 0.55s ease;
}

/* Respect user motion preferences */
@media (prefers-reduced-motion: reduce) {
	[data-r], [data-r].vis {
		transition: none !important;
		transform: none !important;
		opacity: 1 !important;
	}
}

/* No-JS fallback — if JS never runs, show everything */
.no-js [data-r] {
	opacity: 1;
	transform: none;
}

/* Elementor editor — always show elements, never animate */
.elementor-editor-active [data-r],
.elementor-editor-active [data-r].vis {
	opacity: 1 !important;
	transform: none !important;
	transition: none !important;
}

/* ============================================================
   1. HERO SECTION
   ============================================================ */
.fgps-hero {
	position: relative;
	overflow: hidden;
}

/* Each mode panel fills the full hero height */
.fgps-hero-mode {
	min-height: inherit;
	display: flex;
	align-items: center;
	position: relative;
	width: 100%;
}

.fgps-hero-bg {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.fgps-hero-slide {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	opacity: 0;
	transition: opacity 1.2s ease;
}

.fgps-hero-slide.active { opacity: 1; }

.fgps-hero-overlay {
	position: absolute;
	inset: 0;
	/* background + opacity set inline by widget; fallback below */
	background: #000;
	opacity: 0.55;
}

.fgps-hero-inner {
	position: relative;
	z-index: 2;
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
	align-items: center;
	padding-top: 120px;
	padding-bottom: 80px;
	width: 100%;
}

.fgps-hero-left {
	max-width: 780px;
}

/* ── Big typography — mirrors old design impact ── */
.fgps-hero-h1 {
	font-family: 'Poppins', sans-serif;
	font-size: clamp(44px, 7vw, 80px);
	font-weight: 900;
	color: #fff;
	line-height: 1.04;
	letter-spacing: -0.025em;
	margin: 0 0 24px;
}

/* Accent word highlighted in brand blue — like "more" in old design */
.fgps-hero-accent {
	color: var(--fgps-primary-lt);
}

.fgps-hero-sub {
	font-family: 'Inter', sans-serif;
	font-size: 18px;
	color: rgba(255,255,255,0.82);
	line-height: 1.75;
	margin: 0 0 36px;
	max-width: 560px;
}

.fgps-hero-btns {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
}

/* Side Card */
.fgps-hero-card {
	background: rgba(255,255,255,0.95);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	border-radius: var(--fgps-rl);
	padding: 28px;
	box-shadow: 0 24px 64px rgba(0,0,0,0.2);
}

.fgps-hero-card-label {
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--fgps-primary);
	margin-bottom: 8px;
}

.fgps-hero-card-title {
	font-family: 'Poppins', sans-serif;
	font-size: 22px;
	font-weight: 700;
	color: var(--fgps-txt);
	margin: 0 0 10px;
	line-height: 1.2;
}

.fgps-hero-card-copy {
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	color: var(--fgps-muted);
	line-height: 1.6;
	margin: 0 0 20px;
}

.fgps-hero-card-stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
	margin-bottom: 20px;
}

.fgps-hero-stat {
	text-align: center;
}

.fgps-hero-stat strong {
	display: block;
	font-family: 'Poppins', sans-serif;
	font-size: 18px;
	font-weight: 700;
	color: var(--fgps-primary);
}

.fgps-hero-stat span {
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	color: var(--fgps-muted);
}

.fgps-hero-badge {
	display: flex;
	align-items: center;
	gap: 10px;
	background: var(--fgps-bg);
	border-radius: var(--fgps-rm);
	padding: 12px 14px;
}

.fgps-hero-badge-icon { font-size: 22px; }

.fgps-hero-badge strong {
	display: block;
	font-family: 'Poppins', sans-serif;
	font-size: 16px;
	font-weight: 700;
	color: var(--fgps-txt);
}

.fgps-hero-badge span {
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	color: var(--fgps-muted);
}

.fgps-hero-dots {
	position: absolute;
	bottom: 24px;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	gap: 8px;
	z-index: 10;
}

.fgps-hero-dot {
	width: 8px; height: 8px;
	background: rgba(255,255,255,0.35);
	border: none;
	border-radius: 50%;
	cursor: pointer;
	transition: background 0.2s, transform 0.2s;
	padding: 0;
}

.fgps-hero-dot.active {
	background: #fff;
	transform: scale(1.3);
}

@media (max-width: 768px) {
	.fgps-hero-inner { padding-top: 100px; padding-bottom: 60px; }
	.fgps-hero-left  { max-width: 100%; }
}

@media (max-width: 640px) {
	.fgps-hero-inner { padding-top: 88px; padding-bottom: 48px; }
	.fgps-hero-h1    { font-size: clamp(36px, 10vw, 48px); letter-spacing: -0.02em; }
	.fgps-hero-sub   { font-size: 16px; }
	.fgps-hero-btns  { flex-direction: column; }
	.fgps-btn-primary, .fgps-btn-ghost { text-align: center; justify-content: center; }
}

/* ============================================================
   2. TRUST RIBBON
   ============================================================ */
.fgps-trust-ribbon {
	overflow: hidden;
	padding: 14px 0;
	position: relative;
}

.fgps-trust-ribbon--dark   { background: #0e1b30; }
.fgps-trust-ribbon--light  { background: var(--fgps-bg); border-top: 1px solid var(--fgps-border); border-bottom: 1px solid var(--fgps-border); }
.fgps-trust-ribbon--primary { background: var(--fgps-primary); }

.fgps-trust-track {
	display: flex;
	align-items: center;
	gap: 0;
	white-space: nowrap;
	animation: fgps-marquee linear infinite;
	width: max-content;
}

@keyframes fgps-marquee {
	0%   { transform: translateX(0); }
	100% { transform: translateX(-50%); }
}

.fgps-trust-ribbon--light  .fgps-trust-track:hover,
.fgps-trust-ribbon--dark   .fgps-trust-track:hover,
.fgps-trust-ribbon--primary .fgps-trust-track:hover {
	animation-play-state: paused;
}

.fgps-trust-item {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 0 24px;
}

.fgps-trust-icon { font-size: 16px; }

.fgps-trust-text {
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	font-weight: 500;
	white-space: nowrap;
}

.fgps-trust-ribbon--dark .fgps-trust-text   { color: rgba(255,255,255,0.75); }
.fgps-trust-ribbon--light .fgps-trust-text  { color: var(--fgps-txt); }
.fgps-trust-ribbon--primary .fgps-trust-text { color: rgba(255,255,255,0.9); }

.fgps-trust-sep {
	color: var(--fgps-primary-lt);
	font-size: 10px;
	flex-shrink: 0;
}

.fgps-trust-ribbon--dark .fgps-trust-sep { color: rgba(255,255,255,0.2); }

/* ============================================================
   3. STATS SECTION
   ============================================================ */
.fgps-stats-section {
	padding: 72px 24px;
	background: var(--fgps-bg);
	max-width: 1280px;
	margin: 0 auto;
}

.fgps-stats-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 20px;
}

.fgps-stat-card {
	background: #fff;
	border-radius: var(--fgps-rl);
	padding: 28px 20px;
	text-align: center;
	border: 1px solid var(--fgps-border);
	box-shadow: var(--fgps-shadow-sm);
	transition: transform 0.2s, box-shadow 0.2s;
}

.fgps-stat-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--fgps-shadow-md);
}

.fgps-stat-number {
	font-family: 'Poppins', sans-serif;
	font-size: 36px;
	font-weight: 800;
	color: var(--fgps-primary);
	line-height: 1;
	margin-bottom: 8px;
}

.fgps-stat-prefix,
.fgps-stat-suffix {
	font-size: 24px;
	font-weight: 700;
}

.fgps-stat-label {
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	color: var(--fgps-muted);
	line-height: 1.4;
}

/* ============================================================
   4. SOLAR SOLUTIONS SECTION  (replaces old Why section)
   ============================================================ */
.fgps-solsec {
	overflow: hidden;
}

/* Section header */
.fgps-solsec-head {
	margin-bottom: 40px;
}

.fgps-solsec-eyebrow {
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	margin: 0 0 12px;
}

.fgps-solsec-title {
	font-family: 'Poppins', sans-serif;
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: -0.02em;
	margin: 0 0 16px;
}

.fgps-solsec-copy {
	font-family: 'Inter', sans-serif;
	line-height: 1.7;
	max-width: 560px;
	margin: 0;
}

/* Card grid */
.fgps-solsec-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
}

/* Individual card */
.fgps-sol-card {
	position: relative;
	display: block;
	border-radius: var(--sol-radius, 20px);
	overflow: hidden;
	text-decoration: none;
	aspect-ratio: var(--sol-aspect, 2/3);
	cursor: pointer;
}

.fgps-sol-card-photo {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	transition: transform 0.55s ease;
}

.fgps-sol-card-photo--empty {
	background: rgba(255,255,255,0.08);
}

.fgps-sol-card:hover .fgps-sol-card-photo {
	transform: scale(1.07);
}

/* Bottom gradient — darkens toward footer so text always readable */
.fgps-sol-card-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to bottom,
		transparent 40%,
		rgba(0,0,0,0.45) 65%,
		rgba(0,0,0,0.78) 100%
	);
	z-index: 1;
}

/* Configurable colour tint */
.fgps-sol-card::before {
	content: '';
	position: absolute;
	inset: 0;
	background: var(--sol-ov-color, #000);
	opacity: var(--sol-ov-op, 0.35);
	z-index: 0;
}

/* Card content — column, pushes footer to bottom */
.fgps-sol-card-body {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 20px 20px 22px;
	z-index: 2;
	display: flex;
	flex-direction: column;
}

/* Description sits above the footer row; hidden by default, slides up on hover */
.fgps-sol-card-desc {
	font-family: 'Inter', sans-serif;
	line-height: 1.5;
	margin: 0 0 10px;
	opacity: 0;
	max-height: 0;
	overflow: hidden;
	transform: translateY(8px);
	transition: opacity 0.32s ease, transform 0.32s ease, max-height 0.32s ease;
}

.fgps-sol-card:hover .fgps-sol-card-desc {
	opacity: 1;
	max-height: 120px;
	transform: translateY(0);
}

/* Footer row: title left, arrow right */
.fgps-sol-card-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
}

.fgps-sol-card-title {
	font-family: 'Poppins', sans-serif;
	font-weight: 700;
	line-height: 1.2;
	margin: 0;
	flex: 1;
}

/* Arrow — right side, shifts further right on hover */
.fgps-sol-card-arrow {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: rgba(255,255,255,0.15);
	opacity: 0.8;
	transition: opacity 0.22s ease, transform 0.22s ease, background 0.22s ease;
}

.fgps-sol-card:hover .fgps-sol-card-arrow {
	opacity: 1;
	transform: translateX(5px);
	background: rgba(255,255,255,0.28);
}

/* Responsive */
@media (max-width: 1024px) {
	.fgps-solsec-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
	.fgps-solsec-grid { grid-template-columns: 1fr; gap: 12px; }
	.fgps-sol-card-desc {
		opacity: 1;
		max-height: none;
		transform: none;
	}
}

/* ============================================================
   4b. FEATURES / WHY CHOOSE US SECTION
   ============================================================ */

/* ── Accent word highlight ── */
.fgps-feat-accent { color: var(--fgps-primary); }

/* ── Section wrapper ── */
.fgps-feat-section { overflow: hidden; }

/* ─────────────────────────────────────────────
   LAYOUT 1: side-by-side (heading left, cards right)
───────────────────────────────────────────── */
.fgps-feat-section--side-by-side .fgps-feat-inner {
	display: grid;
	grid-template-columns: 1fr 1.6fr;
	gap: 64px;
	align-items: start;
}

.fgps-feat-section--side-by-side .fgps-feat-heading-col {
	position: sticky;
	top: 100px;
}

.fgps-feat-section--side-by-side .fgps-feat-copy {
	max-width: 420px;
}

/* ─────────────────────────────────────────────
   LAYOUT 2: centered (heading center, cards full-width below)
───────────────────────────────────────────── */
.fgps-feat-section--centered .fgps-feat-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 48px;
}

.fgps-feat-section--centered .fgps-feat-heading-col {
	text-align: center;
	max-width: 720px;
	width: 100%;
}

.fgps-feat-section--centered .fgps-feat-copy {
	margin-left: auto;
	margin-right: auto;
	max-width: 560px;
}

.fgps-feat-section--centered .fgps-feat-grid {
	width: 100%;
}

.fgps-feat-section--centered .fgps-feat-cta {
	margin: 0 auto;
}

/* ─────────────────────────────────────────────
   LAYOUT 3: stacked (heading left-aligned, cards below)
───────────────────────────────────────────── */
.fgps-feat-section--stacked .fgps-feat-inner {
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.fgps-feat-section--stacked .fgps-feat-heading-col {
	max-width: 680px;
}

/* ── Shared heading column styles ── */
.fgps-feat-title {
	font-family: 'Poppins', sans-serif;
	font-weight: 800;
	line-height: 1.15;
	letter-spacing: -0.02em;
	margin: 0 0 16px;
}

.fgps-feat-copy {
	font-family: 'Inter', sans-serif;
	font-size: 16px;
	line-height: 1.7;
	margin: 0 0 28px;
}

.fgps-feat-cta { display: inline-flex; }

/* ── Card grid ── */
.fgps-feat-grid {
	display: grid;
	gap: 20px;
}

.fgps-feat-cols-2 { grid-template-columns: repeat(2, 1fr); }
.fgps-feat-cols-3 { grid-template-columns: repeat(3, 1fr); }
.fgps-feat-cols-4 { grid-template-columns: repeat(4, 1fr); }

/* ── Individual card ── */
.fgps-feat-card {
	background: var(--feat-card-bg, #fff);
	border: 1px solid var(--feat-card-border, #e2e8f0);
	border-radius: var(--feat-card-radius, 20px);
	padding: 28px 26px 26px;
	display: flex;
	flex-direction: column;
	gap: 12px;
	transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.fgps-feat-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 36px rgba(49,94,251,0.10);
	border-color: var(--fgps-primary);
}

/* ── Card top row: icon + number ── */
.fgps-feat-card-top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 4px;
}

.fgps-feat-icon-wrap {
	width: 48px;
	height: 48px;
	border-radius: 14px;
	background: var(--feat-icon-bg, #f4f8ff);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
	flex-shrink: 0;
}

.fgps-feat-num {
	font-family: 'Poppins', sans-serif;
	font-size: 13px;
	font-weight: 700;
	color: var(--fgps-primary);
	opacity: 0.35;
	letter-spacing: 0.04em;
}

/* ── Card text ── */
.fgps-feat-card-title {
	font-family: 'Poppins', sans-serif;
	font-weight: 700;
	line-height: 1.3;
	margin: 0;
}

.fgps-feat-card-body {
	font-family: 'Inter', sans-serif;
	line-height: 1.65;
	margin: 0;
}

/* ── Responsive ── */
@media (max-width: 1024px) {
	.fgps-feat-section--side-by-side .fgps-feat-inner {
		grid-template-columns: 1fr;
		gap: 40px;
	}
	.fgps-feat-heading-col { position: static; }
	.fgps-feat-copy { max-width: 100%; }
	.fgps-feat-cols-4 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
	.fgps-feat-cols-2,
	.fgps-feat-cols-3,
	.fgps-feat-cols-4 { grid-template-columns: 1fr; }
	.fgps-feat-card { padding: 22px 20px; }
}

/* ============================================================
   5. SOLUTIONS CARDS
   ============================================================ */
.fgps-solutions-section {
	padding: 80px 24px;
	max-width: 1280px;
	margin: 0 auto;
}

.fgps-solutions-grid {
	display: grid;
	gap: 24px;
}

/* Responsive column variants. Desktop/Tablet/Mobile picked via Elementor responsive control. */
.fgps-cols-d-auto { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.fgps-cols-d-1    { grid-template-columns: 1fr; }
.fgps-cols-d-2    { grid-template-columns: repeat(2, 1fr); }
.fgps-cols-d-3    { grid-template-columns: repeat(3, 1fr); }
.fgps-cols-d-4    { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 1024px) {
	.fgps-cols-t-auto { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
	.fgps-cols-t-1    { grid-template-columns: 1fr; }
	.fgps-cols-t-2    { grid-template-columns: repeat(2, 1fr); }
	.fgps-cols-t-3    { grid-template-columns: repeat(3, 1fr); }
	.fgps-cols-t-4    { grid-template-columns: repeat(4, 1fr); }
}

@media (max-width: 640px) {
	.fgps-cols-m-auto { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
	.fgps-cols-m-1    { grid-template-columns: 1fr; }
	.fgps-cols-m-2    { grid-template-columns: repeat(2, 1fr); }
	.fgps-cols-m-3    { grid-template-columns: repeat(3, 1fr); }
	.fgps-cols-m-4    { grid-template-columns: repeat(4, 1fr); }
}

.fgps-solution-card {
	background: #fff;
	border-radius: var(--fgps-rl);
	overflow: hidden;
	border: 1px solid var(--fgps-border);
	box-shadow: var(--fgps-shadow-sm);
	transition: transform 0.2s, box-shadow 0.2s;
}

.fgps-solution-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--fgps-shadow-lg);
}

.fgps-solution-img {
	position: relative;
	height: 200px;
	overflow: hidden;
	background: linear-gradient(135deg, var(--fgps-bg), var(--fgps-border));
}

.fgps-solution-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s;
}

.fgps-solution-card:hover .fgps-solution-img img { transform: scale(1.05); }

.fgps-solution-img-placeholder {
	width: 100%; height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 48px;
}

.fgps-solution-tag {
	position: absolute;
	top: 12px;
	left: 12px;
	background: var(--fgps-primary);
	color: #fff;
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	font-weight: 600;
	padding: 4px 10px;
	border-radius: 100px;
}

.fgps-solution-body {
	padding: 20px 22px 22px;
}

.fgps-solution-title {
	font-family: 'Poppins', sans-serif;
	font-size: 18px;
	font-weight: 700;
	color: var(--fgps-txt);
	margin: 0 0 10px;
}

.fgps-solution-copy {
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	color: var(--fgps-muted);
	line-height: 1.6;
	margin: 0 0 14px;
}

.fgps-solution-link {
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	font-weight: 600;
	color: var(--fgps-primary);
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	transition: gap 0.2s;
}

.fgps-solution-card:hover .fgps-solution-link { gap: 8px; }

/* ============================================================
   6. GALLERY / PROJECTS
   ============================================================ */
.fgps-gallery-section {
	padding: 80px 0;
	overflow: hidden;
}

.fgps-gallery-section .fgps-section-head {
	padding: 0 24px;
}

.fgps-gallery-track {
	display: flex;
	gap: 20px;
	overflow-x: auto;
	padding: 8px 24px 20px;
	scroll-snap-type: x mandatory;
	-ms-overflow-style: none;
	scrollbar-width: none;
	cursor: grab;
}

.fgps-gallery-track::-webkit-scrollbar { display: none; }
.fgps-gallery-track.fgps-dragging { cursor: grabbing; }

.fgps-gallery-card {
	flex: 0 0 280px;
	background: #fff;
	border-radius: var(--fgps-rl);
	overflow: hidden;
	border: 1px solid var(--fgps-border);
	box-shadow: var(--fgps-shadow-sm);
	scroll-snap-align: start;
	transition: transform 0.2s, box-shadow 0.2s;
}

.fgps-gallery-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--fgps-shadow-md);
}

.fgps-gallery-img {
	height: 180px;
	overflow: hidden;
	background: linear-gradient(135deg, var(--fgps-bg), var(--fgps-border));
}

.fgps-gallery-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s;
}

.fgps-gallery-card:hover .fgps-gallery-img img { transform: scale(1.06); }

.fgps-gallery-img-placeholder {
	width: 100%; height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 40px;
}

.fgps-gallery-info { padding: 16px 18px; }

.fgps-gallery-title {
	font-family: 'Poppins', sans-serif;
	font-size: 15px;
	font-weight: 700;
	color: var(--fgps-txt);
	margin: 0 0 10px;
}

.fgps-gallery-meta {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.fgps-gallery-meta-item {
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	color: var(--fgps-muted);
}

/* ============================================================
   7. TESTIMONIALS — stat + video left / carousel right
   ============================================================ */

/* ── Outer wrapper ── defaults match Elementor control defaults; selectors override */
.fgps-testi-wrap {
	overflow: hidden;
	background: #0c1524;
	padding: 80px 0;
}

/* ── Inner two-column grid ── */
.fgps-testi-inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 64px;
	align-items: start;
}

/* ─────────────────────────────────────────────
   LEFT COLUMN
───────────────────────────────────────────── */
.fgps-testi-left {
	display: flex;
	flex-direction: column;
	/* gap controlled per-element via margin-bottom so each gap is individually adjustable */
}

.fgps-testi-headline {
	font-family: 'Poppins', sans-serif;
	font-weight: 800;
	line-height: 1.15;
	color: #fff;       /* Elementor selector overrides */
	font-size: 48px;   /* Elementor selector overrides */
	margin: 0 0 12px;  /* Elementor selector overrides */
}

.fgps-testi-subtitle {
	font-family: 'Inter', sans-serif;
	font-size: 16px;
	line-height: 1.65;
	color: #94a3b8;    /* Elementor selector overrides */
	margin: 0 0 24px;  /* Elementor selector overrides */
	max-width: 440px;
}

/* ── Video wrap ── border-radius default; Elementor selector overrides */
.fgps-testi-video-wrap {
	position: relative;
	width: 100%;
	border-radius: 14px; /* Elementor selector (video_corner_radius control) overrides */
	overflow: hidden;    /* clips child iframe/poster to border-radius */
	background: #000;
	border: none !important;
	outline: none !important;
	box-shadow: none;
}
.fgps-testi-video-wrap:focus,
.fgps-testi-video-wrap *:focus {
	outline: none;
}

.fgps-testi-video-wrap iframe {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 9;
	border: none;
	outline: none;
}

/* ── Video poster (popup mode) ── */
.fgps-testi-video-poster {
	position: relative;
	display: block;
	width: 100%;
	aspect-ratio: 16 / 9;
	cursor: pointer;
	overflow: hidden;
	outline: none;
}

.fgps-testi-video-poster img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.35s;
}

.fgps-testi-video-poster:hover img { transform: scale(1.04); }

.fgps-testi-video-placeholder {
	width: 100%;
	aspect-ratio: 16 / 9;
	background: #1e2d45;
}

/* Play button — anchored to exact visual centre of poster */
.fgps-testi-play-btn {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: auto;
	height: auto;
	background: transparent !important;
	border: none !important;
	outline: none !important;
	box-shadow: none !important;
	cursor: pointer;
	padding: 0;
	line-height: 0;
}
.fgps-testi-play-btn:hover,
.fgps-testi-play-btn:focus,
.fgps-testi-play-btn:focus-visible,
.fgps-testi-play-btn:active {
	background: transparent !important;
	border: none !important;
	outline: none !important;
	box-shadow: none !important;
}
/* Kill any browser focus ring on the poster div */
.fgps-testi-video-poster:focus,
.fgps-testi-video-poster:focus-visible {
	outline: none;
}

.fgps-testi-play-btn-inner {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: rgba(0, 0, 0, 0.55);
	border: none;               /* no border — prevents coloured ring on hover */
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s, transform 0.2s;
	color: #fff;
}

.fgps-testi-play-btn-inner svg { margin-left: 3px; } /* optical offset for play triangle */

.fgps-testi-video-poster:hover .fgps-testi-play-btn-inner {
	background: var(--fgps-primary);
	transform: scale(1.1);
}

/* ── Video popup modal ── */
.fgps-testi-modal {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 100000;
	align-items: center;
	justify-content: center;
}

.fgps-testi-modal.open {
	display: flex;
}

.fgps-testi-modal-overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.88);
	cursor: pointer;
}

.fgps-testi-modal-inner {
	position: relative;
	z-index: 1;
	width: 92vw;
	max-width: 960px;
}

.fgps-testi-modal-close {
	position: absolute;
	top: -48px;
	right: 0;
	width: 38px;
	height: 38px;
	background: rgba(255, 255, 255, 0.1);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 50%;
	color: #fff;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s;
}

.fgps-testi-modal-close:hover {
	background: rgba(255, 255, 255, 0.22);
}

.fgps-testi-modal-video {
	aspect-ratio: 16 / 9;
	background: #000;
	border-radius: 10px;
	overflow: hidden;
}

.fgps-testi-modal-video iframe {
	width: 100%;
	height: 100%;
	border: 0;
	display: block;
}

.fgps-testi-video-caption {
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	margin: 8px 0 0;
	text-align: center;
}

/* ─────────────────────────────────────────────
   RIGHT COLUMN — carousel
───────────────────────────────────────────── */
.fgps-testi-right {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
}

/* Nav buttons — shape controlled by Elementor selector (border-radius) */
.fgps-testi-nav-btn {
	-webkit-appearance: none;
	appearance: none;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;    /* Elementor nav_shape selector overrides */
	border: none !important;
	outline: none !important;
	box-shadow: none;
	background: #1e2d45;   /* Elementor selector overrides */
	color: #fff;           /* Elementor selector overrides */
	cursor: pointer;
	transition: background 0.2s, transform 0.15s;
	flex-shrink: 0;
	line-height: 0;
}
/* Explicitly kill ALL browser-default focus rings (red in Firefox/Chrome) */
.fgps-testi-nav-btn:focus,
.fgps-testi-nav-btn:active,
.fgps-testi-nav-btn:focus-within {
	outline: none !important;
	border: none !important;
	box-shadow: none !important;
}
.fgps-testi-nav-btn:focus-visible {
	outline: 2px solid rgba(255, 255, 255, 0.5) !important;
	outline-offset: 2px;
}

.fgps-testi-nav-btn svg {
	display: block;
	flex-shrink: 0;
}

.fgps-testi-nav-btn:hover {
	background: var(--fgps-primary);
	transform: scale(1.08);
}

/* ── Cards container — floating peek effect ──────────────────
   --tc-peek: vertical space on each side so prev/next cards
   peek translucently above and below the active card.
   JS sets min-height = card_height + 2 × peek.  ── */
.fgps-testi-cards {
	--tc-peek: 60px;
	position: relative;
	width: 100%;
	overflow: hidden;
	min-height: 280px; /* JS overrides: card_height + 2 × --tc-peek */
}

/* ── All cards: absolutely positioned at top + peek offset ──
   Cards use pointer-events (not visibility) — no transition delay.  ── */
.fgps-testi-card {
	position: absolute;
	left: 0;
	right: 0;
	top: var(--tc-peek); /* offset makes room for prev-card peek above */
	opacity: 0;
	pointer-events: none;
	transform: translateY(40px);
	transition: opacity 0.45s ease, transform 0.45s ease, filter 0.45s ease;
	/* Colors — Elementor selectors override these defaults */
	background: #152035;
	border-left: 3px solid #315efb;
	border-radius: 12px;
	padding: 28px 28px 24px;
}

/* ── ACTIVE card — fully visible at its natural position ── */
.fgps-testi-card.fgps-tc-active {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
	filter: none;
	z-index: 2;
}

/* ── PREV card — peeks from ABOVE: translucent bottom edge visible ──
   translateY(-100%) moves the card entirely above the container;
   the container's overflow shows only the bottom --tc-peek px of it.  ── */
.fgps-testi-card.fgps-tc-prev {
	opacity: 0.3;
	pointer-events: none;
	transform: translateY(-100%) scale(0.94);
	filter: blur(1.5px);
	z-index: 1;
}

/* ── NEXT card — peeks from BELOW: translucent top edge visible ──
   translateY(100%) pushes it below the active card;
   only the top --tc-peek px shows before the container clips it.  ── */
.fgps-testi-card.fgps-tc-next {
	opacity: 0.3;
	pointer-events: none;
	transform: translateY(100%) scale(0.94);
	filter: blur(1.5px);
	z-index: 1;
}

.fgps-tc-stars {
	font-size: 17px;
	letter-spacing: 2px;
	color: #f59e0b;     /* Elementor selector overrides */
	margin-bottom: 14px;
}

.fgps-tc-quote-full {
	font-family: 'Inter', sans-serif;
	font-size: 16px;
	font-style: italic;
	line-height: 1.7;
	color: #e2e8f0;     /* Elementor selector overrides */
	margin: 0 0 20px;
}

.fgps-tc-quote-short { display: none; }

/* ── Author row ── */
.fgps-tc-author-row {
	display: flex;
	align-items: center;
	gap: 10px;
}

.fgps-tc-avatar {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	overflow: hidden;
	flex-shrink: 0;
}

.fgps-tc-avatar img { width: 100%; height: 100%; object-fit: cover; }

.fgps-tc-initials {
	width: 100%;
	height: 100%;
	background: var(--fgps-primary);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: 'Poppins', sans-serif;
	font-weight: 700;
	font-size: 14px;
}

.fgps-tc-meta strong {
	display: block;
	font-family: 'Poppins', sans-serif;
	font-weight: 600;
	font-size: 13px;
	color: #fff;        /* Elementor selector overrides */
}

.fgps-tc-meta span {
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	color: #64748b;
}

/* Avatar always shown (single card viewport) */

/* ── Savings badge ── */
.fgps-tc-badge {
	display: inline-flex;
	align-items: center;
	background: #166534;  /* Elementor selector overrides */
	color: #dcfce7;       /* Elementor selector overrides */
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	font-weight: 600;
	padding: 5px 13px;
	border-radius: 100px;
	margin-top: 14px;
	width: fit-content;
}

/* ── Responsive ── */
@media (max-width: 900px) {
	.fgps-testi-inner {
		grid-template-columns: 1fr;
		gap: 40px;
	}
	.fgps-testi-subtitle { max-width: 100%; }
}

@media (max-width: 640px) {
	.fgps-testi-card { padding: 22px 20px 20px; }
	.fgps-testi-headline { font-size: 36px !important; }
}

/* ============================================================
   8. PROCESS STEPS
   ============================================================ */
.fgps-process-section {
	padding: 80px 24px;
	max-width: 1280px;
	margin: 0 auto;
}

.fgps-process-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 24px;
	position: relative;
}

.fgps-process-step {
	background: #fff;
	border-radius: var(--fgps-rl);
	padding: 24px 22px;
	border: 1px solid var(--fgps-border);
	position: relative;
	transition: transform 0.2s, box-shadow 0.2s;
}

.fgps-process-step:hover {
	transform: translateY(-4px);
	box-shadow: var(--fgps-shadow-md);
}

.fgps-process-step-head {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 14px;
}

.fgps-process-num {
	width: 32px; height: 32px;
	background: var(--fgps-primary);
	color: #fff;
	font-family: 'Poppins', sans-serif;
	font-weight: 700;
	font-size: 14px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.fgps-process-icon { font-size: 22px; }

.fgps-process-duration {
	margin-left: auto;
	background: var(--fgps-bg);
	color: var(--fgps-primary);
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	font-weight: 600;
	padding: 3px 10px;
	border-radius: 100px;
}

.fgps-process-title {
	font-family: 'Poppins', sans-serif;
	font-size: 16px;
	font-weight: 700;
	color: var(--fgps-txt);
	margin: 0 0 8px;
}

.fgps-process-body {
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	color: var(--fgps-muted);
	line-height: 1.6;
	margin: 0 0 14px;
}

.fgps-process-detail {
	background: var(--fgps-bg);
	border-radius: var(--fgps-rm);
	padding: 12px 14px;
}

.fgps-process-detail-label {
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--fgps-primary);
	margin-bottom: 4px;
}

.fgps-process-detail-text {
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	color: var(--fgps-muted);
	line-height: 1.5;
}

/* ============================================================
   9. FAQ ACCORDION — tabbed categories + side image
   ============================================================ */

/* Section wrapper — Elementor selectors override these defaults */
.fgps-faq-section {
	padding: 80px 0;
	background: #fff;          /* faq_section_bg selector overrides */
	overflow: hidden;
	/* Accent colour variable — single control drives tabs, icon, open border, etc. */
	--faq-accent: var(--fgps-primary);
}

/* ── Header ── */
.fgps-faq-hd {
	text-align: center;
	margin-bottom: 44px;
}

.fgps-faq-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-family: 'Poppins', sans-serif;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--faq-accent);                         /* faq_badge_color overrides */
	background: rgba(49, 94, 251, 0.07);              /* faq_badge_bg overrides */
	border: 1px solid rgba(49, 94, 251, 0.18);
	border-radius: 100px;
	padding: 5px 14px 5px 10px;
	margin-bottom: 14px;
}

.fgps-faq-eyebrow svg { flex-shrink: 0; }

.fgps-faq-title {
	font-family: 'Poppins', sans-serif;
	font-size: clamp(26px, 3.5vw, 36px);
	font-weight: 700;
	color: var(--fgps-txt);
	margin: 0;
	line-height: 1.2;
}

/* ── Layout: left accordion + right image ── */
.fgps-faq-layout {
	display: grid;
	grid-template-columns: 1fr 420px;
	gap: 60px;
	align-items: start;
}

/* ── LEFT COLUMN ── */
.fgps-faq-left { min-width: 0; }

/* ── Category tabs ── */
.fgps-faq-tabs {
	display: flex;
	align-items: stretch;
	gap: 0;
	border-bottom: 2px solid var(--fgps-border);
	margin-bottom: 0;
}

.fgps-faq-tab {
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	font-weight: 500;
	color: var(--fgps-muted);
	background: none;
	border: none;
	border-bottom: 3px solid transparent;
	margin-bottom: -2px;
	padding: 10px 22px;
	cursor: pointer;
	transition: color 0.2s, background 0.2s, border-color 0.2s;
	border-radius: 6px 6px 0 0;
	white-space: nowrap;
}

.fgps-faq-tab:hover {
	color: var(--fgps-txt);
	background: var(--fgps-bg);
}

.fgps-faq-tab.active {
	color: #fff;                            /* faq_tab_active_color overrides */
	background: var(--faq-accent);          /* faq_tab_active_bg overrides */
	border-bottom-color: var(--faq-accent); /* keeps underline in sync */
	font-weight: 600;
}

/* Divider line (only shown when tabs present) */
.fgps-faq-tab-rule {
	height: 2px;
	background: linear-gradient(90deg, var(--faq-accent) 0%, transparent 100%);
	margin-bottom: 20px;
}

/* ── Tab panels ── */
.fgps-faq-panel { display: none; }
.fgps-faq-panel.active { display: block; }
.fgps-faq-panel[hidden] { display: none; }

/* ── Individual FAQ item ── */
.fgps-faq-item {
	border-bottom: 1px solid var(--fgps-border);
	/* Always reserve 3px on the left — prevents layout shift when open adds colour */
	border-left: 3px solid transparent;
	background: transparent;                    /* faq_item_bg selector overrides */
	transition: border-left-color 0.25s, border-bottom-color 0.2s, background 0.2s;
}

.fgps-faq-item:first-child { border-top: 1px solid var(--fgps-border); }

/* Open state: colour + subtle tint; Elementor selectors override both */
.fgps-faq-item.open {
	border-left-color: var(--faq-accent, var(--fgps-primary));
	background: rgba(49, 94, 251, 0.04);        /* faq_item_open_bg selector overrides */
}

/* Question button */
.fgps-faq-question {
	display: flex;
	align-items: center;
	gap: 14px;
	width: 100%;
	background: transparent !important;
	border: none;
	outline: none;
	cursor: pointer;
	/* padding-left must match answer indent (20px + 3px reserved border = net 20px) */
	padding: 18px 16px 18px 17px;
	text-align: left;
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	font-weight: 500;
	color: var(--fgps-txt);                     /* faq_q_color overrides */
	transition: color 0.2s;
}

.fgps-faq-question:hover,
.fgps-faq-question:focus,
.fgps-faq-question:focus-visible,
.fgps-faq-question:active {
	background: transparent !important;
	outline: none;
}

.fgps-faq-item.open .fgps-faq-question {
	color: var(--faq-accent);                   /* faq_q_open_color overrides */
	font-weight: 600;
}

.fgps-faq-q-text { flex: 1; }

/* ── Plus / × icon ── */
.fgps-faq-plus {
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	border: 1.5px solid var(--fgps-border);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--faq-accent);                   /* icon colour follows accent */
	transition: background 0.2s, border-color 0.2s;
}

.fgps-faq-item.open .fgps-faq-plus {
	background: var(--faq-accent);
	border-color: var(--faq-accent);
	color: #fff;
}

/* Vertical line collapses when open → becomes × */
.fgps-faq-v-line {
	transform-origin: center;
	transition: transform 0.3s, opacity 0.2s;
}
.fgps-faq-item.open .fgps-faq-v-line {
	transform: rotate(90deg);
	opacity: 0;
}

/* Answer panel */
.fgps-faq-answer { overflow: hidden; }
.fgps-faq-answer[hidden] { display: none; }

.fgps-faq-answer-inner {
	/* indent: 3px border + 17px pad + 28px icon + 14px gap = 62px from item edge */
	padding: 0 20px 20px 62px;
	font-family: 'Inter', sans-serif;
	font-size: 14px;                 /* faq_ans_size overrides */
	color: #64748b;                  /* faq_ans_color overrides */
	line-height: 1.8;
}

.fgps-faq-answer-inner p { margin: 0 0 10px; }
.fgps-faq-answer-inner p:last-child { margin-bottom: 0; }
.fgps-faq-answer-inner ul,
.fgps-faq-answer-inner ol { padding-left: 20px; margin: 8px 0; }
.fgps-faq-answer-inner li { margin-bottom: 4px; }

/* ── RIGHT COLUMN — circular image ── */
.fgps-faq-right {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	padding-top: 20px;
}

.fgps-faq-img-wrap {
	position: relative;
	width: 340px;
	height: 380px;
}

/* Outer decorative ring */
.fgps-faq-img-deco-ring {
	position: absolute;
	border-radius: 50%;
	border: 3px solid var(--faq-deco, #00d4ff);
}

.fgps-faq-deco-outer {
	width: 340px;
	height: 340px;
	top: 0;       /* centred with image circle at (170, 170) */
	left: 0;
	opacity: 0.25;
}

.fgps-faq-deco-inner {
	width: 280px;
	height: 280px;
	top: 30px;    /* (340-280)/2 = 30px → concentric with outer ring */
	left: 30px;
	border-style: dashed;
	opacity: 0.15;
}

/* Rotating sun-ray dots — same bounding box as outer ring so rotation origin matches */
.fgps-faq-img-dots {
	position: absolute;
	width: 340px;
	height: 340px;
	top: 0;
	left: 0;
	border-radius: 50%;
	animation: fgps-faq-spin 18s linear infinite;
}

.fgps-faq-dot {
	position: absolute;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--faq-deco, #00d4ff);
	opacity: 0.55;
	top: 50%;
	left: 50%;
	transform:
		rotate(calc(var(--d) * 45deg))
		translateY(-175px)
		translateX(-4px);
}

@keyframes fgps-faq-spin {
	to { transform: rotate(360deg); }
}

/* Main circle crop */
.fgps-faq-img-circle {
	position: absolute;
	width: 300px;
	height: 300px;
	border-radius: 50%;
	overflow: hidden;
	top: 20px;
	left: 20px;
	background: var(--fgps-bg);
	box-shadow: 0 12px 40px rgba(49, 94, 251, 0.18);
}

.fgps-faq-img-circle img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top center;
}

.fgps-faq-img-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* Brand badge pin */
.fgps-faq-img-badge {
	position: absolute;
	bottom: 20px;
	right: 0;
	display: flex;
	align-items: center;
	gap: 6px;
	background: var(--fgps-primary);
	color: #fff;
	font-family: 'Poppins', sans-serif;
	font-size: 12px;
	font-weight: 600;
	padding: 8px 14px 8px 10px;
	border-radius: 100px;
	box-shadow: 0 4px 16px rgba(49, 94, 251, 0.35);
	white-space: nowrap;
}

/* ── Focus states ── */
.fgps-faq-tab:focus-visible,
.fgps-faq-question:focus-visible {
	outline: 2px solid var(--fgps-primary);
	outline-offset: 2px;
}

/* ── Responsive ── */
@media (max-width: 1024px) {
	.fgps-faq-layout {
		grid-template-columns: 1fr 360px;
		gap: 40px;
	}
	/* wrap 300px wide → outer ring 300px, image 260px (offset 20px → center at 150) */
	.fgps-faq-img-wrap   { width: 300px; height: 340px; }
	.fgps-faq-img-circle { width: 260px; height: 260px; top: 20px; left: 20px; }
	.fgps-faq-deco-outer { width: 300px; height: 300px; top: 0; left: 0; }
	.fgps-faq-deco-inner { width: 240px; height: 240px; top: 30px; left: 30px; }
	.fgps-faq-img-dots   { width: 300px; height: 300px; top: 0; left: 0; }
	.fgps-faq-dot { transform: rotate(calc(var(--d) * 45deg)) translateY(-155px) translateX(-4px); }
}

@media (max-width: 860px) {
	.fgps-faq-layout {
		grid-template-columns: 1fr;
		gap: 40px;
	}
	.fgps-faq-right { order: -1; }
	/* wrap 260px → outer ring 260px, image 220px (offset 20px) */
	.fgps-faq-img-wrap   { width: 260px; height: 300px; }
	.fgps-faq-img-circle { width: 220px; height: 220px; top: 20px; left: 20px; }
	.fgps-faq-deco-outer { width: 260px; height: 260px; top: 0; left: 0; }
	.fgps-faq-deco-inner { display: none; }
	.fgps-faq-img-dots   { display: none; }
}

@media (max-width: 520px) {
	.fgps-faq-tabs { flex-wrap: wrap; gap: 4px; border-bottom: none; margin-bottom: 16px; }
	.fgps-faq-tab { border-radius: 6px; border: 1px solid var(--fgps-border); margin-bottom: 0; }
	.fgps-faq-tab.active { border-color: var(--fgps-primary); }
	.fgps-faq-tab-rule { display: none; }
	.fgps-faq-answer-inner { padding-left: 20px; }
}

/* ============================================================
   10. CTA BANNER
   ============================================================ */
.fgps-cta-banner {
	padding: 80px 0;
	position: relative;
	overflow: hidden;
}

.fgps-cta-banner--dark-gradient {
	background: linear-gradient(135deg, #0e1b30 0%, #1835c4 50%, #0e1b30 100%);
}

.fgps-cta-banner--primary-gradient {
	background: linear-gradient(135deg, var(--fgps-primary-dk) 0%, var(--fgps-primary) 100%);
}

.fgps-cta-banner--light {
	background: var(--fgps-bg);
}

.fgps-cta-banner--pattern::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: radial-gradient(circle at 1px 1px, rgba(255,255,255,0.06) 1px, transparent 0);
	background-size: 32px 32px;
	z-index: 0;
}

.fgps-cta-banner-inner {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 40px;
}

.fgps-cta-banner-content { max-width: 680px; }

.fgps-cta-urgency {
	display: inline-block;
	background: rgba(255,255,255,0.12);
	border: 1px solid rgba(255,255,255,0.2);
	color: rgba(255,255,255,0.9);
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	font-weight: 500;
	padding: 6px 14px;
	border-radius: 100px;
	margin-bottom: 16px;
}

.fgps-cta-banner--light .fgps-cta-urgency {
	background: #fff;
	border-color: var(--fgps-border);
	color: var(--fgps-txt);
}

.fgps-cta-title {
	font-family: 'Poppins', sans-serif;
	font-size: clamp(26px, 4vw, 40px);
	font-weight: 800;
	color: #fff;
	margin: 0 0 16px;
	line-height: 1.15;
}

.fgps-cta-banner--light .fgps-cta-title { color: var(--fgps-txt); }

.fgps-cta-copy {
	font-family: 'Inter', sans-serif;
	font-size: 16px;
	color: rgba(255,255,255,0.8);
	line-height: 1.7;
	margin: 0 0 28px;
}

.fgps-cta-banner--light .fgps-cta-copy { color: var(--fgps-muted); }

.fgps-cta-btns {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.fgps-cta-banner-deco { flex-shrink: 0; }

.fgps-cta-sun {
	font-size: 80px;
	opacity: 0.15;
	animation: fgps-spin 20s linear infinite;
}

@keyframes fgps-spin {
	from { transform: rotate(0deg); }
	to { transform: rotate(360deg); }
}

@media (max-width: 768px) {
	.fgps-cta-banner-inner { flex-direction: column; }
	.fgps-cta-banner-deco { display: none; }
	.fgps-cta-btns { flex-direction: column; }
}

/* ============================================================
   ACCESSIBILITY — Global focus styles
   ============================================================ */

/* Visible focus ring for keyboard navigation */
:focus-visible {
	outline: 2px solid var(--fgps-primary);
	outline-offset: 3px;
	border-radius: 4px;
}

/* Pill-shaped elements get a matching pill focus */
.fgps-btn-primary:focus-visible,
.fgps-btn-ghost:focus-visible,
.fgps-cta-btn:focus-visible,
.fgps-mode-btn:focus-visible,
.fgps-hero-dot:focus-visible,
.fgps-faq-question:focus-visible,
.fgps-sol-card:focus-visible {
	outline: 2px solid var(--fgps-primary);
	outline-offset: 3px;
	border-radius: 100px;
}

/* Nav links */
.fgps-nav-link:focus-visible,
.fgps-footer-link:focus-visible,
.fgps-footer-social-link:focus-visible,
.fgps-brand:focus-visible {
	outline: 2px solid var(--fgps-primary);
	outline-offset: 4px;
	border-radius: 6px;
}

/* Testimonial nav buttons — focus handled in component CSS above */

/* Gallery keyboard scroll */
.fgps-gallery-track:focus {
	outline: 2px solid var(--fgps-primary);
	outline-offset: 4px;
}

/* ── Quote Sidebar ── */

.fgps-quote-overlay {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.5);
	z-index: 99990;
	display: none;
}
.fgps-quote-overlay.open {
	display: block;
}

.fgps-quote-sidebar {
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	width: min(420px, 100vw);
	background: #fff;
	z-index: 99999;
	transform: translateX(100%);
	transition: transform 0.35s cubic-bezier(.4, 0, .2, 1);
	overflow-y: auto;
	display: flex;
	flex-direction: column;
}
.fgps-quote-sidebar.open {
	transform: translateX(0);
}

.fgps-qs-header {
	padding: 28px 28px 16px;
	background: var(--fgps-primary);
	color: #fff;
	flex-shrink: 0;
}
.fgps-qs-header-top {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 16px;
}
.fgps-qs-title {
	font-family: 'Poppins', sans-serif;
	font-size: 20px;
	font-weight: 700;
	margin: 0 0 6px;
	color: #fff;
}
.fgps-qs-subtitle {
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	color: rgba(255, 255, 255, 0.8);
	margin: 0;
}
.fgps-qs-close {
	background: rgba(255, 255, 255, 0.15);
	border: none;
	color: #fff;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	cursor: pointer;
	font-size: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: background 0.2s;
}
.fgps-qs-close:hover {
	background: rgba(255, 255, 255, 0.3);
}

.fgps-qs-form {
	padding: 24px 28px 32px;
	flex: 1;
}
.fgps-qs-field {
	margin-bottom: 20px;
}
.fgps-qs-label {
	display: block;
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	font-weight: 600;
	color: #64748b;
	margin-bottom: 7px;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}
.fgps-qs-label .req {
	color: #e53e3e;
	margin-left: 2px;
}
.fgps-qs-input,
.fgps-qs-select {
	width: 100%;
	padding: 13px 18px;
	border: 1.5px solid #e8edf5;
	border-radius: 100px;
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	color: #0e1b30;
	background: #f8fafc;
	transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
	box-sizing: border-box;
	box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.fgps-qs-textarea {
	width: 100%;
	padding: 13px 18px;
	border: 1.5px solid #e8edf5;
	border-radius: 16px;
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	color: #0e1b30;
	background: #f8fafc;
	transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
	box-sizing: border-box;
	box-shadow: 0 1px 3px rgba(0,0,0,0.04);
	resize: vertical;
	min-height: 84px;
}
.fgps-qs-input:focus,
.fgps-qs-select:focus,
.fgps-qs-textarea:focus {
	outline: none;
	border-color: var(--fgps-primary);
	box-shadow: 0 0 0 3px rgba(49, 94, 251, 0.12);
	background: #fff;
}
.fgps-qs-input::placeholder,
.fgps-qs-textarea::placeholder {
	color: #94a3b8;
}
.fgps-qs-type-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}
.fgps-qs-type-opt {
	position: relative;
}
.fgps-qs-type-opt input[type=radio] {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}
.fgps-qs-type-opt label {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 10px 16px;
	border: 1.5px solid #e2e8f0;
	border-radius: 10px;
	cursor: pointer;
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	font-weight: 500;
	color: #64748b;
	transition: all 0.2s;
	background: #f8fafc;
}
.fgps-qs-type-opt input:checked + label {
	border-color: var(--fgps-primary);
	background: rgba(49, 94, 251, 0.06);
	color: var(--fgps-primary);
	font-weight: 600;
}
.fgps-qs-submit {
	width: 100%;
	padding: 14px 20px;
	background: var(--fgps-primary);
	color: #fff;
	border: none;
	border-radius: 100px;
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	margin-top: 4px;
	transition: background 0.2s, transform 0.2s, box-shadow 0.2s;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	box-shadow: 0 4px 14px rgba(49,94,251,0.28);
	letter-spacing: 0.01em;
}
.fgps-qs-submit:hover {
	background: var(--fgps-primary-dk);
	transform: translateY(-1px);
	box-shadow: 0 6px 18px rgba(49,94,251,0.35);
}
.fgps-qs-submit:active { transform: translateY(0); }
.fgps-qs-submit:disabled {
	opacity: 0.55;
	pointer-events: none;
	box-shadow: none;
}
.fgps-qs-success {
	background: #f0fdf4;
	border: 1.5px solid #bbf7d0;
	border-radius: 12px;
	padding: 20px 24px;
	text-align: center;
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	color: #166534;
	margin-top: 16px;
}
.fgps-qs-error {
	background: #fef2f2;
	border: 1.5px solid #fecaca;
	border-radius: 10px;
	padding: 12px 16px;
	margin-bottom: 12px;
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	color: #991b1b;
}

/* Progress bar */
.fgps-qs-progress {
	height: 3px;
	background: rgba(255, 255, 255, 0.25);
	margin-bottom: 6px;
	border-radius: 2px;
}
.fgps-qs-progress-bar {
	height: 100%;
	background: #fff;
	border-radius: 2px;
	transition: width 0.3s ease;
}
.fgps-qs-step-label {
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	color: rgba(255, 255, 255, 0.7);
	margin: 0;
	padding-bottom: 0;
}

/* Steps inside form */
.fgps-qs-step {
	animation: fgps-step-in 0.25s ease both;
}
@keyframes fgps-step-in {
	from { opacity: 0; transform: translateX(12px); }
	to   { opacity: 1; transform: none; }
}

/* Step inline error */
.fgps-qs-step-error {
	background: #fef2f2;
	border: 1.5px solid #fecaca;
	border-radius: 10px;
	padding: 10px 14px;
	margin-bottom: 10px;
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	color: #991b1b;
}

/* Navigation buttons row */
.fgps-qs-nav-row {
	display: flex;
	gap: 10px;
	margin-top: 12px;
}
.fgps-qs-nav-row .fgps-qs-submit {
	flex: 1;
}
.fgps-qs-back-btn {
	padding: 14px 20px;
	background: transparent;
	border: 1.5px solid #e2e8f0;
	border-radius: 100px;
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	font-weight: 600;
	color: #64748b;
	cursor: pointer;
	transition: border-color 0.2s, color 0.2s, background 0.2s;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	gap: 6px;
}
.fgps-qs-back-btn:hover {
	border-color: #cbd5e1;
	background: #f8fafc;
	color: #0e1b30;
}

/* Range slider */
.fgps-qs-slider-field .fgps-qs-range-wrap {
	padding: 4px 0 0;
}
.fgps-qs-range {
	width: 100%;
	accent-color: var(--fgps-primary);
	cursor: pointer;
	height: 4px;
	border-radius: 100px;
}
.fgps-qs-range-row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 10px;
}
.fgps-qs-range-min,
.fgps-qs-range-max {
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	color: #94a3b8;
}
.fgps-qs-range-val {
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	font-weight: 700;
	color: var(--fgps-primary);
	background: rgba(49,94,251,0.07);
	padding: 4px 14px;
	border-radius: 100px;
}

@media (max-width: 480px) {
	.fgps-qs-header {
		padding: 20px 20px 14px;
	}
	.fgps-qs-form {
		padding: 20px 20px 28px;
	}
}

/* ── Plan My Solar ── */

.fgps-ps-section {
	background: #fff;
	padding: 0;
	overflow: hidden;
	width: 100%;
}
.fgps-ps-inner {
	display: grid;
	grid-template-columns: 44% 56%;
	min-height: 680px;
}

/* ── Left column ── */
.fgps-ps-left {
	background: #0e1b30;
	padding: 72px 56px 64px max(40px, calc((100vw - 1280px) / 2));
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 36px;
	position: relative;
	overflow: hidden;
}
.fgps-ps-left::before {
	content: '';
	position: absolute;
	top: -120px;
	right: -80px;
	width: 360px;
	height: 360px;
	background: radial-gradient(circle, rgba(49,94,251,0.18) 0%, transparent 70%);
	pointer-events: none;
}
.fgps-ps-left::after {
	content: '';
	position: absolute;
	bottom: -80px;
	left: -60px;
	width: 280px;
	height: 280px;
	background: radial-gradient(circle, rgba(49,94,251,0.1) 0%, transparent 70%);
	pointer-events: none;
}
.fgps-ps-heading {
	position: relative;
	z-index: 1;
}
.fgps-ps-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--fgps-primary-lt, #7fb2ff);
	margin-bottom: 18px;
}
.fgps-ps-eyebrow::before {
	content: '';
	display: inline-block;
	width: 24px;
	height: 2px;
	background: var(--fgps-primary-lt, #7fb2ff);
	border-radius: 2px;
}
.fgps-ps-title {
	font-family: 'Poppins', sans-serif;
	font-size: clamp(24px, 2.4vw, 38px);
	font-weight: 700;
	color: #fff;
	line-height: 1.2;
	margin: 0 0 16px;
}
.fgps-ps-free {
	color: var(--fgps-primary-lt, #7fb2ff);
}
.fgps-ps-subtitle {
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	color: rgba(255, 255, 255, 0.6);
	margin: 0;
	line-height: 1.75;
	max-width: 400px;
}
.fgps-ps-images {
	position: relative;
	z-index: 1;
	border-radius: 20px;
	overflow: hidden;
	flex: 1;
	min-height: 240px;
	max-height: 340px;
	box-shadow: 0 16px 48px rgba(0,0,0,0.35);
}
.fgps-ps-img {
	position: absolute;
	inset: 0;
}
.fgps-ps-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.fgps-ps-img:not(.fgps-ps-img--active) {
	display: none;
}
.fgps-ps-img.fgps-ps-img--active {
	display: block;
}

/* ── Right column ── */
.fgps-ps-right {
	padding: 0;
	display: flex;
	align-items: stretch;
	background: #f4f7ff;
}
.fgps-ps-form-card {
	background: #fff;
	width: 100%;
	padding: 0;
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

/* ── Tabs ── */
.fgps-ps-tabs {
	display: flex;
	border-bottom: 1px solid #e8edf5;
	background: #f8fafc;
	flex-shrink: 0;
}
.fgps-ps-tab {
	flex: 1;
	padding: 18px 12px;
	background: transparent;
	border: none;
	border-bottom: 3px solid transparent;
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	font-weight: 600;
	color: #94a3b8;
	cursor: pointer;
	transition: color 0.2s, border-color 0.2s, background 0.2s;
	white-space: nowrap;
	letter-spacing: 0.01em;
}
.fgps-ps-tab:hover {
	color: #0e1b30;
	background: #fff;
}
.fgps-ps-tab.active {
	color: var(--fgps-primary);
	border-bottom-color: var(--fgps-primary);
	background: #fff;
}

/* ── Form ── */
.fgps-ps-form {
	padding: 36px max(32px, calc((100vw - 1280px) / 2)) 44px 48px;
	flex: 1;
}
.fgps-ps-panel {
	display: none;
}
.fgps-ps-panel.active {
	display: block;
}
.fgps-ps-field {
	margin-bottom: 22px;
}
.fgps-ps-label {
	display: block;
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: #64748b;
	margin-bottom: 9px;
}
.fgps-ps-label .req {
	color: #e53e3e;
	margin-left: 2px;
}
.fgps-ps-input,
.fgps-ps-select {
	width: 100%;
	padding: 14px 20px;
	border: 1.5px solid #e2e8f0;
	border-radius: 100px;
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	color: #0e1b30;
	background: #f8fafc;
	transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
	box-sizing: border-box;
	-webkit-appearance: none;
	appearance: none;
}
.fgps-ps-input::placeholder { color: #c0ccd8; }
.fgps-ps-input:focus,
.fgps-ps-select:focus {
	outline: none;
	border-color: var(--fgps-primary);
	box-shadow: 0 0 0 4px rgba(49, 94, 251, 0.1);
	background: #fff;
}
.fgps-ps-select {
	border-radius: 100px;
	padding-right: 40px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='8' viewBox='0 0 14 8' fill='none'%3E%3Cpath d='M1 1L7 7L13 1' stroke='%2394a3b8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 18px center;
}

/* Two-column fields grid */
.fgps-ps-fields-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}

/* Bill radio pills */
.fgps-ps-bill-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.fgps-ps-bill-opt {
	position: relative;
}
.fgps-ps-bill-opt input[type=radio] {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
}
.fgps-ps-bill-opt label {
	display: inline-block;
	padding: 9px 16px;
	border: 1.5px solid #e2e8f0;
	border-radius: 100px;
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	font-weight: 500;
	color: #64748b;
	cursor: pointer;
	transition: all 0.15s;
	white-space: nowrap;
	background: #f8fafc;
}
.fgps-ps-bill-opt label:hover {
	border-color: var(--fgps-primary);
	color: var(--fgps-primary);
	background: rgba(49, 94, 251, 0.04);
}
.fgps-ps-bill-opt input:checked + label {
	border-color: var(--fgps-primary);
	background: rgba(49, 94, 251, 0.08);
	color: var(--fgps-primary);
	font-weight: 600;
}

/* Designation radio pills */
.fgps-ps-desig-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

/* Range slider */
.fgps-ps-range {
	width: 100%;
	accent-color: var(--fgps-primary);
	cursor: pointer;
	height: 4px;
	border-radius: 100px;
	margin-top: 6px;
}
.fgps-ps-range-val {
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	font-weight: 700;
	color: var(--fgps-primary);
	background: rgba(49,94,251,0.07);
	display: inline-block;
	padding: 4px 14px;
	border-radius: 100px;
	margin-top: 10px;
}

/* Terms + Submit */
.fgps-ps-common {
	border-top: 1px solid #f1f5f9;
	margin-top: 4px;
	padding-top: 24px;
}
.fgps-ps-terms {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	color: #64748b;
	margin-bottom: 20px;
	cursor: pointer;
	line-height: 1.5;
}
.fgps-ps-terms input[type=checkbox] {
	margin-top: 2px;
	width: 16px;
	height: 16px;
	accent-color: var(--fgps-primary);
	flex-shrink: 0;
	cursor: pointer;
}
.fgps-ps-submit {
	width: 100%;
	padding: 16px;
	background: var(--fgps-primary);
	color: #fff;
	border: none;
	border-radius: 100px;
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	font-weight: 700;
	letter-spacing: 0.02em;
	cursor: pointer;
	transition: background 0.2s, transform 0.15s, box-shadow 0.2s;
	box-shadow: 0 4px 18px rgba(49,94,251,0.3);
}
.fgps-ps-submit:hover {
	background: var(--fgps-primary-dk);
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(49,94,251,0.38);
}
.fgps-ps-submit:active { transform: translateY(0); }
.fgps-ps-submit:disabled {
	opacity: 0.6;
	pointer-events: none;
}
.fgps-ps-success {
	background: #f0fdf4;
	border: 1.5px solid #bbf7d0;
	border-radius: 16px;
	padding: 18px;
	text-align: center;
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	color: #166534;
	margin-top: 16px;
}
.fgps-ps-error {
	background: #fef2f2;
	border: 1.5px solid #fecaca;
	border-radius: 100px;
	padding: 12px 20px;
	margin-bottom: 16px;
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	color: #991b1b;
}

/* ── Responsive ── */
@media (max-width: 900px) {
	.fgps-ps-inner {
		grid-template-columns: 1fr;
	}
	.fgps-ps-left {
		padding: 52px 32px 48px 32px;
		min-height: 0;
		justify-content: flex-start;
	}
	.fgps-ps-images {
		max-height: 240px;
	}
	.fgps-ps-right {
		background: #fff;
	}
	.fgps-ps-form {
		padding: 32px 32px 40px 32px;
	}
}
@media (max-width: 480px) {
	.fgps-ps-fields-grid {
		grid-template-columns: 1fr;
	}
	.fgps-ps-tab {
		font-size: 11.5px;
		padding: 15px 6px;
	}
	.fgps-ps-form {
		padding: 28px 20px 36px 20px;
	}
	.fgps-ps-left {
		padding: 44px 20px 40px;
	}
}

/* ── Solar Savings Calculator ── */

.fgps-calc-section {
	background: var(--fgps-bg, #f4f8ff);
	padding: 80px 0 96px;
}
.fgps-calc-wrap {
	max-width: 1100px;
}

/* Header */
.fgps-calc-header {
	text-align: center;
	margin-bottom: 48px;
}
.fgps-calc-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--fgps-primary);
	margin-bottom: 14px;
}
.fgps-calc-title {
	font-family: 'Poppins', sans-serif;
	font-size: clamp(26px, 4vw, 42px);
	font-weight: 800;
	color: var(--fgps-txt, #0e1b30);
	line-height: 1.15;
	margin: 0 0 14px;
}
.fgps-calc-subtitle {
	font-family: 'Inter', sans-serif;
	font-size: 16px;
	color: var(--fgps-muted, #64748b);
	line-height: 1.7;
	margin: 0;
	max-width: 560px;
	margin-inline: auto;
}

/* Main card */
.fgps-calc-card {
	background: #fff;
	border-radius: 24px;
	box-shadow: 0 8px 48px rgba(49,94,251,0.1), 0 1px 4px rgba(0,0,0,0.06);
	overflow: hidden;
	border: 1px solid #e8edf5;
}

/* Inputs row */
.fgps-calc-inputs-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	border-bottom: 1px solid #f1f5f9;
}
.fgps-calc-input-group {
	padding: 32px 40px 28px;
}
.fgps-calc-input-group--bill {
	border-right: 1px solid #f1f5f9;
}
.fgps-calc-input-label {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin-bottom: 20px;
}
.fgps-calc-input-label > span {
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	color: #94a3b8;
}
.fgps-calc-bill-display {
	display: flex;
	align-items: baseline;
	gap: 2px;
}
.fgps-calc-currency {
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	font-weight: 600;
	color: var(--fgps-primary);
}
.fgps-calc-bill-val {
	font-family: 'Poppins', sans-serif;
	font-size: 24px;
	font-weight: 800;
	color: var(--fgps-primary);
	line-height: 1;
	transition: color 0.2s;
}
.fgps-calc-per {
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	color: #94a3b8;
	margin-left: 3px;
}

/* Slider */
.fgps-calc-slider-wrap {
	position: relative;
}
.fgps-calc-slider {
	-webkit-appearance: none;
	appearance: none;
	width: 100%;
	height: 6px;
	border-radius: 100px;
	background: #e2e8f0;
	outline: none;
	cursor: pointer;
	position: relative;
	z-index: 1;
}
.fgps-calc-slider::-webkit-slider-thumb {
	-webkit-appearance: none;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: var(--fgps-primary);
	box-shadow: 0 2px 8px rgba(49,94,251,0.35);
	cursor: pointer;
	transition: transform 0.15s, box-shadow 0.15s;
	border: 3px solid #fff;
}
.fgps-calc-slider::-moz-range-thumb {
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: var(--fgps-primary);
	box-shadow: 0 2px 8px rgba(49,94,251,0.35);
	cursor: pointer;
	border: 3px solid #fff;
}
.fgps-calc-slider:active::-webkit-slider-thumb,
.fgps-calc-slider:hover::-webkit-slider-thumb {
	transform: scale(1.15);
	box-shadow: 0 4px 14px rgba(49,94,251,0.45);
}
.fgps-calc-slider-labels {
	display: flex;
	justify-content: space-between;
	margin-top: 10px;
}
.fgps-calc-slider-labels span {
	font-family: 'Inter', sans-serif;
	font-size: 10px;
	color: #c0ccd8;
	font-weight: 500;
}

/* Type buttons */
.fgps-calc-type-btns {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.fgps-calc-type-btn {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 13px 16px;
	background: #f8fafc;
	border: 1.5px solid #e2e8f0;
	border-radius: 12px;
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	font-weight: 500;
	color: #64748b;
	cursor: pointer;
	transition: background 0.2s, border-color 0.2s, color 0.2s, box-shadow 0.2s;
	text-align: left;
}
.fgps-calc-type-btn svg { flex-shrink: 0; opacity: 0.7; transition: opacity 0.2s; }
.fgps-calc-type-btn:hover {
	border-color: var(--fgps-primary);
	color: var(--fgps-primary);
}
.fgps-calc-type-btn.active {
	background: rgba(49,94,251,0.06);
	border-color: var(--fgps-primary);
	color: var(--fgps-primary);
	font-weight: 600;
	box-shadow: 0 0 0 3px rgba(49,94,251,0.1);
}
.fgps-calc-type-btn.active svg { opacity: 1; }

/* ── Results ── */
.fgps-calc-results {
	padding: 32px 40px 36px;
}

/* ─── Simplified results layout (3 cards: System · Savings · Investment) ─── */
.fgps-calc-results--simple {
	display: flex;
	flex-direction: column;
	gap: 24px;
}
.fgps-calc-rcard {
	background: #fff;
	border: 1px solid #eef1f5;
	border-radius: 16px;
	padding: 22px 24px 20px;
	box-shadow: 0 1px 2px rgba(15, 23, 42, 0.03);
}
.fgps-calc-rcard-title {
	font-family: 'Poppins', sans-serif;
	font-size: 17px;
	font-weight: 700;
	color: var(--fgps-txt, #0e1b30);
	margin: 0 0 14px;
	line-height: 1.2;
}
.fgps-calc-rcard-split {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 16px;
	padding: 8px 0;
}
.fgps-calc-rcard-split--savings {
	padding: 14px 0 6px;
}
.fgps-calc-rcard-split--highlight {
	background: linear-gradient(180deg, #f7faff 0%, #f0f5ff 100%);
	border-radius: 12px;
	padding: 18px 20px;
	margin-top: 16px;
	gap: 12px;
}
.fgps-calc-rstat {
	display: flex;
	align-items: center;
	gap: 14px;
	min-width: 0;
}
.fgps-calc-rstat-icon {
	width: 36px;
	height: 36px;
	flex-shrink: 0;
	color: #64748b;
	display: flex;
	align-items: center;
	justify-content: center;
}
.fgps-calc-rstat-body {
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 3px;
}
.fgps-calc-rstat-label {
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	font-weight: 500;
	color: #64748b;
}
.fgps-calc-rstat-val {
	font-family: 'Poppins', sans-serif;
	font-size: 22px;
	font-weight: 700;
	color: var(--fgps-txt, #0e1b30);
	line-height: 1.15;
	transition: all 0.25s;
}
.fgps-calc-rstat-val small {
	font-size: 13px;
	font-weight: 500;
	color: #64748b;
	margin-left: 2px;
}
.fgps-calc-rstat-val--accent { color: var(--fgps-primary, #315efb); }
.fgps-calc-rstat-val--pos    { color: #059669; }
.fgps-calc-rstat-divider {
	width: 1px;
	align-self: stretch;
	background: #e2e8f0;
	min-height: 32px;
}
.fgps-calc-rcard-note {
	margin: 14px 0 0;
	padding: 12px 16px;
	background: #f0f6ff;
	border-radius: 10px;
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	color: #334155;
	text-align: center;
	line-height: 1.55;
}
.fgps-calc-rcard-note a {
	color: var(--fgps-primary, #315efb);
	text-decoration: underline;
	font-weight: 600;
}

/* Investment line items */
.fgps-calc-rlines {
	display: flex;
	flex-direction: column;
	gap: 12px;
	padding: 4px 0;
}
.fgps-calc-rline {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	color: #475569;
}
.fgps-calc-rline strong {
	font-family: 'Poppins', sans-serif;
	font-size: 15px;
	font-weight: 600;
	color: var(--fgps-txt, #0e1b30);
}
.fgps-calc-rline-neg { color: #ea580c !important; }
.fgps-calc-rline--total {
	padding-top: 12px;
	border-top: 1px solid #eef1f5;
	font-weight: 600;
	color: var(--fgps-txt, #0e1b30);
}
.fgps-calc-rline--total strong {
	font-size: 18px;
	font-weight: 800;
}

/* System hero */
.fgps-calc-sys-hero {
	display: grid;
	grid-template-columns: 72px 1fr 1fr;
	gap: 20px;
	align-items: center;
	background: linear-gradient(135deg, #0e1b30 0%, #1a2f54 100%);
	border-radius: 16px;
	padding: 24px 28px;
	margin-bottom: 24px;
}
.fgps-calc-sys-icon {
	width: 64px;
	height: 64px;
	background: rgba(255,255,255,0.06);
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.fgps-calc-sys-icon svg { width: 44px; height: 44px; }
.fgps-calc-sys-text { flex: 1; }
.fgps-calc-sys-label {
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: rgba(255,255,255,0.5);
	margin-bottom: 6px;
}
.fgps-calc-sys-kw {
	font-family: 'Poppins', sans-serif;
	font-size: 36px;
	font-weight: 800;
	color: #fff;
	line-height: 1;
	margin-bottom: 4px;
	transition: all 0.3s;
}
.fgps-calc-sys-kw span { color: var(--fgps-primary-lt, #7fb2ff); }
.fgps-calc-sys-sub {
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	color: rgba(255,255,255,0.45);
}
.fgps-calc-bill-offset { }
.fgps-calc-offset-label {
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	color: rgba(255,255,255,0.5);
	margin-bottom: 8px;
}
.fgps-calc-offset-bar-wrap {
	width: 100%;
	height: 8px;
	background: rgba(255,255,255,0.1);
	border-radius: 100px;
	overflow: hidden;
	margin-bottom: 6px;
}
.fgps-calc-offset-bar {
	height: 100%;
	background: linear-gradient(90deg, #7fb2ff, #315efb);
	border-radius: 100px;
	transition: width 0.6s cubic-bezier(0.34,1.56,0.64,1);
}
.fgps-calc-offset-pct {
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	font-weight: 600;
	color: rgba(255,255,255,0.75);
}
.fgps-calc-offset-pct span {
	color: var(--fgps-primary-lt, #7fb2ff);
	font-size: 16px;
	font-weight: 800;
}

/* Metrics grid */
.fgps-calc-metrics {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
}
.fgps-calc-metric {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	background: #f8fafc;
	border: 1px solid #f1f5f9;
	border-radius: 14px;
	padding: 16px 18px;
	transition: box-shadow 0.2s, transform 0.2s;
}
.fgps-calc-metric:hover {
	box-shadow: 0 4px 16px rgba(0,0,0,0.06);
	transform: translateY(-2px);
}
.fgps-calc-metric-icon {
	width: 36px;
	height: 36px;
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.fgps-calc-metric-body { min-width: 0; }
.fgps-calc-metric-label {
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: #94a3b8;
	margin-bottom: 5px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.fgps-calc-metric-val {
	font-family: 'Poppins', sans-serif;
	font-size: 18px;
	font-weight: 700;
	color: var(--fgps-txt, #0e1b30);
	line-height: 1.1;
	transition: all 0.25s;
}
.fgps-calc-unit {
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	font-weight: 500;
	color: #94a3b8;
}
.fgps-calc-highlight {
	color: #059669 !important;
}

/* Metric colour variants */
.fgps-calc-metric--savings .fgps-calc-metric-icon  { background: #f0fdf4; color: #059669; }
.fgps-calc-metric--annual .fgps-calc-metric-icon   { background: #eff6ff; color: var(--fgps-primary); }
.fgps-calc-metric--lifetime .fgps-calc-metric-icon { background: #fefce8; color: #d97706; }
.fgps-calc-metric--cost .fgps-calc-metric-icon     { background: #f1f5f9; color: #475569; }
.fgps-calc-metric--subsidy .fgps-calc-metric-icon  { background: #fdf4ff; color: #9333ea; }
.fgps-calc-metric--net .fgps-calc-metric-icon      { background: #f0fdf4; color: #059669; }
.fgps-calc-metric--payback .fgps-calc-metric-icon  { background: #fff7ed; color: #ea580c; }
.fgps-calc-metric--co2 .fgps-calc-metric-icon      { background: #f0fdf4; color: #16a34a; }

/* Commercial note */
.fgps-calc-commercial-note {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	background: #fffbeb;
	border: 1px solid #fde68a;
	border-radius: 12px;
	padding: 14px 18px;
	margin-top: 16px;
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	color: #92400e;
	line-height: 1.6;
}
.fgps-calc-commercial-note svg { flex-shrink: 0; margin-top: 1px; }

/* CTA row */
.fgps-calc-cta-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	padding: 24px 40px;
	background: linear-gradient(135deg, #f4f8ff 0%, #eef2ff 100%);
	border-top: 1px solid #e8edf5;
}
.fgps-calc-cta-text {
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.fgps-calc-cta-text strong {
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	font-weight: 700;
	color: var(--fgps-txt, #0e1b30);
}
.fgps-calc-cta-text span {
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	color: #64748b;
}
.fgps-calc-disclaimer {
	padding: 0 40px 20px;
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	color: #c0ccd8;
	line-height: 1.6;
	margin: 0;
}

/* Responsive */
@media (max-width: 900px) {
	.fgps-calc-inputs-row { grid-template-columns: 1fr; }
	.fgps-calc-input-group--bill { border-right: none; border-bottom: 1px solid #f1f5f9; }
	.fgps-calc-type-btns { flex-direction: row; flex-wrap: wrap; gap: 8px; }
	.fgps-calc-type-btn { flex: 1; min-width: 140px; }
	.fgps-calc-metrics { grid-template-columns: repeat(2, 1fr); }
	.fgps-calc-sys-hero { grid-template-columns: 60px 1fr; }
	.fgps-calc-bill-offset { grid-column: 1 / -1; }
}
@media (max-width: 640px) {
	.fgps-calc-input-group { padding: 24px 20px 20px; }
	.fgps-calc-results { padding: 24px 20px 28px; }
	.fgps-calc-sys-hero { grid-template-columns: 1fr; text-align: center; }
	.fgps-calc-sys-icon { margin: 0 auto; }
	.fgps-calc-metrics { grid-template-columns: repeat(2, 1fr); gap: 10px; }
	.fgps-calc-metric { padding: 14px 12px; }
	.fgps-calc-metric-val { font-size: 15px; }
	.fgps-calc-cta-row { flex-direction: column; align-items: flex-start; padding: 20px; }
	.fgps-calc-disclaimer { padding: 0 20px 16px; }

	/* Simplified results: stack split columns on mobile */
	.fgps-calc-rcard { padding: 18px 18px 16px; }
	.fgps-calc-rcard-split { grid-template-columns: 1fr; gap: 14px; }
	.fgps-calc-rstat-divider { width: 100%; height: 1px; min-height: 0; }
	.fgps-calc-rstat-val { font-size: 20px; }
}
@media (max-width: 380px) {
	.fgps-calc-metrics { grid-template-columns: 1fr; }
}

/* ── Page Header (inner-page hero banner) ── */

.fgps-ph-section {
	padding: 0;
	overflow: hidden;
}
.fgps-ph-hero {
	position: relative;
	min-height: 420px;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center center;
	background-color: #0e1b30;
	display: flex;
	flex-direction: column;
}
.fgps-ph-overlay {
	position: absolute;
	inset: 0;
	pointer-events: none;
}
.fgps-ph-content {
	position: relative;
	z-index: 2;
	flex: 1;
	display: flex;
	align-items: center;
	padding-top: 100px; /* clears fixed header */
	padding-bottom: 72px;
}
/* Alignment variants */
.fgps-ph-align--center .fgps-ph-content { justify-content: center; }
.fgps-ph-align--center .fgps-ph-inner   { text-align: center; align-items: center; }
.fgps-ph-align--left   .fgps-ph-inner   { text-align: left; align-items: flex-start; }

.fgps-ph-inner {
	display: flex;
	flex-direction: column;
	max-width: 680px;
}
.fgps-ph-align--center .fgps-ph-inner { max-width: 760px; }

/* Badge / eyebrow */
.fgps-ph-badge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: rgba(49,94,251,0.85);
	color: #fff;
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 5px 14px;
	border-radius: 100px;
	margin-bottom: 20px;
}
.fgps-ph-badge-dot {
	width: 6px; height: 6px;
	background: rgba(255,255,255,0.85);
	border-radius: 50%;
}

/* Decorative left accent line */
.fgps-ph-decor-line {
	width: 40px;
	height: 3px;
	background: var(--fgps-primary);
	border-radius: 3px;
	margin-bottom: 20px;
}

/* Heading */
.fgps-ph-title {
	font-family: 'Poppins', sans-serif;
	font-size: clamp(30px, 5vw, 54px);
	font-weight: 800;
	color: #fff;
	line-height: 1.1;
	margin: 0 0 18px;
	letter-spacing: -0.01em;
}
.fgps-ph-highlight {
	color: var(--fgps-primary-lt, #7fb2ff);
}

/* Subheading */
.fgps-ph-subtitle {
	font-family: 'Inter', sans-serif;
	font-size: 16px;
	color: rgba(255,255,255,0.68);
	line-height: 1.75;
	margin: 0 0 28px;
	max-width: 540px;
}
.fgps-ph-align--center .fgps-ph-subtitle { max-width: 600px; }

/* CTA button */
.fgps-ph-cta {
	align-self: flex-start;
	margin-bottom: 32px;
}
.fgps-ph-align--center .fgps-ph-cta { align-self: center; }

/* Breadcrumb */
.fgps-ph-breadcrumb {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: 4px;
}
.fgps-ph-bc-link {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	font-weight: 500;
	color: rgba(255,255,255,0.55);
	text-decoration: none;
	transition: color 0.2s;
}
.fgps-ph-bc-link:hover { color: rgba(255,255,255,0.9); }
.fgps-ph-bc-sep {
	color: rgba(255,255,255,0.3);
	display: flex;
	align-items: center;
}
.fgps-ph-bc-current {
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	font-weight: 600;
	color: rgba(255,255,255,0.85);
}

/* Responsive */
@media (max-width: 768px) {
	.fgps-ph-hero { min-height: 320px; }
	.fgps-ph-content {
		padding-top: 88px;
		padding-bottom: 60px;
	}
	.fgps-ph-title { font-size: clamp(26px, 7vw, 40px); }
	.fgps-ph-subtitle { font-size: 14px; }
}
@media (max-width: 480px) {
	.fgps-ph-content {
		padding-top: 80px;
		padding-bottom: 52px;
	}
}

/* ── WhatsApp Floating Button ── */
@keyframes fgpsWaEntrance {
	from { opacity: 0; transform: translateY(24px); }
	to   { opacity: 1; transform: translateY(0); }
}

.fgps-wa-wrap {
	position: fixed;
	bottom: 24px;
	right: 24px;
	z-index: 99990;
	display: flex;
	align-items: center;
	gap: 10px;
	animation: fgpsWaEntrance 0.5s cubic-bezier(0.34,1.56,0.64,1) 1.2s both;
}

/* Bubble pill */
.fgps-wa-bubble {
	display: flex;
	align-items: center;
	gap: 10px;
	background: #fff;
	border-radius: 100px;
	padding: 11px 8px 11px 18px;
	box-shadow: 0 4px 24px rgba(0,0,0,0.13), 0 1px 4px rgba(0,0,0,0.06);
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	font-weight: 500;
	color: #0e1b30;
	white-space: nowrap;
	transition: opacity 0.25s ease, transform 0.25s ease;
	transform-origin: right center;
}
.fgps-wa-bubble.fgps-wa-hidden {
	opacity: 0;
	transform: scaleX(0.85) translateX(12px);
	pointer-events: none;
}

/* Label text */
.fgps-wa-label {
	line-height: 1;
}

/* Close button inside bubble */
.fgps-wa-close {
	width: 24px;
	height: 24px;
	background: #4b5563;
	border: none;
	box-shadow: none;
	border-radius: 50%;
	color: #fff;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: background 0.15s;
	padding: 0;
	outline: none;
}
.fgps-wa-close:hover {
	background: #374151;
}
.fgps-wa-close:focus-visible {
	outline: 2px solid #25d366;
	outline-offset: 2px;
}

/* Green circle WhatsApp button */
.fgps-wa-btn {
	width: 58px;
	height: 58px;
	background: #25d366;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	text-decoration: none;
	box-shadow: 0 4px 16px rgba(37,211,102,0.45), 0 1px 4px rgba(0,0,0,0.08);
	transition: transform 0.2s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.2s;
	flex-shrink: 0;
}
.fgps-wa-btn svg {
	width: 30px;
	height: 30px;
}
.fgps-wa-btn:hover {
	transform: scale(1.1);
	box-shadow: 0 6px 22px rgba(37,211,102,0.55);
}
.fgps-wa-btn:focus-visible {
	outline: 3px solid #25d366;
	outline-offset: 3px;
}

@media (max-width: 480px) {
	.fgps-wa-wrap {
		bottom: 16px;
		right: 16px;
	}
	.fgps-wa-bubble {
		font-size: 13px;
	}
}

/* ================================================================
   FGPS Projects — All project-related block styles
   Blocks: Project All Hero, Project All Grid, Project Detail Header
   ================================================================ */

/* ── Project Type Badges ── */
.fgps-proj-type-badge {
	display: inline-flex;
	align-items: center;
	padding: 4px 12px;
	border-radius: 100px;
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}
.fgps-proj-badge--residential  { background: #e0e7ff; color: #3730a3; }
.fgps-proj-badge--commercial   { background: #cffafe; color: #155e75; }
.fgps-proj-badge--ground-mount { background: #d1fae5; color: #065f46; }
.fgps-proj-badge--industrial   { background: #fef3c7; color: #92400e; }

/* ── Project All — Hero ── */
.fgps-proj-hero {
	position: relative;
	display: flex;
	flex-direction: column;
	overflow: hidden;
}
.fgps-proj-hero-bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	transform: scale(1.04);
	transition: transform 6s ease;
}
.fgps-proj-hero:hover .fgps-proj-hero-bg { transform: scale(1.0); }
.fgps-proj-hero-overlay {
	position: absolute;
	inset: 0;
	background: rgba(14,27,48,0.75);
	z-index: 1;
}
.fgps-proj-hero-content {
	position: relative;
	z-index: 2;
	display: flex;
	align-items: center;
	min-height: 500px;
	padding: 80px 0 60px;
}
.fgps-proj-hero-inner {
	max-width: 700px;
}
.fgps-proj-hero-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: var(--fgps-primary);
	color: #fff;
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: 5px 14px;
	border-radius: 100px;
	margin-bottom: 20px;
}
.fgps-proj-hero-badge::before {
	content: '';
	width: 6px; height: 6px;
	background: #fff;
	border-radius: 50%;
	opacity: 0.8;
}
.fgps-proj-hero-title {
	font-family: 'Poppins', sans-serif;
	font-size: clamp(32px, 5vw, 56px);
	font-weight: 800;
	color: #fff;
	line-height: 1.1;
	margin: 0 0 20px;
}
.fgps-proj-hero-sub {
	font-family: 'Inter', sans-serif;
	font-size: 16px;
	color: rgba(255,255,255,0.75);
	line-height: 1.7;
	margin: 0;
	max-width: 560px;
}
/* Stats bar */
.fgps-proj-hero-stats-bar {
	position: relative;
	z-index: 2;
	background: rgba(255,255,255,0.06);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border-top: 1px solid rgba(255,255,255,0.1);
	padding: 0;
}
.fgps-proj-hero-stats-inner {
	display: flex;
	flex-wrap: wrap;
	gap: 0;
	padding: 0;
}
.fgps-proj-hero-stat {
	flex: 1;
	min-width: 120px;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 20px 16px;
	border-right: 1px solid rgba(255,255,255,0.08);
}
.fgps-proj-hero-stat:last-child { border-right: none; }
.fgps-proj-hero-stat strong {
	font-family: 'Poppins', sans-serif;
	font-size: 20px;
	font-weight: 700;
	color: #fff;
	line-height: 1.1;
}
.fgps-proj-hero-stat span {
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	color: rgba(255,255,255,0.55);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin-top: 4px;
}
@media (max-width: 640px) {
	.fgps-proj-hero-stat { min-width: 50%; border-right: 1px solid rgba(255,255,255,0.08); }
	.fgps-proj-hero-stat:nth-child(even) { border-right: none; }
}

/* ── Project All — Filter Tabs ── */
.fgps-proj-grid-section {
	padding: 48px 0 64px;
	background: #fff;
}
.fgps-proj-filters-wrap {
	margin-bottom: 36px;
}
.fgps-proj-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
}
.fgps-proj-filter {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 18px;
	background: transparent;
	border: 1.5px solid var(--fgps-border);
	border-radius: 100px;
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	font-weight: 500;
	color: var(--fgps-muted);
	cursor: pointer;
	transition: background 0.2s, border-color 0.2s, color 0.2s;
	outline: none;
}
.fgps-proj-filter:hover {
	border-color: var(--fgps-primary);
	color: var(--fgps-primary);
}
.fgps-proj-filter.active {
	background: var(--fgps-primary);
	border-color: var(--fgps-primary);
	color: #fff;
	font-weight: 600;
}
.fgps-proj-filter-count {
	background: rgba(0,0,0,0.08);
	border-radius: 100px;
	padding: 1px 7px;
	font-size: 11px;
}
.fgps-proj-filter.active .fgps-proj-filter-count { background: rgba(255,255,255,0.2); }

/* ── Project Grid Cards ── */
.fgps-proj-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}
.fgps-proj-grid[data-columns="2"] { grid-template-columns: repeat(2, 1fr); }
.fgps-proj-grid[data-columns="4"] { grid-template-columns: repeat(4, 1fr); }

.fgps-proj-card {
	border-radius: var(--fgps-rl);
	overflow: hidden;
	background: #fff;
	box-shadow: var(--fgps-shadow-sm);
	transition: transform 0.25s cubic-bezier(.34,1.56,.64,1), box-shadow 0.25s;
	border: 1px solid var(--fgps-border);
}
.fgps-proj-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--fgps-shadow-md);
}
.fgps-proj-card.fgps-proj-hidden { display: none; }
.fgps-proj-card-link {
	text-decoration: none;
	color: inherit;
	display: block;
}
.fgps-proj-card-img {
	position: relative;
	aspect-ratio: 16/10;
	overflow: hidden;
	background: #e2e8f0;
}
.fgps-proj-card-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}
.fgps-proj-card:hover .fgps-proj-card-img img { transform: scale(1.04); }
.fgps-proj-card-img-placeholder {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, #e2e8f0, #f1f5f9);
}
.fgps-proj-card-badges {
	position: absolute;
	top: 12px;
	left: 12px;
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
}
.fgps-proj-card-body {
	padding: 16px 18px 18px;
}
.fgps-proj-card-title {
	font-family: 'Poppins', sans-serif;
	font-size: 15px;
	font-weight: 600;
	color: var(--fgps-txt);
	margin: 0 0 10px;
	line-height: 1.4;
}
.fgps-proj-card-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
}
.fgps-proj-card-meta-item {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	color: var(--fgps-muted);
	background: #f8fafc;
	border: 1px solid var(--fgps-border);
	padding: 3px 9px;
	border-radius: 100px;
}
.fgps-proj-card-meta-item svg { flex-shrink: 0; opacity: 0.7; }
.fgps-proj-card-savings {
	background: #f0fdf4;
	border-color: #bbf7d0;
	color: #065f46;
	font-weight: 600;
}

@media (max-width: 900px) {
	.fgps-proj-grid,
	.fgps-proj-grid[data-columns="3"],
	.fgps-proj-grid[data-columns="4"] { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 580px) {
	.fgps-proj-grid,
	.fgps-proj-grid[data-columns="2"],
	.fgps-proj-grid[data-columns="3"],
	.fgps-proj-grid[data-columns="4"] { grid-template-columns: 1fr; }
}

/* ── Project Detail — Single Hero ── */
.fgps-proj-single-wrap { display: block; }
.fgps-proj-single-hero {
	position: relative;
	display: flex;
	align-items: flex-end;
	min-height: 460px;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	background-color: var(--fgps-txt);
}
.fgps-proj-single-overlay {
	position: absolute;
	inset: 0;
	background: rgba(14,27,48,0.65);
}
.fgps-proj-single-inner {
	position: relative;
	z-index: 2;
	padding-bottom: 40px;
}
.fgps-proj-single-inner .fgps-proj-type-badge { margin-bottom: 14px; }
.fgps-proj-single-title {
	font-family: 'Poppins', sans-serif;
	font-size: clamp(26px, 4vw, 44px);
	font-weight: 800;
	color: #fff;
	margin: 0 0 12px;
	line-height: 1.15;
}
.fgps-proj-single-location {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	color: rgba(255,255,255,0.7);
	margin: 0;
}
/* Stats bar */
.fgps-proj-single-stats-bar {
	background: var(--fgps-txt);
	padding: 0;
}
.fgps-proj-single-stats-inner {
	display: flex;
	flex-wrap: wrap;
}
.fgps-proj-single-stat {
	flex: 1;
	min-width: 120px;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 24px 16px;
	border-right: 1px solid rgba(255,255,255,0.07);
}
.fgps-proj-single-stat:last-child { border-right: none; }
.fgps-proj-single-stat strong {
	font-family: 'Poppins', sans-serif;
	font-size: 22px;
	font-weight: 700;
	color: var(--fgps-primary);
	line-height: 1.1;
}
.fgps-proj-single-stat span {
	font-family: 'Inter', sans-serif;
	font-size: 10px;
	font-weight: 600;
	color: rgba(255,255,255,0.45);
	text-transform: uppercase;
	letter-spacing: 0.07em;
	margin-top: 5px;
	text-align: center;
}
@media (max-width: 640px) {
	.fgps-proj-single-stat { min-width: 50%; border-bottom: 1px solid rgba(255,255,255,0.07); }
	.fgps-proj-single-stat:nth-child(odd) { border-right: 1px solid rgba(255,255,255,0.07); }
	.fgps-proj-single-stat:nth-child(even) { border-right: none; }
}

/* ================================================================
   FGPS Blog — All blog-related block styles
   Blocks: Blog Hero, Blog Grid, Blog Single Hero
   ================================================================ */

/* ── Blog Hero ── */
.fgps-blog-hero {
	position: relative;
	overflow: hidden;
	background: var(--fgps-txt);
	display: flex;
	flex-direction: column;
}
.fgps-blog-hero-bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	z-index: 0;
}
.fgps-blog-hero-overlay {
	position: absolute;
	inset: 0;
	z-index: 1;
	background: rgba(14,27,48,0.80);
}
.fgps-blog-hero-content {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-height: 420px;
	padding: 60px 0;
}
.fgps-blog-hero-inner { text-align: center; }
.fgps-blog-hero-badge {
	display: inline-block;
	background: rgba(49,94,251,.18);
	border: 1px solid rgba(49,94,251,.45);
	color: var(--fgps-primary-lt);
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .12em;
	text-transform: uppercase;
	padding: 5px 16px;
	border-radius: 100px;
	margin-bottom: 18px;
}
.fgps-blog-hero-title {
	font-family: 'Poppins', sans-serif;
	font-size: clamp(2rem, 4vw, 3.2rem);
	font-weight: 800;
	color: #fff;
	line-height: 1.15;
	margin: 0 0 16px;
}
.fgps-blog-hero-sub {
	font-family: 'Inter', sans-serif;
	font-size: 1.05rem;
	color: rgba(255,255,255,.7);
	max-width: 560px;
	margin: 0 auto;
	line-height: 1.7;
}
.fgps-blog-cat-strip {
	position: relative;
	z-index: 2;
	background: rgba(255,255,255,.06);
	border-top: 1px solid rgba(255,255,255,.1);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
}
.fgps-blog-cat-strip-inner {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	align-items: center;
	justify-content: center;
	padding: 14px 20px;
}
.fgps-blog-cat-pill {
	display: inline-block;
	padding: 5px 16px;
	border-radius: 100px;
	border: 1px solid rgba(255,255,255,.2);
	color: rgba(255,255,255,.8);
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	font-weight: 500;
	text-decoration: none;
	transition: all .2s;
}
.fgps-blog-cat-pill:hover,
.fgps-blog-cat-pill.active {
	background: var(--fgps-primary);
	border-color: var(--fgps-primary);
	color: #fff;
}

/* ── Blog Grid ── */
.fgps-blog-grid-section {
	padding: 48px 0 64px;
	background: #fff;
}
.fgps-blog-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 32px;
}
.fgps-blog-filter {
	padding: 7px 20px;
	border-radius: 100px;
	border: 1.5px solid var(--fgps-border);
	background: #fff;
	color: var(--fgps-txt);
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	transition: all .2s;
}
.fgps-blog-filter.active,
.fgps-blog-filter:hover {
	background: var(--fgps-primary);
	border-color: var(--fgps-primary);
	color: #fff;
}
.fgps-blog-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}
.fgps-blog-grid[data-columns="2"] { grid-template-columns: repeat(2, 1fr); }
.fgps-blog-grid[data-columns="4"] { grid-template-columns: repeat(4, 1fr); }
.fgps-blog-card {
	border-radius: var(--fgps-rl);
	overflow: hidden;
	background: #fff;
	box-shadow: var(--fgps-shadow-sm);
	border: 1px solid var(--fgps-border);
	display: flex;
	flex-direction: column;
	transition: transform .25s cubic-bezier(.34,1.56,.64,1), box-shadow .25s;
}
.fgps-blog-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--fgps-shadow-md);
}
.fgps-blog-card-img {
	aspect-ratio: 16/9;
	overflow: hidden;
	background: var(--fgps-border);
	position: relative;
}
.fgps-blog-card-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .4s ease;
}
.fgps-blog-card:hover .fgps-blog-card-img img { transform: scale(1.04); }
.fgps-blog-card-img-placeholder {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, var(--fgps-border), #f1f5f9);
	display: flex;
	align-items: center;
	justify-content: center;
}
.fgps-blog-card-img-placeholder::after { content: '📰'; font-size: 2.5rem; opacity: .4; }
.fgps-blog-card-body {
	padding: 16px 18px 18px;
	display: flex;
	flex-direction: column;
	flex: 1;
}
.fgps-blog-card-meta {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 10px;
	flex-wrap: wrap;
}
.fgps-blog-card-dot {
	width: 3px;
	height: 3px;
	border-radius: 50%;
	background: var(--fgps-border);
}
.fgps-blog-card-cat {
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--fgps-primary);
	text-decoration: none;
}
.fgps-blog-card-cat:hover { color: var(--fgps-primary-dk); }
.fgps-blog-card-date,
.fgps-blog-card-rt {
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	color: var(--fgps-muted);
	font-weight: 500;
}
.fgps-blog-card-title {
	font-family: 'Poppins', sans-serif;
	font-size: 1.05rem;
	font-weight: 700;
	color: var(--fgps-txt);
	line-height: 1.35;
	margin: 0 0 10px;
	flex: 1;
}
.fgps-blog-card-title a { color: inherit; text-decoration: none; }
.fgps-blog-card-title a:hover { color: var(--fgps-primary); }
.fgps-blog-card-excerpt {
	font-family: 'Inter', sans-serif;
	font-size: .9rem;
	color: var(--fgps-muted);
	line-height: 1.6;
	margin: 0 0 16px;
}
.fgps-blog-card-read-more {
	display: inline-flex;
	align-items: center;
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	font-weight: 600;
	color: var(--fgps-primary);
	text-decoration: none;
	margin-top: auto;
}
.fgps-blog-card-read-more:hover { color: var(--fgps-primary-dk); }
@media (max-width: 900px) {
	.fgps-blog-grid,
	.fgps-blog-grid[data-columns="3"],
	.fgps-blog-grid[data-columns="4"] { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 580px) {
	.fgps-blog-grid,
	.fgps-blog-grid[data-columns="2"],
	.fgps-blog-grid[data-columns="3"],
	.fgps-blog-grid[data-columns="4"] { grid-template-columns: 1fr; }
}

/* ── Blog Single Hero ── */
.fgps-blog-single-hero {
	position: relative;
	display: flex;
	align-items: flex-end;
	min-height: 440px;
	background-size: cover;
	background-position: center;
	background-color: var(--fgps-txt);
}
.fgps-blog-single-overlay {
	position: absolute;
	inset: 0;
	background: rgba(14,27,48,0.72);
}
.fgps-blog-single-inner {
	position: relative;
	z-index: 2;
	padding: 60px 0 50px;
	width: 100%;
}
.fgps-blog-single-cat {
	display: inline-block;
	padding: 4px 14px;
	border-radius: 100px;
	background: rgba(49,94,251,.22);
	border: 1px solid rgba(49,94,251,.5);
	color: var(--fgps-primary-lt);
	font-family: 'Inter', sans-serif;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	text-decoration: none;
	margin-bottom: 18px;
}
.fgps-blog-single-cat:hover { background: var(--fgps-primary); color: #fff; }
.fgps-blog-single-title {
	font-family: 'Poppins', sans-serif;
	font-size: clamp(1.7rem, 3.5vw, 2.8rem);
	font-weight: 800;
	color: #fff;
	line-height: 1.2;
	margin: 0 0 20px;
}
.fgps-blog-single-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	align-items: center;
}
.fgps-blog-single-meta-item {
	display: flex;
	align-items: center;
	gap: 5px;
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	color: rgba(255,255,255,.7);
	font-weight: 500;
}

/* ================================================================
   Footer Widget — .fgps-fw-* classes
   ================================================================ */

/* ── Root ── */
.fgps-fw {
	background: #0e1b30;
	color: rgba(255,255,255,0.75);
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	line-height: 1.6;
	padding: 64px 0 0;
}

/* ── Inner container ── */
.fgps-fw-inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 24px;
}

/* ── 4-column grid ── */
.fgps-fw-grid {
	display: grid;
	grid-template-columns: 1.6fr 1fr 1fr 1.2fr;
	gap: 48px 40px;
	padding-bottom: 48px;
	border-bottom: 1px solid rgba(255,255,255,0.08);
}

/* ── Individual column ── */
.fgps-fw-col { display: flex; flex-direction: column; }

/* ── Brand column ── */
.fgps-fw-brand {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	margin-bottom: 16px;
}

.fgps-fw-logo {
	width: 52px;
	height: 52px;
	object-fit: contain;
	flex-shrink: 0;
}

.fgps-fw-brand-mark {
	width: 52px;
	height: 52px;
	flex-shrink: 0;
	background: var(--fgps-primary, #315efb);
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: 'Poppins', sans-serif;
	font-size: 22px;
	font-weight: 700;
	color: #fff;
	line-height: 1;
}

.fgps-fw-brand-text { display: flex; flex-direction: column; gap: 2px; }

.fgps-fw-brand-name {
	font-family: 'Poppins', sans-serif;
	font-size: 18px;
	font-weight: 700;
	color: #fff;
	line-height: 1.2;
	margin: 0;
}

.fgps-fw-brand-tagline {
	font-size: 12px;
	font-weight: 500;
	color: var(--fgps-primary-lt, #7fb2ff);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin: 0;
}

.fgps-fw-desc {
	font-size: 14px;
	color: rgba(255,255,255,0.6);
	margin: 0 0 24px;
	line-height: 1.7;
}

/* ── Social icons ── */
.fgps-fw-socials {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
	margin-top: auto;
}

.fgps-fw-social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border-radius: 8px;
	background: rgba(255,255,255,0.08);
	color: rgba(255,255,255,0.7);
	text-decoration: none;
	transition: background 0.2s, color 0.2s;
}

.fgps-fw-social-link svg {
	width: 18px;
	height: 18px;
	fill: currentColor;
}

.fgps-fw-social-link:hover {
	background: var(--fgps-primary, #315efb);
	color: #fff;
}

/* ── Column headings ── */
.fgps-fw-col-heading {
	font-family: 'Poppins', sans-serif;
	font-size: 14px;
	font-weight: 600;
	color: #fff;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin: 0 0 18px;
	padding-bottom: 10px;
	border-bottom: 2px solid var(--fgps-primary, #315efb);
	display: inline-block;
}

/* ── Link lists ── */
.fgps-fw-links {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.fgps-fw-links a {
	color: rgba(255,255,255,0.65);
	text-decoration: none;
	font-size: 14px;
	transition: color 0.2s, padding-left 0.2s;
}

.fgps-fw-links a:hover {
	color: var(--fgps-primary-lt, #7fb2ff);
	padding-left: 4px;
}

/* ── Contact items ── */
.fgps-fw-contact-item {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	padding: 8px 0;
	border-bottom: 1px solid rgba(255,255,255,0.06);
	font-size: 14px;
	color: rgba(255,255,255,0.65);
	text-decoration: none;
}

.fgps-fw-contact-item:last-child { border-bottom: none; }

.fgps-fw-contact-item a {
	color: inherit;
	text-decoration: none;
	transition: color 0.2s;
}

.fgps-fw-contact-item a:hover { color: var(--fgps-primary-lt, #7fb2ff); }

.fgps-fw-contact-item svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	fill: var(--fgps-primary, #315efb);
	margin-top: 2px;
}

/* ── Bottom bar ── */
.fgps-fw-bottom {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 16px;
	padding: 20px 0;
	border-top: 1px solid rgba(255,255,255,0.07);
}

.fgps-fw-copyright {
	font-size: 13px;
	color: rgba(255,255,255,0.45);
	margin: 0;
}

.fgps-fw-bottom-links {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 4px 18px;
}

.fgps-fw-bottom-links a {
	font-size: 13px;
	color: rgba(255,255,255,0.45);
	text-decoration: none;
	transition: color 0.2s;
}

.fgps-fw-bottom-links a:hover { color: var(--fgps-primary-lt, #7fb2ff); }

/* ── Certifications ── */
.fgps-fw-certs {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
}

.fgps-fw-cert {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: rgba(255,255,255,0.06);
	border: 1px solid rgba(255,255,255,0.1);
	border-radius: 6px;
	padding: 5px 10px;
	font-size: 12px;
	font-weight: 500;
	color: rgba(255,255,255,0.6);
	line-height: 1.2;
}

.fgps-fw-cert-icon { font-size: 14px; line-height: 1; }

/* ── Responsive ── */
@media (max-width: 1024px) {
	.fgps-fw-grid {
		grid-template-columns: 1fr 1fr;
		gap: 36px 32px;
	}
}

@media (max-width: 640px) {
	.fgps-fw { padding-top: 48px; }
	.fgps-fw-grid {
		grid-template-columns: 1fr;
		gap: 28px;
	}
	.fgps-fw-bottom {
		flex-direction: column;
		align-items: flex-start;
		gap: 12px;
	}
	.fgps-fw-certs { order: -1; }
}

/* ================================================================
   Service Page Template — auxiliary CSS
   Targets classes used in templates/fgps-service-page.json so that
   imported solution pages render correctly in free Elementor without
   requiring inline custom CSS per page.
   ================================================================ */

/* Eyebrow badge — force the heading widget to shrink to the text width
   instead of stretching across the column (Elementor columns are flex w/
   align-items:stretch by default). */
.fgps-tpl-eyebrow,
.elementor-widget.fgps-tpl-eyebrow,
.elementor-element.fgps-tpl-eyebrow {
	display: inline-block !important;
	width: auto !important;
	max-width: 100% !important;
	align-self: flex-start !important;
	flex: 0 0 auto !important;
}
.fgps-tpl-eyebrow > .elementor-widget-container {
	display: inline-block;
}
.fgps-tpl-eyebrow .elementor-heading-title {
	display: inline-block;
}

/* Hero button row — both buttons sit inside ONE 100% column whose
   widget-wrap is flipped to flex-row so the buttons sit inline. */
.fgps-tpl-btn-row .elementor-widget-wrap,
.elementor-section.fgps-tpl-btn-row .elementor-widget-wrap {
	flex-direction: row !important;
	flex-wrap: wrap !important;
	align-content: flex-start !important;
	align-items: center !important;
	gap: 14px !important;
	justify-content: flex-start !important;
}
.fgps-tpl-btn-row .elementor-widget-button,
.elementor-section.fgps-tpl-btn-row .elementor-widget-button {
	width: auto !important;
	flex: 0 0 auto !important;
}
.fgps-tpl-btn-row .elementor-widget-button .elementor-button-wrapper {
	display: inline-block;
}
@media (max-width: 600px) {
	.fgps-tpl-btn-row .elementor-widget-button { width: 100% !important; }
	.fgps-tpl-btn-row .elementor-widget-button .elementor-button {
		display: flex; width: 100%; justify-content: center;
	}
}

/* Overview stat numbers — keep each value on a single line so things
   like "100 kW – 5 MW" don't wrap awkwardly inside narrow columns. */
.fgps-tpl-stat-num .elementor-heading-title { white-space: nowrap; }

/* Card row — inner sections holding visible-card columns (Process, Benefits,
   Sizes, Gallery). Elementor sets per-column inline width:25% (or 33%) styles
   that compete with flex-basis overrides; CSS Grid sidesteps that entirely
   because grid items ignore flex/width and just fill their grid cell.

   Doubled-class selectors below boost specificity above Elementor's defaults. */
.fgps-tpl-card-row.fgps-tpl-card-row > .elementor-container {
	display: grid !important;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 24px !important;
	align-items: stretch !important;
}

/* 4-col variant (Process steps, Gallery thumbnails) */
.fgps-tpl-card-row.fgps-tpl-cols-4 > .elementor-container {
	grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

/* 2-col variant */
.fgps-tpl-card-row.fgps-tpl-cols-2 > .elementor-container {
	grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

/* Reset every column inside a card-row so it just fills its grid cell —
   neutralise Elementor's _column_size width/flex/max-width inline styles. */
.fgps-tpl-card-row.fgps-tpl-card-row > .elementor-container > .elementor-column {
	width: 100% !important;
	max-width: none !important;
	min-width: 0 !important;
	flex: unset !important;
	margin: 0 !important;
	box-sizing: border-box;
}

/* Card inner wrapper fills its column for equal heights */
.fgps-tpl-card-row.fgps-tpl-card-row > .elementor-container > .elementor-column > .elementor-element-populated {
	height: 100%;
	margin: 0 !important;
	box-sizing: border-box;
}

/* Tablet — collapse to 2 across regardless of desktop count */
@media (max-width: 1024px) {
	.fgps-tpl-card-row.fgps-tpl-card-row > .elementor-container,
	.fgps-tpl-card-row.fgps-tpl-cols-4 > .elementor-container,
	.fgps-tpl-card-row.fgps-tpl-cols-2 > .elementor-container {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}
}
/* Mobile — stack to 1 */
@media (max-width: 600px) {
	.fgps-tpl-card-row.fgps-tpl-card-row > .elementor-container,
	.fgps-tpl-card-row.fgps-tpl-cols-4 > .elementor-container,
	.fgps-tpl-card-row.fgps-tpl-cols-2 > .elementor-container {
		grid-template-columns: 1fr !important;
	}
}
