/* ====================================================
   FOOTER
   ==================================================== */

.footer {
}

/* Container: gridlines full-height, dark-100 color */
.footer > .container {
	padding-inline: 0;
	padding-block: 0;
	overflow-x: unset;
	border-inline: 1px solid var(--color-border-dark-100);
	min-height: 100%;
}

/* Lift footer children above .bg-texture-dark::before */
.footer-inner {
	position: relative;
	z-index: 1;
}


/* ── Top section: nav cols + FAQ grid ─────────────── */
.footer-top {
	padding-block-start: var(--size-v-pad-lg);
	padding-block-end: var(--size-v-pad-xl);
}

.footer-top .section-content {
	display: grid;
	grid-template-columns: 1fr 1fr;
	column-gap: calc(100% / 24);
}

/* ── Nav columns ───────────────────────────────────── */
.footer-nav {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--size-pad-md);
}

.footer-nav-heading {
	color: var(--color-text-pri-light);
	margin: 0 0 var(--size-pad-2xs) 0;
	font-size: var(--fs-h5);
	font-weight: var(--fw-semibold);
	line-height: var(--lh-snug);
	letter-spacing: var(--ls-xs);
}

.footer-nav-links {
	display: flex;
	flex-direction: column;
	gap: var(--size-gap-cards);
	list-style: none;
	margin: 0;
	margin-top: 0; /* reset h6+* from base.css */
	padding: 0;
	line-height: 1.3em; /* must live here so <li> strut matches, not just on <a> */
}

.footer-nav-links a {
	font-size: var(--fs-body-s);
	font-weight: var(--fw-regular);
	color: var(--color-text-sec-light);
	text-decoration: none;
	transition: color var(--duration-base) var(--ease-default);
}

@media (hover: hover) {
    .footer-nav-links a:hover {
        color: var(--color-text-pri-light);
        opacity: 1;
    }
}

/* ── FAQ accordion ─────────────────────────────────── */
.footer-faq-list {
	margin-top: var(--size-section-stack-mt);
}

.footer-faq-item {
	border-bottom: 1px solid var(--color-border-dark-100);
}

.footer-faq-btn {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	padding-block: var(--size-gap-cards);
	color: var(--color-text-pri-light);
	cursor: pointer;
	list-style: none;
	user-select: none;
	gap: var(--size-pad-sm);
}

.footer-faq-btn::-webkit-details-marker {
	display: none;
}

@media (hover: hover) {
.footer-faq-btn:hover {
	color: var(--color-text-sec-light);
}
}

.footer-faq-icon-wrap {
	width: var(--size-icon-widget-wrap);
	height: var(--size-icon-widget-wrap);
	background: var(--color-accent-green-dark);
	border-radius: var(--radius-btn);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.footer-faq-icon {
	width: var(--size-icon-widget);
	height: var(--size-icon-widget);
	object-fit: contain;
	transition: transform var(--duration-base) var(--ease-default);
}

.footer-faq-item[open] .footer-faq-icon,
.footer-faq-item.is-open .footer-faq-icon {
	transform: rotate(45deg);
}

.footer-faq-item.closing .footer-faq-icon {
	transform: rotate(0deg);
}

.footer-faq-answer-wrap {
	display: grid;
	grid-template-rows: 0fr;
	transition: grid-template-rows var(--duration-slow) var(--ease-reveal);
}

.footer-faq-item[open] .footer-faq-answer-wrap {
	grid-template-rows: 1fr;
}

.footer-faq-item.closing .footer-faq-answer-wrap {
	grid-template-rows: 0fr;
}

.footer-faq-answer {
	overflow: hidden;
	min-height: 0;
	color: var(--color-text-sec-light);
}

.footer-faq-answer > :last-child {
	padding-bottom: var(--size-gap-cards);
}

/* ── Brand name image ──────────────────────────────── */
.footer-brand {
	overflow: hidden;
}

.footer-brand img {
	display: block;
	width: 100%;
	height: auto;
}

/* ── Bottom bar ────────────────────────────────────── */
.footer-bottom {
	padding-block-start: var(--size-pad-xs);
	padding-block-end: var(--size-pad-xl);
	color: var(--color-text-ter-light);
}

.footer-bottom .section-content {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.footer-bottom a {
	color: var(--color-text-ter-light);
	font-weight: var(--fw-regular);
	text-decoration: underline;
	transition: color var(--duration-base) var(--ease-default);
}

@media (hover: hover) {
    .footer-bottom a:hover {
        color: var(--color-text-pri-light);
        opacity: 1;
    }
}

/* ── Desktop: pull FAQ list up so first question aligns with first nav link */
@media only screen and (min-width: 992px) {
	.footer-faq-list {
		margin-top: calc(-1 * var(--size-gap-cards));
	}
}

/* ── Responsive: tablet and below ─────────────────── */
@media only screen and (max-width: 991.98px) {
	.footer-inner {
		display: flex;
		flex-direction: column;
	}

	.footer-brand {
		order: -1;
		padding-block-start: var(--size-v-pad-lg);
		padding-block-end: var(--size-v-pad-2xs);
	}

	.footer-top {
		padding-block-start: 0;
		padding-block-end: var(--size-v-pad-sm);
	}

	.footer-top .section-content {
		grid-template-columns: 1fr;
		gap: var(--size-pad-xl);
	}

	.footer-faq {
		order: -1;
	}

	.footer-faq > .footer-nav-heading {
		display: none;
	}

	.footer-faq-btn {
		align-items: flex-start;
	}

	.footer-faq-icon-wrap {
		margin-top: 0.4rem;
	}

	.footer-nav {
		grid-template-columns: 1fr;
		gap: var(--size-pad-sm);
	}

	.footer-bottom .section-content {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.75rem;
	}

	.footer-nav-links {
		gap: 0;
	}

	.footer-nav-links a {
		display: block;
		padding-block: 0.625rem;
		min-height: 2.75rem;
	}

	.footer-bottom {
		padding-block-end: 3rem;
	}
}