:root {
	--csfaq-primary: #04faa0;
	--csfaq-bg: #001011;
	--csfaq-text: #ebe9e9;
	--csfaq-radius: 8px;
	--csfaq-speed: 300ms;
}

/* ─── Wrapper ─── */
.csfaq-wrapper {
	background-color: var(--csfaq-bg);
	border-radius: var(--csfaq-radius);
	margin: 24px 0;
	max-width: 100%;
	width: 100%;
	box-sizing: border-box;
	overflow: hidden;
	min-width: 0;
}

/* ─── Item rows ─── */
.csfaq-item {
	border-bottom: 1px solid color-mix(in srgb, var(--csfaq-text) 15%, transparent);
	transition: background-color 0.2s ease;
	overflow: hidden;
	min-width: 0;
	max-width: 100%;
	box-sizing: border-box;
}

.csfaq-item:last-child {
	border-bottom: none;
}

.csfaq-item:hover {
	background-color: color-mix(in srgb, var(--csfaq-primary) 12%, transparent);
}

/* ─── Question button ─── */
.csfaq-question {
	width: 100%;
	text-align: left;
	background: transparent;
	border: none;
	color: var(--csfaq-text);
	padding: 16px 24px;
	font-size: 1rem;
	font-weight: 600;
	cursor: pointer;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	line-height: 1.4;
	font-family: inherit;
	outline: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	-webkit-tap-highlight-color: transparent;
	word-break: break-word;
	overflow-wrap: break-word;
	hyphens: auto;
	min-width: 0;
	max-width: 100%;
	box-sizing: border-box;
}

.csfaq-question:focus-visible {
	outline: 2px solid var(--csfaq-primary);
	outline-offset: -2px;
	border-radius: 0;
}

.csfaq-item:first-child .csfaq-question:focus-visible {
	border-radius: var(--csfaq-radius) var(--csfaq-radius) 0 0;
}

.csfaq-item:last-child .csfaq-question:focus-visible {
	border-radius: 0 0 var(--csfaq-radius) var(--csfaq-radius);
}

.csfaq-question:hover {
	color: var(--csfaq-primary);
}

/* ─── +/× icon ─── */
.csfaq-question::after {
	content: "+";
	font-size: 1.4rem;
	font-weight: 400;
	color: var(--csfaq-primary);
	transition: transform var(--csfaq-speed) ease;
	flex-shrink: 0;
	line-height: 1;
}

.csfaq-question[aria-expanded="true"]::after {
	transform: rotate(45deg);
}

/* ─── Answer ─── */
.csfaq-answer {
	overflow: hidden;
	max-height: 0;
	transition: max-height var(--csfaq-speed) ease;
	color: var(--csfaq-text);
	opacity: 0.85;
	padding: 0 24px 0;
	line-height: 1.6;
	font-size: 0.95rem;
	word-break: break-word;
	overflow-wrap: break-word;
}

.csfaq-answer.is-open {
	max-height: 2000px;
	padding: 0 24px 16px;
}

.csfaq-answer p {
	margin: 0 0 12px;
}

.csfaq-answer p:last-child {
	margin-bottom: 0;
}

.csfaq-answer a {
	color: var(--csfaq-primary);
	text-decoration: underline;
}

.csfaq-answer a:hover {
	text-decoration: none;
}

.csfaq-answer ul,
.csfaq-answer ol {
	margin: 0 0 12px 20px;
	padding: 0;
}

.csfaq-answer li {
	margin-bottom: 4px;
}

/* ─── Responsive ─── */
@media (max-width: 600px) {
	.csfaq-question {
		padding: 14px 16px;
		font-size: 0.9rem;
		gap: 12px;
	}

	.csfaq-answer {
		padding-left: 16px;
		padding-right: 16px;
		font-size: 0.875rem;
	}

	.csfaq-answer.is-open {
		padding-left: 16px;
		padding-right: 16px;
	}

	.csfaq-question::after {
		font-size: 1.2rem;
	}
}

/* ─── Page Builder overrides (Elementor, Breakdance, Divi, Beaver) ─── */

/* Elementor flex-container chain: force min-width:0 all the way down */
.elementor-widget-wrap > .elementor-element:has(.csfaq-wrapper),
.elementor-element > .elementor-widget-container:has(.csfaq-wrapper) {
	min-width: 0 !important;
	max-width: 100% !important;
	overflow: hidden !important;
}

/* Fallback for browsers without :has() support */
.elementor-shortcode,
.elementor-widget-shortcode .elementor-widget-container,
.elementor-widget-text-editor .elementor-widget-container,
.elementor-widget .elementor-widget-container {
	min-width: 0;
	max-width: 100%;
}

.elementor-widget .csfaq-wrapper,
.elementor-element .csfaq-wrapper,
.elementor .csfaq-wrapper,
body .csfaq-wrapper {
	max-width: 100% !important;
	width: 100% !important;
	box-sizing: border-box !important;
	overflow: hidden !important;
	min-width: 0 !important;
}

.elementor-widget .csfaq-item,
.elementor-element .csfaq-item,
body .csfaq-wrapper .csfaq-item {
	max-width: 100% !important;
	min-width: 0 !important;
	overflow: hidden !important;
	box-sizing: border-box !important;
}

.csfaq-wrapper .csfaq-item .csfaq-question,
.elementor-widget .csfaq-question,
.elementor-element .csfaq-question,
.elementor .csfaq-question,
.brxe-shortcode .csfaq-question,
.ct-shortcode .csfaq-question,
.fl-module .csfaq-question,
.et_pb_module .csfaq-question,
body .csfaq-wrapper button.csfaq-question {
	background: transparent !important;
	background-color: transparent !important;
	background-image: none !important;
	border: none !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	text-shadow: none !important;
	padding: 16px 24px !important;
	margin: 0 !important;
	color: var(--csfaq-text) !important;
	font-size: 1rem !important;
	font-weight: 600 !important;
	font-family: inherit !important;
	letter-spacing: normal !important;
	text-transform: none !important;
	text-decoration: none !important;
	line-height: 1.4 !important;
	display: flex !important;
	width: 100% !important;
	min-height: 0 !important;
	justify-content: space-between !important;
	align-items: center !important;
	gap: 16px !important;
	cursor: pointer !important;
	-webkit-appearance: none !important;
	appearance: none !important;
	-webkit-tap-highlight-color: transparent !important;
	word-break: break-word !important;
	overflow-wrap: break-word !important;
	hyphens: auto !important;
	min-width: 0 !important;
	max-width: 100% !important;
	box-sizing: border-box !important;
	white-space: normal !important;
	overflow: visible !important;
	text-overflow: clip !important;
	transition: color 0.2s ease !important;
}

.csfaq-wrapper .csfaq-item .csfaq-question:hover,
.elementor-widget .csfaq-question:hover,
.elementor-element .csfaq-question:hover,
body .csfaq-wrapper button.csfaq-question:hover {
	color: var(--csfaq-primary) !important;
	background: transparent !important;
	background-color: transparent !important;
	border: none !important;
	box-shadow: none !important;
	text-decoration: none !important;
}

.csfaq-wrapper .csfaq-item .csfaq-question:focus,
.csfaq-wrapper .csfaq-item .csfaq-question:active,
body .csfaq-wrapper button.csfaq-question:focus,
body .csfaq-wrapper button.csfaq-question:active {
	background: transparent !important;
	background-color: transparent !important;
	border: none !important;
	box-shadow: none !important;
	outline: none !important;
}

.csfaq-wrapper .csfaq-item .csfaq-question:focus-visible,
body .csfaq-wrapper button.csfaq-question:focus-visible {
	outline: 2px solid var(--csfaq-primary) !important;
	outline-offset: -2px !important;
}

.csfaq-wrapper .csfaq-item .csfaq-question::after,
.elementor-widget .csfaq-question::after,
body .csfaq-wrapper button.csfaq-question::after {
	content: "+" !important;
	font-size: 1.4rem !important;
	font-weight: 400 !important;
	color: var(--csfaq-primary) !important;
	background: none !important;
	border: none !important;
	box-shadow: none !important;
	flex-shrink: 0 !important;
	line-height: 1 !important;
	margin: 0 !important;
	padding: 0 !important;
	width: auto !important;
	height: auto !important;
	transition: transform var(--csfaq-speed) ease !important;
}

@media (max-width: 600px) {
	.csfaq-wrapper .csfaq-item .csfaq-question,
	.elementor-widget .csfaq-question,
	body .csfaq-wrapper button.csfaq-question {
		padding: 14px 16px !important;
		font-size: 0.9rem !important;
		gap: 12px !important;
	}

	.csfaq-wrapper .csfaq-item .csfaq-question::after,
	body .csfaq-wrapper button.csfaq-question::after {
		font-size: 1.2rem !important;
	}
}
