/* =========================================================
   HAVN FAQ — matches havn-dashboard premium aesthetic
   Black canvas, gold accents, glass panels, Inter font
   ========================================================= */

.havn-faq,
.havn-faq-form-wrap {
	--havn-bg:        #000000;
	--havn-bg-2:      #050608;
	--havn-panel:     rgba(255,255,255,0.035);
	--havn-panel-2:   rgba(255,255,255,0.055);
	--havn-border:    rgba(255,255,255,0.07);
	--havn-border-2:  rgba(255,255,255,0.14);
	--havn-text:      #F4F4F5;
	--havn-muted:     #9CA3AF;
	--havn-accent:    #D4B370;
	--havn-accent-2:  #F2D390;
	--havn-success:   #6FCF97;
	--havn-danger:    #EB5757;
	--havn-radius:    18px;
	--havn-radius-sm: 12px;
	--havn-shadow:    0 10px 40px rgba(0,0,0,0.6);
	--havn-shadow-sm: 0 4px 14px rgba(0,0,0,0.4);
	--havn-ease:      cubic-bezier(.2,.7,.2,1);

	font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
	-webkit-font-smoothing: antialiased;
	color: var(--havn-text);
	max-width: 920px;
	margin: 0 auto;
	padding: 32px clamp(16px, 4vw, 40px);
}

/* Force pitch-black canvas on the FAQ page — overrides theme wrappers */
html.havn-faq-page,
body.havn-faq-page {
	background: #000 !important;
	background-color: #000 !important;
	color: var(--havn-text) !important;
}
body.havn-faq-page #page,
body.havn-faq-page #wrapper,
body.havn-faq-page #content,
body.havn-faq-page .site,
body.havn-faq-page .site-content,
body.havn-faq-page .site-main,
body.havn-faq-page .ast-container,
body.havn-faq-page .entry-content,
body.havn-faq-page .elementor-section-wrap,
body.havn-faq-page .elementor,
body.havn-faq-page .elementor-inner,
body.havn-faq-page .elementor-section,
body.havn-faq-page main,
body.havn-faq-page article {
	background: transparent !important;
	background-color: transparent !important;
	color: var(--havn-text);
}
body.havn-faq-page::before {
	content: "";
	position: fixed; inset: 0;
	background:
		radial-gradient(1200px 600px at 80% -10%, rgba(212,179,112,.06), transparent 60%),
		radial-gradient(900px 500px at -10% 110%, rgba(138,180,248,.04), transparent 60%),
		#000;
	z-index: -1;
	pointer-events: none;
}

/* Force readable text inside the FAQ page on every theme-injected node */
body.havn-faq-page p,
body.havn-faq-page h1,
body.havn-faq-page h2,
body.havn-faq-page h3,
body.havn-faq-page h4,
body.havn-faq-page h5,
body.havn-faq-page h6,
body.havn-faq-page span,
body.havn-faq-page li,
body.havn-faq-page strong,
body.havn-faq-page em,
body.havn-faq-page small,
body.havn-faq-page label {
	color: var(--havn-text);
}

/* ---------- accordion sections ---------- */

.havn-faq__section + .havn-faq__section {
	margin-top: 48px;
}

.havn-faq__section-title {
	margin: 0 0 18px;
	font-size: 22px;
	font-weight: 700;
	letter-spacing: -0.01em;
	color: var(--havn-text);
	display: flex;
	align-items: center;
	gap: 12px;
}
.havn-faq__section-title::before {
	content: "";
	display: inline-block;
	width: 28px;
	height: 2px;
	background: linear-gradient(90deg, var(--havn-accent), transparent);
	border-radius: 2px;
}

.havn-faq__items {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

/* ---------- accordion item ---------- */

.havn-faq__item {
	background: var(--havn-panel);
	border: 1px solid var(--havn-border);
	border-radius: var(--havn-radius);
	overflow: hidden;
	transition: border-color .35s var(--havn-ease), background .35s var(--havn-ease), box-shadow .35s var(--havn-ease), transform .35s var(--havn-ease);
}

.havn-faq__item:hover {
	border-color: var(--havn-border-2);
	background: var(--havn-panel-2);
}

.havn-faq__item[open] {
	border-color: rgba(212,179,112,.35);
	background: var(--havn-panel-2);
	box-shadow: var(--havn-shadow-sm);
}

.havn-faq__question {
	cursor: pointer;
	list-style: none;
	padding: 18px 22px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	font-weight: 600;
	font-size: 15.5px;
	color: var(--havn-text);
	transition: color .25s var(--havn-ease);
}
.havn-faq__question::-webkit-details-marker { display: none; }
.havn-faq__question::marker { content: ''; }

.havn-faq__item[open] .havn-faq__question,
.havn-faq__question:hover {
	color: var(--havn-accent-2);
}

.havn-faq__q-text {
	flex: 1;
}

.havn-faq__icon {
	flex: 0 0 auto;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	background: rgba(212,179,112,.12);
	border: 1px solid rgba(212,179,112,.35);
	color: var(--havn-accent-2);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	font-weight: 600;
	line-height: 1;
	transition: transform .35s var(--havn-ease), background .25s var(--havn-ease);
}

.havn-faq__item[open] .havn-faq__icon {
	transform: rotate(45deg);
	background: linear-gradient(135deg, var(--havn-accent), #B8975C);
	color: #15110A;
	border-color: transparent;
}

.havn-faq__answer {
	padding: 0 22px 22px;
	border-top: 1px solid var(--havn-border);
	color: var(--havn-text);
}

.havn-faq__answer p {
	margin: 16px 0 0;
	color: #D6D7DB;
	line-height: 1.65;
	font-size: 14.5px;
}

.havn-faq__answer a {
	color: var(--havn-accent-2);
	text-decoration: none;
	border-bottom: 1px solid rgba(212,179,112,.4);
	transition: border-color .2s var(--havn-ease);
}
.havn-faq__answer a:hover {
	border-bottom-color: var(--havn-accent-2);
}

/* ---------- question form ---------- */

.havn-faq-form-wrap {
	margin-top: 56px;
	background: linear-gradient(135deg, #121317 0%, #0B0C10 60%);
	border: 1px solid var(--havn-border);
	border-radius: var(--havn-radius);
	padding: 36px clamp(20px, 4vw, 40px);
	box-shadow: var(--havn-shadow);
	position: relative;
	overflow: hidden;
}

.havn-faq-form-wrap::before {
	content: "";
	position: absolute;
	top: -40%; right: -20%;
	width: 360px; height: 360px;
	background: radial-gradient(closest-side, rgba(212,179,112,.18) 0%, transparent 70%);
	pointer-events: none;
}

.havn-faq-form__title {
	position: relative;
	margin: 0 0 8px;
	font-size: 22px;
	font-weight: 700;
	letter-spacing: -0.01em;
	color: var(--havn-text);
}

.havn-faq-form__desc {
	position: relative;
	margin: 0 0 24px;
	color: var(--havn-muted);
	font-size: 14.5px;
}

.havn-faq-form {
	position: relative;
}

.havn-faq-form__row {
	display: flex;
	flex-direction: column;
	gap: 6px;
	margin-bottom: 16px;
}

.havn-faq-form__row label {
	font-size: 12.5px;
	font-weight: 600;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--havn-muted);
}

.havn-faq-form__row input[type="text"],
.havn-faq-form__row input[type="email"],
.havn-faq-form__row select,
.havn-faq-form__row textarea {
	width: 100%;
	padding: 12px 14px;
	border: 1px solid var(--havn-border);
	border-radius: 10px;
	background: rgba(0,0,0,.35);
	color: var(--havn-text);
	font-size: 14.5px;
	font-family: inherit;
	transition: border-color .25s var(--havn-ease), background .25s var(--havn-ease), box-shadow .25s var(--havn-ease);
	box-sizing: border-box;
}

.havn-faq-form__row input::placeholder,
.havn-faq-form__row textarea::placeholder {
	color: rgba(156,163,175,.6);
}

.havn-faq-form__row input:focus,
.havn-faq-form__row select:focus,
.havn-faq-form__row textarea:focus {
	outline: none;
	border-color: rgba(212,179,112,.5);
	background: rgba(0,0,0,.55);
	box-shadow: 0 0 0 3px rgba(212,179,112,.15);
}

.havn-faq-form__row textarea {
	resize: vertical;
	min-height: 130px;
	line-height: 1.5;
}

.havn-faq-form__row select {
	appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23D4B370' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
	background-repeat: no-repeat;
	background-position: right 14px center;
	padding-right: 38px;
}

/* honeypot — hidden offscreen */
.havn-faq-form__hp {
	position: absolute !important;
	left: -10000px !important;
	top: auto !important;
	width: 1px !important;
	height: 1px !important;
	overflow: hidden !important;
}

.havn-faq-form__actions {
	margin-top: 22px;
}

.havn-faq-form__submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	background: linear-gradient(135deg, var(--havn-accent), #B8975C);
	color: #15110A;
	border: 1px solid transparent;
	padding: 12px 28px;
	font-size: 14px;
	font-weight: 700;
	border-radius: 10px;
	letter-spacing: .02em;
	cursor: pointer;
	box-shadow: 0 6px 20px rgba(212,179,112,.25);
	transition: transform .25s var(--havn-ease), box-shadow .25s var(--havn-ease), filter .25s var(--havn-ease);
}

.havn-faq-form__submit:hover {
	transform: translateY(-1px);
	box-shadow: 0 10px 28px rgba(212,179,112,.35);
	filter: brightness(1.05);
}

.havn-faq-form__submit:active {
	transform: translateY(0);
}

.havn-faq-form__submit[disabled] {
	opacity: 0.65;
	cursor: not-allowed;
	transform: none;
	filter: none;
}

.havn-faq-form__status {
	margin-top: 16px;
	padding: 12px 14px;
	border-radius: 10px;
	display: none;
	font-size: 14px;
	border: 1px solid var(--havn-border);
	background: var(--havn-panel);
}

.havn-faq-form__status.is-success {
	display: block;
	background: rgba(111,207,151,.10);
	border-color: rgba(111,207,151,.35);
	color: var(--havn-success);
}

.havn-faq-form__status.is-error {
	display: block;
	background: rgba(235,87,87,.10);
	border-color: rgba(235,87,87,.35);
	color: var(--havn-danger);
}

.havn-faq-form__status.is-info {
	display: block;
	background: rgba(212,179,112,.08);
	border-color: rgba(212,179,112,.30);
	color: var(--havn-accent-2);
}

/* ---------- responsive ---------- */

@media (max-width: 600px) {
	.havn-faq,
	.havn-faq-form-wrap {
		padding: 20px 16px;
	}
	.havn-faq-form-wrap {
		padding: 28px 20px;
	}
	.havn-faq__section-title { font-size: 18px; }
	.havn-faq__question { font-size: 14.5px; padding: 16px 18px; }
	.havn-faq__answer { padding: 0 18px 18px; }
	.havn-faq__answer p { font-size: 14px; }
}
