/* ═══════════════════════════════════════════
   FAQ PAGE (faq2, ID 545) — front-page style
   Scoped to body.sf-faq-page. Elementor page:
     hero (sf-faq-title / sf-faq-desc),
     body section with 6 category labels (sf-faq-cat-label)
     + 6 Elementor Accordion widgets (sf-faq-accordion),
     CTA (sf-faq-cta-title / -sub / -btn).
   NOTE: section custom classes are NOT rendered by Elementor
   here, so sections are targeted by element id
   (.elementor-element-s-faq-hero / -body / -cta).
   Design system mirrors the home page:
     Accent #cde738 · dark bg #0c1202 · Bebas Neue / Inter ·
     strong rounding · glossy inset shadows.
   We only restyle — Elementor content/accordion JS untouched.
═══════════════════════════════════════════ */

body.sf-faq-page {
	--fq-accent: #cde738;
	--fq-rgb: 205, 231, 54;
	--fq-bg: #0c1202;
	--fq-title-gradient: radial-gradient(ellipse at 50% 50%, #fff152 0%, #cfe636 50%, #9edb1a 100%);
	--fq-card-shadow:
		inset 0px 0.361px 0.65px -1px rgba(255,255,255,0.19),
		inset 0px 1.373px 2.472px -2px rgba(255,255,255,0.18),
		inset 0px 6px 10.8px -3px rgba(255,255,255,0.13);
	--fq-btn-shadow:
		inset 0px 0.723px 1.879px -0.333px rgba(255,255,255,0.24),
		inset 0px 2.746px 7.14px -0.667px rgba(255,255,255,0.34),
		inset 0px 12px 31.2px -1px rgba(255,255,255,0.8);
}

/* ── Page background — home recipe (#0c1202 + green glow).
   background-image layers beat the global
   body{background-color:#111111!important} override. ── */
body.sf-faq-page {
	background-color: #0c1202 !important;
	background-image:
		radial-gradient(ellipse 120% 60% at 50% 14%, rgba(25, 62, 4, 0.7) 0%, transparent 62%),
		linear-gradient(#0c1202, #0c1202) !important;
	background-repeat: no-repeat !important;
}
body.sf-faq-page .site-content,
body.sf-faq-page .entry-content,
body.sf-faq-page #page,
body.sf-faq-page .page-wrapper { background: transparent !important; padding-top: 0; }
.sf-faq-page .elementor,
.sf-faq-page .elementor-section,
.sf-faq-page .elementor-container { background: transparent; }

/* ══════════════════════════════════════════════════════════
   HERO — compact, like contact-us (no min-height, no label)
══════════════════════════════════════════════════════════ */
.sf-faq-page .elementor-element-s-faq-hero,
.sf-faq-page .sf-faq-hero-section {
	position: relative;
	text-align: center;
	overflow: hidden;
	padding-top: calc(var(--header-h, 80px) + clamp(40px, 6vw, 72px)) !important;
	padding-bottom: clamp(24px, 3.5vw, 44px) !important;
}
/* Soft accent glow behind the title */
.sf-faq-page .elementor-element-s-faq-hero::after {
	content: '';
	position: absolute;
	top: 38%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 680px;
	height: 300px;
	max-width: 90%;
	background: radial-gradient(ellipse, rgba(var(--fq-rgb), .1) 0%, transparent 70%);
	pointer-events: none;
	z-index: 0;
}
.sf-faq-page .elementor-element-s-faq-hero .elementor-container { position: relative; z-index: 1; }

.sf-faq-page .sf-faq-title .elementor-heading-title {
	font-family: 'Bebas Neue', sans-serif !important;
	font-size: clamp(44px, 7vw, 88px) !important;
	font-weight: 400 !important;
	line-height: 0.9;
	letter-spacing: -1px;
	text-transform: uppercase;
	margin: 0 auto 16px !important;
	max-width: 16ch;            /* keep the title to ~2 lines */
	background: var(--fq-title-gradient);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}
.sf-faq-page .sf-faq-desc .elementor-widget-container,
.sf-faq-page .sf-faq-desc p {
	font-family: 'Inter', sans-serif;
	font-size: clamp(14px, 1.6vw, 17px);
	color: rgba(255, 255, 255, .6);
	line-height: 1.65;
	max-width: 560px;
	margin: 0 auto;
}

/* ══════════════════════════════════════════════════════════
   BODY — category labels + accordions
══════════════════════════════════════════════════════════ */
.sf-faq-page .elementor-element-s-faq-body {
	padding-top: clamp(28px, 4vw, 48px) !important;
	padding-bottom: clamp(48px, 7vw, 80px) !important;
}

/* Category label — accent cyber bar */
.sf-faq-page .sf-faq-cat-label .elementor-heading-title {
	font-family: 'Bebas Neue', sans-serif !important;
	font-size: clamp(20px, 2.4vw, 28px) !important;
	font-weight: 400 !important;
	letter-spacing: .02em;
	text-transform: uppercase;
	color: #fff !important;
	display: flex;
	align-items: center;
	gap: 12px;
	margin: clamp(28px, 4vw, 44px) 0 14px !important;
}
.sf-faq-page .sf-faq-cat-label .elementor-heading-title::before {
	content: '';
	width: 4px;
	height: 20px;
	flex-shrink: 0;
	border-radius: 2px;
	background: linear-gradient(180deg, var(--fq-accent), rgba(var(--fq-rgb), .2));
	box-shadow: 0 0 12px rgba(var(--fq-rgb), .5);
}
.sf-faq-page .sf-faq-cat-label .elementor-heading-title::after {
	content: '';
	flex: 1;
	height: 1px;
	background: linear-gradient(90deg, rgba(var(--fq-rgb), .22), transparent);
}
.sf-faq-page .sf-faq-cat-label:first-of-type .elementor-heading-title { margin-top: 0 !important; }

/* ── Elementor Accordion ── */
.sf-faq-page .sf-faq-accordion { margin-bottom: 10px; }
.sf-faq-page .sf-faq-accordion .elementor-accordion { border: none !important; }
.sf-faq-page .sf-faq-accordion .elementor-accordion-item {
	background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.008)) !important;
	border: 1px solid rgba(var(--fq-rgb), .1) !important;
	border-radius: 16px !important;
	margin-bottom: 10px !important;
	overflow: hidden;
	transition: border-color .25s ease, box-shadow .25s ease;
}
.sf-faq-page .sf-faq-accordion .elementor-accordion-item:hover {
	border-color: rgba(var(--fq-rgb), .28) !important;
}
.sf-faq-page .sf-faq-accordion .elementor-accordion-item:has(.elementor-active) {
	border-color: rgba(var(--fq-rgb), .4) !important;
	box-shadow: 0 0 0 1px rgba(var(--fq-rgb), .1), 0 14px 40px rgba(0,0,0,.35), 0 0 26px rgba(var(--fq-rgb), .08) !important;
}

/* Question row */
.sf-faq-page .sf-faq-accordion .elementor-tab-title {
	background: transparent !important;
	padding: 18px 22px !important;
	border: none !important;
	cursor: pointer;
	font-family: 'Inter', sans-serif !important;
	font-weight: 600 !important;
	font-size: clamp(15px, 1.5vw, 17px) !important;
	line-height: 1.4 !important;
	color: rgba(255, 255, 255, .9) !important;
	display: flex !important;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	transition: color .2s ease, background .2s ease;
}
.sf-faq-page .sf-faq-accordion .elementor-tab-title:hover { color: #fff !important; }
.sf-faq-page .sf-faq-accordion .elementor-tab-title.elementor-active {
	color: #fff !important;
	background: rgba(var(--fq-rgb), .06) !important;
}
.sf-faq-page .sf-faq-accordion .elementor-accordion-title {
	color: inherit !important;
	font-size: inherit !important;
	font-weight: inherit !important;
	font-family: inherit !important;
}

/* Expand icon */
.sf-faq-page .sf-faq-accordion .elementor-accordion-icon {
	color: var(--fq-accent) !important;
	flex-shrink: 0;
	transition: color .2s ease;
}
.sf-faq-page .sf-faq-accordion .elementor-accordion-icon svg { fill: var(--fq-accent) !important; }

/* Answer panel */
.sf-faq-page .sf-faq-accordion .elementor-tab-content {
	background: transparent !important;
	padding: 0 22px 20px !important;
	border: none !important;
	font-family: 'Inter', sans-serif !important;
	font-size: 14px !important;
	line-height: 1.75 !important;
	color: rgba(255, 255, 255, .55) !important;
}
.sf-faq-page .sf-faq-accordion .elementor-tab-content p { margin: 0; color: inherit !important; }
.sf-faq-page .sf-faq-accordion .elementor-tab-content strong { color: rgba(255, 255, 255, .82) !important; font-weight: 600; }
.sf-faq-page .sf-faq-accordion .elementor-tab-content a {
	color: var(--fq-accent) !important;
	text-decoration: none;
	transition: opacity .2s ease;
}
.sf-faq-page .sf-faq-accordion .elementor-tab-content a:hover { opacity: .7; text-decoration: underline; }

/* ══════════════════════════════════════════════════════════
   CTA — rounded glossy card + pill button
══════════════════════════════════════════════════════════ */
.sf-faq-page .elementor-element-s-faq-cta {
	padding-top: clamp(16px, 3vw, 28px) !important;
	padding-bottom: clamp(48px, 7vw, 88px) !important;
}
.sf-faq-page .elementor-element-s-faq-cta > .elementor-container {
	position: relative;
	overflow: hidden;
	text-align: center;
	border: 1px solid rgba(var(--fq-rgb), .22);
	border-radius: 40px;
	background:
		radial-gradient(ellipse at 100% 0%, rgba(var(--fq-rgb), .14) 0%, transparent 55%),
		linear-gradient(180deg, rgba(20, 42, 12, .7), rgba(7, 14, 3, .95));
	box-shadow: var(--fq-card-shadow), 0 24px 64px rgba(0, 0, 0, .4);
	padding: clamp(40px, 5vw, 56px) clamp(28px, 4vw, 48px) !important;
}
.sf-faq-page .elementor-element-s-faq-cta > .elementor-container::before {
	content: '';
	position: absolute;
	bottom: -90px; left: 50%;
	transform: translateX(-50%);
	width: 320px; height: 240px;
	background: radial-gradient(ellipse, rgba(var(--fq-rgb), .12) 0%, transparent 70%);
	pointer-events: none;
	z-index: 0;
}
.sf-faq-page .elementor-element-s-faq-cta .elementor-column,
.sf-faq-page .elementor-element-s-faq-cta .elementor-widget-wrap { position: relative; z-index: 1; }

.sf-faq-page .sf-faq-cta-title .elementor-heading-title {
	font-family: 'Bebas Neue', sans-serif !important;
	font-size: clamp(30px, 4.5vw, 52px) !important;
	font-weight: 400 !important;
	color: #fff !important;
	letter-spacing: -.5px;
	line-height: 1;
	text-transform: uppercase;
	max-width: 16ch;
	margin: 0 auto 14px !important;
	text-shadow: none;
}
.sf-faq-page .sf-faq-cta-sub .elementor-widget-container,
.sf-faq-page .sf-faq-cta-sub p {
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	color: rgba(255, 255, 255, .6) !important;
	line-height: 1.65;
	max-width: 480px;
	margin: 0 auto 26px;
}
.sf-faq-page .sf-faq-cta-btn .elementor-button-wrapper { display: flex; justify-content: center; }
.sf-faq-page .sf-faq-cta-btn .elementor-button {
	display: inline-flex !important;
	align-items: center !important;
	gap: 10px;
	height: 60px !important;
	padding: 0 40px !important;
	background: var(--fq-accent) !important;
	color: #000 !important;
	font-family: 'Bebas Neue', sans-serif !important;
	font-size: 26px !important;
	font-weight: 400 !important;
	letter-spacing: .02em !important;
	text-transform: uppercase;
	border: none !important;
	border-radius: 999px !important;
	box-shadow: var(--fq-btn-shadow) !important;
	transition: transform .2s ease, filter .2s ease !important;
}
.sf-faq-page .sf-faq-cta-btn .elementor-button:hover {
	transform: scale(1.03);
	filter: brightness(1.04) drop-shadow(0 0 24px rgba(var(--fq-rgb), .45)) !important;
	color: #000 !important;
}
.sf-faq-page .sf-faq-cta-btn .elementor-button:active { transform: scale(.98); }
.sf-faq-page .sf-faq-cta-btn .elementor-button:focus-visible { outline: 2px solid var(--fq-accent) !important; outline-offset: 4px !important; }

/* ══════════════════════════════════════════════════════════
   ACCESSIBILITY
══════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
	.sf-faq-page .sf-faq-accordion .elementor-accordion-item,
	.sf-faq-page .sf-faq-accordion .elementor-tab-title,
	.sf-faq-page .sf-faq-accordion .elementor-accordion-icon,
	.sf-faq-page .sf-faq-cta-btn .elementor-button { transition: none !important; }
}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
	.sf-faq-page .sf-faq-accordion .elementor-tab-title { padding: 16px 18px !important; }
	.sf-faq-page .sf-faq-accordion .elementor-tab-content { padding: 0 18px 16px !important; }
	.sf-faq-page .elementor-element-s-faq-cta > .elementor-container { border-radius: 28px; }
}

@media (max-width: 480px) {
	.sf-faq-page .sf-faq-cta-btn .elementor-button { width: 100%; justify-content: center; }
}
