/**
 * TOMS 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--*). */
	--color-primary:       var(--wp--preset--color--primary);
	--color-primary-hover: var(--wp--preset--color--primary-hover);
	--color-accent:        var(--wp--preset--color--accent);
	--color-bg-cream:      var(--wp--preset--color--bg-cream);
	--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);
	--color-footer-text:   var(--color-bg-cream);

	/* Typography */
	--font-heading:    "new-order", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--font-subheading: "geraldica-regular", Georgia, "Times New Roman", serif;
	--font-body:       -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, 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 */
	--header-transition: 0.3s ease;
	--header-height:     90px;
}


/* ============================================================
   FONTS — self-hosted
============================================================ */

@font-face {
	font-family: "new-order";
	src: url("../fonts/new-order-regular.woff2") format("woff2");
	font-weight: 400;
	font-style:  normal;
	font-display: swap;
}

@font-face {
	font-family: "new-order";
	src: url("../fonts/new-order-medium.woff2") format("woff2");
	font-weight: 500;
	font-style:  normal;
	font-display: swap;
}

@font-face {
	font-family: "new-order";
	src: url("../fonts/new-order-semibold.woff2") format("woff2");
	font-weight: 600;
	font-style:  normal;
	font-display: swap;
}

@font-face {
	font-family: "new-order";
	src: url("../fonts/new-order-bold.woff2") format("woff2");
	font-weight: 700;
	font-style:  normal;
	font-display: swap;
}

@font-face {
	font-family: "new-order";
	src: url("../fonts/new-order-light.woff2") format("woff2");
	font-weight: 300;
	font-style:  normal;
	font-display: swap;
}

@font-face {
	font-family: "geraldica-regular";
	src: url("../fonts/geraldica-regular.woff2") format("woff2");
	font-weight: 400;
	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-cream);
	color: var(--color-body);
	font-family: var(--font-heading);
	font-size: 17px;
	line-height: 1.65;
	font-weight: 400;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	margin: 0;
}

/* Headings — no uppercase, font-weight 500, primary green */
h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-heading);
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1.2;
	margin-top: 0;
	color: var(--color-heading);
	text-transform: none;
}

h1 { font-size: 2.125rem; }
h2 { font-size: 1.75rem; }
h3 { font-size: 1.25rem; }
h4 { font-size: 1.125rem; }
h5 { font-size: 1rem; }
h6 { font-size: 0.875rem; }

/* WP block headings */
.wp-block-heading {
	font-weight: 500 !important;
	text-transform: none !important;
	color: var(--color-heading);
}

/* Linked headings — remove underline and override link colour */
a .wp-block-heading,
.wp-block-heading a,
h1 a, h2 a, h3 a, h4 a, h5 a, h6 a {
	text-decoration: none !important;
	color: inherit !important;
}

/* Mixed-font headings: <span class="script"> inside heading renders geraldica.
   Only the span gets the script font — parent heading stays new-order. */
.wp-block-heading .script,
h1 .script, h2 .script, h3 .script, h4 .script {
	font-family: var(--font-subheading) !important;
	font-weight: 400 !important;
}

/* Override WP's is-layout blockGap for paragraphs */
:root p {
	margin-block-start: 0.75em;
	margin-block-end: 0;
}

strong, b {
	font-weight: 700;
}

a {
	color: var(--color-primary);
	text-decoration: underline;
}

a:hover {
	color: var(--color-primary-hover);
}

img {
	max-width: 100%;
	height: auto;
}


/* ============================================================
   POST CONTENT — FIRST CHILD FLUSH
============================================================ */

.wp-site-blocks > main {
	margin-block-start: 0 !important;
}

main.wp-block-group > .wp-block-post-content {
	margin-block-start: 0 !important;
}

.wp-block-post-content > *:first-child {
	margin-block-start: 0 !important;
	padding-block-start: 0 !important;
}

/* Top spacing for pages without a hero */
.wp-block-post-content > *:first-child:not(.wp-block-vl-mosaic-hero):not(.wp-block-cover):not(.wp-block-group):not([class*="slider"]):not([class*="hero"]),
.entry-content > *:first-child:not(.wp-block-vl-mosaic-hero):not(.wp-block-cover):not(.wp-block-group):not([class*="slider"]):not([class*="hero"]) {
	margin-block-start: var(--wp--preset--spacing--xl) !important;
}

/* Hero / cover / slider / group flush — all sit tight under header */
.wp-block-post-content > .wp-block-vl-mosaic-hero:first-child,
.entry-content > .wp-block-vl-mosaic-hero:first-child,
.wp-block-post-content > .wp-block-cover:first-child,
.entry-content > .wp-block-cover:first-child,
.wp-block-post-content > .wp-block-group:first-child,
.entry-content > .wp-block-group:first-child {
	margin-block-start: 0 !important;
	padding-block-start: 0 !important;
}

.wp-block-post-content > .wp-block-group:first-child .wp-block-cover,
.wp-block-post-content > .wp-block-group:first-child [class*="slider"],
.entry-content > .wp-block-group:first-child .wp-block-cover {
	margin-block-start: 0 !important;
	padding-block-start: 0 !important;
}

.wp-site-blocks > .wp-block-post-content > .wp-block-cover:first-child,
.wp-site-blocks > .wp-block-post-content > .wp-block-group:first-child {
	margin-top: 0 !important;
}


/* ============================================================
   MOSAIC HERO — PANEL LAYOUT
============================================================ */

.wp-block-vl-mosaic-hero {
	align-items: stretch;
}

.vl-mosaic-panel {
	display: flex;
	align-self: stretch;
}

.vl-mosaic-panel img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}


/* ============================================================
   CONTENT OFFSET FOR FIXED HEADER
============================================================ */

.wp-site-blocks {
	padding-top: var(--header-height) !important;
}

/* ============================================================
Slider
============================================================ */
.vl-hero-slider__logo {
  width: 520px;
}

/* ============================================================
   HEADER — FIXED SHELL
============================================================ */

.toms-header {
	position: fixed;
	top: var(--wp-admin--admin-bar--height, 0px);
	left: 0;
	right: 0;
	z-index: 100;
	background-color: var(--color-primary);
	transition: box-shadow var(--header-transition);
}

.toms-header.is-shrunk {
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.12);
}

.toms-header.wp-block-template-part {
	padding: 0;
	margin: 0;
}


/* ============================================================
   HEADER — INNER WRAPPER
============================================================ */

.toms-header__inner {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	max-width: var(--wp--style--global--content-size, 1310px);
	margin-inline: auto;
	padding: 0;
	min-height: 90px;
	transition: min-height var(--header-transition);
}

.toms-header__inner.wp-block-group {
	gap: 0;
}

.toms-header .wp-block-group > *,
.toms-header__inner > * {
	margin-block: 0 !important;
}


/* ============================================================
   HEADER — LOGO
============================================================ */

.toms-header__logo-link {
	display: block;
	line-height: 0;
	text-decoration: none;
	flex-shrink: 0;
	
}

.toms-header__logo-img {
	display: block;
	height: 50px;
	width: auto;
	transition: height var(--header-transition);
	filter: brightness(0) invert(1) sepia(1) saturate(0.3) hue-rotate(5deg);
}

.toms-header.is-shrunk .toms-header__inner {
	min-height: 65px;
}

.toms-header.is-shrunk .toms-header__logo-img {
	height: 36px;
}


/* ============================================================
   HEADER — RIGHT GROUP
============================================================ */

.toms-header__right {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	flex-shrink: 0;
}

.toms-header__right.wp-block-group {
	padding: 0 !important;
	gap: 1.5rem;
}

.toms-header__right .wp-block-navigation {
	margin: 0;
}



/* ============================================================
   HEADER — SOCIAL ICONS
   No circle. Cream at rest, white on hover.
============================================================ */

.toms-header__social.wp-block-social-links {
	gap: 0.75rem !important;
	padding: 0 !important;
	margin: 0 !important;
	flex-shrink: 0;
}

.toms-header__social .wp-block-social-link,
.toms-header__social li.wp-block-social-link {
	width: 22px !important;
	height: 22px !important;
	background: none !important;
	background-color: transparent !important;
	border-radius: 0 !important;
}

.toms-header__social .wp-block-social-link a,
.toms-header__social .wp-block-social-link a:link,
.toms-header__social .wp-block-social-link a:visited,
.toms-header__social li.wp-block-social-link a {
	background: none !important;
	background-color: transparent !important;
	border-radius: 0 !important;
	border: none !important;
	padding: 0 !important;
	width: 22px !important;
	height: 22px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
}

.toms-header__social .wp-block-social-link svg,
.toms-header__social .wp-block-social-link a svg {
	fill: var(--color-bg-cream) !important;
	color: var(--color-bg-cream) !important;
	width: 22px !important;
	height: 22px !important;
	transition: fill 0.2s ease;
}

.toms-header__social .wp-block-social-link a:hover svg {
	fill: var(--color-bg) !important;
	color: var(--color-bg) !important;
}


/* ============================================================
   HEADER — MOBILE LAYOUT (< 1250px)
============================================================ */

@media (max-width: 1249px) {
	.toms-header__inner,
	.toms-header__inner.wp-block-group {
		padding: 0 1rem;
	}

	.toms-header__social {
		display: none !important;
	}

	/* Hamburger icon — cream on green header */
	.toms-header .wp-block-navigation__responsive-container-open {
		color: var(--color-bg-cream) !important;
	}

	.toms-header .wp-block-navigation__responsive-container-open svg {
		stroke: var(--color-bg-cream) !important;
		fill: var(--color-bg-cream) !important;
	}
}


/* ============================================================
   HEADER — NAV BREAKPOINT OVERRIDE
============================================================ */

@media (max-width: 1249px) {
	.toms-header .wp-block-navigation__responsive-container-open:not(.always-shown) {
		display: flex !important;
	}
	.toms-header .wp-block-navigation__responsive-container:not(.is-menu-open):not(.hidden-by-default) {
		display: none !important;
	}
}

@media (min-width: 1250px) {
	.toms-header .wp-block-navigation__responsive-container-open {
		display: none !important;
	}
	.toms-header .wp-block-navigation__responsive-container-close {
		display: none !important;
	}
	.toms-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;
	}
	.toms-header .wp-block-navigation__responsive-container-content {
		display: flex !important;
		justify-content: flex-start;
		align-items: center;
		width: 100%;
	}
}


/* ============================================================
   HEADER — DESKTOP NAV ITEMS
============================================================ */

.toms-header .wp-block-navigation,
.toms-header .wp-block-navigation__container,
.toms-header nav,
.toms-header .wp-block-navigation-item {
	border: none !important;
	outline: none !important;
	box-shadow: none !important;
	padding-top: 0;
	padding-bottom: 0;
}

.toms-header .wp-block-navigation__container {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 1.5rem;
}

.toms-header .wp-block-navigation-item__content,
.toms-header .wp-block-navigation-item__content:link,
.toms-header .wp-block-navigation-item__content:visited {
	display: inline-flex !important;
	align-items: center !important;
	padding: 0.75rem 0 !important;
	color: var(--color-bg-cream) !important;
	font-family: var(--font-heading) !important;
	font-size: 16px !important;
	font-weight: 600 !important;
	text-transform: none !important;
	letter-spacing: 0 !important;
	text-decoration: none !important;
	white-space: nowrap !important;
	transition: color 0.2s ease !important;
	position: relative !important;
}

.toms-header .wp-block-navigation-item__content::after {
	content: '';
	position: absolute;
	bottom: -1px;
	left: 0;
	width: 100%;
	height: 2px;
	background-color: var(--color-bg);
	opacity: 0;
	transition: opacity 0.15s;
}

.toms-header .wp-block-navigation-item__content:hover,
.toms-header .wp-block-navigation-item__content:focus {
	color: var(--color-bg) !important;
}

.toms-header .wp-block-navigation-item__content:hover::after {
	opacity: 1;
}

.toms-header .wp-block-navigation-item.current-menu-item > .wp-block-navigation-item__content,
.toms-header .wp-block-navigation-item.current-menu-ancestor > .wp-block-navigation-item__content,
.toms-header .wp-block-navigation-item__content[aria-current="page"] {
	color: var(--color-bg) !important;
}

.toms-header .wp-block-navigation-item.current-menu-item > .wp-block-navigation-item__content::after,
.toms-header .wp-block-navigation-item.current-menu-ancestor > .wp-block-navigation-item__content::after,
.toms-header .wp-block-navigation-item__content[aria-current="page"]::after {
	opacity: 1;
}

.toms-header .wp-block-navigation__submenu-container .wp-block-navigation-item__content,
.toms-header .wp-block-navigation__submenu-container .wp-block-navigation-item__content:link,
.toms-header .wp-block-navigation__submenu-container .wp-block-navigation-item__content:visited {
	color: var(--color-primary) !important;
}

.toms-header .wp-block-navigation__submenu-container .wp-block-navigation-item__content::after {
	display: none !important;
}


/* ============================================================
   HEADER — SUBMENU DROPDOWN
============================================================ */

.toms-header .wp-block-navigation-item.has-child {
	position: relative;
}

.toms-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;
}

.toms-header .wp-block-navigation-item.has-child:hover > .wp-block-navigation__submenu-container,
.toms-header .wp-block-navigation-item.has-child:focus-within > .wp-block-navigation__submenu-container {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.toms-header .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
	display: block !important;
	padding: 0.5rem 0.9375rem !important;
	font-size: 0.75rem !important;
	font-weight: 400 !important;
	text-transform: none !important;
	letter-spacing: 0 !important;
	text-decoration: none !important;
	width: 100% !important;
}

.toms-header .wp-block-navigation__submenu-container .wp-block-navigation-item__content:hover {
	color: var(--color-primary-hover) !important;
	background-color: var(--color-bg-subtle);
}

.toms-header .wp-block-navigation__submenu-icon {
	display: inline-flex;
	margin-left: 2px;
	width: 12px;
	height: 12px;
	opacity: 0.6;
}

.toms-header .wp-block-navigation__submenu-icon svg {
	width: 12px;
	height: 12px;
}


/* ============================================================
   HEADER — MOBILE DRAWER
============================================================ */

body:has(.wp-block-navigation__responsive-container.is-menu-open) {
	overflow: hidden;
}

@media (max-width: 1249px) {

	.toms-header .wp-block-navigation__responsive-container.is-menu-open::before {
		display: none !important;
	}

	.toms-header .wp-block-navigation__responsive-close {
		position: fixed !important;
		inset: 0 !important;
		background: rgba(0, 0, 0, 0.4) !important;
		z-index: 9998 !important;
	}

	.toms-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: 5.5rem 1.75rem 1.75rem !important;
		box-shadow: -4px 0 24px rgba(0, 0, 0, 0.15) !important;
		animation: toms-drawer-in 0.25s ease-out !important;
		display: flex !important;
		flex-direction: column !important;
	}

	@keyframes toms-drawer-in {
		from { transform: translateX(100%); }
		to   { transform: translateX(0); }
	}

	body .toms-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 — fixed in same top-right position as the hamburger */
	.toms-header .wp-block-navigation__responsive-container-close {
		position: fixed !important;
		top: calc(var(--wp-admin--admin-bar--height, 0px) + 1.4rem) !important;
		right: 1.25rem !important;
		z-index: 10000 !important;
		margin: 0 !important;
		color: var(--color-body) !important;
	}

	.toms-header .is-menu-open .wp-block-navigation__container {
		width: 100% !important;
		flex-direction: column !important;
		align-items: stretch !important;
		justify-content: flex-start !important;
		gap: 0 !important;
	}

	.toms-header .is-menu-open .wp-block-navigation-item__content,
	.toms-header .is-menu-open .wp-block-navigation-item__content:link,
	.toms-header .is-menu-open .wp-block-navigation-item__content:visited {
		display: block !important;
		width: 100% !important;
		padding: 0.9rem 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;
	}

	.toms-header .is-menu-open .wp-block-navigation-item__content::after {
		display: none !important;
	}

	.toms-header .is-menu-open .wp-block-navigation-item:last-child
	> .wp-block-navigation-item__content {
		border-bottom: none !important;
	}

	.toms-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;
	}

	.toms-header .is-menu-open .wp-block-navigation-item__content:hover {
		color: var(--color-primary) !important;
	}

	.toms-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;
	}

	.toms-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
============================================================ */

.toms-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;
}

.toms-header .is-menu-open
.wp-block-navigation-submenu__toggle[aria-expanded="true"] {
	transform: rotate(180deg) !important;
}

.toms-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;
}

.toms-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;
}

.toms-header .is-menu-open .wp-block-navigation-item.has-child
> .wp-block-navigation-submenu__toggle {
	flex: 0 0 auto !important;
	margin-left: 0 !important;
}

.toms-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;
}

.toms-header .is-menu-open
.wp-block-navigation-submenu__toggle[aria-expanded="true"]
~ .wp-block-navigation__submenu-container {
	display: block !important;
}

.toms-header .is-menu-open .wp-block-navigation-item {
	display: block !important;
	width: 100% !important;
	border-bottom: 1px solid var(--color-rule) !important;
}

.toms-header .is-menu-open .wp-block-navigation-item:last-child {
	border-bottom: none !important;
}

.toms-header .is-menu-open .wp-block-navigation-item__content {
	border-bottom: none !important;
}

.toms-header .is-menu-open .wp-block-navigation-submenu__toggle svg {
	width: 18px !important;
	height: 18px !important;
	stroke: currentColor !important;
	fill: none !important;
}

.toms-header .is-menu-open .wp-block-navigation-submenu__toggle svg path {
	stroke: currentColor !important;
	stroke-width: 2 !important;
}


/* ============================================================
   TABLES — borderless, flush-left, tight spacing
============================================================ */

.wp-block-table,
.wp-block-table table {
	border-collapse: collapse;
	width: 100%;
	border: none !important;
}

.wp-block-table td,
.wp-block-table th {
	border: none !important;
	padding: 0.1rem 1rem 0.1rem 0 !important;
	font-size: 1rem;
	vertical-align: top;
	background: none !important;
}

.wp-block-table th {
	font-weight: 600;
	color: var(--color-heading);
}

.wp-block-table tr {
	border-bottom: none !important;
}

.wp-block-table.is-style-stripes td,
.wp-block-table.is-style-stripes th {
	border: none !important;
}

.wp-block-table figure {
	margin: 0;
}


/* ============================================================
   "OUR GALLERY" HEADING
   Add class "gallery-heading" to the heading block in the editor.
   Structure heading as: Our <span class="script">Gallery</span>
============================================================ */

.gallery-heading,
.gallery-heading:link,
.gallery-heading:visited,
a.gallery-heading,
a .gallery-heading {
	color: var(--color-accent) !important;
	text-transform: none !important;
	font-weight: 500 !important;
	text-decoration: none !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 0.5rem !important;
}

.gallery-heading .script {
	font-family: var(--font-subheading) !important;
	font-weight: 400 !important;
}

.gallery-heading::after {
	content: '';
	display: inline-block;
	width: 1em;
	height: 1em;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23e16928' d='M12 2.163c3.204 0 3.584.012 4.85.07 3.252.148 4.771 1.691 4.919 4.919.058 1.265.069 1.645.069 4.849 0 3.205-.012 3.584-.069 4.849-.149 3.225-1.664 4.771-4.919 4.919-1.266.058-1.644.07-4.85.07-3.204 0-3.584-.012-4.849-.07-3.26-.149-4.771-1.699-4.919-4.92-.058-1.265-.07-1.644-.07-4.849 0-3.204.013-3.583.07-4.849.149-3.227 1.664-4.771 4.919-4.919 1.266-.057 1.645-.069 4.849-.069zM12 0C8.741 0 8.333.014 7.053.072 2.695.272.273 2.69.073 7.052.014 8.333 0 8.741 0 12c0 3.259.014 3.668.072 4.948.2 4.358 2.618 6.78 6.98 6.98C8.333 23.986 8.741 24 12 24c3.259 0 3.668-.014 4.948-.072 4.354-.2 6.782-2.618 6.979-6.98.059-1.28.073-1.689.073-4.948 0-3.259-.014-3.667-.072-4.947-.196-4.354-2.617-6.78-6.979-6.98C15.668.014 15.259 0 12 0zm0 5.838a6.162 6.162 0 100 12.324 6.162 6.162 0 000-12.324zM12 16a4 4 0 110-8 4 4 0 010 8zm6.406-11.845a1.44 1.44 0 100 2.881 1.44 1.44 0 000-2.881z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-size: contain;
	vertical-align: middle;
	flex-shrink: 0;
}


/* ============================================================
   FOOTER
============================================================ */

.toms-footer {
	background-color: var(--color-footer-bg);
	border-top: none;
	margin-top: 0;
}

.toms-footer__columns,
.toms-footer .wp-block-columns {
	align-items: flex-start;
	gap: 2.5rem !important;
}

.toms-footer__logo-link {
	display: inline-block;
	line-height: 0;
	text-decoration: none;
	margin-bottom: 0;
	width: 100%;
}

.toms-footer__logo-img {
	display: block;
	max-width: 250px;
	width: 100%;
	height: auto;
}

.toms-footer__contact {
	margin: 0 0 0.375rem !important;
	font-size: 0.9375rem !important;
	color: color-mix(in srgb, var(--color-footer-text) 82%, transparent);
	line-height: 1.55;
}

.toms-footer__contact a {
	color: color-mix(in srgb, var(--color-footer-text) 82%, transparent);
	text-decoration: none;
}

.toms-footer__contact a:hover {
	color: var(--color-footer-text);
	text-decoration: underline;
}

.toms-footer__col-heading {
	font-family: var(--font-heading);
	font-size: 1.15rem;
	font-weight: 600;
	text-transform: none;
	letter-spacing: 0;
	color: color-mix(in srgb, var(--color-footer-text) 92%, transparent);
	margin: 0 0 0.875rem !important;
}

/* Footer Navigation block */
.toms-footer__nav-links {
	margin: 0 !important;
	padding: 0 !important;
}

.toms-footer__nav-links .wp-block-navigation__container {
	display: grid !important;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0.5rem 1.5rem;
	align-items: start;
	margin: 0;
	padding: 0;
	list-style: none;
}

.toms-footer__nav-links .wp-block-navigation-item {
	margin: 0 !important;
	padding: 0 !important;
}

.toms-footer__nav-links .wp-block-navigation-item__content,
.toms-footer__nav-links .wp-block-navigation-item__content:link,
.toms-footer__nav-links .wp-block-navigation-item__content:visited {
	color: color-mix(in srgb, var(--color-footer-text) 88%, transparent) !important;
	font-size: 0.9375rem !important;
	font-weight: 400 !important;
	text-decoration: none !important;
	line-height: 1.4 !important;
	padding: 0 !important;
}

.toms-footer__nav-links .wp-block-navigation-item__content:hover,
.toms-footer__nav-links .wp-block-navigation-item__content:focus {
	color: var(--color-footer-text) !important;
	text-decoration: underline !important;
}

.toms-footer__hours-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.toms-footer__hours-item {
	display: flex;
	justify-content: space-between;
	gap: 1.5rem;
	font-size: 0.9375rem;
	color: color-mix(in srgb, var(--color-footer-text) 86%, transparent);
	padding: 0.35rem 0;
	border-bottom: none;
	line-height: 1.45;
	flex-wrap: nowrap;
}

.toms-footer__hours-item span:last-child {
	white-space: nowrap;
	min-width: 0;
}

.toms-footer__hours-day {
	font-weight: 700;
	color: color-mix(in srgb, var(--color-footer-text) 95%, transparent);
	white-space: nowrap;
}

.toms-footer__social.wp-block-social-links {
	gap: 0.75rem !important;
	padding: 0 !important;
	margin: 1.25rem 0 0 !important;
}

.toms-footer__social .wp-block-social-link,
.toms-footer__social li.wp-block-social-link {
	width: 22px !important;
	height: 22px !important;
	background: none !important;
	background-color: transparent !important;
	border-radius: 0 !important;
}

.toms-footer__social .wp-block-social-link a,
.toms-footer__social .wp-block-social-link a:link,
.toms-footer__social .wp-block-social-link a:visited,
.toms-footer__social li.wp-block-social-link a {
	background: none !important;
	background-color: transparent !important;
	border-radius: 0 !important;
	border: none !important;
	padding: 0 !important;
	width: 22px !important;
	height: 22px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
}

.toms-footer__social .wp-block-social-link svg,
.toms-footer__social .wp-block-social-link a svg {
	fill: color-mix(in srgb, var(--color-footer-text) 70%, transparent) !important;
	color: color-mix(in srgb, var(--color-footer-text) 70%, transparent) !important;
	width: 22px !important;
	height: 22px !important;
	transition: fill 0.2s ease;
}

.toms-footer__social .wp-block-social-link a:hover svg {
	fill: var(--color-footer-text) !important;
	color: var(--color-footer-text) !important;
}

.toms-footer__rule {
	border-color: color-mix(in srgb, var(--color-footer-text) 15%, transparent) !important;
	margin-top: 0 !important;
	margin-bottom: 1.25rem !important;
}

.toms-footer__acknowledgement {
	font-size: 0.75rem !important;
	color: color-mix(in srgb, var(--color-footer-text) 45%, transparent) !important;
	line-height: 1.65;
	text-align: center;
	max-width: 980px;
	margin-inline: auto;
	margin-bottom: 0.875rem !important;
}

.toms-footer__bottom {
	font-size: 0.72rem !important;
	color: color-mix(in srgb, var(--color-footer-text) 45%, transparent) !important;
	text-align: center;
}

@media (max-width: 1249px) {
	.toms-footer__nav-links .wp-block-navigation__container {
		width: fit-content;
		margin-inline: auto;
	}
}

@media (max-width: 900px) {
	.toms-footer__columns,
	.toms-footer .wp-block-columns {
		flex-wrap: wrap !important;
	}

	.toms-footer__col-logo,
	.toms-footer__col-contact,
	.toms-footer__col-nav,
	.toms-footer__col-hours {
		flex-basis: calc(50% - 1.25rem) !important;
	}
}

@media (max-width: 1100px) {
	.toms-footer__hours-item {
		gap: 0.75rem;
		font-size: 0.875rem;
	}

	.toms-footer__hours-day {
		font-size: 0.875rem;
	}
}

@media (max-width: 767px) {
	.toms-footer {
		text-align: center;
	}

	.toms-footer__col-nav {
		text-align: center;
	}

	.toms-footer__columns,
	.toms-footer .wp-block-columns {
		flex-direction: column !important;
	}

	.toms-footer__col-logo,
	.toms-footer__col-contact,
	.toms-footer__col-nav,
	.toms-footer__col-hours {
		flex-basis: 100% !important;
		width: 100%;
	}

	.toms-footer__logo-img {
		margin-inline: auto;
	}

	.toms-footer__nav-links .wp-block-navigation__container {
		grid-template-columns: 1fr;
		justify-items: center;
		width:100%;
	}

	.toms-footer__hours-item {
		justify-content: center;
	}

	.toms-footer__social {
		justify-content: center;
	}
}


/* ============================================================
   BUTTONS
============================================================ */

.wp-block-button__link {
	background-color: var(--color-primary);
	color: var(--color-bg);
	font-family: var(--font-heading);
	font-size: 17px;
	font-weight: 600;
	padding: 10px 30px;
	border-radius: 999px;
	text-decoration: none;
	text-transform: none;
	letter-spacing: normal;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background-color 0.2s ease;
	border: none;
}

.wp-block-button__link:hover {
	background-color: var(--color-primary-hover);
	color: var(--color-bg);
}


/* ============================================================
   HEADING STYLE — PAGE TITLE
============================================================ */

.wp-block-heading.is-style-page-title {
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--color-primary);
}


/* ============================================================
   PHONE BREAKPOINT (≤ 767px)
============================================================ */

@media (max-width: 767px) {
	.toms-header__logo-img {
		max-width: 200px !important;
		height: auto !important;
	}
}


/* ============================================================
   RESPONSIVE CONTENT PADDING
============================================================ */

@media (max-width: 1309px) {
	.toms-header__inner,
	.toms-header__inner.wp-block-group {
		padding-inline: 1.25rem;
	}

	body .wp-block-post-content {
		padding-inline: 1.25rem;
	}

	body .wp-block-post-content .wp-block-vl-mosaic-hero {
		margin-inline: -1.25rem;
		width: calc(100% + 2.5rem);
	}

	.toms-footer > * {
		padding-inline: 1.25rem;
		box-sizing: border-box;
	}
}


/* ============================================================
   MENU BLOCK — toms/menu (toms-blocks plugin)
   Overrides plugin's built style.css for brand alignment.
============================================================ */

/* Page title "Menu" — left-aligned, geraldica script */
.toms-menu__header {
	text-align: left !important;
}

.toms-menu__header h2 {
	font-family: var(--font-subheading) !important;
	font-weight: 400 !important;
	font-size: 2.5rem !important;
	color: var(--color-heading) !important;
	text-align: left !important;
	text-transform: none !important;
}

/* Section headings (All Day Everyday, Sandos etc.) — geraldica script */
.toms-menu-section h3,
.toms-menu-package__top h3 {
	font-family: var(--font-subheading) !important;
	font-weight: 400 !important;
	font-size: 1.7rem !important;
	color: var(--color-heading) !important;
	text-transform: none !important;
	margin: 0 0 0.75rem !important;
}

.toms-menu-item__subsection-heading {
    font-family: var(--font-subheading);
    font-size: 1.2rem;          /* smaller than section h3 at 1.5rem */
    font-weight: 400;
    color: var(--color-primary-hover);   /* #415937 dark green */
    margin: 0.75rem 0 0.25rem;
    text-transform: none;
}

/* Tighter item gaps */
.toms-menu-section__items {
	gap: 0.6rem !important;
}

.toms-menu-item {
	border-bottom: 1px solid color-mix(in srgb, var(--color-body) 8%, transparent) !important;
	padding-bottom: 0.6rem !important;
}

/* Item name — bold, dark body colour, tighter */
.toms-menu-item__top h4 {
	font-family: var(--font-heading) !important;
	font-size: 0.9375rem !important;
	font-weight: 600 !important;
	color: var(--color-primary-hover) !important;  /* dark green — matches PDF */
	margin: 0 !important;
	line-height: 1.3 !important;
}

/* Price — matches item name weight and colour */
.toms-menu-item__price,
.toms-menu-package__price {
	font-family: var(--font-heading) !important;
	font-size: 0.9375rem !important;
	font-weight: 600 !important;
	color: var(--color-body) !important;
}

/* Description — slightly muted, tighter size */
.toms-menu-item__description {
	font-size: 0.875rem !important;
	color: var(--color-body) !important;
	opacity: 0.85;
	margin: 0.15rem 0 0 !important;
	line-height: 1.4 !important;
}

/* Addons line */
.toms-menu-item__addons {
	font-size: 0.8125rem !important;
	color: var(--color-body) !important;
	opacity: 0.7;
	margin: 0.15rem 0 0 !important;
}

/* Dietary tags — inline after name, small caps style, no background.
   Matches PDF reference: "(vg, gf)" in parentheses after item name. */
.toms-menu-item__tags {
	display: inline-flex !important;
	gap: 0.2rem !important;
	margin-left: 0.3rem !important;
	vertical-align: baseline !important;
	opacity: 1 !important;
}

.toms-menu-item__tag {
	font-family: var(--font-heading) !important;
	font-size: 0.65rem !important;
	font-weight: 600 !important;
	color: var(--color-primary) !important;
	text-transform: lowercase !important;
	letter-spacing: 0 !important;
	opacity: 0.8 !important;
	line-height: 1 !important;
}

/* First tag gets opening paren, last gets closing — CSS counters approach */
.toms-menu-item__tags::before {
	content: '(';
	font-size: 0.65rem;
	color: var(--color-primary);
	opacity: 0.8;
	align-self: baseline;
}

.toms-menu-item__tags::after {
	content: ')';
	font-size: 0.65rem;
	color: var(--color-primary);
	opacity: 0.8;
	align-self: baseline;
}

/* Tags separator — comma between tags */
.toms-menu-item__tag + .toms-menu-item__tag::before {
	content: ', ';
	font-size: 0.65rem;
	color: var(--color-primary);
	opacity: 0.8;
}

/* Section gap — override plugin CSS variable that controls column gap */
.toms-menu,
.wp-block-toms-menu {
	--toms-menu-gap: 4rem;
}

.toms-menu__sections {
	gap: var(--toms-menu-gap) !important;
}

/* Opening Hours Table */
.opening-hours-table {
	max-width: 360px;
}

.opening-hours-table table {
	width: auto;
}

.opening-hours-table td:first-child {
	width: 110px;
	white-space: nowrap;
}

.opening-hours-table td:last-child {
	white-space: nowrap;
}

/* 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; }