/*
 * Al Manal front-end styles.
 * Logical properties only (inline/block, start/end) so every rule
 * mirrors automatically between Arabic (RTL) and English (LTR).
 */

:root {
	--almanal-radius: 8px;
	--almanal-maxw: 1320px;
	--almanal-gutter: clamp(0.75rem, 1.8vw, 1.5rem);
}

/* The block-theme <main> group carries a default flow margin-top (~24px)
   that opens a gap below the sticky navbar. Zero it so content (and the
   full-bleed hero) sits flush under the header. */
main.wp-block-group {
	margin-block-start: 0;
}

/* ---------- Layered page: animated gradient backdrop ---------- */
/* The page background is a slow, subtle brand-tone gradient. It shows
   in the gutters around the content. Content floats on a solid surface
   over it. Navbar + footer stay full-width (handled in their own rules). */
body {
	background: linear-gradient(
		135deg,
		color-mix(in srgb, var(--wp--preset--color--primary) 12%, #fff) 0%,
		color-mix(in srgb, var(--wp--preset--color--accent) 22%, #fff) 35%,
		var(--wp--preset--color--surface) 65%,
		color-mix(in srgb, var(--wp--preset--color--primary) 9%, #fff) 100%
	);
	background-size: 300% 300%;
	background-attachment: fixed;
	animation: almanal-gradient 22s ease infinite;
}

@keyframes almanal-gradient {
	0%   { background-position: 0% 50%; }
	50%  { background-position: 100% 50%; }
	100% { background-position: 0% 50%; }
}

@media (prefers-reduced-motion: reduce) {
	body { animation: none; }
}

/* Sticky footer: make the FSE wrapper a full-height flex column so the
   main content grows to fill short pages and the footer is pushed to the
   bottom (no gap below it on thin/empty pages). header + footer keep their
   natural height; only .almanal-main grows. */
.wp-site-blocks {
	display: flex;
	flex-direction: column;
	min-block-size: 100svh;
}
.wp-site-blocks > main,
.wp-site-blocks > .almanal-main {
	flex: 1 0 auto;
	/* In the flex column, a max-width + auto-margin child collapses to its
	   content width on the cross axis — force full width so the inner grid
	   sizes correctly, then max-inline-size + margin-inline:auto re-center. */
	inline-size: 100%;
}

/* Main content floats on a solid surface over the gradient, with
   horizontal gutters. Logical props so the inset mirrors RTL/LTR.
   Navbar/footer opt OUT of this by being outside .almanal-main. */
.almanal-main {
	max-inline-size: var(--almanal-maxw);
	margin-inline: auto;
	margin-block-start: var(--wp--preset--spacing--30);
	margin-block-end: var(--wp--preset--spacing--50);
	padding-inline: var(--almanal-gutter);
	padding-block: var(--wp--preset--spacing--50);
	background: var(--wp--preset--color--base);
	border-radius: var(--almanal-radius);
	box-shadow: 0 2px 24px rgba(46, 62, 78, 0.07);
}

/* ---------- Site Header ---------- */
/* Make the block-theme template-part wrapper itself the sticky element —
   sticking the inner div fails because its parent wrapper is only as tall
   as the header, leaving no scroll distance to stick within. */
header.wp-block-template-part:has(> .almanal-header),
.almanal-header {
	position: sticky;
	inset-block-start: 0;
	z-index: 50;
}

.almanal-header {
	background: color-mix(in srgb, var(--wp--preset--color--surface) 92%, var(--wp--preset--color--primary));
	border-block-end: 1px solid var(--wp--preset--color--border);
	box-shadow: 0 1px 0 rgba(46, 62, 78, 0.04);
	transition: box-shadow 0.25s ease, background-color 0.25s ease;
}

/* Elevation once scrolled away from the top. */
.almanal-header.is-scrolled {
	background: color-mix(in srgb, var(--wp--preset--color--surface) 80%, var(--wp--preset--color--primary));
	box-shadow: 0 4px 18px rgba(46, 62, 78, 0.14);
	-webkit-backdrop-filter: saturate(1.1) blur(2px);
	backdrop-filter: saturate(1.1) blur(2px);
}


.almanal-header__inner {
	max-inline-size: var(--almanal-maxw);
	margin-inline: auto;
	padding-inline: var(--wp--preset--spacing--40);
	padding-block: 0.75rem;
	display: flex;
	align-items: center;
	gap: var(--wp--preset--spacing--40);
	flex-wrap: wrap;
}

.almanal-header__logo {
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
}

.almanal-header__logo-img {
	block-size: 44px;
	inline-size: auto;
	display: block;
}

/* Desktop: nav + lang sit inline in one row, nav pushed toward the end side. */
.almanal-header__menu {
	display: flex;
	align-items: center;
	gap: var(--wp--preset--spacing--40);
	margin-inline-start: auto; /* push the whole menu group to the end; mirrors RTL */
	flex: 1 1 auto;
	justify-content: flex-end;
}

.almanal-header__nav {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	flex-wrap: wrap;
}

.almanal-header__link {
	color: var(--wp--preset--color--primary);
	text-decoration: none;
	font-weight: 600;
	font-size: var(--wp--preset--font-size--medium);
	padding-block: 0.25rem;
	border-block-end: 2px solid transparent;
	transition: border-color 0.15s ease;
}

.almanal-header__link:hover,
.almanal-header__link.is-current {
	border-block-end-color: var(--wp--preset--color--accent-deep);
}
.almanal-header__link.is-current {
	color: var(--wp--preset--color--accent-deep);
}

/* The drawer-only logo strip is hidden on desktop (logo lives in the bar). */
.almanal-header__menu-brand { display: none; }

.almanal-header__lang {
	flex-shrink: 0;
}

/* Polylang renders the <li> items directly inside the <nav> (no <ul> wrapper),
   so reset the list marker on the items themselves and lay them out here. */
.almanal-header__lang ul,
.almanal-header__lang {
	list-style: none;
	margin: 0;
	padding: 0;
}
.almanal-header__lang ul {
	display: flex;
	gap: 0.5rem;
}
.almanal-header__lang li {
	list-style: none;
	display: inline-flex;
}

.almanal-header__lang a {
	color: var(--wp--preset--color--muted);
	text-decoration: none;
	font-size: var(--wp--preset--font-size--small);
	font-weight: 600;
	padding-inline: 0.5rem;
	padding-block: 0.25rem;
	border: 1px solid var(--wp--preset--color--border);
	border-radius: 4px;
}

.almanal-header__lang a:hover {
	border-color: var(--wp--preset--color--accent-deep);
	color: var(--wp--preset--color--primary);
}

/* ---------- Header: mobile menu ---------- */
/* Hamburger toggle + backdrop are desktop-hidden; the media query below
   reveals them and turns .almanal-header__menu into a slide-in drawer. */
.almanal-header__toggle {
	display: none; /* shown ≤720px */
	margin-inline-start: auto; /* sits at the end side next to the logo */
	inline-size: 44px;
	block-size: 44px;
	padding: 0;
	border: 0;
	background: transparent;
	cursor: pointer;
	position: relative;
	flex-shrink: 0;
	z-index: 60; /* above the open drawer so it stays tappable as the close (X) */
}

/* The three bars, drawn from one element + its ::before/::after. */
.almanal-header__toggle-bars,
.almanal-header__toggle-bars::before,
.almanal-header__toggle-bars::after {
	content: "";
	position: absolute;
	inset-inline: 11px;
	block-size: 2px;
	background: var(--wp--preset--color--primary);
	border-radius: 2px;
	transition: transform 0.25s ease, opacity 0.2s ease;
}
.almanal-header__toggle-bars { inset-block-start: 21px; }      /* middle bar */
.almanal-header__toggle-bars::before { inset-block-start: -7px; }
.almanal-header__toggle-bars::after  { inset-block-start: 7px; }

/* Morph to an X when the menu is open. */
.almanal-header.is-menu-open .almanal-header__toggle-bars { background: transparent; }
.almanal-header.is-menu-open .almanal-header__toggle-bars::before { transform: translateY(7px) rotate(45deg); }
.almanal-header.is-menu-open .almanal-header__toggle-bars::after  { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 720px) {
	.almanal-header__toggle { display: block; }

	/* CRITICAL (mobile): the drawer + backdrop are position:fixed CHILDREN of
	   the header. A backdrop-filter on the header makes it a containing block
	   for those fixed descendants, re-anchoring them to the ~69px header — so
	   on scroll the off-canvas (closed) drawer lands back on-screen, shifting
	   the layout. The drawer only exists at this breakpoint, so we drop the
	   header's backdrop-filter here entirely; elevation still reads from the
	   solid background + shadow. (Desktop keeps the blur — no drawer there.) */
	.almanal-header,
	.almanal-header.is-scrolled {
		-webkit-backdrop-filter: none;
		backdrop-filter: none;
	}

	/* Menu becomes a slide-in drawer anchored to the inline-end edge
	   (right in LTR, left in RTL — logical props mirror it automatically). */
	.almanal-header__menu {
		position: fixed;
		inset-block: 0;
		inset-inline-end: 0;
		inline-size: min(78vw, 280px);
		margin: 0;
		flex-direction: column;
		align-items: stretch;
		justify-content: flex-start;
		gap: 0;
		padding: 0;
		background: var(--wp--preset--color--surface);
		border-inline-start: 1px solid var(--wp--preset--color--border);
		box-shadow: -8px 0 30px rgba(46, 62, 78, 0.16);
		transform: translateX(100%); /* off-canvas toward the end edge */
		transition: transform 0.28s ease;
		z-index: 55;
		overflow-y: auto;
	}
	/* In RTL the drawer hides toward the opposite (left) edge. */
	[dir="rtl"] .almanal-header__menu { transform: translateX(-100%); }

	.almanal-header.is-menu-open .almanal-header__menu { transform: translateX(0); }

	/* Logo strip at the top of the drawer — a faint sage-tinted band that
	   grounds the panel and echoes the main bar. */
	.almanal-header__menu-brand {
		display: flex;
		align-items: center;
		min-block-size: 64px;
		padding: 0.75rem 1.5rem;
		background: color-mix(in srgb, var(--wp--preset--color--accent) 16%, var(--wp--preset--color--surface));
		border-block-end: 1px solid var(--wp--preset--color--border);
	}
	.almanal-header__menu-logo .almanal-header__logo-img {
		block-size: 38px;
		inline-size: auto;
		display: block;
	}

	/* Nav fills the middle; each link sits in its own row with a hairline
	   divider between items (sage-tinted, very faint). */
	.almanal-header__nav {
		flex: 1 1 auto;
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		inline-size: 100%;
		padding: 0.5rem 0;
	}
	.almanal-header__link {
		font-size: var(--wp--preset--font-size--medium);
		font-weight: 600;
		padding: 0.85rem 1.5rem;
		inline-size: 100%;
		border-block-end: 1px solid color-mix(in srgb, var(--wp--preset--color--accent) 28%, transparent);
		/* override the desktop underline-on-hover treatment inside the drawer */
		border-block-end-width: 1px;
		transition: background-color 0.15s ease, color 0.15s ease;
	}
	.almanal-header__nav .almanal-header__link:last-child { border-block-end: 0; }
	.almanal-header__link:hover {
		background: color-mix(in srgb, var(--wp--preset--color--accent) 12%, transparent);
	}
	/* Current page: sage leading accent bar + colour, no bottom underline shift. */
	.almanal-header__link.is-current {
		color: var(--wp--preset--color--accent-deep);
		box-shadow: inset 3px 0 0 0 var(--wp--preset--color--accent);
		background: color-mix(in srgb, var(--wp--preset--color--accent) 10%, transparent);
	}
	[dir="rtl"] .almanal-header__link.is-current {
		box-shadow: inset -3px 0 0 0 var(--wp--preset--color--accent);
	}

	/* Language switcher pinned to a separated footer zone at the bottom. */
	.almanal-header__lang {
		margin-block-start: auto;
		inline-size: 100%;
		padding: 1.25rem 1.5rem;
		border-block-start: 1px solid var(--wp--preset--color--border);
		background: color-mix(in srgb, var(--wp--preset--color--accent) 8%, var(--wp--preset--color--surface));
	}
	/* Polylang puts the <li> straight under the <nav> (no <ul>); style the
	   item + link directly. Full width, no marker. */
	.almanal-header__lang li { inline-size: 100%; }
	.almanal-header__lang a {
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 0.6rem;
		inline-size: 100%;
		font-size: var(--wp--preset--font-size--medium);
		padding-block: 0.7rem;
		padding-inline: 0.75rem;
	}
	/* Real SVG country flag of the TARGET language (Polylang tags each item with
	   a lang-item-<code> class). Emoji flags don't render on Windows/Chrome, so
	   we draw the flag as a crisp little SVG image. UAE for Arabic, UK for EN. */
	.almanal-header__lang a::before {
		content: "";
		flex-shrink: 0;
		inline-size: 22px;
		block-size: 15px;
		border-radius: 2px;
		background-size: cover;
		background-position: center;
		box-shadow: 0 0 0 1px rgba(46, 62, 78, 0.12);
	}
	.almanal-header__lang .lang-item-ar a::before {
		background-image: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 9 6"%3E%3Crect width="9" height="6" fill="%23fff"/%3E%3Crect width="9" height="2" fill="%23009639"/%3E%3Crect y="4" width="9" height="2" fill="%23000"/%3E%3Crect width="3" height="6" fill="%23ce1126"/%3E%3C/svg%3E');
	}
	.almanal-header__lang .lang-item-en a::before {
		background-image: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 60 30"%3E%3CclipPath id="s"%3E%3Cpath d="M0,0 v30 h60 v-30 z"/%3E%3C/clipPath%3E%3Cg clip-path="url(%23s)"%3E%3Cpath d="M0,0 v30 h60 v-30 z" fill="%23012169"/%3E%3Cpath d="M0,0 L60,30 M60,0 L0,30" stroke="%23fff" stroke-width="6"/%3E%3Cpath d="M0,0 L60,30 M60,0 L0,30" clip-path="url(%23s)" stroke="%23C8102E" stroke-width="4"/%3E%3Cpath d="M30,0 v30 M0,15 h60" stroke="%23fff" stroke-width="10"/%3E%3Cpath d="M30,0 v30 M0,15 h60" stroke="%23C8102E" stroke-width="6"/%3E%3C/g%3E%3C/svg%3E');
	}

	/* Dim backdrop behind the drawer. */
	.almanal-header__backdrop {
		position: fixed;
		inset: 0;
		background: rgba(46, 62, 78, 0.45);
		opacity: 0;
		transition: opacity 0.28s ease;
		z-index: 54;
	}
	.almanal-header.is-menu-open .almanal-header__backdrop {
		opacity: 1;
	}
}

/* Respect reduced motion: no slide/morph transitions. */
@media (prefers-reduced-motion: reduce) {
	.almanal-header__menu,
	.almanal-header__backdrop,
	.almanal-header__toggle-bars,
	.almanal-header__toggle-bars::before,
	.almanal-header__toggle-bars::after {
		transition: none;
	}
}

/* ---------- Home: Hero ---------- */
.almanal-hero {
	--hero-img: none;
	--almanal-navh: 69px;
	position: relative;
	/* Fill the viewport below the sticky navbar. svh is mobile-safe. */
	min-block-size: calc(100svh - var(--almanal-navh));
	display: flex;
	align-items: center;
	overflow: hidden;
	isolation: isolate;
}

/* The slideshow variant fills the same height. */
.almanal-hero--slides,
.almanal-hero--slides .almanal-slide.is-active {
	min-block-size: calc(100svh - var(--almanal-navh));
}

/* ---- Slideshow ---- */
.almanal-hero--slides {
	display: block;
}
.almanal-hero--slides .almanal-slide {
	position: absolute;
	inset: 0;
	inline-size: 100%;
	opacity: 0;
	visibility: hidden;
	/* Slow, eased cross-fade — slides melt rather than blink. */
	transition: opacity 1.5s cubic-bezier(0.4, 0, 0.2, 1), visibility 1.5s;
	display: flex;
	align-items: center;
	overflow: hidden;
}
.almanal-hero--slides .almanal-slide.is-active {
	opacity: 1;
	visibility: visible;
	position: relative; /* the active slide gives the hero its height */
	inline-size: 100%;
	z-index: 1;
}

/* Background image per slide, blurred slightly, with a slow Ken Burns
   pan/zoom on the active slide. */
.almanal-slide::before {
	content: "";
	position: absolute;
	inset: -24px;
	z-index: -2;
	background-image: var(--hero-img);
	background-size: cover;
	background-position: center;
	filter: blur(4px) saturate(1.05);
	transform: scale(1.08);
}
/* Continuous Ken Burns on the active slide — slow, never stops, gentle
   alternating drift so it stays alive the whole dwell. */
.almanal-slide.is-active::before {
	animation: almanal-kenburns 16s ease-in-out infinite alternate;
}
@keyframes almanal-kenburns {
	from { transform: scale(1.08) translate3d(0, 0, 0); }
	to   { transform: scale(1.2) translate3d(-1.5%, -2.5%, 0); }
}

/* Brand tint over each slide image. */
.almanal-slide::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background: linear-gradient(
		to inline-start,
		color-mix(in srgb, var(--wp--preset--color--primary) 22%, transparent) 0%,
		color-mix(in srgb, var(--wp--preset--color--primary) 58%, transparent) 100%
	);
}

/* Text slides up + fades in AFTER the image has begun cross-fading
   (staggered), so the slide reads as layered, not flat. */
.almanal-slide .almanal-hero__glass {
	opacity: 0;
	transform: translateY(26px);
	transition: opacity 0.8s ease, transform 0.8s ease;
}
.almanal-slide.is-active .almanal-hero__glass {
	opacity: 1;
	transform: translateY(0);
	transition: opacity 0.9s cubic-bezier(0.2, 0.7, 0.2, 1) 0.55s,
	            transform 0.9s cubic-bezier(0.2, 0.7, 0.2, 1) 0.55s;
}

/* Inner stagger: title, lead, then CTA each a beat later. */
.almanal-slide .almanal-hero__title,
.almanal-slide .almanal-hero__lead,
.almanal-slide .almanal-hero__cta {
	opacity: 0;
	transform: translateY(12px);
}
.almanal-slide.is-active .almanal-hero__title { transition: opacity 0.7s ease 0.6s, transform 0.7s ease 0.6s; opacity: 1; transform: translateY(0); }
.almanal-slide.is-active .almanal-hero__lead  { transition: opacity 0.7s ease 0.75s, transform 0.7s ease 0.75s; opacity: 1; transform: translateY(0); }
.almanal-slide.is-active .almanal-hero__cta   { transition: opacity 0.7s ease 0.9s, transform 0.7s ease 0.9s; opacity: 1; transform: translateY(0); display: inline-block; }

/* Nav dots. */
.almanal-hero__dots {
	position: absolute;
	z-index: 3;
	inset-block-end: 1.25rem;
	inset-inline-start: 0;
	inline-size: 100%;
	display: flex;
	gap: 0.6rem;
	justify-content: center;
}
.almanal-hero__dot {
	inline-size: 11px;
	block-size: 11px;
	border-radius: 50%;
	border: 1.5px solid #fff;
	background: transparent;
	padding: 0;
	cursor: pointer;
	transition: background-color 0.2s ease, transform 0.2s ease;
}
.almanal-hero__dot:hover { background: rgba(255, 255, 255, 0.6); }
.almanal-hero__dot:focus-visible { outline: 2px solid #fff; outline-offset: 3px; }
.almanal-hero__dot.is-active { background: #fff; transform: scale(1.15); }

@media (prefers-reduced-motion: reduce) {
	.almanal-slide.is-active::before { animation: none; }
	.almanal-hero--slides .almanal-slide { transition: opacity 0.2s linear; }
	.almanal-slide.is-active .almanal-hero__glass,
	.almanal-slide.is-active .almanal-hero__title,
	.almanal-slide.is-active .almanal-hero__lead,
	.almanal-slide.is-active .almanal-hero__cta {
		transition: none;
		opacity: 1;
		transform: none;
	}
}

.almanal-hero__overlay {
	inline-size: 100%;
	display: flex;
	align-items: center;
	padding-block: var(--wp--preset--spacing--60);
}

.almanal-hero__content {
	max-inline-size: var(--almanal-maxw);
	margin-inline: auto;
	padding-inline: var(--almanal-gutter);
	inline-size: 100%;
}

/* Frosted-glass container holding the hero text. */
.almanal-hero__glass {
	max-inline-size: 40rem;
	padding: clamp(1.5rem, 4vw, 2.75rem);
	border-radius: 16px;
	background: color-mix(in srgb, var(--wp--preset--color--primary) 72%, transparent);
	-webkit-backdrop-filter: blur(14px) saturate(1.2);
	backdrop-filter: blur(14px) saturate(1.2);
	border: 1px solid color-mix(in srgb, #fff 22%, transparent);
	box-shadow: 0 8px 40px rgba(46, 62, 78, 0.35);
}

.almanal-hero__title {
	color: #fff;
	font-size: clamp(2rem, 5vw, 3.25rem);
	line-height: 1.15;
	margin-block: 0 1rem;
}

.almanal-hero__lead {
	color: #fff;
	font-size: var(--wp--preset--font-size--large);
	line-height: 1.6;
	margin-block: 0 1.75rem;
}

.almanal-hero__cta {
	display: inline-block;
	background: var(--wp--preset--color--accent-deep);
	color: #fff;
	font-weight: 600;
	padding-block: 0.85rem;
	padding-inline: 1.75rem;
	border-radius: 6px;
	text-decoration: none;
}

.almanal-hero__cta:hover { background: #fff; color: var(--wp--preset--color--primary); }

/* Home middle (focus + tracks) sits on the surfaced .almanal-home-body
   wrapper, which provides width + gutters. Sections just space vertically. */
.almanal-home-body {
	margin-block-start: var(--wp--preset--spacing--50);
}
.almanal-focus,
.almanal-tracks {
	padding-block: var(--wp--preset--spacing--50);
}

.almanal-focus { text-align: center; }
.almanal-focus h2,
.almanal-tracks h2 {
	font-size: var(--wp--preset--font-size--x-large);
	color: var(--wp--preset--color--primary);
	margin-block: 0 1rem;
}
.almanal-focus p { max-inline-size: 65ch; margin-inline: auto; color: var(--wp--preset--color--ink); font-size: var(--wp--preset--font-size--large); }

.almanal-tracks__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: var(--wp--preset--spacing--40);
	margin-block-start: var(--wp--preset--spacing--40);
}

.almanal-track {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	padding: var(--wp--preset--spacing--50);
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--border);
	border-radius: var(--almanal-radius);
	text-decoration: none;
	color: inherit;
	box-shadow: 0 2px 16px rgba(46, 62, 78, 0.06);
	transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}
.almanal-track:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(46,62,78,0.12); border-color: var(--wp--preset--color--accent-deep); }
.almanal-track h3 { color: var(--wp--preset--color--primary); margin: 0; font-size: var(--wp--preset--font-size--large); }
.almanal-track__count { color: var(--wp--preset--color--muted); font-size: var(--wp--preset--font-size--small); }
.almanal-track__cta { margin-block-start: auto; color: var(--wp--preset--color--accent-deep); font-weight: 600; }

/* Track card WITH a background image: image fills the card, text sits on a
   dark gradient for contrast (white text). */
.almanal-track--has-visual {
	--track-img: none;
	position: relative;
	min-block-size: 200px;
	border: none;
	overflow: hidden;
	color: #fff;
	isolation: isolate;
}
.almanal-track--has-visual::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -2;
	background-image: var(--track-img);
	background-size: cover;
	background-position: center;
	transition: transform 0.3s ease;
}
.almanal-track--has-visual::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background: linear-gradient(to top, color-mix(in srgb, var(--wp--preset--color--primary) 92%, transparent) 8%, color-mix(in srgb, var(--wp--preset--color--primary) 30%, transparent) 100%);
}
.almanal-track--has-visual:hover::before { transform: scale(1.06); }
.almanal-track--has-visual h3 { color: #fff; }
.almanal-track--has-visual .almanal-track__count { color: color-mix(in srgb, #fff 80%, transparent); }
.almanal-track--has-visual .almanal-track__cta { color: #fff; }

/* ---------- Trust Bar ---------- */
.almanal-trust {
	margin-block: var(--wp--preset--spacing--50);
	padding-block: var(--wp--preset--spacing--40);
	border-block: 1px solid var(--wp--preset--color--border);
	text-align: center;
}

.almanal-trust__label {
	font-size: var(--wp--preset--font-size--small);
	color: var(--wp--preset--color--muted);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	margin-block: 0 1.25rem;
}

.almanal-trust__logos {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: clamp(1.5rem, 5vw, 3.5rem);
}

.almanal-trust__logo {
	display: block;
	block-size: auto;
	max-block-size: 56px;
	inline-size: auto;
	filter: grayscale(0.2);
	opacity: 0.9;
	transition: filter 0.2s ease, opacity 0.2s ease;
}

.almanal-trust__logo:hover {
	filter: grayscale(0);
	opacity: 1;
}

/* SPEA is very wide; give it a touch more height room */
.almanal-trust__logo--spea { max-block-size: 44px; }

/* ---------- Site Footer ---------- */
.almanal-footer {
	background: var(--wp--preset--color--primary);
	color: #fff;
}

.almanal-footer__inner {
	max-inline-size: var(--almanal-maxw);
	margin-inline: auto;
	padding-inline: var(--almanal-gutter);
	padding-block: var(--wp--preset--spacing--60) var(--wp--preset--spacing--50);
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr;
	gap: var(--wp--preset--spacing--50);
}

@media (max-width: 720px) {
	.almanal-footer__inner { grid-template-columns: 1fr; }
}

.almanal-footer__col h3 {
	color: #fff;
	font-size: var(--wp--preset--font-size--large);
	margin-block: 0 0.75rem;
}

.almanal-footer__col h4 {
	color: var(--wp--preset--color--accent);
	font-size: var(--wp--preset--font-size--medium);
	margin-block: 0 1rem;
}

.almanal-footer__brand p {
	color: color-mix(in srgb, #fff 80%, var(--wp--preset--color--primary));
	font-size: var(--wp--preset--font-size--small);
	line-height: 1.7;
	margin: 0;
}

.almanal-footer__col ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.6rem;
}

.almanal-footer__col a {
	color: color-mix(in srgb, #fff 88%, var(--wp--preset--color--primary));
	text-decoration: none;
	font-size: var(--wp--preset--font-size--small);
}

.almanal-footer__col a:hover {
	color: var(--wp--preset--color--accent);
}

.almanal-footer__contact li {
	color: color-mix(in srgb, #fff 80%, var(--wp--preset--color--primary));
	font-size: var(--wp--preset--font-size--small);
	line-height: 1.6;
}

.almanal-footer__bar {
	border-block-start: 1px solid color-mix(in srgb, #fff 15%, transparent);
}

.almanal-footer__bar p {
	max-inline-size: var(--almanal-maxw);
	margin-inline: auto;
	padding-inline: var(--almanal-gutter);
	padding-block: 1rem;
	font-size: var(--wp--preset--font-size--small);
	color: color-mix(in srgb, #fff 70%, var(--wp--preset--color--primary));
	margin-block: 0;
}

/* ---------- Single Track Page (taxonomy) ---------- */
.almanal-track-page__head {
	margin-block-end: var(--wp--preset--spacing--50);
	padding: var(--wp--preset--spacing--60) var(--wp--preset--spacing--50);
	border-radius: var(--almanal-radius);
	background-color: var(--wp--preset--color--surface);
	border: 1px solid var(--wp--preset--color--border);
}

/* When the track has a card image, layer it under a navy wash for white
   text (same proven technique as the home track cards). */
.almanal-track-page__head--has-visual {
	--track-img: none;
	position: relative;
	overflow: hidden;
	border: 0;
	isolation: isolate;
}
.almanal-track-page__head--has-visual::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -2;
	background-image: var(--track-img);
	background-size: cover;
	background-position: center;
}
.almanal-track-page__head--has-visual::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background: linear-gradient( color-mix( in srgb, var(--wp--preset--color--primary) 80%, transparent ), color-mix( in srgb, var(--wp--preset--color--primary) 90%, transparent ) );
}
.almanal-track-page__head--has-visual,
.almanal-track-page__head--has-visual a,
.almanal-track-page__head--has-visual .almanal-track-page__crumbs span {
	color: #fff;
}

.almanal-track-page__crumbs {
	font-size: var(--wp--preset--font-size--small);
	margin-block-end: 0.6rem;
	display: flex;
	gap: 0.5rem;
	align-items: center;
	flex-wrap: wrap;
}
.almanal-track-page__crumbs a {
	color: var(--wp--preset--color--accent-deep);
	text-decoration: none;
	font-weight: 600;
}
.almanal-track-page__head--has-visual .almanal-track-page__crumbs a { color: #fff; text-decoration: underline; }
.almanal-track-page__crumbs a:hover { text-decoration: underline; }

.almanal-track-page__title {
	font-size: var(--wp--preset--font-size--xx-large);
	margin-block: 0;
	color: var(--wp--preset--color--primary);
}
.almanal-track-page__head--has-visual .almanal-track-page__title { color: #fff; }

.almanal-track-page__intro {
	margin-block-start: 0.6rem;
	max-inline-size: 62ch;
	line-height: 1.7;
}

.almanal-track-page__empty {
	padding: var(--wp--preset--spacing--60) var(--wp--preset--spacing--40);
	text-align: center;
	color: var(--wp--preset--color--muted);
	background: var(--wp--preset--color--surface);
	border: 1px dashed var(--wp--preset--color--border);
	border-radius: var(--almanal-radius);
}

/* ---------- Courses Listing ---------- */
.almanal-courses__head h1 {
	font-size: var(--wp--preset--font-size--xx-large);
	color: var(--wp--preset--color--primary);
	margin-block: 0 var(--wp--preset--spacing--40);
}

.almanal-courses__section {
	margin-block-end: var(--wp--preset--spacing--60);
}

.almanal-courses__cat {
	font-size: var(--wp--preset--font-size--large);
	color: var(--wp--preset--color--primary);
	padding-block-end: 0.5rem;
	margin-block-end: var(--wp--preset--spacing--40);
	border-block-end: 2px solid var(--wp--preset--color--accent);
}

.almanal-courses__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: var(--wp--preset--spacing--40);
}

.almanal-card {
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
	padding: var(--wp--preset--spacing--40);
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--border);
	border-radius: var(--almanal-radius);
	text-decoration: none;
	color: inherit;
	transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

.almanal-card:hover {
	border-color: var(--wp--preset--color--accent-deep);
	box-shadow: 0 6px 20px rgba(46, 62, 78, 0.10);
	transform: translateY(-2px);
}

.almanal-card__visual {
	display: flex;
	align-items: center;
	justify-content: center;
	block-size: 120px;
	margin: calc(-1 * var(--wp--preset--spacing--40)) calc(-1 * var(--wp--preset--spacing--40)) 0.4rem;
	background: var(--wp--preset--color--surface);
	border-end-start-radius: 0;
	border-end-end-radius: 0;
	border-start-start-radius: var(--almanal-radius);
	border-start-end-radius: var(--almanal-radius);
	overflow: hidden;
}

/* Logo: contained on a clean surface, never cropped. */
.almanal-card__visual--logo {
	background: var(--wp--preset--color--base);
	padding: 1rem;
}
.almanal-card__visual--logo img {
	max-block-size: 64px;
	max-inline-size: 72%;
	inline-size: auto;
	block-size: auto;
	object-fit: contain;
}

/* Photo: fills the visual area edge to edge. */
.almanal-card__visual--photo img {
	inline-size: 100%;
	block-size: 120px;
	object-fit: cover;
}

.almanal-card__badge {
	align-self: flex-start;
	font-size: var(--wp--preset--font-size--small);
	font-weight: 600;
	color: var(--wp--preset--color--accent-deep);
	background: color-mix(in srgb, var(--wp--preset--color--accent) 35%, white);
	padding-block: 0.2rem;
	padding-inline: 0.7rem;
	border-radius: 999px;
}

.almanal-card__title {
	font-size: var(--wp--preset--font-size--large);
	color: var(--wp--preset--color--primary);
	margin: 0;
	line-height: 1.3;
}

.almanal-card__meta {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.3rem 1rem;
	color: var(--wp--preset--color--muted);
	font-size: var(--wp--preset--font-size--small);
}

.almanal-card__cta {
	margin-block-start: auto;
	color: var(--wp--preset--color--accent-deep);
	font-weight: 600;
	font-size: var(--wp--preset--font-size--small);
}

/* ---------- Course Profile ---------- */
.almanal-course {
	/* Width + gutters now come from .almanal-main wrapper. */
}

.almanal-course__head {
	padding-block-end: var(--wp--preset--spacing--40);
	border-block-end: 1px solid var(--wp--preset--color--border);
	margin-block-end: var(--wp--preset--spacing--50);
}

.almanal-badge {
	display: inline-block;
	font-size: var(--wp--preset--font-size--small);
	font-weight: 600;
	color: var(--wp--preset--color--accent-deep);
	background: color-mix(in srgb, var(--wp--preset--color--accent) 35%, white);
	padding-block: 0.25rem;
	padding-inline: 0.75rem;
	border-radius: 999px;
	margin-block-end: 0.75rem;
}

.almanal-course__title {
	font-size: var(--wp--preset--font-size--xx-large);
	color: var(--wp--preset--color--primary);
	line-height: 1.2;
	margin-block: 0 1rem;
}

.almanal-course__meta {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 2rem;
}

.almanal-course__meta li {
	display: flex;
	flex-direction: column;
	gap: 0.1rem;
}

.almanal-course__meta-k {
	font-size: var(--wp--preset--font-size--small);
	color: var(--wp--preset--color--muted);
}

/* Two-column body + CTA on wide screens; stacks on small. */
.almanal-course__body {
	display: grid;
	gap: var(--wp--preset--spacing--50);
}

.almanal-course__section h2 {
	font-size: var(--wp--preset--font-size--large);
	color: var(--wp--preset--color--primary);
	margin-block-end: 0.75rem;
}

/* Rich author-entered overview content (wp_kses_post output). */
.almanal-prose {
	line-height: 1.8;
	color: var(--wp--preset--color--ink);
}
.almanal-prose > :first-child { margin-block-start: 0; }
.almanal-prose > :last-child { margin-block-end: 0; }
.almanal-prose p { margin-block: 0 1rem; }
.almanal-prose ul,
.almanal-prose ol { margin-block: 0 1rem; padding-inline-start: 1.4rem; }
.almanal-prose li { margin-block-end: 0.4rem; }
.almanal-prose a {
	color: var(--wp--preset--color--accent-deep);
	text-decoration: underline;
}
.almanal-prose h2,
.almanal-prose h3 {
	color: var(--wp--preset--color--primary);
	margin-block: 1.4rem 0.5rem;
}
.almanal-prose hr {
	border: 0;
	block-size: 1px;
	background: var(--wp--preset--color--accent, #99CAA5);
	margin-block: 1.6rem;
}

/* Honour the alignment the author sets in the editor (the classes WP
   emits). Logical floats so left/right mirror correctly in RTL. */
.almanal-prose img { max-inline-size: 100%; height: auto; }
.almanal-prose .alignleft {
	float: inline-start;
	margin-inline-end: 1.25rem;
	margin-block: 0.3rem 0.8rem;
}
.almanal-prose .alignright {
	float: inline-end;
	margin-inline-start: 1.25rem;
	margin-block: 0.3rem 0.8rem;
}
.almanal-prose .aligncenter {
	display: block;
	margin-inline: auto;
	margin-block: 0.8rem;
}
.almanal-prose .alignnone {
	display: block;
	margin-block: 0.8rem;
}
.almanal-prose figure { margin: 0.8rem 0; }
.almanal-prose .wp-caption { max-inline-size: 100%; }
.almanal-prose .wp-caption-text,
.almanal-prose figcaption {
	font-size: var(--wp--preset--font-size--small);
	color: var(--wp--preset--color--muted);
	text-align: center;
	margin-block-start: 0.4rem;
}
/* Clear floats so following sections don't wrap awkwardly. */
.almanal-prose::after { content: ""; display: block; clear: both; }

/* Tables authored in the rich editor. RTL-aware, brand-styled. */
.almanal-prose table {
	inline-size: 100%;
	border-collapse: collapse;
	margin-block: 1rem;
	font-size: 0.96em;
}
.almanal-prose th,
.almanal-prose td {
	border: 1px solid var(--wp--preset--color--border);
	padding: 0.6rem 0.8rem;
	text-align: start;
	vertical-align: top;
}
.almanal-prose th {
	background: color-mix( in srgb, var(--wp--preset--color--accent) 22%, #fff );
	color: var(--wp--preset--color--primary);
	font-weight: 700;
}
.almanal-prose tbody tr:nth-child(even) td {
	background: color-mix( in srgb, var(--wp--preset--color--surface) 60%, #fff );
}
/* A 2-col key/value table (first column = labels) reads cleaner shaded. */
.almanal-prose table.almanal-table td:first-child {
	font-weight: 600;
	color: var(--wp--preset--color--primary);
	background: color-mix( in srgb, var(--wp--preset--color--accent) 14%, #fff );
	inline-size: 32%;
}

.almanal-course__outcomes {
	display: grid;
	gap: 0.5rem;
	padding-inline-start: 1.25rem;
}

.almanal-course__outline {
	list-style: none;
	counter-reset: mod;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 1rem;
}

.almanal-module {
	counter-increment: mod;
	background: var(--wp--preset--color--surface);
	border: 1px solid var(--wp--preset--color--border);
	border-radius: var(--almanal-radius);
	padding: 1.25rem;
	position: relative;
	padding-inline-start: 3.25rem;
}

.almanal-module::before {
	content: counter(mod);
	position: absolute;
	inset-inline-start: 1rem;
	inset-block-start: 1.25rem;
	inline-size: 1.6rem;
	block-size: 1.6rem;
	display: grid;
	place-items: center;
	background: var(--wp--preset--color--primary);
	color: #fff;
	border-radius: 50%;
	font-size: 0.85rem;
	font-weight: 700;
}

.almanal-module__title {
	font-size: var(--wp--preset--font-size--medium);
	color: var(--wp--preset--color--primary);
	margin: 0 0 0.25rem;
}

.almanal-module__desc {
	margin: 0;
	color: var(--wp--preset--color--ink);
}

/* CTA panel */
.almanal-course__cta {
	margin-block-start: var(--wp--preset--spacing--60);
	background: var(--wp--preset--color--surface);
	border: 1px solid var(--wp--preset--color--border);
	border-radius: var(--almanal-radius);
	padding: var(--wp--preset--spacing--50);
}

.almanal-course__cta h2 {
	color: var(--wp--preset--color--primary);
	margin-block-start: 0;
}

.almanal-course__dates {
	font-weight: 600;
	color: var(--wp--preset--color--accent-deep);
}

/* ---------- Registration form ---------- */
.almanal-reg {
	margin-block-start: var(--wp--preset--spacing--40);
}

.almanal-reg__row {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	margin-block: 0 var(--wp--preset--spacing--30);
}

.almanal-reg__row label {
	font-weight: 600;
	font-size: 0.9rem;
	color: var(--wp--preset--color--primary);
}

.almanal-reg__row input,
.almanal-reg__row textarea {
	inline-size: 100%;
	padding: 0.6rem 0.75rem;
	border: 1px solid var(--wp--preset--color--border);
	border-radius: calc(var(--almanal-radius) * 0.6);
	background: #fff;
	font: inherit;
	color: inherit;
}

.almanal-reg__row input:focus,
.almanal-reg__row textarea:focus {
	outline: 3px solid var(--wp--preset--color--primary);
	outline-offset: 2px;
	border-color: var(--wp--preset--color--primary);
}

.almanal-reg__row input[readonly] {
	background: var(--wp--preset--color--surface);
	color: var(--wp--preset--color--ink);
	font-weight: 600;
}

.almanal-reg__row.has-error input {
	border-color: #8b2e23;
}

.almanal-reg__error {
	color: #8b2e23;
	font-size: 0.82rem;
	font-weight: 600;
}

.almanal-reg__actions {
	margin-block-start: var(--wp--preset--spacing--30);
}

/* Honeypot: removed from layout + a11y tree, kept fillable for bots. */
.almanal-reg--done {
	background: color-mix(in srgb, var(--wp--preset--color--accent) 18%, #fff);
	border: 1px solid var(--wp--preset--color--accent);
	border-radius: var(--almanal-radius);
	padding: var(--wp--preset--spacing--40);
}

.almanal-reg__thanks {
	margin: 0;
	font-weight: 600;
	color: var(--wp--preset--color--accent-deep);
}

/* ---------- Trainers Listing ---------- */
.almanal-trainers__head h1 {
	font-size: var(--wp--preset--font-size--xx-large);
	color: var(--wp--preset--color--primary);
	margin-block: 0 0.5rem;
}

.almanal-trainers__intro {
	color: var(--wp--preset--color--muted);
	max-inline-size: 60ch;
	margin-block: 0 var(--wp--preset--spacing--50);
}

.almanal-trainers__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: var(--wp--preset--spacing--40);
}

.almanal-trainer-card {
	position: relative; /* containing block for the stretched main link */
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 0.45rem;
	padding: var(--wp--preset--spacing--40);
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--border);
	border-radius: var(--almanal-radius);
	transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

.almanal-trainer-card:hover {
	border-color: var(--wp--preset--color--accent-deep);
	box-shadow: 0 6px 20px rgba(46, 62, 78, 0.10);
	transform: translateY(-2px);
}

/* The whole card is clickable via this stretched link; social icons below
   sit above it (own stacking context) so they remain independently clickable. */
.almanal-trainer-card__main {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.45rem;
	text-decoration: none;
	color: inherit;
}
.almanal-trainer-card__main::after {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: var(--almanal-radius);
}

/* Social icons row on the card. */
.almanal-trainer-card__socials {
	position: relative; /* above the stretched link */
	z-index: 1;
	list-style: none;
	margin: 0.6rem 0 0;
	padding: 0;
	display: flex;
	gap: 0.5rem;
}
.almanal-trainer-card__social {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	inline-size: 34px;
	block-size: 34px;
	border-radius: 50%;
	border: 1px solid var(--wp--preset--color--border);
	color: var(--wp--preset--color--muted);
	transition: border-color 0.15s ease, background-color 0.15s ease, color 0.15s ease;
}
.almanal-trainer-card__social:hover {
	border-color: var(--wp--preset--color--accent-deep);
	background: color-mix(in srgb, var(--wp--preset--color--accent) 16%, transparent);
	color: var(--wp--preset--color--accent-deep);
}

.almanal-trainer-card__photo {
	inline-size: 96px;
	block-size: 96px;
	border-radius: 50%;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--wp--preset--color--surface);
	margin-block-end: 0.3rem;
}

.almanal-trainer-card__photo img {
	inline-size: 100%;
	block-size: 100%;
	object-fit: cover;
}

.almanal-trainer-card__photo--placeholder {
	background: color-mix(in srgb, var(--wp--preset--color--accent) 30%, white);
}

.almanal-trainer-card__initial {
	font-size: 2.2rem;
	font-weight: 700;
	color: var(--wp--preset--color--accent-deep);
	line-height: 1;
}

.almanal-trainer-card__name {
	font-size: var(--wp--preset--font-size--large);
	color: var(--wp--preset--color--primary);
	margin: 0;
	line-height: 1.3;
}

.almanal-trainer-card__title {
	font-weight: 600;
	color: var(--wp--preset--color--accent-deep);
	margin: 0;
	font-size: var(--wp--preset--font-size--small);
}

.almanal-trainer-card__expertise {
	color: var(--wp--preset--color--muted);
	font-size: var(--wp--preset--font-size--small);
	margin: 0;
}

.almanal-trainer-card__cta {
	margin-block-start: auto;
	padding-block-start: 0.4rem;
	color: var(--wp--preset--color--accent-deep);
	font-weight: 600;
	font-size: var(--wp--preset--font-size--small);
}

/* Empty state — intentional, not broken-looking. */
.almanal-trainers__empty {
	text-align: center;
	padding: var(--wp--preset--spacing--70) var(--wp--preset--spacing--40);
	background: var(--wp--preset--color--surface);
	border: 1px dashed var(--wp--preset--color--border);
	border-radius: var(--almanal-radius);
	color: var(--wp--preset--color--muted);
}

.almanal-trainers__empty-cta {
	display: inline-block;
	margin-block-start: var(--wp--preset--spacing--40);
}

/* ---------- Trainer Profile ---------- */
/* Profile is one panel: a tinted header band + body sections, hairline-separated. */
.almanal-trainer {
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--border);
	border-radius: var(--almanal-radius);
	overflow: hidden;
}

.almanal-trainer__head {
	display: flex;
	align-items: center;
	gap: var(--wp--preset--spacing--40);
	flex-wrap: wrap;
	padding: var(--wp--preset--spacing--50);
	background: color-mix(in srgb, var(--wp--preset--color--accent) 12%, var(--wp--preset--color--surface));
	border-block-end: 1px solid var(--wp--preset--color--border);
}

.almanal-trainer__photo {
	inline-size: 110px;
	block-size: 110px;
	border-radius: 50%;
	overflow: hidden;
	flex: none;
	background: var(--wp--preset--color--surface);
	box-shadow: 0 0 0 4px var(--wp--preset--color--base);
}

.almanal-trainer__photo img {
	inline-size: 100%;
	block-size: 100%;
	object-fit: cover;
}

.almanal-trainer__photo--placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	background: color-mix(in srgb, var(--wp--preset--color--accent) 30%, white);
}
.almanal-trainer__initial {
	font-size: 2.6rem;
	font-weight: 700;
	line-height: 1;
	color: var(--wp--preset--color--accent-deep);
}

.almanal-trainer__heading { min-inline-size: 0; }

.almanal-trainer__name {
	font-size: var(--wp--preset--font-size--xx-large);
	color: var(--wp--preset--color--primary);
	margin: 0 0 0.15rem;
}

.almanal-trainer__title {
	font-weight: 600;
	color: var(--wp--preset--color--accent-deep);
	margin: 0 0 0.45rem;
}

.almanal-trainer__expertise {
	color: var(--wp--preset--color--muted);
	font-size: var(--wp--preset--font-size--small);
	line-height: 1.6;
	margin: 0;
}

/* Body sections — each labelled, separated by hairlines. */
.almanal-trainer__body { padding: 0; }

.almanal-trainer__section {
	padding: var(--wp--preset--spacing--50);
	border-block-end: 1px solid var(--wp--preset--color--border);
}
.almanal-trainer__section:last-child { border-block-end: 0; }

.almanal-trainer__label {
	margin: 0 0 0.75rem;
	font-size: var(--wp--preset--font-size--small);
	font-weight: 700;
	letter-spacing: 0.02em;
	color: var(--wp--preset--color--muted);
}

.almanal-trainer__bio {
	margin: 0;
	line-height: 1.7;
	color: var(--wp--preset--color--ink);
}

/* Qualifications as credential chips (the standards she holds). */
.almanal-trainer__quals {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}
.almanal-trainer__qual {
	display: inline-flex;
	align-items: center;
	padding: 0.4rem 0.85rem;
	border: 1px solid var(--wp--preset--color--border);
	border-radius: 999px;
	background: var(--wp--preset--color--surface);
	color: var(--wp--preset--color--primary);
	font-size: var(--wp--preset--font-size--small);
	font-weight: 600;
	line-height: 1.2;
}
/* The trainer's own methodology / signature credential — sage-filled. */
.almanal-trainer__qual.is-signature {
	background: var(--wp--preset--color--accent);
	border-color: transparent;
	color: var(--wp--preset--color--primary);
}
.almanal-trainer__qual.is-signature::before {
	content: "\2605"; /* ★ */
	margin-inline-end: 0.35rem;
	color: var(--wp--preset--color--accent-deep);
}

/* Courses delivered — clean linked list. */
.almanal-trainer__courses {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}
.almanal-trainer__courses li {
	padding-inline-start: 1.1rem;
	position: relative;
}
.almanal-trainer__courses li::before {
	content: "";
	position: absolute;
	inset-inline-start: 0;
	inset-block-start: 0.62em;
	inline-size: 6px;
	block-size: 6px;
	border-radius: 50%;
	background: var(--wp--preset--color--accent);
}
.almanal-trainer__courses a {
	color: var(--wp--preset--color--accent-deep);
	font-weight: 600;
	text-decoration: none;
}
.almanal-trainer__courses a:hover { text-decoration: underline; }

/* Trainer social links — round icon buttons in the header band. */
.almanal-trainer__socials {
	list-style: none;
	margin: 0.85rem 0 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}
.almanal-trainer__social {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	inline-size: 36px;
	block-size: 36px;
	border: 1px solid var(--wp--preset--color--border);
	border-radius: 50%;
	background: var(--wp--preset--color--base);
	color: var(--wp--preset--color--muted);
	text-decoration: none;
	transition: border-color 0.15s ease, background-color 0.15s ease, color 0.15s ease;
}
.almanal-trainer__social:hover {
	border-color: var(--wp--preset--color--accent-deep);
	background: color-mix(in srgb, var(--wp--preset--color--accent) 16%, transparent);
	color: var(--wp--preset--color--accent-deep);
}
.almanal-trainer__social-icon {
	display: inline-flex;
	align-items: center;
}

/* ---------- Feedback / Testimonials ---------- */
.almanal-feedback {
	margin-block-start: var(--wp--preset--spacing--60);
}

.almanal-feedback__heading {
	font-size: var(--wp--preset--font-size--x-large);
	color: var(--wp--preset--color--primary);
	margin-block: 0 var(--wp--preset--spacing--40);
}

.almanal-feedback__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: var(--wp--preset--spacing--40);
}

.almanal-feedback__card {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
	padding: var(--wp--preset--spacing--40);
	background: var(--wp--preset--color--base);
	border: 1px solid var(--wp--preset--color--border);
	border-radius: var(--almanal-radius);
	position: relative;
}

/* A soft opening quotation mark, mirrored for RTL via logical inset. */
.almanal-feedback__card::before {
	content: "\201C";
	position: absolute;
	inset-block-start: -0.2em;
	inset-inline-start: 0.4rem;
	font-size: 3rem;
	line-height: 1;
	color: color-mix(in srgb, var(--wp--preset--color--accent) 55%, white);
	font-family: Georgia, "Times New Roman", serif;
}

.almanal-feedback__stars {
	color: var(--wp--preset--color--accent-deep);
	letter-spacing: 0.1em;
	font-size: var(--wp--preset--font-size--small);
}

.almanal-feedback__quote {
	margin: 0;
	color: var(--wp--preset--color--ink);
	line-height: 1.6;
	font-style: italic;
}

.almanal-feedback__by {
	margin-block-start: auto;
	display: flex;
	flex-direction: column;
	gap: 0.1rem;
}

.almanal-feedback__name {
	font-weight: 700;
	color: var(--wp--preset--color--primary);
}

.almanal-feedback__name--anon {
	font-weight: 600;
	color: var(--wp--preset--color--muted);
}

.almanal-feedback__course {
	font-size: var(--wp--preset--font-size--small);
	color: var(--wp--preset--color--accent-deep);
}

/* ---------- 404 ---------- */
.almanal-404 {
	text-align: center;
	padding-block: var(--wp--preset--spacing--70);
	max-inline-size: 56ch;
	margin-inline: auto;
}

.almanal-404__code {
	font-size: clamp(4rem, 12vw, 7rem);
	font-weight: 800;
	line-height: 1;
	margin: 0;
	color: var(--wp--preset--color--accent);
}

.almanal-404__title {
	font-size: var(--wp--preset--font-size--x-large);
	color: var(--wp--preset--color--primary);
	margin-block: 0.4rem 0.6rem;
}

.almanal-404__lead {
	color: var(--wp--preset--color--muted);
	margin-block: 0 var(--wp--preset--spacing--40);
}

.almanal-404__links {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.6rem 1.4rem;
	margin-block-end: var(--wp--preset--spacing--40);
}

.almanal-404__link {
	color: var(--wp--preset--color--accent-deep);
	font-weight: 600;
	text-decoration: none;
}

.almanal-404__link:hover {
	text-decoration: underline;
}

.almanal-404__cta {
	display: inline-block;
}

/* ---------- Reduced motion safety ---------- */
@media (prefers-reduced-motion: reduce) {
	::view-transition-group(*),
	::view-transition-old(*),
	::view-transition-new(*) {
		animation: none !important;
	}
}
