/**
 * MASE Theme — assets/css/style.css
 * Front-end styles. All colour values use CSS custom properties.
 */


/* ============================================================
   DESIGN TOKENS
============================================================ */

:root {
	/* Brand colour aliases - single source of truth is theme.json palette (--wp--preset--color--*).
	   Component-scoped colours (bg-subtle, highlight panel) live with the mase-blocks
	   plugin, which self-defines them via var() fallbacks. */
	--color-primary:       var(--wp--preset--color--primary);
	--color-primary-hover: var(--wp--preset--color--primary-hover);
	--color-heading:       var(--wp--preset--color--heading);
	--color-body:          var(--wp--preset--color--body);
	--color-secondary:     var(--wp--preset--color--secondary);
	--color-bg:            var(--wp--preset--color--bg);
	--color-border:        var(--wp--preset--color--border);
	--color-text-dark:     var(--wp--preset--color--text-dark);
	--color-text-mid:      var(--wp--preset--color--text-mid);
	--color-text-muted:    var(--wp--preset--color--text-muted);
	--color-rule:          var(--wp--preset--color--rule);
	--color-footer-bg:     var(--wp--preset--color--footer-bg);

	/* Typography — MarkOT throughout */
	--font-body:    "MarkOT", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--font-heading: "MarkOT", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

	/* Spacing */
	--space-xs:  0.5rem;
	--space-sm:  1rem;
	--space-md:  1.5rem;
	--space-lg:  2rem;
	--space-xl:  3rem;
	--space-2xl: 4rem;
	--space-3xl: 6rem;

	/* Border radius */
	--radius-sm: 2px;
	--radius-md: 4px;

	/* Header — MASE-SPECIFIC
	   Content-driven height: logo + padding + nav row define the height naturally.
	   --header-height is a fallback; JS measures the actual rendered height and
	   overwrites it so sticky subnav top and content offset are always accurate. */
	--header-transition: 0.3s ease;
	--header-height:     84px; /* fallback for mobile/tablet — overwritten by JS after render */
}

/* Desktop fallback — matches the measured ~134px rendered header so the
   pre-JS paint and post-JS measurement differ by < 2px, eliminating the
   visible snap on refresh. JS still refines to the precise pixel value. */
@media (min-width: 1024px) {
	:root {
		--header-height: 134px;
	}
}


/* ============================================================
   FONTS — MarkOT (self-hosted)
============================================================ */

@font-face {
	font-family: "MarkOT";
	src: url("../fonts/MarkOT-Regular.woff2") format("woff2"),
	     url("../fonts/MarkOT-Regular.woff")  format("woff");
	font-weight: 400;
	font-style:  normal;
	font-display: swap;
}

@font-face {
	font-family: "MarkOT";
	src: url("../fonts/MarkOT-Medium.woff2") format("woff2"),
	     url("../fonts/MarkOT-Medium.woff")  format("woff");
	font-weight: 500;
	font-style:  normal;
	font-display: swap;
}

@font-face {
	font-family: "MarkOT";
	src: url("../fonts/MarkOT-Heavy.woff2") format("woff2"),
	     url("../fonts/MarkOT-Heavy.woff")  format("woff");
	font-weight: 700;
	font-style:  normal;
	font-display: swap;
}


/* ============================================================
   BASE RESET
============================================================ */

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

html {
	scroll-padding-top: calc(
		var(--header-height) +
		var(--wp-admin--admin-bar--height, 0px) +
		0.5rem
	);
}

body {
	background-color: var(--color-bg);
	color: var(--color-body);
	font-family: var(--font-body);
	font-size: 16px;
	line-height: 1.6;
	font-weight: 400;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	margin: 0;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-heading);
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.1;
	margin-top: 0;
}

h1, h2, h3 { color: var(--color-primary-hover); }
h4, h5, h6 { color: var(--color-heading); }

h1 { font-size: 2.125rem; text-transform: uppercase; }
h2 { font-size: 1.75rem; text-transform: uppercase; }
h3 { font-size: 1.25rem; }
h4 { font-size: 1.125rem; }
h5 { font-size: 1rem; }
h6 { font-size: 0.875rem; }

/* Override WP's is-layout blockGap (margin-block-start: 2rem) for paragraphs.
   :root prefix = specificity (0,1,1) which beats WP's (0,1,0). */
:root p {
	margin-block-start: 0.75em;
	margin-block-end: 0;
}

strong, b {
	font-family: var(--font-body);
	font-weight: 500;
}

a {
	color: var(--color-primary);
	text-decoration: underline;
}

/* Generic link hover — scoped to exclude button links, which have their
   own hover treatment (background change to darker teal, text stays white). */
a:not(.wp-block-button__link):hover {
	color: var(--color-primary-hover);
}

img {
	max-width: 100%;
	height: auto;
}


/* ============================================================
   POST CONTENT — FIRST CHILD FLUSH
   WP's block layout engine injects:
     :where(.wp-site-blocks) > * { margin-block-start: var(--spacing-lg) }
   via inline <style>, adding a gap between header and <main>.
   Zero it out at each nesting level so a full-width hero sits flush.
============================================================ */

/* Gap between header and main */
.wp-site-blocks > main {
	margin-block-start: 0 !important;
}

/* Gap before post-content inside main */
main.wp-block-group > .wp-block-post-content {
	margin-block-start: 0 !important;
}

/* Gap before first block inside post-content (non-alignfull blocks) */
.wp-block-post-content > *:first-child {
	margin-block-start: 0 !important;
}

/* Top spacing for pages without a hero. Exempt full-bleed heroes (the mosaic-hero
   block AND a wp:cover hero, e.g. the home-hero) so they sit flush under the fixed
   header instead of picking up the xl content margin. */
.wp-block-post-content > *:first-child:not(.wp-block-vl-mosaic-hero):not(.wp-block-cover),
.entry-content > *:first-child:not(.wp-block-vl-mosaic-hero):not(.wp-block-cover) {
	margin-block-start: var(--wp--preset--spacing--xl) !important;
}

/* Ensure mosaic hero stays flush when it IS the first element */
.wp-block-post-content > .wp-block-vl-mosaic-hero:first-child,
.entry-content > .wp-block-vl-mosaic-hero:first-child {
	margin-block-start: 0 !important;
}



/* ============================================================
   CONTENT OFFSET FOR FIXED HEADER
============================================================ */

.wp-site-blocks {
	padding-top: var(--header-height) !important;
}


/* ============================================================
   HEADER — FIXED SHELL
============================================================ */

.mase-header {
	position: fixed;
	top: var(--wp-admin--admin-bar--height, 0px);
	left: 0;
	right: 0;
	z-index: 100;
	background-color: var(--color-bg);
	border-bottom: 1px solid var(--color-border);
	transition: box-shadow var(--header-transition);
}

.mase-header.is-shrunk {
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
	border-bottom-color: transparent;
}

.mase-header.wp-block-template-part {
	padding: 0;
	margin: 0;
}


/* ============================================================
   HEADER — INNER WRAPPER (column on desktop, row on mobile)
============================================================ */

.mase-header__inner {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	width: 100%;
	padding: 0;
}

/* Override WP block group gap */
.mase-header__inner.wp-block-group {
	gap: 0;
}


/* ============================================================
   HEADER — LOGO ROW (row 1)
============================================================ */

.mase-header__logo-row,
.mase-header__logo-row.wp-block-group {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	padding: 0 1.5rem;
	transition: padding var(--header-transition);
	gap: 0;
}

/* Shrunk: reduce logo row padding */
.mase-header.is-shrunk .mase-header__logo-row,
.mase-header.is-shrunk .mase-header__logo-row.wp-block-group {
	padding-block: 0.5rem;
}

/* Header logo — wp:site-logo block (per-site logo set in Site Editor).
   Legacy .mase-header__logo-* selectors retained for the wp:html fallback so
   either logo mechanism renders identically on the shared theme. */
.mase-header__logo-link,
.mase-header .wp-block-site-logo,
.mase-header .wp-block-site-logo .custom-logo-link {
	display: block;
	line-height: 0;
	text-decoration: none;
	flex-shrink: 0;
}

.mase-header__logo-img,
.mase-header .wp-block-site-logo img {
	display: block;
	height: 88px;
	width: auto;
	max-width: 340px;
	transition: height var(--header-transition);
}

.mase-header.is-shrunk .mase-header__logo-img,
.mase-header.is-shrunk .wp-block-site-logo img {
	height: 50px;
}

/* Site-title text fallback (when no logo image uploaded).
   Styled to visually match the osmaselogo.png appearance. */
.mase-header .wp-block-site-title {
	margin: 0;
	line-height: 1;
}

.mase-header .wp-block-site-title a,
.mase-header .wp-block-site-title a:visited {
	font-family: var(--font-heading);
	font-size: 2.5rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--color-primary);
	text-decoration: none;
}

.mase-header .wp-block-site-tagline {
	font-size: 0.6875rem;
	font-weight: 400;
	text-transform: uppercase;
	letter-spacing: 0.22em;
	color: var(--color-heading);
	margin: 0.25rem 0 0;
	text-align: center;
}


/* ============================================================
   HEADER — NAV ROW (row 2, desktop only)
============================================================ */

/* Kill any is-layout-flow margin-block WordPress generates on header children */
.mase-header .wp-block-group > *,
.mase-header__inner > * {
	margin-block: 0 !important;
}

.mase-header__nav-row {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	border-top: none;
}

.mase-header__nav-row.wp-block-group {
	padding: 0;
	gap: 0;
}

/* Navigation block fills the row */
.mase-header__nav-row .wp-block-navigation {
	width: 100%;
	margin: 0;
}


/* ============================================================
   HEADER — MOBILE LAYOUT (< 1250px)
   Collapses to a single flex row: logo left, hamburger right.
============================================================ */

@media (max-width: 1249px) {
	/* __inner is the positioning context for the absolutely-placed hamburger.
	   Do NOT set position: relative on .mase-header — that would override
	   position: fixed and cause the header to scroll with the page. */
	.mase-header__inner,
	.mase-header__inner.wp-block-group {
		display: block !important;
		position: relative;
		padding: 0;
	}

	/* Logo row fills the header width and sets the header height on mobile */
	.mase-header__logo-row,
	.mase-header__logo-row.wp-block-group {
		display: flex;
		align-items: center;
		justify-content: flex-start !important;
		padding: 0.875rem var(--space-md);
		width: 100%;
		box-sizing: border-box;
		/* Reserve space on right for the absolutely-positioned hamburger */
		padding-right: calc(var(--space-md) + 60px);
	}

	/* Hamburger pinned to right edge, vertically centred within __inner */
	.mase-header__nav-row,
	.mase-header__nav-row.wp-block-group {
		position: absolute;
		top: 0;
		right: var(--space-md);
		bottom: 0;
		width: auto;
		display: flex;
		align-items: center;
		border-top: none;
		padding: 0;
	}

	.mase-header .wp-block-site-logo img {
		max-height: 44px;
	}

	.mase-header.is-shrunk .mase-header__logo-row,
	.mase-header.is-shrunk .mase-header__logo-row.wp-block-group {
		padding-top: 0.625rem;
		padding-bottom: 0.625rem;
	}
}


/* ============================================================
   HEADER — NAV BREAKPOINT OVERRIDE
   Force hamburger mode for all widths below 1250px.
   WP's default only kicks in below 600px — we extend it upward.
============================================================ */

@media (max-width: 1249px) {
	.mase-header .wp-block-navigation__responsive-container-open:not(.always-shown) {
		display: flex !important;
	}
	.mase-header .wp-block-navigation__responsive-container:not(.is-menu-open):not(.hidden-by-default) {
		display: none !important;
	}
}

@media (min-width: 1250px) {
	.mase-header .wp-block-navigation__responsive-container-open,
	.mase-header .wp-block-navigation__responsive-container-close {
		display: none !important;
	}
	.mase-header .wp-block-navigation__responsive-container:not(.is-menu-open) {
		display: flex !important;
		position: static !important;
		background: none !important;
		height: auto !important;
		width: 100% !important;
		overflow: visible !important;
	}
	.mase-header .wp-block-navigation__responsive-container-content {
		display: flex !important;
		justify-content: center;
		align-items: center;
		width: 100%;
	}
}


/* ============================================================
   HEADER — DESKTOP NAV ITEMS (centred, all-caps, evenly spaced)
============================================================ */

.mase-header .wp-block-navigation,
.mase-header .wp-block-navigation__container,
.mase-header nav,
.mase-header .wp-block-navigation-item {
	border: none !important;
	outline: none !important;
	box-shadow: none !important;
	padding-top: 0;
	padding-bottom: 0;
}

.mase-header .wp-block-navigation__container {
	display: flex;
	align-items: center;
	justify-content: center;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 1.5rem;
	width: 100%;
}

.mase-header .wp-block-navigation-item__content {
	display: inline-flex;
	align-items: center;
	padding: 0.75rem 0;
	color: var(--color-body);
	font-family: var(--font-body);
	font-size: 13px;
	font-weight: 400;
	text-transform: uppercase;
	letter-spacing: 0;
	text-decoration: none;
	white-space: nowrap;
	transition: color 0.2s ease;
	position: relative;
}

/* Hidden underline bar — shown on hover and active */
.mase-header .wp-block-navigation-item__content::after {
	content: '';
	position: absolute;
	bottom: -1px;
	left: 0;
	width: 100%;
	height: 3px;
	background-color: var(--color-primary);
	opacity: 0;
	transition: opacity 0.15s;
}

/* Hover — !important beats WP core navigation stylesheet. */
.mase-header .wp-block-navigation-item__content:hover {
	color: var(--color-primary) !important;
}

.mase-header .wp-block-navigation-item__content:hover::after {
	opacity: 1;
}

/* Active/current — registered menu (current-menu-item on <li>) */
.mase-header .wp-block-navigation-item.current-menu-item > .wp-block-navigation-item__content,
.mase-header .wp-block-navigation-item.current-menu-ancestor > .wp-block-navigation-item__content {
	color: var(--color-primary) !important;
}

.mase-header .wp-block-navigation-item.current-menu-item > .wp-block-navigation-item__content::after,
.mase-header .wp-block-navigation-item.current-menu-ancestor > .wp-block-navigation-item__content::after {
	opacity: 1;
}

/* Active/current — block links fallback (aria-current="page" on <a>) */
.mase-header .wp-block-navigation-item__content[aria-current="page"] {
	color: var(--color-primary) !important;
}

.mase-header .wp-block-navigation-item__content[aria-current="page"]::after {
	opacity: 1;
}

/* Suppress ::after on submenu items */
.mase-header .wp-block-navigation__submenu-container .wp-block-navigation-item__content::after {
	display: none;
}

/* Non-clickable parent items */
.mase-header .wp-block-navigation-item.has-child > a[href="#"],
.mase-header .wp-block-navigation-item.has-child > .wp-block-navigation-item__content[href="#"] {
	cursor: default;
	pointer-events: none;
	color: var(--color-text-muted);
}


/* ============================================================
   HEADER — SUBMENU DROPDOWN
============================================================ */

.mase-header .wp-block-navigation-item.has-child {
	position: relative;
}

.mase-header .wp-block-navigation__submenu-container {
	position: absolute;
	top: 100%;
	left: 0;
	z-index: 200;
	min-width: auto;
	background-color: var(--color-bg);
	border: none;
	box-shadow: 0 8px 15px rgba(0, 0, 0, 0.1);
	list-style: none;
	margin: 0;
	padding: 0.375rem 0;
	opacity: 0;
	visibility: hidden;
	transform: translateY(4px);
	transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
}

.mase-header .wp-block-navigation-item.has-child:hover > .wp-block-navigation__submenu-container,
.mase-header .wp-block-navigation-item.has-child:focus-within > .wp-block-navigation__submenu-container {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.mase-header .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
	display: block;
	padding: 0.5rem 0.9375rem;
	font-size: 0.75rem;
	font-weight: 400;
	text-transform: none;
	letter-spacing: 0;
	text-decoration: none;
	color: var(--color-primary);
	width: 100%;
	border-bottom: none;
}

.mase-header .wp-block-navigation__submenu-container .wp-block-navigation-item__content:hover {
	color: var(--color-primary-hover);
	background-color: var(--color-bg);
}

/* Chevron — visible on desktop, tight to text */
.mase-header .wp-block-navigation__submenu-icon {
	display: inline-flex;
	margin-left: 2px;
	width: 12px;
	height: 12px;
	opacity: 0.6;
}

.mase-header .wp-block-navigation__submenu-icon svg {
	width: 12px;
	height: 12px;
}


/* ============================================================
   HEADER — MOBILE DRAWER  (< 1250px)
   Slide-in panel from the right, with backdrop overlay.
============================================================ */

/* Scroll lock — prevent page scrolling while drawer is open */
body:has(.wp-block-navigation__responsive-container.is-menu-open) {
	overflow: hidden;
}

@media (max-width: 1249px) {

	/* Remove our ::before backdrop — WP provides its own via responsive-close */
	.mase-header .wp-block-navigation__responsive-container.is-menu-open::before {
		display: none !important;
	}

	/* WP's built-in backdrop — style it as our overlay */
	.mase-header .wp-block-navigation__responsive-close {
		position: fixed !important;
		inset: 0 !important;
		background: rgba(0, 0, 0, 0.4) !important;
		z-index: 9998 !important;
	}

	/* The dialog panel — this is the actual white drawer.
	   padding-top reserves the header-equivalent area so menu items
	   don't sit underneath the fixed-position close button above. */
	.mase-header .wp-block-navigation__responsive-dialog {
		position: fixed !important;
		top: 0 !important;
		right: 0 !important;
		bottom: 0 !important;
		left: auto !important;
		width: 320px !important;
		max-width: 85vw !important;
		height: 100dvh !important;
		background: var(--color-bg) !important;
		z-index: 9999 !important;
		overflow-y: auto !important;
		padding: var(--header-height) 1.5rem 1.5rem !important;
		box-shadow: -4px 0 24px rgba(0, 0, 0, 0.15) !important;
		animation: mase-drawer-in 0.25s ease-out !important;
		display: flex !important;
		flex-direction: column !important;
	}

	@keyframes mase-drawer-in {
		from { transform: translateX(100%); }
		to   { transform: translateX(0); }
	}

	/* Reset the container itself — no longer the drawer */
	body .mase-header .wp-block-navigation__responsive-container.is-menu-open {
		position: fixed !important;
		inset: 0 !important;
		width: 100% !important;
		height: 100% !important;
		background: none !important;
		z-index: 9998 !important;
		box-shadow: none !important;
		padding: 0 !important;
		animation: none !important;
		overflow: visible !important;
	}

	/* Close button — pinned to the hamburger's screen position.
	   Fixed-positioned over the header area so the X appears exactly
	   where the hamburger was, not inside the drawer's flex flow. */
	.mase-header .wp-block-navigation__responsive-container-close {
		position: fixed !important;
		top: 0 !important;
		right: var(--space-md) !important;
		bottom: auto !important;
		left: auto !important;
		height: var(--header-height) !important;
		margin: 0 !important;
		padding: 0 !important;
		display: flex !important;
		align-items: center !important;
		justify-content: flex-end !important;
		z-index: 10000 !important;
		flex-shrink: 0 !important;
	}

	.mase-header .wp-block-navigation__responsive-container-close button {
		background: none !important;
		border: 1px solid var(--color-border) !important;
		border-radius: 4px !important;
		padding: 0.5rem !important;
		cursor: pointer !important;
		color: var(--color-heading) !important;
		width: 40px !important;
		height: 40px !important;
		display: flex !important;
		align-items: center !important;
		justify-content: center !important;
	}

	.mase-header .wp-block-navigation__responsive-container-close button:hover {
		border-color: var(--color-primary) !important;
		color: var(--color-primary) !important;
	}

	/* Nav container inside dialog */
	.mase-header .is-menu-open .wp-block-navigation__container {
		flex-direction: column !important;
		align-items: stretch !important;
		justify-content: flex-start !important;
		gap: 0 !important;
	}

	/* Nav items */
	.mase-header .is-menu-open .wp-block-navigation-item__content {
		display: block !important;
		width:100%!important;
		padding: 0.75rem 0 !important;
		font-size: 0.9375rem !important;
		font-weight: 500 !important;
		color: var(--color-body) !important;
		text-transform: none !important;
		letter-spacing: normal !important;
		text-decoration: none !important;
		border-bottom: 1px solid var(--color-rule) !important;
	}

	.mase-header .is-menu-open .wp-block-navigation-item__content::after {
		display: none !important;
	}

	.mase-header .is-menu-open .wp-block-navigation-item:last-child
	> .wp-block-navigation-item__content {
		border-bottom: none !important;
	}

	.mase-header .is-menu-open .wp-block-navigation-item.current-menu-item
	> .wp-block-navigation-item__content {
		color: var(--color-primary) !important;
		font-weight: 600 !important;
	}

	.mase-header .is-menu-open .wp-block-navigation-item__content:hover {
		color: var(--color-primary) !important;
	}

	/* Submenu */
	.mase-header .is-menu-open .wp-block-navigation__submenu-container {
		display: none !important;
		position: static !important;
		box-shadow: none !important;
		border: none !important;
		padding: 0 0 0 1rem !important;
		background: none !important;
		min-width: 0 !important;
	}

	.mase-header .is-menu-open
	.wp-block-navigation-submenu__toggle[aria-expanded="true"]
	~ .wp-block-navigation__submenu-container {
		display: block !important;
	}

}


/* ============================================================
   MOBILE DRAWER — GLOBAL OPEN STATE
   Applied at any viewport width when drawer is open.
   Must be outside media queries..
============================================================ */

/* Toggle chevron — show whenever drawer is open */
.mase-header .is-menu-open .wp-block-navigation-submenu__toggle {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	background: none !important;
	border: none !important;
	cursor: pointer !important;
	color: var(--color-primary) !important;
	padding: 0.5rem !important;
	margin-left: auto !important;
	flex-shrink: 0 !important;
	opacity: 1 !important;
	width: 40px !important;
	height: 40px !important;
	transition: transform 0.2s ease !important;
}

.mase-header .is-menu-open
.wp-block-navigation-submenu__toggle[aria-expanded="true"] {
	transform: rotate(180deg) !important;
}

/* Parent has-child — flex row so chevron sits right of label */
.mase-header .is-menu-open .wp-block-navigation-item.has-child {
	width: 100% !important;
	display: flex !important;
	flex-direction: row !important;
	flex-wrap: wrap !important;
	align-items: center !important;
	border-bottom: 1px solid var(--color-rule) !important;
}

.mase-header .is-menu-open .wp-block-navigation-item.has-child
> .wp-block-navigation-item__content {
	flex: 1 1 auto !important;
	border-bottom: none !important;
	width: auto !important;
	padding: 0.75rem 0 !important;
	pointer-events: none !important;
}

.mase-header .is-menu-open .wp-block-navigation-item.has-child
> .wp-block-navigation-submenu__toggle {
	flex: 0 0 auto !important;
	margin-left: 0 !important;
}

.mase-header .is-menu-open .wp-block-navigation-item.has-child
> .wp-block-navigation__submenu-container {
	flex: 0 0 100% !important;
	width: 100% !important;
	display: none !important;
	position: static !important;
	padding: 0 0 0.5rem 1rem !important;
	box-shadow: none !important;
	border: none !important;
	background: none !important;
	min-width: 0 !important;
}

.mase-header .is-menu-open
.wp-block-navigation-submenu__toggle[aria-expanded="true"]
~ .wp-block-navigation__submenu-container {
	display: block !important;
}

/* Full-width dividers on ALL nav items via <li> not <a> */
.mase-header .is-menu-open .wp-block-navigation-item {
	border-bottom: 1px solid var(--color-rule) !important;
	width: 100% !important;
}

.mase-header .is-menu-open .wp-block-navigation-item:last-child {
	border-bottom: none !important;
}

/* Remove border from <a> — border is now on <li> */
.mase-header .is-menu-open .wp-block-navigation-item__content {
	border-bottom: none !important;
}

/* Chevron SVG */
.mase-header .is-menu-open .wp-block-navigation-submenu__toggle svg {
	width: 18px !important;
	height: 18px !important;
	stroke: currentColor !important;
	fill: none !important;
}

.mase-header .is-menu-open .wp-block-navigation-submenu__toggle svg path {
	stroke: currentColor !important;
	stroke-width: 2 !important;
}


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

.mase-footer {
	background-color: var(--color-text-dark);
	border-top: none;
	margin-top: 0;
	padding: 48px 0 32px;
}

.mase-footer__acknowledgment {
	text-align: center;
}

.mase-footer__ack-label {
	font-size: 0.8rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: rgba(255, 255, 255, 0.5);
	margin-block-end: 0.75rem;
}

.mase-footer__acknowledgment p:not(.mase-footer__ack-label) {
	font-size: 1rem;
}

/* Site-title used as footer logo placeholder */
.mase-footer__site-title {
	font-size: 2rem !important;
	font-weight: 700 !important;
	color: var(--color-primary) !important;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	text-align: center;
}

/* Footer logo image */
.mase-footer__logo-img {
	display: block;
	max-width: 350px;
	width: 100%;
	height: auto;
	margin: 0 auto;
	padding-left: 2.5rem;
	padding-right: 2.5rem;
}

/* Footer logo wrap */
.mase-footer__logo-wrap {
	margin-top: 0;
}

.mase-footer__rule {
	border-color: rgba(255, 255, 255, 0.15);
	margin-top: 8px;
	margin-bottom: 8px;
}

.mase-footer__bottom {
	font-size: 0.72rem;
	color: rgba(255, 255, 255, 0.7);
}

.mase-footer__bottom a {
	text-decoration: none;
}
.mase-footer__bottom a:hover {
	text-decoration: underline;
}


/* ============================================================
   CATEGORY PAGE — BLOCK GAP / ALIGNMENT OVERRIDES
   WordPress generates margin-block-end on all .is-layout-flow
   children from theme.json blockGap. Zero these out so the
   full-bleed alternating package rows sit flush with no gaps
============================================================ */

/* Zero out blockGap and all padding/margin on the category page so
   the hero sits flush under the fixed header, and subnav sits flush
   under the hero with no gap between any of the three elements. */
.mase-category-page {
	--wp--style--block-gap: 0 !important;
	padding: 0 !important;
	margin: 0 !important;
}

.mase-category-page.wp-block-group {
	padding: 0 !important;
	margin: 0 !important;
}

/* The post-template renders as a <ul> — reset all list styles and spacing */
.mase-category-page .wp-block-post-template {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
	max-width: none !important;
	width: 100% !important;
}

/* Each post-template <li> must be full-width with no gap */
.mase-category-page .wp-block-post-template > li {
	list-style: none;
	padding: 0 !important;
	margin: 0 !important;
	max-width: none !important;
	width: 100% !important;
}

/* Ensure our custom blocks are never constrained by WP layout system,
   and carry no block-gap margins */
.mase-category-page .wp-block-mase-menu-package,
.mase-category-page .wp-block-vl-mosaic-hero,
.mase-category-page .wp-block-mase-sticky-subnav {
	max-width: none !important;
	margin-inline: 0 !important;
	margin-block: 0 !important;
	width: 100% !important;
}

/* Inner query group — no constraint */
.mase-category-page .wp-block-group {
	max-width: none;
}

.mase-category-page .wp-block-query {
	width: 100%;
}


/* ============================================================
   BUTTON HOVER — STANDARDISED ACROSS ALL BUTTONS
   WordPress applies !important to .has-primary-background-color,
   which beats theme.json's :hover rule on the cascade. The only
   way to override a !important rule is with another !important.
   Trade-off: locks out per-instance hover overrides — acceptable
   since the design intent is all buttons hover to darker teal.
============================================================ */

.wp-block-button__link.wp-element-button:hover,
.wp-block-button__link.wp-element-button:focus {
	background-color: var(--color-primary-hover) !important;
	transition: background-color 0.2s ease;
}

.wp-block-button__link.wp-element-button {
	transition: background-color 0.2s ease;
}


/* ============================================================
   STANDARD PAGE LAYOUT — VERTICAL RHYTHM
   Adds breathing room around headings, images, and columns on
   regular pages (homepage, Our Story, Dietaries, etc.).
   Excludes taxonomy archives, which manage their own full-bleed
   layout via .tax-menu_category rules above.

   Works on bare core blocks — NO wrapper classes required.
   Editors just add headings/paragraphs/columns and the rhythm
   applies automatically.
============================================================ */

body:not(.tax-menu_category) main {
	--page-heading-space-top: clamp(2.5rem, 5vw, 4rem);
	--page-heading-space-bot: clamp(0.75rem, 1.5vw, 1.25rem);
	--page-section-gap:       clamp(2.5rem, 5vw, 4rem);
}

/* H1 — page title or hero heading */
body:not(.tax-menu_category) main h1.wp-block-heading {
	margin-block: clamp(3rem, 6vw, 5rem) var(--page-heading-space-bot);
}

/* H2 — section dividers */
body:not(.tax-menu_category) main h2.wp-block-heading {
	margin-block: var(--page-heading-space-top) var(--page-heading-space-bot);
}

/* H3 — sub-section headings */
body:not(.tax-menu_category) main h3.wp-block-heading {
	margin-block: clamp(1.5rem, 3vw, 2rem) 0.5rem;
}

/* Paragraphs — comfortable line-height, full content width */
body:not(.tax-menu_category) main p {
	line-height: 1.7;
}

/* Standalone images at top level — vertical breathing room */
body:not(.tax-menu_category) .wp-block-post-content > .wp-block-image,
body:not(.tax-menu_category) main > .wp-block-image {
	margin-block: var(--page-section-gap);
}

/* Mosaic hero at the top of post-content — always flush with header */
body:not(.tax-menu_category) .wp-block-post-content > .wp-block-vl-mosaic-hero:first-child {
	margin-block-start: 0;
}


/* ----- COLUMNS BLOCK — standard image + text row treatment -----
   Applies to any .wp-block-columns inside post-content, no custom
   class required. Used by Our Story chef rows, About pages, etc.
*/

body:not(.tax-menu_category) .wp-block-post-content .wp-block-columns {
	align-items: center;
	gap: clamp(2rem, 4vw, 3.5rem);
	margin-block: var(--page-section-gap);
}

/* Stacked column rows — extra space between adjacent rows */
body:not(.tax-menu_category) .wp-block-post-content .wp-block-columns + .wp-block-columns {
	margin-block-start: clamp(3rem, 5vw, 4rem);
}

/* Headings inside columns — left-aligned, no top margin (column context) */
body:not(.tax-menu_category) .wp-block-post-content .wp-block-columns h1.wp-block-heading,
body:not(.tax-menu_category) .wp-block-post-content .wp-block-columns h2.wp-block-heading,
body:not(.tax-menu_category) .wp-block-post-content .wp-block-columns h3.wp-block-heading {
	text-align: left;
	margin-block: 0 0.25rem;
}

/* Paragraphs inside columns — small bottom margin only */
body:not(.tax-menu_category) .wp-block-post-content .wp-block-columns p {
	margin-block: 0 0.75rem;
}

/* Images inside columns — fill column, no margin */
body:not(.tax-menu_category) .wp-block-post-content .wp-block-columns .wp-block-image {
	margin: 0;
}

body:not(.tax-menu_category) .wp-block-post-content .wp-block-columns .wp-block-image img {
	width: 100%;
	height: auto;
	display: block;
}

/* Buttons inside columns — spacing above CTA */
body:not(.tax-menu_category) .wp-block-post-content .wp-block-columns .wp-block-buttons {
	margin-block-start: 1.25rem;
}

/* Mobile — tighter gap when columns stack vertically */
@media (max-width: 781px) {
	body:not(.tax-menu_category) .wp-block-post-content .wp-block-columns {
		gap: 1.5rem;
	}

	body:not(.tax-menu_category) .wp-block-post-content .wp-block-columns h2.wp-block-heading {
		margin-block-start: 1rem;
	}

	/* Image-first stacking pattern on mobile.
	   When a row has its image in the second column on desktop (text-left
	   layout, e.g. Matt Moran's row), reorder so the image appears first
	   when stacked. Keeps the visual rhythm consistent down the page:
	   image → text, image → text, image → text. */
	body:not(.tax-menu_category) .wp-block-post-content .wp-block-columns:has(> .wp-block-column:last-child .wp-block-image):not(:has(> .wp-block-column:first-child .wp-block-image)) > .wp-block-column:first-child {
		order: 2;
	}
}


/* ----- LISTS — in-column lists and inline code emphasis -----
   Used by the Dietaries page (4-column allergen list, codes legend
   with <strong> abbreviations). Items in column-laid-out lists read
   as compact reference data, so they get medium-weight + teal styling.
   font-weight 500 matches the global strong/b baseline (MarkOT Medium).
*/

/* List items inside columns — treated as reference labels (allergens etc.) */
body:not(.tax-menu_category) .wp-block-post-content .wp-block-columns .wp-block-list li,
body:not(.tax-menu_category) .wp-block-post-content .wp-block-columns ul li {
	color: var(--color-primary);
	font-weight: 500;
}

/* Bullet markers — match the item colour so they don't look stranded */
body:not(.tax-menu_category) .wp-block-post-content .wp-block-columns .wp-block-list li::marker,
body:not(.tax-menu_category) .wp-block-post-content .wp-block-columns ul li::marker {
	color: var(--color-primary);
}

/* Inline code emphasis (e.g. <strong>LF</strong>, <strong>GF</strong>).
   font-weight inherits 500 from global strong/b rule — no override needed. */
body:not(.tax-menu_category) .wp-block-post-content li > strong:first-child,
body:not(.tax-menu_category) .wp-block-post-content li > b:first-child {
	color: var(--color-primary);
	display: inline-block;
	min-width: 2.25rem;
}

/* Compact column layout — lists only, no images.
   Detects "reference list" columns (like the dietaries allergens) and
   tightens the surrounding margins + inner gaps. Image-bearing column
   blocks (chef rows etc.) keep the generous default rhythm. */
body:not(.tax-menu_category) .wp-block-post-content .wp-block-columns:has(.wp-block-list):not(:has(.wp-block-image)) {
	margin-block: clamp(1rem, 2vw, 1.5rem);
	gap: clamp(1rem, 2vw, 2rem);
}


/* ============================================================
   SCROLL REVEAL — partner CSS for animations.js
   Auto-applied to top-level headings and column-row blocks.
   Mirrors the live Avia site's fade-up motion on scroll.
============================================================ */

.mase-reveal {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 0.7s cubic-bezier(0.2, 0.6, 0.2, 1),
	            transform 0.7s cubic-bezier(0.2, 0.6, 0.2, 1);
	will-change: opacity, transform;
}

.mase-reveal.is-revealed {
	opacity: 1;
	transform: translateY(0);
	will-change: auto;
}

@media (prefers-reduced-motion: reduce) {
	.mase-reveal,
	.mase-reveal.is-revealed {
		opacity: 1 !important;
		transform: none !important;
		transition: none !important;
	}
}


/* ============================================================
   PHONE BREAKPOINT (≤ 767px)
============================================================ */

@media (max-width: 767px) {

	/* Logo — constrain at phone width */
	.mase-header__logo-img,
	.mase-header .wp-block-site-logo img {
		max-width: 200px !important;
		height: auto !important;
	}

	/* Menu packages — single column, no indent */
	.mase-menu-package__inner {
		padding-inline: 1rem !important;
	}

	.mase-menu-package__columns {
		grid-template-columns: 1fr !important;
		display: block !important;
	}

	.mase-menu-package__left {
		padding: 1.5rem 0 1rem !important;
		border-right: none !important;
		border-bottom: 1px solid var(--color-rule) !important;
	}

	.mase-menu-package__right {
		padding: 1rem 0 1.5rem !important;
		padding-left: 0 !important;
	}

	.mase-menu-package__title {
		font-size: 1.75rem !important;
	}

}


/* ============================================================
   MOBILE CONTENT PADDING
   Standard pages (page, single, dietaries etc.) get no side
   padding from the block layout engine at narrow viewports.
   Exclude category archive pages which manage their own layout.
============================================================ */

@media (max-width: 1309px) {
	body:not(.tax-menu_category) .wp-block-post-content {
		padding-inline: 1.25rem;
	}

	/* Full-width blocks bleed back out of the padded post-content container */
	body:not(.tax-menu_category) .wp-block-post-content .wp-block-vl-mosaic-hero {
		margin-inline: -1.25rem;
		width: calc(100% + 2.5rem);
	}
}


/* ============================================================
   HEADING STYLE — PAGE TITLE
   is-style-page-title: dark teal uppercase label used as a
   section/page heading above body content.
============================================================ */

.wp-block-heading.is-style-page-title {
	text-transform: uppercase;
		color: var(--color-primary-hover);
}


/* ============================================================
   DIETARY / BRACKET INLINE CODES
   font-weight 500 (MarkOT Medium) matches the live site —
   reserved 700 for display elements, not body emphasis.
============================================================ */

.cm-dietary-code {
	font-size: 0.75rem;
	font-weight: 500;
	color: var(--color-primary);
	vertical-align: baseline;
}

.cm-bracket-code {
	font-size: 0.75rem;
	font-weight: 500;
	color: var(--color-heading);
	vertical-align: baseline;
}

/* Right panel — list items match body text size */
.mase-menu-package__right ul,
.mase-menu-package__right ol,
.mase-menu-package__right li {
	font-size: 1rem;
	line-height: 1.6;
	padding-bottom: 0.125rem;
}

/* Right panel — nested lists (dash bullets defined in plugin SCSS) */
.mase-menu-package__right li > ul {
	margin-top: 0.25rem;
	margin-bottom: 0.5rem;
}

/* Right panel — <strong> inside list items = dietary codes (bolded in WYSIWYG editor) */
.mase-block-content li strong,
.mase-block-content li b {
	font-size: 0.75rem;
	font-weight: 500;
	color: var(--color-primary);
	vertical-align: baseline;
}

/* Right panel — dietary/bracket codes inside lists (specificity fix) */
.mase-menu-package__right li .cm-dietary-code,
.mase-menu-package__right li ul li .cm-dietary-code {
	font-size: 0.75rem;
	font-weight: 500;
	color: var(--color-primary);
	vertical-align: baseline;
}

.mase-menu-package__right li .cm-bracket-code,
.mase-menu-package__right li ul li .cm-bracket-code {
	font-size: 0.75rem;
	font-weight: 500;
	color: var(--color-text-dark);
	vertical-align: baseline;
}

/* Right panel — inline strong/b inside paragraphs styled as teal sub-labels */
.mase-menu-package__right p > strong,
.mase-menu-package__right p > b {
	color: var(--color-primary);
	font-weight: 500;
}

/* Key section — item text size */
.mase-pkg-keys__item {
	font-size: 0.72rem;
}

/* Key section — dietary codes match inline dietary style */
.mase-pkg-keys__code {
	font-weight: 500;
	color: var(--color-primary);
}

/* Key section — seafood origin (last section) uses dark colour to match bracket codes */
.mase-pkg-keys__section:last-child .mase-pkg-keys__code {
	color: var(--color-heading);
}


/* ============================================================
   STICKY SUBNAV LINKS
============================================================ */

.mase-subnav__link {
	color: var(--color-primary);
	font-weight: 600;
	font-size: 0.9rem;
	letter-spacing: normal;
	text-decoration: none;
	white-space: nowrap;
	padding: 14px 0;
	transition: color 0.15s;
	border-bottom: none;
}

.mase-subnav__link:hover,
.mase-subnav__item.is-active .mase-subnav__link {
	color: var(--color-text-dark);
}

.mase-subnav__item.is-active .mase-subnav__link {
	font-weight: 700;
}

/* Accessibility: skip-link + screen-reader-text (VL-BUILD-STANDARDS 2.1a) */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	width: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	word-wrap: normal;
}
.skip-link:focus {
	clip: auto;
	clip-path: none;
	height: auto;
	width: auto;
	display: block;
	background: var(--color-primary);
	color: var(--color-bg);
	font-family: var(--font-heading);
	font-size: 0.9rem;
	font-weight: 700;
	left: 1rem;
	top: 1rem;
	padding: 0.75rem 1.25rem;
	text-decoration: none;
	z-index: 100001;
}

/* Skip-link is the first child of .wp-site-blocks, bumping the fixed header off
   :first-child - WP block-gap then adds an unwanted 24px margin above the header
   (a visible gap below the fixed header). The fixed header must never have a top margin. */
.wp-site-blocks > header.wp-block-template-part,
.wp-site-blocks > main { margin-block-start: 0 !important; }

/* ============================================================
   COVER HERO - VL fleet hero standard (2026-06)
   Viewport-relative cover-hero heights, governed by class. Home/event = impact
   tier; content pages = compact. The mase home hero is a wp:cover.home-hero
   (swapped from the single-image mosaic-hero). !important beats the cover
   block's inline minHeight; dvh avoids the mobile address-bar jump.
============================================================ */
.wp-site-blocks > .wp-block-cover.home-hero,
.wp-site-blocks > .wp-block-cover.page-hero,
.wp-site-blocks > .wp-block-cover.post-hero,
.wp-site-blocks > .wp-block-cover.event-hero {
	margin-block-start: 0 !important;
}

/* Impact (Tier 1) - home + event/key-landing heroes */
.wp-block-cover.home-hero,
.wp-block-cover.event-hero {
	min-height: clamp( 480px, 75dvh, 840px ) !important;
}

/* Compact (Tier 3) - standard content pages + posts */
.wp-block-cover.page-hero,
.wp-block-cover.post-hero {
	min-height: clamp( 260px, 45dvh, 460px ) !important;
}

/* Off-ratio creative that must show whole - letterbox (object-fit contain) */
.wp-block-cover.hero--contain .wp-block-cover__image-background {
	object-fit: contain !important;
}
.wp-block-cover.hero--contain .wp-block-cover__background {
	display: none;
}