/**
 * Godfreys 2026 — modern editorial / brunch-show
 */

:root {
	--gf-bg: #f7f5f2;
	--gf-bg-elevated: #ffffff;
	--gf-surface: rgba(255, 255, 255, 0.72);
	--gf-ink: #0f0f0f;
	--gf-ink-muted: #5c5a57;
	--gf-ink-faint: #8a8783;
	--gf-accent: #e11d48;
	--gf-accent-hover: #be123c;
	--gf-violet: #6d28d9;
	--gf-violet-soft: #ede9fe;
	--gf-warm: #ffedd5;
	--gf-gold: #fbbf24;
	--gf-radius: 1.5rem;
	--gf-radius-sm: 0.625rem;
	--gf-radius-pill: 999px;
	--gf-font-display: "Bricolage Grotesque", system-ui, sans-serif;
	--gf-font-sans: "Plus Jakarta Sans", system-ui, sans-serif;
	--gf-max: 80rem;
	--gf-prose: 42rem;
	--gf-header-h: 3.75rem;
	--gf-ease-out: cubic-bezier(0.22, 1, 0.36, 1);
	--gf-shadow-sm: 0 1px 2px rgba(15, 15, 15, 0.06);
	--gf-shadow: 0 20px 50px -12px rgba(15, 15, 15, 0.15);
	--gf-shadow-glow: 0 0 0 1px rgba(255, 255, 255, 0.12), 0 25px 80px -20px rgba(225, 29, 72, 0.35);
	--gf-pad-x: clamp(1.25rem, 5vw, 3rem);
	/* Bottom stop of .front-band--sunset — hairline above .footer-cta only (no tall blend) */
	--gf-sunset-end: #e9d5ff;
	/* Homepage “Plan your visit” + footer reserve strip */
	--gf-cta-strip-bg: linear-gradient(135deg, #4c1d95 0%, #be123c 50%, #9d174d 100%);
}

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

html {
	scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}
}

body {
	margin: 0;
	font-family: var(--gf-font-sans);
	font-size: 1.0625rem;
	line-height: 1.65;
	letter-spacing: -0.01em;
	color: var(--gf-ink);
	background-color: var(--gf-bg);
	background-image:
		radial-gradient(1200px 800px at 10% -10%, rgba(237, 233, 254, 0.65) 0%, transparent 55%),
		radial-gradient(900px 600px at 90% 0%, rgba(255, 237, 213, 0.5) 0%, transparent 50%),
		radial-gradient(ellipse at 50% 100%, rgba(15, 15, 15, 0.03) 0%, transparent 45%);
	text-rendering: optimizeLegibility;
	-webkit-font-smoothing: antialiased;
}

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

a {
	color: var(--gf-accent);
	text-decoration: none;
	transition: color 0.2s var(--gf-ease-out);
}

a:hover {
	color: var(--gf-accent-hover);
}

.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}

.skip-link:focus {
	clip: auto !important;
	clip-path: none !important;
	height: auto !important;
	width: auto !important;
	margin: 0;
	top: 0.5rem;
	left: 0.5rem;
	z-index: 100000;
	padding: 0.5rem 1rem;
	background: var(--gf-ink);
	color: #fff;
	border-radius: var(--gf-radius-sm);
}

a:focus-visible {
	outline: 2px solid var(--gf-violet);
	outline-offset: 2px;
}

/* ——— Buttons ——— */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	padding: 0.65rem 1.15rem;
	font-family: var(--gf-font-sans);
	font-size: 0.9rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1.2;
	text-decoration: none;
	border-radius: var(--gf-radius-pill);
	border: 2px solid transparent;
	cursor: pointer;
	transition:
		background 0.2s var(--gf-ease-out),
		color 0.2s var(--gf-ease-out),
		border-color 0.2s var(--gf-ease-out),
		transform 0.2s var(--gf-ease-out),
		box-shadow 0.2s var(--gf-ease-out);
}

.btn:focus-visible {
	outline: 2px solid var(--gf-violet);
	outline-offset: 3px;
}

.btn--sm {
	padding: 0.45rem 0.95rem;
	font-size: 0.8125rem;
}

.btn--lg {
	padding: 0.85rem 1.65rem;
	font-size: 1rem;
}

.btn--primary {
	background: linear-gradient(135deg, var(--gf-accent) 0%, #db2777 100%);
	color: #fff;
	border-color: rgba(255, 255, 255, 0.2);
	box-shadow: 0 4px 20px rgba(225, 29, 72, 0.45);
}

.btn--primary:hover {
	color: #fff;
	transform: translateY(-1px);
	box-shadow: 0 8px 28px rgba(225, 29, 72, 0.55);
}

.btn--ghost {
	background: rgba(255, 255, 255, 0.12);
	color: #fff;
	border-color: rgba(255, 255, 255, 0.35);
	backdrop-filter: blur(8px);
}

.btn--ghost:hover {
	background: rgba(255, 255, 255, 0.22);
	color: #fff;
}

.btn--header {
	background: linear-gradient(135deg, var(--gf-accent) 0%, #db2777 100%);
	color: #fff;
	border-color: transparent;
	box-shadow: 0 2px 12px rgba(225, 29, 72, 0.35);
	white-space: nowrap;
	flex-shrink: 0;
}

.btn--header:hover {
	color: #fff;
	transform: translateY(-1px);
}

/* Mobile: reserve is below the glass bar (sibling of .site-header__inner). */
.site-header__reserve {
	box-sizing: border-box;
}

.btn--hero {
	min-height: 3rem;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
}

.btn--action-primary {
	background: #fff;
	color: var(--gf-ink);
	border-color: rgba(255, 255, 255, 0.95);
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
}

.btn--action-primary:hover {
	color: var(--gf-accent);
	transform: translateY(-2px);
}

.btn--action-secondary {
	background: rgba(255, 255, 255, 0.12);
	color: #fff;
	border-color: rgba(255, 255, 255, 0.45);
}

.btn--action-secondary:hover {
	background: rgba(255, 255, 255, 0.22);
	color: #fff;
}

/* ——— Block editor: Button — match theme .btn / homepage CTAs ——— */
.wp-block-button .wp-block-button__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	box-sizing: border-box;
	padding: 0.65rem 1.15rem;
	font-family: var(--gf-font-sans);
	font-size: 0.9rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1.2;
	text-decoration: none;
	border-radius: var(--gf-radius-pill);
	border: 2px solid transparent;
	cursor: pointer;
	transition:
		background 0.2s var(--gf-ease-out),
		color 0.2s var(--gf-ease-out),
		border-color 0.2s var(--gf-ease-out),
		transform 0.2s var(--gf-ease-out),
		box-shadow 0.2s var(--gf-ease-out);
}

.wp-block-button .wp-block-button__link:focus-visible {
	outline: 2px solid var(--gf-violet);
	outline-offset: 3px;
}

/* Filled (default) — same as .btn--primary */
.wp-block-button:not(.is-style-outline) .wp-block-button__link {
	background: linear-gradient(135deg, var(--gf-accent) 0%, #db2777 100%);
	color: #fff;
	border-color: rgba(255, 255, 255, 0.2);
	box-shadow: 0 4px 20px rgba(225, 29, 72, 0.45);
}

.wp-block-button:not(.is-style-outline) .wp-block-button__link:hover {
	color: #fff;
	transform: translateY(-1px);
	box-shadow: 0 8px 28px rgba(225, 29, 72, 0.55);
}

/* Outline — accent ring on light backgrounds (body / entry content) */
.wp-block-button.is-style-outline .wp-block-button__link {
	background: transparent;
	color: var(--gf-accent);
	border-color: var(--gf-accent);
	box-shadow: none;
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
	background: rgba(225, 29, 72, 0.08);
	color: var(--gf-accent-hover);
	border-color: var(--gf-accent-hover);
	transform: translateY(-1px);
}

/* Hero / dark overlays — outline reads like .btn--ghost (homepage secondary) */
.hero .wp-block-button.is-style-outline .wp-block-button__link,
.front-band--action .wp-block-button.is-style-outline .wp-block-button__link,
.footer-cta .wp-block-button.is-style-outline .wp-block-button__link {
	background: rgba(255, 255, 255, 0.12);
	color: #fff;
	border-color: rgba(255, 255, 255, 0.35);
	backdrop-filter: blur(8px);
}

.hero .wp-block-button.is-style-outline .wp-block-button__link:hover,
.front-band--action .wp-block-button.is-style-outline .wp-block-button__link:hover,
.footer-cta .wp-block-button.is-style-outline .wp-block-button__link:hover {
	background: rgba(255, 255, 255, 0.22);
	color: #fff;
	border-color: rgba(255, 255, 255, 0.5);
}

/* Button row spacing — mirrors .hero__actions / .front-band__action-row */
.wp-block-buttons {
	gap: 0.75rem 1rem;
}

.wp-block-buttons.is-layout-flex {
	gap: 0.75rem 1rem;
}

.wp-block-buttons.is-content-justification-center {
	justify-content: center;
}

.wp-block-buttons.is-content-justification-right {
	justify-content: flex-end;
}

/* ——— Header — floating glass ——— */
.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	padding: 0.75rem var(--gf-pad-x) 0;
	transition: padding 0.35s var(--gf-ease-out);
}

.site-header.is-scrolled {
	padding-top: 0.5rem;
}

.site-header__cluster {
	max-width: var(--gf-max);
	margin-left: auto;
	margin-right: auto;
}

/* Mobile: glass pill = inner only; reserve sits outside below */
.site-header__inner {
	position: relative;
	max-width: none;
	margin: 0;
	padding: 0.65rem 1.1rem;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.65rem 0.75rem;
	min-height: var(--gf-header-h);
	background: var(--gf-surface);
	backdrop-filter: blur(16px) saturate(1.4);
	-webkit-backdrop-filter: blur(16px) saturate(1.4);
	border: 1px solid rgba(15, 15, 15, 0.06);
	border-radius: var(--gf-radius-pill);
	box-shadow: var(--gf-shadow-sm);
	transition: box-shadow 0.35s var(--gf-ease-out), border-color 0.35s var(--gf-ease-out);
}

@media (max-width: 899px) {
	.site-header {
		padding-bottom: 1rem;
	}

	.site-header__cluster {
		display: flex;
		flex-direction: column;
		align-items: stretch;
		gap: 0.65rem;
		width: 100%;
	}

	.site-header .site-header__reserve {
		width: 100%;
		max-width: none;
		justify-content: center;
		margin: 0;
		white-space: normal;
		text-align: center;
		line-height: 1.25;
		min-height: 2.75rem;
		padding-left: 1rem;
		padding-right: 1rem;
	}

	.site-header.is-scrolled .site-header__inner {
		box-shadow: var(--gf-shadow);
		border-color: rgba(15, 15, 15, 0.08);
	}
}

.site-branding {
	flex: 0 1 auto;
	min-width: 0;
	display: flex;
	align-items: center;
}

.site-logo {
	position: relative;
	display: block;
	height: 2.625rem;
	max-width: 10.5rem;
	line-height: 0;
	text-decoration: none;
	outline-offset: 4px;
}

.site-logo:focus-visible {
	outline: 2px solid var(--gf-violet);
	border-radius: var(--gf-radius-sm);
}

.site-logo__canvas {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	display: block;
	opacity: 0;
	transition: opacity 0.4s var(--gf-ease-out);
	z-index: 1;
	pointer-events: none;
}

.site-branding--canvas-live .site-logo__canvas {
	opacity: 1;
}

.site-logo__fallback {
	height: 2.625rem;
	width: auto;
	max-width: 10.5rem;
	object-fit: contain;
	object-position: left center;
	display: block;
	transition: opacity 0.4s var(--gf-ease-out);
}

.site-branding--canvas-live .site-logo__fallback {
	opacity: 0;
}

/* Nav */
.main-nav {
	display: none;
}

.main-nav.is-open {
	display: block;
	position: absolute;
	left: 0;
	right: 0;
	top: calc(100% + 0.5rem);
	background: var(--gf-bg-elevated);
	border: 1px solid rgba(15, 15, 15, 0.08);
	border-radius: var(--gf-radius);
	padding: 1rem 1.25rem 1.25rem;
	box-shadow: var(--gf-shadow);
	z-index: 60;
}

.main-nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
}

.main-nav li {
	margin: 0;
}

.main-nav a {
	font-weight: 600;
	font-size: 0.9375rem;
	color: var(--gf-ink);
	padding: 0.5rem 0.65rem;
	border-radius: var(--gf-radius-sm);
	display: block;
	transition: background 0.2s var(--gf-ease-out), color 0.2s var(--gf-ease-out);
}

.main-nav a:hover {
	color: var(--gf-accent);
	background: rgba(225, 29, 72, 0.06);
}

/* Current page / section — distinct from other primary links */
.main-nav li.current-menu-item > a,
.main-nav li.current_page_item > a,
.main-nav a[aria-current="page"] {
	font-weight: 700;
	color: var(--gf-accent);
	background: rgba(225, 29, 72, 0.12);
	box-shadow: inset 0 0 0 1px rgba(225, 29, 72, 0.2);
}

.main-nav li.current-menu-item > a:hover,
.main-nav li.current_page_item > a:hover,
.main-nav a[aria-current="page"]:hover {
	color: var(--gf-accent-hover);
	background: rgba(225, 29, 72, 0.16);
}

.menu-toggle {
	border: none;
	background: rgba(15, 15, 15, 0.05);
	padding: 0.55rem 0.65rem;
	cursor: pointer;
	border-radius: var(--gf-radius-sm);
	transition: background 0.2s var(--gf-ease-out);
}

.menu-toggle:hover {
	background: rgba(15, 15, 15, 0.08);
}

.menu-toggle:focus-visible {
	outline: 2px solid var(--gf-violet);
	outline-offset: 2px;
}

.menu-toggle__bars {
	display: block;
	width: 1.35rem;
	height: 2px;
	background: var(--gf-ink);
	box-shadow: 0 6px 0 var(--gf-ink), 0 -6px 0 var(--gf-ink);
	border-radius: 1px;
}

@media (min-width: 900px) {
	/* One glass pill wraps inner + reserve */
	.site-header__cluster {
		display: flex;
		flex-direction: row;
		flex-wrap: nowrap;
		align-items: center;
		gap: 0.65rem 0.75rem;
		padding: 0.65rem 1.1rem;
		min-height: var(--gf-header-h);
		background: var(--gf-surface);
		backdrop-filter: blur(16px) saturate(1.4);
		-webkit-backdrop-filter: blur(16px) saturate(1.4);
		border: 1px solid rgba(15, 15, 15, 0.06);
		border-radius: var(--gf-radius-pill);
		box-shadow: var(--gf-shadow-sm);
		transition: box-shadow 0.35s var(--gf-ease-out), border-color 0.35s var(--gf-ease-out);
	}

	.site-header__inner {
		flex: 1 1 auto;
		min-width: 0;
		flex-wrap: nowrap;
		justify-content: flex-start;
		gap: 0.5rem;
		padding: 0;
		min-height: 0;
		background: transparent;
		border: none;
		box-shadow: none;
		backdrop-filter: none;
		-webkit-backdrop-filter: none;
		border-radius: 0;
	}

	.site-header.is-scrolled .site-header__cluster {
		box-shadow: var(--gf-shadow);
		border-color: rgba(15, 15, 15, 0.08);
	}

	.site-header.is-scrolled .site-header__inner {
		box-shadow: none;
		border-color: transparent;
	}

	.site-branding {
		order: 1;
	}

	.main-nav {
		order: 2;
		display: flex;
		flex: 1 1 auto;
		justify-content: center;
		align-items: center;
		min-width: 0;
		position: static;
		background: transparent;
		border: none;
		padding: 0;
		box-shadow: none;
	}

	.main-nav ul {
		flex-direction: row;
		align-items: center;
		justify-content: center;
		gap: 0.25rem;
	}

	.main-nav a {
		padding: 0.45rem 0.85rem;
		font-size: 0.875rem;
	}

	.main-nav li.current-menu-item > a,
	.main-nav li.current_page_item > a,
	.main-nav a[aria-current="page"] {
		border-radius: var(--gf-radius-pill);
	}

	.site-header__reserve {
		order: 3;
		flex-shrink: 0;
	}

	.menu-toggle {
		order: 4;
		display: none;
	}
}

/* ——— Hero ——— */
.hero {
	position: relative;
	min-height: min(85vh, 42rem);
	display: flex;
	align-items: flex-end;
	padding: 4rem var(--gf-pad-x) 4.5rem;
	margin: 0 var(--gf-pad-x) 0;
	border-radius: var(--gf-radius);
	overflow: hidden;
	background: linear-gradient(135deg, #1a0a14 0%, #312e81 45%, #0f172a 100%);
}

/* Featured image fills the hero (crop edges if aspect ratio differs) */
.hero--has-media {
	background-image: var(--hero-image);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

.hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.07'/%3E%3C/svg%3E");
	opacity: 1;
	pointer-events: none;
}

.hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to top,
		rgba(15, 15, 15, 0.88) 0%,
		rgba(15, 15, 15, 0.35) 42%,
		rgba(109, 40, 217, 0.2) 100%
	);
	pointer-events: none;
}

.hero__content {
	position: relative;
	z-index: 1;
	max-width: var(--gf-max);
	margin: 0 auto;
	width: 100%;
}

.hero__badge {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	color: #fff;
	margin: 0 0 0.75rem;
	padding: 0.35rem 0.9rem;
	background: rgba(251, 191, 36, 0.22);
	border: 1px solid rgba(251, 191, 36, 0.45);
	border-radius: var(--gf-radius-pill);
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}

.hero__eyebrow {
	display: inline-block;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--gf-warm);
	margin: 0 0 1rem;
	padding: 0.4rem 0.85rem;
	background: rgba(255, 255, 255, 0.1);
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: var(--gf-radius-pill);
	backdrop-filter: blur(8px);
}

.hero__title {
	font-family: var(--gf-font-display);
	font-size: clamp(2.75rem, 7vw, 4.25rem);
	font-weight: 800;
	line-height: 0.98;
	letter-spacing: -0.045em;
	color: #fff;
	margin: 0;
	max-width: min(18ch, 100%);
	text-shadow: 0 4px 60px rgba(0, 0, 0, 0.45);
}

.hero__lead {
	font-size: clamp(1.05rem, 2.5vw, 1.25rem);
	line-height: 1.55;
	font-weight: 500;
	color: rgba(255, 255, 255, 0.92);
	margin: 1.25rem 0 0;
	max-width: 36rem;
	text-shadow: 0 2px 24px rgba(0, 0, 0, 0.35);
}

.hero__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.75rem 1rem;
	margin-top: 1.75rem;
}

@media (prefers-reduced-motion: no-preference) {
	.hero__content {
		animation: hero-in 0.9s var(--gf-ease-out) both;
	}

	@keyframes hero-in {
		from {
			opacity: 0;
			transform: translateY(1.25rem);
		}
		to {
			opacity: 1;
			transform: translateY(0);
		}
	}
}

/* Interior pages & posts — same language as homepage, slightly tighter */
.hero--interior {
	min-height: min(70vh, 38rem);
	padding: 3rem var(--gf-pad-x) 3.25rem;
}

.hero--interior .hero__title {
	max-width: min(24ch, 100%);
}

/* ——— Main ——— */
.site-main {
	min-height: 40vh;
}

/* ——— Front page: full-bleed gradient bands ——— */
.front-stack {
	width: 100%;
	overflow-x: hidden;
}

.front-band {
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	padding: clamp(2.75rem, 7vw, 5rem) 0;
	position: relative;
}

.front-band::after {
	content: "";
	position: absolute;
	inset: 0;
	background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='gn'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23gn)' opacity='0.04'/%3E%3C/svg%3E");
	pointer-events: none;
	opacity: 1;
}

.front-band__inner {
	position: relative;
	z-index: 1;
	max-width: var(--gf-max);
	margin: 0 auto;
	padding-left: var(--gf-pad-x);
	padding-right: var(--gf-pad-x);
}

.front-band__inner--narrow {
	max-width: 48rem;
}

.front-band__inner--action {
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

.front-band--sunset {
	background: linear-gradient(
		180deg,
		#fffbeb 0%,
		#ffedd5 28%,
		#fbcfe8 55%,
		var(--gf-sunset-end) 100%
	);
}

.front-band--action {
	background: var(--gf-cta-strip-bg);
	color: #fff;
	padding-top: clamp(3rem, 8vw, 5.5rem);
	padding-bottom: clamp(3rem, 8vw, 5.5rem);
}

.front-band__action-title {
	font-family: var(--gf-font-display);
	font-size: clamp(1.65rem, 3.5vw, 2.25rem);
	font-weight: 800;
	letter-spacing: -0.03em;
	margin: 0 auto 0.5rem;
	color: #fff;
	text-align: center;
	max-width: 28rem;
}

.front-band__action-lead {
	margin: 0 auto 1.75rem;
	font-size: 1.05rem;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.82);
	text-align: center;
	max-width: 36rem;
}

.front-band__action-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 0.75rem 1rem;
	width: 100%;
}

/* ——— Front page: optional media CTA strips (nightlife + show times) ——— */
.nightlife-strip,
.showtimes-strip {
	position: relative;
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	min-height: min(52vh, 28rem);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	padding: clamp(2.75rem, 8vw, 5rem) var(--gf-pad-x);
	color: #fff;
}

.nightlife-strip__media,
.showtimes-strip__media {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.nightlife-strip__base {
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, #0c0a12 0%, #1e1b4b 42%, #312e81 100%);
}

/* Brunch-show warmth (distinct from nightlife indigo) */
.showtimes-strip__base {
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, #1c1917 0%, #9a3412 38%, #be185d 72%, #831843 100%);
}

.nightlife-strip__image,
.showtimes-strip__image {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
}

.nightlife-strip__video,
.showtimes-strip__video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

@media (prefers-reduced-motion: reduce) {
	.nightlife-strip__video,
	.showtimes-strip__video {
		display: none !important;
	}
}

.nightlife-strip__scrim {
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(
		to top,
		rgba(8, 6, 14, 0.92) 0%,
		rgba(8, 6, 14, 0.5) 48%,
		rgba(49, 46, 129, 0.4) 100%
	);
	pointer-events: none;
}

.showtimes-strip__scrim {
	position: absolute;
	inset: 0;
	z-index: 1;
	/* Stronger dim so type reads on busy photos */
	background: linear-gradient(
		165deg,
		rgba(8, 6, 10, 0.88) 0%,
		rgba(12, 10, 14, 0.72) 38%,
		rgba(28, 12, 22, 0.78) 100%
	);
	pointer-events: none;
}

.nightlife-strip__inner,
.showtimes-strip__inner {
	position: relative;
	z-index: 2;
	max-width: 42rem;
	margin: 0 auto;
	text-align: center;
}

/* Show times: spotlight + angled wash (no glass “card”) */
.showtimes-strip__inner {
	max-width: min(46rem, 100%);
	padding: clamp(1.25rem, 4vw, 2rem) var(--gf-pad-x);
	isolation: isolate;
}

.showtimes-strip__inner::before {
	content: "";
	position: absolute;
	z-index: -1;
	left: 50%;
	top: 48%;
	width: min(120vw, 56rem);
	height: min(70vh, 24rem);
	transform: translate(-50%, -50%);
	background: radial-gradient(
		ellipse 50% 46% at 50% 45%,
		rgba(12, 8, 18, 0.92) 0%,
		rgba(18, 10, 24, 0.62) 48%,
		rgba(24, 12, 28, 0.2) 68%,
		transparent 78%
	);
	pointer-events: none;
}

.showtimes-strip__inner::after {
	content: "";
	position: absolute;
	z-index: -2;
	left: 50%;
	top: 50%;
	width: min(92%, 40rem);
	height: 72%;
	max-height: 18rem;
	transform: translate(-50%, -50%) rotate(-1.5deg);
	background: linear-gradient(
		122deg,
		rgba(251, 191, 36, 0.14) 0%,
		rgba(251, 113, 133, 0.08) 35%,
		transparent 50%,
		transparent 62%,
		rgba(192, 38, 211, 0.1) 100%
	);
	clip-path: polygon(0 6%, 100% 0, 100% 94%, 0 100%);
	pointer-events: none;
	filter: blur(0.5px);
}

.nightlife-strip__title {
	font-family: var(--gf-font-display);
	font-size: clamp(1.85rem, 4vw, 2.65rem);
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 1.12;
	margin: 0 0 0.65rem;
	text-shadow: 0 2px 24px rgba(0, 0, 0, 0.45);
}

.showtimes-strip__title {
	font-family: var(--gf-font-display);
	font-size: clamp(2.35rem, 6vw, 3.5rem);
	font-weight: 800;
	letter-spacing: -0.035em;
	line-height: 1.08;
	margin: 0 auto 0.35rem;
	width: fit-content;
	max-width: 100%;
	color: #fff;
	text-shadow:
		0 1px 2px rgba(0, 0, 0, 0.9),
		0 4px 24px rgba(0, 0, 0, 0.65),
		0 0 40px rgba(0, 0, 0, 0.35);
}

.showtimes-strip__title::after {
	content: "";
	display: block;
	width: min(11rem, 70vw);
	height: 0.28rem;
	margin: 0.4em auto 0.55em;
	border-radius: var(--gf-radius-pill);
	background: linear-gradient(
		90deg,
		transparent 0%,
		#fbbf24 18%,
		#fef3c7 42%,
		#fda4af 72%,
		transparent 100%
	);
	box-shadow:
		0 0 28px rgba(251, 191, 36, 0.45),
		0 2px 12px rgba(0, 0, 0, 0.4);
}

.nightlife-strip__lead {
	margin: 0 0 1.5rem;
	font-size: clamp(1.02rem, 2vw, 1.15rem);
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.88);
	text-shadow: 0 1px 12px rgba(0, 0, 0, 0.35);
}

.showtimes-strip__lead {
	margin: 0 auto 1.65rem;
	max-width: 36rem;
	font-size: clamp(1.2rem, 2.6vw, 1.5rem);
	font-weight: 600;
	line-height: 1.55;
	color: #fff;
	text-shadow:
		0 1px 3px rgba(0, 0, 0, 0.85),
		0 6px 28px rgba(0, 0, 0, 0.45);
}

.nightlife-strip__actions,
.showtimes-strip__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
}

.nightlife-strip__cta,
.showtimes-strip__cta {
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.35);
}

.entry-content--front {
	font-size: 1.08rem;
	line-height: 1.75;
	max-width: 46rem;
	margin-left: auto;
	margin-right: auto;
}

.entry-content--front > *:first-child {
	margin-top: 0;
}

.entry-content--front > p:first-of-type {
	font-size: clamp(1.15rem, 2.2vw, 1.35rem);
	line-height: 1.65;
	font-weight: 500;
	color: var(--gf-ink);
}

.entry-content--front h2,
.entry-content--front h3 {
	font-family: var(--gf-font-display);
	font-weight: 800;
	letter-spacing: -0.03em;
	margin-top: 2rem;
	margin-bottom: 0.75rem;
	line-height: 1.15;
}

.entry-content--front h2 {
	font-size: clamp(1.65rem, 3vw, 2rem);
}

.entry-content--front h3 {
	font-size: 1.35rem;
}

.entry-content--front ul,
.entry-content--front ol {
	margin: 1rem 0 1.5rem;
	padding: 1.1rem 1.25rem 1.1rem 2rem;
	background: rgba(255, 255, 255, 0.55);
	border-radius: var(--gf-radius);
	border: 1px solid rgba(15, 15, 15, 0.06);
	box-shadow: var(--gf-shadow-sm);
}

.entry-content--front li {
	margin: 0.35rem 0;
}

.entry-content--front a {
	font-weight: 600;
}

.entry-content--front p + p {
	margin-top: 1.1rem;
}

/* Show times pattern (block pattern — class gf-showtimes) */
.gf-showtimes {
	margin-top: 2.25rem !important;
	margin-bottom: 0.5rem !important;
	padding: 1.5rem 1.25rem 1.5rem;
	background: rgba(255, 255, 255, 0.65);
	border: 1px solid rgba(15, 15, 15, 0.08);
	border-radius: var(--gf-radius);
	box-shadow: 0 12px 40px rgba(109, 40, 217, 0.12);
	max-width: 100% !important;
}

.gf-showtimes .wp-block-heading,
.gf-showtimes h2 {
	font-family: var(--gf-font-display);
	font-size: clamp(1.35rem, 2.5vw, 1.65rem) !important;
	font-weight: 800;
	letter-spacing: -0.03em;
	margin: 0 0 0.35rem !important;
	color: var(--gf-ink);
}

.gf-showtimes__meta {
	margin: 0 0 1.25rem !important;
	font-size: 0.9rem !important;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: var(--gf-ink-muted);
}

.gf-showtimes__grid {
	margin-bottom: 0 !important;
	gap: 1rem 1.25rem !important;
}

.gf-showtimes__grid .wp-block-column {
	margin: 0 !important;
}

.gf-showtimes__card {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.95) 0%, #faf5ff 100%);
	border: 1px solid rgba(109, 40, 217, 0.18);
	border-radius: var(--gf-radius-sm);
	padding: 1.1rem 1rem !important;
	text-align: center;
	min-height: 100%;
	box-sizing: border-box;
}

.gf-showtimes__label {
	margin: 0 0 0.35rem !important;
	font-size: 0.75rem !important;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--gf-ink-muted);
}

.gf-showtimes__time {
	margin: 0 !important;
	font-family: var(--gf-font-display);
	font-size: clamp(1.65rem, 4vw, 2.15rem) !important;
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 1.1 !important;
	color: var(--gf-violet);
}

@media (max-width: 782px) {
	.gf-showtimes__grid {
		flex-direction: column !important;
	}

	.gf-showtimes__grid .wp-block-column {
		flex-basis: 100% !important;
	}
}

.front-content {
	max-width: var(--gf-max);
	margin: 0 auto;
	padding: 3rem var(--gf-pad-x) 5rem;
}

.content-area {
	max-width: var(--gf-max);
	margin: 0 auto;
	padding: 2.5rem var(--gf-pad-x) 0;
}

/* Full-bleed bands like the homepage (no empty “second column” from a narrow shell) */
.page-shell,
.single-shell {
	padding: 2.5rem 0 5rem;
}

/* Flush sunset content band against the “Ready to brunch…” strip — no body-colored gap */
main.site-main:has(+ .footer-cta) .page-shell,
main.site-main:has(+ .footer-cta) .single-shell {
	padding-bottom: 0;
}

/* No featured image: compact title stack (not a full-height hero “slot”) */
.interior-header {
	max-width: var(--gf-max);
	margin-left: auto;
	margin-right: auto;
	padding: 0 var(--gf-pad-x) 1.75rem;
}

.interior-header__badge {
	display: inline-block;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--gf-accent);
	margin: 0 0 0.5rem;
	padding: 0.25rem 0.65rem;
	border-radius: var(--gf-radius-pill);
	background: rgba(225, 29, 72, 0.08);
	border: 1px solid rgba(225, 29, 72, 0.2);
}

.interior-header__eyebrow {
	color: var(--gf-ink-muted);
	font-size: 0.875rem;
	font-weight: 500;
	margin: 0 0 0.35rem;
	letter-spacing: 0.02em;
}

.interior-header__title {
	font-family: var(--gf-font-display);
	font-size: clamp(2.25rem, 4.5vw, 3.25rem);
	font-weight: 800;
	letter-spacing: -0.04em;
	line-height: 1.05;
	color: var(--gf-ink);
	margin: 0 0 0.65rem;
}

.interior-header__lead {
	font-size: 1.0625rem;
	line-height: 1.6;
	color: var(--gf-ink-muted);
	margin: 0;
	max-width: var(--gf-prose);
}

.page-shell__title,
.single-shell__title {
	font-family: var(--gf-font-display);
	font-size: clamp(2.25rem, 4.5vw, 3.25rem);
	font-weight: 800;
	letter-spacing: -0.04em;
	line-height: 1.05;
	color: var(--gf-ink);
	margin: 0 0 1rem;
}

.single-shell__meta {
	color: var(--gf-ink-muted);
	font-size: 0.875rem;
	font-weight: 500;
	margin: 0 0 2rem;
	letter-spacing: 0.02em;
}

.single-shell__thumb {
	margin: 0 0 2rem;
	border-radius: var(--gf-radius);
	overflow: hidden;
	box-shadow: var(--gf-shadow);
	border: 1px solid rgba(15, 15, 15, 0.06);
}

.entry-content {
	font-size: 1.0625rem;
	line-height: 1.75;
}

/* Readable measure for block content — centered so prose isn’t stuck in one column */
.front-content .entry-content,
.page-shell .entry-content,
.single-shell .entry-content {
	max-width: var(--gf-prose);
	margin-left: auto;
	margin-right: auto;
}

.front-content .entry-content.alignwide,
.front-content .entry-content .alignwide {
	max-width: none;
}

.entry-content > * + * {
	margin-top: 1.35rem;
}

.entry-content > *:first-child {
	margin-top: 0;
}

.entry-content h2 {
	font-family: var(--gf-font-display);
	font-size: clamp(1.65rem, 3vw, 2rem);
	font-weight: 700;
	letter-spacing: -0.03em;
	color: var(--gf-ink);
	margin-top: 2.75rem;
}

.entry-content h3 {
	font-family: var(--gf-font-display);
	font-size: 1.25rem;
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--gf-ink);
}

.entry-content p a {
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.2em;
}

.entry-content a:hover {
	text-decoration-thickness: 2px;
}

.wp-block-image img {
	border-radius: var(--gf-radius-sm);
}

.wp-block-quote {
	border-left: 4px solid var(--gf-accent);
	padding-left: 1.25rem;
	margin-left: 0;
	font-family: var(--gf-font-display);
	font-weight: 600;
	font-size: 1.2rem;
	color: var(--gf-ink-muted);
}

.entry-content .alignwide {
	width: min(100vw - 2 * var(--gf-pad-x), var(--gf-max));
	max-width: min(100vw - 2 * var(--gf-pad-x), var(--gf-max));
	margin-left: calc(50% - 50vw + var(--gf-pad-x));
	margin-right: calc(50% - 50vw + var(--gf-pad-x));
}

@media (max-width: 782px) {
	.entry-content .alignwide {
		margin-left: 0;
		margin-right: 0;
		width: 100%;
		max-width: 100%;
	}
}

/* Blog / archive index — title band (not full hero) */
.archive-hero {
	text-align: center;
	padding: 0 0 2rem;
	margin-bottom: 0.5rem;
	border-bottom: 1px solid rgba(15, 15, 15, 0.08);
}

.archive-hero__eyebrow {
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--gf-ink-faint);
	margin: 0 0 0.5rem;
}

.archive-hero__title {
	font-family: var(--gf-font-display);
	font-size: clamp(1.85rem, 4vw, 2.5rem);
	font-weight: 800;
	letter-spacing: -0.04em;
	line-height: 1.1;
	color: var(--gf-ink);
	margin: 0;
}

.archive-hero__excerpt {
	margin: 0.75rem auto 0;
	max-width: 36rem;
	font-size: clamp(1rem, 2vw, 1.125rem);
	line-height: 1.55;
	font-weight: 500;
	color: var(--gf-ink-muted);
}

/* Archive */
.archive-card {
	padding: 2rem 0;
	border-bottom: 1px solid rgba(15, 15, 15, 0.06);
}

.archive-card__title {
	font-family: var(--gf-font-display);
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: -0.03em;
	margin: 0 0 0.35rem;
}

.archive-card__title a {
	color: var(--gf-ink);
	text-decoration: none;
	transition: color 0.2s var(--gf-ease-out);
}

.archive-card__title a:hover {
	color: var(--gf-accent);
}

.archive-card__meta {
	margin: 0;
	font-size: 0.8125rem;
	font-weight: 500;
	color: var(--gf-ink-faint);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.archive-card__thumb {
	display: block;
	margin: 1.25rem 0;
	border-radius: var(--gf-radius);
	overflow: hidden;
	border: 1px solid rgba(15, 15, 15, 0.06);
	box-shadow: var(--gf-shadow-sm);
}

.no-results {
	text-align: center;
	padding: 4rem var(--gf-pad-x);
}

/* Footer CTA band — same fill as before; thin seam from sunset (no gradient bleed into the strip) */
.footer-cta {
	background: var(--gf-cta-strip-bg);
	border-top: 1px solid var(--gf-sunset-end);
	color: #fff;
	padding: 2.5rem var(--gf-pad-x);
	margin-top: 0;
}

.footer-cta__inner {
	max-width: var(--gf-max);
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1.25rem;
	text-align: center;
}

.footer-cta__title {
	font-family: var(--gf-font-display);
	font-size: clamp(1.35rem, 3vw, 1.75rem);
	font-weight: 700;
	letter-spacing: -0.03em;
	margin: 0;
	line-height: 1.25;
	max-width: 28rem;
}

@media (min-width: 600px) {
	.footer-cta__inner {
		flex-direction: row;
		flex-wrap: wrap;
		text-align: left;
		justify-content: space-between;
	}

	.footer-cta__title {
		margin-right: auto;
	}
}

/* Footer */
.site-footer {
	background: linear-gradient(180deg, #141414 0%, #0a0a0a 100%);
	color: rgba(255, 255, 255, 0.88);
	padding: 3.5rem var(--gf-pad-x) 2.5rem;
	margin-top: 0;
	border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.site-footer a {
	color: var(--gf-gold);
}

.site-footer a:hover {
	color: #fde68a;
}

.site-footer__inner {
	max-width: var(--gf-max);
	margin: 0 auto;
	text-align: center;
}

.footer-menu {
	list-style: none;
	margin: 0 0 1.75rem;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.5rem 1.25rem;
}

.footer-menu a {
	color: rgba(255, 255, 255, 0.75);
	text-decoration: none;
	font-weight: 600;
	font-size: 0.875rem;
	letter-spacing: 0.02em;
	transition: color 0.2s var(--gf-ease-out);
}

.footer-menu a:hover {
	color: #fff;
}

.site-footer__copy {
	margin: 0;
	font-size: 0.8125rem;
	font-weight: 500;
	color: #c8c8c8;
	letter-spacing: 0.03em;
}

.site-footer__copy a {
	color: inherit;
	text-decoration: none;
}

.widget-title {
	font-family: var(--gf-font-display);
	font-size: 1.1rem;
	font-weight: 700;
	margin-bottom: 0.75rem;
}

.footer-widgets {
	margin-bottom: 2rem;
	text-align: left;
}

@media (min-width: 600px) {
	.footer-widgets {
		display: grid;
		gap: 1.5rem;
		grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	}
}

/* ——— PB Accordion (block editor) — modern cards ——— */
.wp-block-pb-accordion,
.entry-content .c-accordion {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
	margin: 1.75rem 0;
}

.wp-block-pb-accordion-item.c-accordion__item,
.entry-content .c-accordion__item {
	position: relative;
	background: var(--gf-bg-elevated);
	border: 1px solid rgba(15, 15, 15, 0.08);
	border-radius: var(--gf-radius);
	box-shadow: var(--gf-shadow-sm);
	overflow: hidden;
	transition:
		border-color 0.25s var(--gf-ease-out),
		box-shadow 0.25s var(--gf-ease-out);
}

.wp-block-pb-accordion-item.c-accordion__item:has(.c-accordion__title[aria-expanded="true"]),
.entry-content .c-accordion__item:has(.c-accordion__title[aria-expanded="true"]) {
	border-color: rgba(109, 40, 217, 0.28);
	box-shadow: 0 12px 40px rgba(109, 40, 217, 0.12);
}

/* Title row: block + absolutely positioned chevron so the caret stays inside the padded header bar (flex on h2/button is unreliable across browsers). */
.wp-block-pb-accordion-item > .c-accordion__title,
.entry-content .c-accordion__item > .c-accordion__title {
	position: relative;
	display: block !important;
	width: 100%;
	margin: 0 !important;
	padding: 1rem 2.65rem 1rem 1.25rem !important;
	font-family: var(--gf-font-display) !important;
	font-size: clamp(1.05rem, 2vw, 1.2rem) !important;
	font-weight: 800 !important;
	letter-spacing: -0.02em !important;
	line-height: 1.25 !important;
	color: var(--gf-ink) !important;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(250, 245, 255, 0.5) 100%);
	cursor: pointer;
	user-select: none;
	text-align: left !important;
	border: none !important;
	box-sizing: border-box;
	min-height: 3.25rem;
	transition: background 0.2s var(--gf-ease-out);
	-webkit-appearance: none;
	appearance: none;
}

.c-accordion__title:hover {
	background: linear-gradient(180deg, #fff 0%, rgba(237, 233, 254, 0.65) 100%);
	color: var(--gf-violet) !important;
}

.c-accordion__title:focus {
	outline: none;
}

.c-accordion__title:focus-visible {
	outline: 2px solid var(--gf-violet);
	outline-offset: 2px;
}

.wp-block-pb-accordion-item > .c-accordion__title::after,
.entry-content .c-accordion__item > .c-accordion__title::after {
	content: "";
	position: absolute;
	right: 1.2rem;
	top: 50%;
	width: 0.55rem;
	height: 0.55rem;
	margin: 0;
	border-right: 2.5px solid currentColor;
	border-bottom: 2.5px solid currentColor;
	opacity: 0.55;
	transform: translateY(-50%) rotate(45deg);
	transform-origin: 50% 50%;
	transition:
		transform 0.3s var(--gf-ease-out),
		opacity 0.2s ease;
	pointer-events: none;
}

.wp-block-pb-accordion-item > .c-accordion__title[aria-expanded="true"]::after,
.entry-content .c-accordion__item > .c-accordion__title[aria-expanded="true"]::after {
	transform: translateY(-50%) rotate(-135deg);
	opacity: 0.85;
}

.c-accordion__title[aria-expanded="true"] {
	border-bottom: 1px solid rgba(15, 15, 15, 0.06) !important;
}

.c-accordion__content {
	padding: 1.1rem 1.25rem 1.35rem !important;
	background: linear-gradient(180deg, rgba(255, 251, 248, 0.9) 0%, rgba(255, 255, 255, 0.98) 100%);
}

.c-accordion__content[hidden] {
	display: none !important;
}

.c-accordion__content .wp-block-heading,
.c-accordion__content h3 {
	position: relative;
	font-family: var(--gf-font-display);
	font-size: 1.05rem !important;
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--gf-ink);
	margin: 1.35rem 0 0 !important;
	padding: 0 0 0 0.75rem;
	line-height: 1.3;
}

.c-accordion__content .wp-block-heading::before,
.c-accordion__content h3::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.2em;
	bottom: 0.2em;
	width: 3px;
	border-radius: 2px;
	background: linear-gradient(180deg, var(--gf-accent), var(--gf-violet));
}

.c-accordion__content .wp-block-heading:first-child,
.c-accordion__content h3:first-of-type {
	margin-top: 0 !important;
}

.c-accordion__content p {
	margin: 0.4rem 0 0 !important;
	font-size: 0.95rem;
	line-height: 1.6;
	color: var(--gf-ink-muted);
	max-width: 40rem;
}

.c-accordion__content p + .wp-block-heading,
.c-accordion__content p + h3 {
	margin-top: 1.35rem !important;
}

@media (prefers-reduced-motion: reduce) {
	.wp-block-pb-accordion-item > .c-accordion__title::after,
	.entry-content .c-accordion__item > .c-accordion__title::after {
		transition: none;
	}
}
