/**
 * Reflex Mega Menu styles.
 *
 * Colours, fonts and spacing are pulled from the active theme's own design
 * tokens (the --wp--preset--* custom properties that Twenty Twenty-Four and
 * your Global Styles expose). That means this menu tracks your brand
 * automatically: change a colour in the Site Editor and the menu follows.
 * Hex values appear only as fallbacks, matching the live theme.json.
 *
 * Everything is scoped under .reflex-megamenu to avoid leaking styles.
 *
 * FONTS: body text is Arial (a system font, always available). Headings use
 * Poppins, which is NOT bundled with Twenty Twenty-Four, so you must make it
 * available once. Easiest, self-hosted, GDPR-safe route:
 *   WP Admin > Appearance > Editor > Styles > Typography > Fonts >
 *   "Install Fonts" > search "Poppins" > install the weights you want.
 * Until Poppins is installed, headings fall back to Arial (set above).
 * Alternatively self-host inside this plugin by adding the woff2 files to
 * assets/fonts/ and uncommenting the @font-face block below.
 */

/*
@font-face {
	font-family: "Poppins";
	font-style: normal;
	font-weight: 500;
	font-display: swap;
	src: url("../fonts/poppins-500.woff2") format("woff2");
}
@font-face {
	font-family: "Poppins";
	font-style: normal;
	font-weight: 600;
	font-display: swap;
	src: url("../fonts/poppins-600.woff2") format("woff2");
}
*/

.reflex-megamenu {
	--reflex-mm-maxw: var(--wp--style--global--wide-size, 1280px);
	--reflex-mm-bg: var(--wp--preset--color--base-2, #ffffff);
	--reflex-mm-page: var(--wp--preset--color--base, #f9f9f9);
	--reflex-mm-text: var(--wp--preset--color--contrast, #111111);
	--reflex-mm-muted: var(--wp--preset--color--contrast-2, #636363);
	--reflex-mm-hairline: var(--wp--preset--color--contrast-3, #a4a4a4);

	/* Reflex brand palette — read from the live site (purple-led, pastel cards).
	   These are explicit brand colours rather than theme tokens, because the
	   theme's own palette is neutral. Retune everything from here. */
	--reflex-mm-primary: #401dcd;        /* brand purple/indigo: CTAs, icons, links */
	--reflex-mm-primary-hover: #3216a4;  /* darker purple for hover (derived) */
	--reflex-mm-lead: var(--reflex-mm-primary);
	--reflex-mm-tint-purple: #ece8fb;    /* light tint of brand purple (derived) */
	--reflex-mm-tint-blue: #e9f5ff;      /* pastel blue (site section cards) */
	--reflex-mm-tint-pink: #ffe2f7;      /* pastel pink (site section cards) */
	--reflex-mm-tint-mint: #cdfff1;      /* pastel mint (site section cards) */

	--reflex-mm-radius: 0.33rem;
	--reflex-mm-tile-radius: 0.6rem;
	--reflex-mm-gap: var(--wp--preset--spacing--20, min(1.5rem, 2vw));
	--reflex-mm-font: Arial, Helvetica, sans-serif;            /* body / UI text */
	--reflex-mm-heading-font: "Poppins", Arial, sans-serif;    /* column headings */

	font-family: var(--reflex-mm-font);
	color: var(--reflex-mm-text);
	background: var(--reflex-mm-bg);
	box-sizing: border-box;
}

.reflex-megamenu *,
.reflex-megamenu *::before,
.reflex-megamenu *::after {
	box-sizing: border-box;
}

.reflex-mm__inner {
	position: relative; /* anchor for the absolutely-positioned panel */
	max-width: var(--reflex-mm-maxw);
	margin-inline: auto;
	padding: 0.75rem var(--wp--preset--spacing--50, min(6.5rem, 8vw));
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}

/* Brand / logo */
.reflex-mm__brand {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
	color: inherit;
	font-weight: 600;
	flex: 0 0 auto;
}
.reflex-mm__logo {
	display: block;
	height: auto;
	max-height: 40px;
	width: auto;
}

/* Top-level list */
.reflex-mm__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	gap: clamp(0.5rem, 1.5vw, 1.5rem);
}
.reflex-mm__item {
	margin: 0;
}

.reflex-mm__top-link {
	display: inline-flex;
	align-items: center;
	gap: 0.35em;
	padding: 0.5rem 0.25rem;
	font-size: var(--wp--preset--font-size--small, 0.9rem);
	font-weight: 500;
	line-height: 1.2;
	color: var(--reflex-mm-text);
	text-decoration: none;
	background: none;
	border: 0;
	cursor: pointer;
}
.reflex-mm__top-link:hover .reflex-mm__top-label,
.reflex-mm__top-link:focus-visible .reflex-mm__top-label {
	text-decoration: underline;
	text-underline-offset: 0.25em;
}

/* Caret */
.reflex-mm__caret {
	width: 0.42em;
	height: 0.42em;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: translateY(-0.12em) rotate(45deg);
	transition: transform 0.2s ease;
}
.reflex-mm__item--mega.is-open .reflex-mm__caret {
	transform: translateY(0.08em) rotate(225deg);
}

/* Hidden-until-JS toggle button (sits next to the link on touch/mobile) */
.reflex-mm__toggle {
	display: none;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	min-height: 44px;
	padding: 0;
	background: none;
	border: 0;
	color: inherit;
	cursor: pointer;
}

/* ---- Panel ------------------------------------------------------------- */
.reflex-mm__panel {
	background: var(--reflex-mm-bg);
}
.reflex-mm__panel-inner {
	padding: clamp(1.25rem, 3vw, 2rem);
}

.reflex-mm__columns {
	display: grid;
	gap: clamp(1rem, 3vw, 2.5rem);
}
.reflex-mm__col-heading {
	margin: 0 0 0.75rem;
	font-family: var(--reflex-mm-heading-font);
	font-size: var(--wp--preset--font-size--medium, 1.05rem);
	font-weight: 600;
	color: var(--reflex-mm-text);
}
.reflex-mm__col-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.35rem;
}

/* Item card: icon tile + title + description */
.reflex-mm__card {
	display: flex;
	align-items: flex-start;
	gap: 0.85rem;
	padding: 0.6rem;
	border-radius: var(--reflex-mm-radius);
	text-decoration: none;
	color: inherit;
	transition: background-color 0.15s ease;
}
.reflex-mm__card:hover,
.reflex-mm__card:focus-visible {
	background: var(--reflex-mm-page);
}
.reflex-mm__card:hover .reflex-mm__card-title,
.reflex-mm__card:focus-visible .reflex-mm__card-title {
	text-decoration: underline;
	text-underline-offset: 0.2em;
}

.reflex-mm__tile {
	flex: 0 0 auto;
	width: 44px;
	height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: var(--reflex-mm-tile-radius);
	color: var(--reflex-mm-primary); /* icon colour (SVGs use currentColor) */
}
.reflex-mm__tile svg {
	width: 22px;
	height: 22px;
}

/* Pastel brand tile backgrounds with the brand-purple icon. The purple icon
   keeps strong contrast on every tint (WCAG AA). */
.reflex-mm__tile[data-accent="purple"] { background: var(--reflex-mm-tint-purple); }
.reflex-mm__tile[data-accent="blue"]   { background: var(--reflex-mm-tint-blue); }
.reflex-mm__tile[data-accent="pink"]   { background: var(--reflex-mm-tint-pink); }
.reflex-mm__tile[data-accent="mint"]   { background: var(--reflex-mm-tint-mint); }

.reflex-mm__card-text {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
}
.reflex-mm__card-title {
	font-weight: 600;
	font-size: var(--wp--preset--font-size--small, 0.9rem);
	color: var(--reflex-mm-text);
	line-height: 1.3;
}
.reflex-mm__card-desc {
	font-size: 0.8rem;
	color: var(--reflex-mm-muted);
	line-height: 1.45;
}

/* CTA row pinned at the bottom of the panel */
.reflex-mm__cta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	gap: 1.25rem;
	margin-top: clamp(1rem, 3vw, 1.75rem);
	padding-top: 1rem;
	border-top: 1px solid color-mix(in srgb, var(--reflex-mm-hairline) 45%, transparent);
}
.reflex-mm__cta-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.4em;
	padding: 0.6rem 1rem;
	border-radius: var(--reflex-mm-radius);
	background: var(--reflex-mm-primary);
	color: #ffffff;
	font-size: var(--wp--preset--font-size--small, 0.9rem);
	font-weight: 500;
	text-decoration: none;
	transition: background-color 0.15s ease;
}
.reflex-mm__cta-btn:hover,
.reflex-mm__cta-btn:focus-visible {
	background: var(--reflex-mm-primary-hover);
}
.reflex-mm__cta-link {
	display: inline-flex;
	align-items: center;
	gap: 0.4em;
	color: var(--reflex-mm-primary);
	font-size: var(--wp--preset--font-size--small, 0.9rem);
	font-weight: 500;
	text-decoration: none;
}
.reflex-mm__cta-link:hover,
.reflex-mm__cta-link:focus-visible {
	text-decoration: underline;
	text-underline-offset: 0.2em;
}
.reflex-mm__arrow::after { content: "\2192"; }

/* Burger (hamburger) button — revealed by JS on small screens */
.reflex-mm__burger {
	display: none;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	min-height: 44px;
	padding: 0;
	background: none;
	border: 0;
	color: inherit;
	cursor: pointer;
}
.reflex-mm__burger-box {
	position: relative;
	display: block;
	width: 24px;
	height: 2px;
}
.reflex-mm__burger-bar,
.reflex-mm__burger-bar::before,
.reflex-mm__burger-bar::after {
	position: absolute;
	left: 0;
	width: 24px;
	height: 2px;
	background: currentColor;
	transition: transform 0.2s ease, opacity 0.2s ease;
}
.reflex-mm__burger-bar { top: 0; }
.reflex-mm__burger-bar::before { content: ""; top: -7px; }
.reflex-mm__burger-bar::after  { content: ""; top: 7px; }
.reflex-megamenu.reflex-mm--nav-open .reflex-mm__burger-bar { background: transparent; }
.reflex-megamenu.reflex-mm--nav-open .reflex-mm__burger-bar::before { transform: translateY(7px) rotate(45deg); }
.reflex-megamenu.reflex-mm--nav-open .reflex-mm__burger-bar::after  { transform: translateY(-7px) rotate(-45deg); }

/* Visually-hidden text */
.reflex-megamenu .screen-reader-text {
	position: absolute !important;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden; clip: rect(0,0,0,0);
	white-space: nowrap; border: 0;
}

/* ======================================================================= */
/* DESKTOP (>= 900px): hover/focus mega panel                              */
/* ======================================================================= */
@media (min-width: 900px) {
	.reflex-mm__columns {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
	/* Column dividers, like the reference design */
	.reflex-mm__column + .reflex-mm__column {
		padding-left: clamp(1rem, 3vw, 2.5rem);
		border-left: 1px solid color-mix(in srgb, var(--reflex-mm-hairline) 40%, transparent);
	}

	.reflex-mm__panel {
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		margin-top: 0.5rem;
		border: 1px solid color-mix(in srgb, var(--reflex-mm-hairline) 35%, transparent);
		border-radius: var(--reflex-mm-radius);
		box-shadow: 0 18px 40px -20px rgba(17, 17, 17, 0.35);
		opacity: 0;
		visibility: hidden;
		transform: translateY(8px);
		transition: opacity 0.18s ease, transform 0.18s ease, visibility 0s linear 0.18s;
		pointer-events: none;
		z-index: 50;
	}

	/* No-JS pointer users: reveal on hover. JS users: reveal on .is-open. */
	.reflex-mm__item--mega:hover > .reflex-mm__panel,
	.reflex-mm__item--mega.is-open > .reflex-mm__panel {
		opacity: 1;
		visibility: visible;
		transform: translateY(0);
		transition: opacity 0.18s ease, transform 0.18s ease;
		pointer-events: auto;
	}
}

/* ======================================================================= */
/* MOBILE (< 900px): burger + accordion                                    */
/* ======================================================================= */
@media (max-width: 899px) {
	.reflex-mm__inner {
		flex-wrap: wrap;
	}
	.reflex-mm__list {
		flex-direction: column;
		align-items: stretch;
		width: 100%;
		gap: 0;
	}
	.reflex-mm__item {
		border-top: 1px solid color-mix(in srgb, var(--reflex-mm-hairline) 35%, transparent);
	}
	.reflex-mm__item--mega {
		display: grid;
		grid-template-columns: 1fr auto;
		align-items: center;
	}
	.reflex-mm__top-link {
		padding: 0.9rem 0.25rem;
		font-size: var(--wp--preset--font-size--medium, 1.05rem);
	}
	.reflex-mm__caret { display: none; } /* the toggle button carries state on mobile */

	.reflex-mm__panel-inner { padding: 0 0.25rem 1rem; }
	.reflex-mm__columns { grid-template-columns: 1fr; gap: 1rem; }
	.reflex-mm__cta { justify-content: flex-start; }

	/* Interactive states only apply once JS has upgraded the menu. */
	.reflex-megamenu.reflex-mm--js .reflex-mm__burger { display: inline-flex; }

	.reflex-megamenu.reflex-mm--js .reflex-mm__list {
		display: none;
	}
	.reflex-megamenu.reflex-mm--js.reflex-mm--nav-open .reflex-mm__list {
		display: flex;
	}

	.reflex-megamenu.reflex-mm--js .reflex-mm__toggle {
		display: inline-flex;
		grid-column: 2;
	}

	/* Accordion: collapse panels with a smooth grid-rows transition. */
	.reflex-megamenu.reflex-mm--js .reflex-mm__panel {
		grid-column: 1 / -1;
		display: grid;
		grid-template-rows: 0fr;
		transition: grid-template-rows 0.25s ease;
	}
	.reflex-megamenu.reflex-mm--js .reflex-mm__item--mega.is-open > .reflex-mm__panel {
		grid-template-rows: 1fr;
	}
	.reflex-megamenu.reflex-mm--js .reflex-mm__panel > .reflex-mm__panel-inner {
		overflow: hidden;
		min-height: 0;
	}
	/* Mobile toggle caret indicator */
	.reflex-mm__toggle::after {
		content: "";
		width: 0.5em;
		height: 0.5em;
		border-right: 2px solid currentColor;
		border-bottom: 2px solid currentColor;
		transform: rotate(45deg);
		transition: transform 0.2s ease;
	}
	.reflex-mm__item--mega.is-open .reflex-mm__toggle::after {
		transform: translateY(0.15em) rotate(225deg);
	}
}

/* ======================================================================= */
/* Reduced motion                                                          */
/* ======================================================================= */
@media (prefers-reduced-motion: reduce) {
	.reflex-megamenu *,
	.reflex-megamenu *::before,
	.reflex-megamenu *::after {
		transition-duration: 0.001ms !important;
		animation-duration: 0.001ms !important;
	}
}
