/* ============================================================
   WFI UTILITIES
   RTL overrides, elevation system, marquee, common utilities
   ============================================================ */

/* -- Alpine.js -- */

/* Hide [x-cloak] elements until Alpine initializes, preventing a flash of
   open menus on first paint. Alpine strips the x-cloak attribute once ready.
   REQUIRED by any component using x-cloak (NavMenu dropdowns/mobile panel,
   back-to-top button). See https://alpinejs.dev/directives/cloak */
[x-cloak] {
	display: none !important;
}

/* -- RTL Direction Overrides -- */

[dir="rtl"] .text-start {
	text-align: right;
}

[dir="rtl"] .text-end {
	text-align: left;
}

[dir="rtl"] .rtl-flip {
	transform: scaleX(-1);
}

[dir="rtl"] .ms-auto {
	margin-inline-start: auto;
}

[dir="rtl"] .me-auto {
	margin-inline-end: auto;
}

/* -- Elevation Utilities -- */

.wfi-hover-elevate {
	position: relative;
	z-index: 0;
}

.wfi-hover-elevate::after {
	content: "";
	pointer-events: none;
	position: absolute;
	inset: 0;
	border-radius: inherit;
	z-index: 999;
	transition: background-color 150ms ease;
}

.wfi-hover-elevate:hover::after {
	background-color: var(--wfi-elevate-1);
}

.wfi-hover-elevate-2:hover::after {
	background-color: var(--wfi-elevate-2);
}

.wfi-toggle-elevate {
	position: relative;
}

.wfi-toggle-elevate::before {
	content: "";
	pointer-events: none;
	position: absolute;
	inset: 0;
	border-radius: inherit;
	z-index: -1;
}

.wfi-toggle-elevate.active::before {
	background-color: var(--wfi-elevate-2);
}

/* -- Marquee Animation (Logo Ticker) -- */

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

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

.wfi-marquee {
	animation: wfi-marquee 30s linear infinite;
}

[dir="rtl"] .wfi-marquee {
	animation: wfi-marquee-rtl 30s linear infinite;
}

.wfi-marquee:hover {
	animation-play-state: paused;
}

@media (prefers-reduced-motion: reduce) {
	.wfi-marquee {
		animation-play-state: paused;
	}
}

.wfi-marquee-container {
	-webkit-mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
	mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
	overflow: hidden;
}

/* -- Common Utility Classes -- */

.wfi-container {
	width: 100%;
	max-width: 1280px;
	margin-inline: auto;
	padding-inline: 1rem;
}

@media (min-width: 768px) {
	.wfi-container {
		padding-inline: 1.5rem;
	}
}

@media (min-width: 1024px) {
	.wfi-container {
		padding-inline: 2rem;
	}
}

.wfi-eyebrow {
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	color: var(--wfi-primary);
	font-family: var(--wfi-font-mono);
}

.wfi-section {
	padding-block: 4rem;
}

@media (min-width: 768px) {
	.wfi-section {
		padding-block: 5rem;
	}
}

.wfi-section-default {
	background-color: var(--wfi-background);
}

.wfi-section-muted {
	background-color: color-mix(in srgb, var(--wfi-muted) 30%, transparent);
}

.wfi-section-primary {
	background-color: var(--wfi-primary);
	overflow: hidden;
}

.wfi-section-hero {
	padding-block-start: 4rem;
	padding-block-end: 0;
}

.wfi-section-compact {
	padding-block: 2.5rem;
}

@media (min-width: 768px) {
	.wfi-section-hero {
		padding-block-start: 6rem;
	}

	.wfi-section-compact {
		padding-block: 3.5rem;
	}
}

.wfi-card {
	background-color: var(--wfi-card);
	border: 1px solid var(--wfi-card-border);
	border-radius: var(--wfi-radius-lg);
	box-shadow: var(--wfi-shadow-2xs);
}

/* -- Shared Tile Grid (used by SolvesGrid + DeliverablesGrid) -- */

.wfi-tile-grid {
	/*border: 1px solid var(--wfi-border);*/
	border-radius: 0.375rem;
	background-color: var(--wfi-card);
	overflow: hidden;
	display: grid;
	grid-template-columns: 1fr;
	border: none !important;
}

@media (min-width: 576px) {
	.wfi-tile-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.wfi-tile-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.wfi-tile {
	padding: 1.25rem;
	/*border-bottom: 1px solid var(--wfi-border);*/
	border: 1px solid var(--wfi-border) !important;
	margin: 6px;
	border-radius: 0.75rem;
	box-shadow: var(--wfi-shadow-xs);
}

.wfi-tile:last-child {
	border-bottom: none;
}

@media (min-width: 576px) {
	.wfi-tile:nth-child(odd) {
		border-inline-end: 1px solid var(--wfi-border);
	}

	.wfi-tile:nth-child(2n) {
		border-inline-end: none;
	}
}

@media (min-width: 1024px) {
	.wfi-tile:nth-child(3n) {
		border-inline-end: none;
	}
}

@media (min-width: 768px) {
	.wfi-tile {
		padding: 1.75rem;
	}
}

.wfi-tile__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 0.5rem;
	background-color: color-mix(in srgb, var(--wfi-primary) 10%, transparent);
	box-shadow: 0 0 0 1px color-mix(in srgb, var(--wfi-primary) 15%, transparent);
	margin-block-end: 1rem;
	color: var(--wfi-primary);
}

.wfi-tile__text {
	font-size: 0.875rem;
	line-height: 1.6;
	color: var(--wfi-foreground);
	margin: 0;
}

.wfi-tile__title {
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--wfi-foreground);
	margin-block-end: 0.25rem;
}

.wfi-tile__detail {
	font-size: 0.875rem;
	color: var(--wfi-muted-foreground);
	line-height: 1.6;
	margin: 0;
}

.wfi-img-hover {
	transition: transform 500ms ease-out;
	will-change: transform;
}

.wfi-img-hover:hover {
	transform: scale(1.05);
}

input[type="search"]::-webkit-search-cancel-button {
	display: none;
}

/* -- Button & Nav Animations (CSS-only) -- */

.wfi-btn-arrow {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	transition: gap 200ms ease;
}

.wfi-btn-arrow:hover {
	gap: 0.5rem;
}

.wfi-btn-arrow .arrow-icon {
	transition: transform 200ms ease;
}

.wfi-btn-arrow:hover .arrow-icon {
	transform: translateX(2px);
}

[dir="rtl"] .wfi-btn-arrow:hover .arrow-icon {
	transform: translateX(-2px);
}

.wfi-nav-dropdown {
	opacity: 0;
	transform: translateY(-8px);
	pointer-events: none;
	transition: opacity 150ms ease, transform 150ms ease;
}

.wfi-nav-dropdown.open {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}

/* -- In-page anchor scroll offset --
   Keeps the target of an in-page "#hash" link clear of the header when scrolled
   into view. Honoured by BOTH the JS smooth-scroll handler (wfi-ui.js) AND native
   browser fragment navigation — so a visitor landing directly on
   …/programs/123/slug#registerForm (bookmark / shared link) also lands below the
   header, a case the click handler never sees. `:where()` keeps specificity at 0
   so a component can still override it. Covers every <section id="…"> scroll
   target (e.g. #registerForm, #lead-form) plus an opt-in utility for non-sections. */
:where(section[id], [id].wfi-scroll-target) {
	scroll-margin-top: var(--wfi-header-offset, 6rem);
}
