/*
Theme Name: Theatre Custom Theme
Description: Theme sur mesure developpe pour le theatre.
Version: 1.0
Author: Ton Nom
*/

:root {
	--black: #100b0f;
	--black-2: #21131b;
	--cream: #fff1d2;
	--paper: #fff0d0;
	--pink: #c85b72;
	--red: #b5162e;
	--orange: #c95532;
	--gold: #c99a42;
	--acid: #e0bf63;
	--cyan: #c85b72;
	--blue: #4c1d2b;
	--violet: #7b2f49;
	--green: #9f7248;
	--muted: #5c4037;
	--ink: rgba(16, 11, 15, 0.15);
	--light-ink: rgba(255, 241, 210, 0.2);
	--glass: rgba(255, 255, 255, 0.34);
	--blur: blur(24px);
	--shadow: 0 24px 70px rgba(62, 18, 38, 0.22);
	--space: clamp(1rem, 2vw, 1.6rem);
	--max: 1280px;
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
	scroll-padding-top: 7rem;
}

body {
	background: var(--paper);
	color: var(--black);
	margin: 0;
	overflow-x: hidden;
}

h1,
h2,
h3,
.logo,
.nav-link,
.date-block span,
.poster-badge,
.season-metrics strong {
	font-family: Georgia, "Times New Roman", serif;
}

body.nav-open {
	overflow: hidden;
}

body::before {
	background:
		radial-gradient(circle at var(--mx, 50%) var(--my, 20%), rgba(181, 22, 46, 0.12), transparent 18rem),
		radial-gradient(circle at 16% 32%, rgba(123, 47, 73, 0.14), transparent 24rem),
		radial-gradient(circle at 82% 58%, rgba(201, 154, 66, 0.24), transparent 27rem),
		linear-gradient(135deg, #fff0d0 0%, #f5d3bd 46%, #ead09b 100%);
	content: "";
	inset: 0;
	pointer-events: none;
	position: fixed;
	z-index: -3;
}

body::after {
	background-image:
		linear-gradient(rgba(16, 11, 15, 0.045) 1px, transparent 1px),
		linear-gradient(90deg, rgba(16, 11, 15, 0.045) 1px, transparent 1px);
	background-size: 46px 46px;
	content: "";
	inset: 0;
	mask-image: linear-gradient(to bottom, transparent, #000 18%, #000 82%, transparent);
	opacity: 0.45;
	pointer-events: none;
	position: fixed;
	z-index: -2;
}

a {
	color: inherit;
	text-decoration: none;
}

:focus-visible {
	outline: 3px solid var(--red);
	outline-offset: 4px;
}

.skip-link {
	background: var(--black);
	border-radius: 999px;
	color: var(--cream);
	font-weight: 950;
	left: 1rem;
	padding: 0.85rem 1rem;
	position: fixed;
	top: 1rem;
	transform: translateY(-150%);
	transition: transform 180ms ease;
	z-index: 200;
}

.skip-link:focus {
	transform: translateY(0);
}

.scroll-progress {
	height: 4px;
	inset: 0 0 auto;
	position: fixed;
	z-index: 180;
}

.scroll-progress span {
	background: linear-gradient(90deg, var(--red), var(--pink), var(--gold));
	display: block;
	height: 100%;
	transform: scaleX(0);
	transform-origin: left;
	width: 100%;
}

.stage-noise {
	background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
	inset: 0;
	mix-blend-mode: multiply;
	opacity: 0.11;
	pointer-events: none;
	position: fixed;
	z-index: 100;
}

.cursor-orbit {
	border: 2px solid rgba(255, 36, 70, 0.38);
	border-radius: 999px;
	height: 34px;
	left: 0;
	mix-blend-mode: multiply;
	pointer-events: none;
	position: fixed;
	top: 0;
	transform: translate3d(-50%, -50%, 0);
	transition: height 180ms ease, width 180ms ease, border-color 180ms ease;
	width: 34px;
	z-index: 120;
}

.cursor-orbit.is-hot {
	border-color: var(--gold);
	height: 58px;
	width: 58px;
}

.site-header {
	backdrop-filter: var(--blur);
	background: rgba(255, 241, 210, 0.62);
	border-bottom: 2px solid rgba(16, 11, 15, 0.1);
	position: sticky;
	top: 0;
	transition: background 240ms ease, box-shadow 240ms ease;
	z-index: 60;
}

.site-header.is-scrolled {
	background: rgba(255, 241, 210, 0.92);
	box-shadow: 0 14px 40px rgba(151, 60, 90, 0.18);
}

.header-inner {
	align-items: center;
	display: grid;
	gap: 0.9rem;
	grid-template-columns: 1fr auto;
	margin: 0 auto;
	max-width: var(--max);
	padding: 1rem var(--space);
}

.logo {
	align-items: center;
	display: inline-flex;
	width: clamp(10rem, 18vw, 15.5rem);
}

.logo img {
	display: block;
	height: auto;
	width: 100%;
}

.menu-button {
	align-items: center;
	background: var(--gold);
	border: 1px solid var(--ink);
	border-radius: 60% 40% 48% 52% / 48% 56% 44% 52%;
	cursor: pointer;
	display: inline-flex;
	font-size: 0.82rem;
	font-weight: 900;
	gap: 0.6rem;
	letter-spacing: 0.08em;
	padding: 0.75rem 0.95rem;
	text-transform: uppercase;
	z-index: 82;
}

.menu-icon {
	display: grid;
	gap: 0.22rem;
	width: 1rem;
}

.menu-icon span {
	background: currentColor;
	border-radius: 999px;
	height: 2px;
	transition: transform 220ms ease, opacity 220ms ease;
}

.menu-button[aria-expanded="true"] .menu-icon span:nth-child(1) {
	transform: translateY(6px) rotate(45deg);
}

.menu-button[aria-expanded="true"] .menu-icon span:nth-child(2) {
	opacity: 0;
}

.menu-button[aria-expanded="true"] .menu-icon span:nth-child(3) {
	transform: translateY(-6px) rotate(-45deg);
}

.main-nav {
	background:
		radial-gradient(circle at 15% 20%, rgba(255, 111, 177, 0.38), transparent 34%),
		radial-gradient(circle at 85% 74%, rgba(32, 200, 255, 0.32), transparent 32%),
		var(--paper);
	clip-path: inset(0 0 100% 0 round 0 0 32px 32px);
	display: grid;
	grid-column: 1 / -1;
	inset: 0;
	min-height: 100dvh;
	opacity: 0;
	padding: 6.2rem var(--space) 2rem;
	pointer-events: none;
	position: fixed;
	transition: clip-path 520ms cubic-bezier(0.2, 1, 0.2, 1), opacity 220ms ease;
	z-index: 70;
}

.main-nav.is-open {
	clip-path: inset(0 0 0 0 round 0);
	opacity: 1;
	pointer-events: auto;
}

.nav-list,
.submenu,
.footer-nav {
	list-style: none;
	margin: 0;
	padding: 0;
}

.nav-list {
	display: grid;
	gap: 0.5rem;
	margin: auto 0;
	padding-top: 0.45rem;
}

.nav-item {
	position: relative;
}

.nav-link {
	align-items: center;
	border: 1px solid transparent;
	border-radius: 55% 45% 47% 53% / 48% 58% 42% 52%;
	display: flex;
	font-size: clamp(1.9rem, 11vw, 5.4rem);
	font-style: italic;
	font-weight: 900;
	letter-spacing: -0.085em;
	line-height: 0.82;
	justify-content: space-between;
	padding: 0.42rem 0;
}

.nav-link:hover,
.nav-link:focus-visible {
	background: var(--red);
	border-color: var(--black);
	color: #fff;
	outline: 0;
}

.has-submenu > .nav-link::after {
	color: var(--red);
	content: "+";
}

.submenu {
	background: rgba(255, 241, 210, 0.92);
	border: 1px solid var(--ink);
	border-radius: 24px 42px 28px 36px;
	display: grid;
	gap: 0.1rem;
	margin-bottom: 0.3rem;
	padding: 0.32rem;
}

.submenu a {
	border-radius: 6px;
	color: var(--black);
	display: block;
	font-weight: 750;
	padding: 0.72rem 0.78rem;
}

.submenu a:hover,
.submenu a:focus-visible {
	background: var(--red);
	color: #fff;
	outline: 0;
}

.search-shell {
	display: none;
	grid-column: 1 / -1;
	position: relative;
	z-index: 85;
}

.search-shell {
	display: block;
}

.search-form {
	background: #fff7e6;
	border: 1px solid var(--ink);
	border-radius: 999px 999px 999px 36px;
	display: flex;
	overflow: hidden;
}

.search-form input {
	background: transparent;
	border: 0;
	color: var(--black);
	font: inherit;
	outline: 0;
	padding: 0.95rem 1rem;
	width: 100%;
}

.search-form input::placeholder {
	color: rgba(16, 11, 15, 0.48);
}

.search-form button {
	background: var(--red);
	border: 0;
	color: #fff;
	cursor: pointer;
	font: inherit;
	font-weight: 950;
	min-height: 3rem;
	width: 4rem;
}

.search-panel {
	background: rgba(255, 247, 230, 0.94);
	backdrop-filter: var(--blur);
	border: 1px solid rgba(16, 11, 15, 0.12);
	border-radius: 24px 44px 26px 38px;
	box-shadow: var(--shadow);
	display: grid;
	gap: 0.35rem;
	inset: calc(100% + 0.55rem) 0 auto;
	opacity: 0;
	padding: 0.7rem;
	pointer-events: none;
	position: absolute;
	transform: translateY(-8px) scale(0.98);
	transform-origin: top;
	transition: opacity 180ms ease, transform 180ms ease;
	z-index: 90;
}

.search-panel.is-open {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0) scale(1);
}

.search-hint {
	color: var(--muted);
	font-size: 0.82rem;
	font-weight: 800;
	margin: 0;
	padding: 0.45rem 0.55rem;
}

.suggestion {
	align-items: center;
	background: transparent;
	border: 0;
	border-radius: 12px;
	color: var(--black);
	cursor: pointer;
	display: grid;
	font: inherit;
	gap: 0.1rem;
	grid-template-columns: auto 1fr auto;
	padding: 0.72rem 0.65rem;
	text-align: left;
	width: 100%;
}

.suggestion:hover,
.suggestion:focus-visible,
.suggestion.is-active {
	background: var(--gold);
	outline: 0;
}

.suggestion strong {
	font-size: 0.96rem;
	font-weight: 950;
}

.suggestion span {
	color: var(--muted);
	font-size: 0.78rem;
	font-weight: 850;
	text-transform: uppercase;
}

.suggestion mark {
	background: var(--violet);
	border-radius: 999px;
	color: #fff;
	font-size: 0.72rem;
	font-weight: 950;
	padding: 0.24rem 0.45rem;
}

.hero {
	min-height: clamp(620px, 88dvh, 900px);
	overflow: hidden;
	position: relative;
}

.hero::before {
	background:
		linear-gradient(100deg, rgba(255, 241, 210, 0.88), rgba(255, 241, 210, 0.16)),
		conic-gradient(from 220deg at 68% 42%, var(--red), var(--pink), var(--gold), var(--orange), var(--red));
	content: "";
	inset: 0;
	position: absolute;
	z-index: -2;
}

.hero::after {
	background:
		linear-gradient(90deg, rgba(16, 11, 15, 0.16) 1px, transparent 1px),
		linear-gradient(rgba(16, 11, 15, 0.12) 1px, transparent 1px);
	background-size: 9vw 9vw;
	content: "";
	inset: 0;
	opacity: 0.26;
	position: absolute;
	transform: skewY(-8deg) translateY(-8%);
	z-index: -1;
}

.hero .hero-copy::before {
	background: var(--acid);
	border-radius: 66% 34% 54% 46% / 38% 62% 38% 62%;
	content: "";
	filter: drop-shadow(18px 18px 0 rgba(255, 36, 70, 0.18));
	height: clamp(8rem, 20vw, 18rem);
	left: clamp(-3rem, -5vw, -1rem);
	position: absolute;
	top: clamp(5rem, 12vw, 10rem);
	transform: rotate(-12deg);
	width: clamp(9rem, 24vw, 21rem);
	z-index: -1;
}

.kinetic-words {
	color: rgba(16, 11, 15, 0.08);
	font-size: clamp(4rem, 17vw, 17rem);
	font-weight: 950;
	inset: 0;
	letter-spacing: -0.09em;
	line-height: 0.78;
	pointer-events: none;
	position: absolute;
	text-transform: uppercase;
}

.kinetic-words span {
	animation: drift-word 12s ease-in-out infinite alternate;
	position: absolute;
}

.kinetic-words span:nth-child(1) { left: 4%; top: 10%; }
.kinetic-words span:nth-child(2) { animation-delay: -3s; right: -5%; top: 2%; }
.kinetic-words span:nth-child(3) { animation-delay: -5s; bottom: 4%; left: -3%; }
.kinetic-words span:nth-child(4) { animation-delay: -7s; bottom: 22%; right: 10%; }
.kinetic-words span:nth-child(5) { animation-delay: -9s; left: 18%; top: 55%; }

.hero-inner,
.section {
	margin: 0 auto;
	max-width: var(--max);
	padding-left: var(--space);
	padding-right: var(--space);
}

.hero-inner {
	display: grid;
	gap: clamp(2rem, 5vw, 4rem);
	min-height: inherit;
	padding-bottom: clamp(3rem, 7vw, 6rem);
	padding-top: clamp(4.5rem, 9vw, 8rem);
	position: relative;
}

.hero-copy {
	align-self: center;
	max-width: 880px;
}

.kicker,
.card-meta {
	color: var(--red);
	display: block;
	font-size: 0.75rem;
	font-weight: 950;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

.hero h1,
.section-head h2 {
	font-size: clamp(3.45rem, 14vw, 10rem);
	font-weight: 950;
	font-style: italic;
	letter-spacing: -0.105em;
	line-height: 0.74;
	margin: 0;
	text-wrap: balance;
}

.hero h1 span:nth-child(1) {
	color: var(--black);
}

.hero h1 span:nth-child(2) {
	color: var(--red);
	text-shadow: 4px 4px 0 var(--gold);
	transform: translateX(clamp(0.8rem, 6vw, 5rem)) rotate(-1deg);
}

.hero h1 span:nth-child(3) {
	color: var(--violet);
	text-shadow: 4px 4px 0 var(--pink);
	transform: translateX(clamp(-0.4rem, -2vw, -2rem)) rotate(1.5deg);
}

.hero h1 span {
	display: block;
}

.hero p,
.section-head p {
	color: var(--muted);
	font-size: clamp(1.05rem, 2vw, 1.35rem);
	line-height: 1.7;
	max-width: 660px;
}

.hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.8rem;
	margin-top: 1.8rem;
}

.season-metrics {
	display: grid;
	gap: 0.65rem;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	margin-top: 1.7rem;
	max-width: 560px;
}

.season-metrics div {
	background: rgba(255, 247, 230, 0.58);
	border: 1px solid rgba(16, 11, 15, 0.12);
	border-radius: 16px;
	padding: 0.8rem;
}

.season-metrics strong {
	display: block;
	font-size: clamp(1.5rem, 5vw, 2.8rem);
	font-weight: 950;
	letter-spacing: -0.06em;
	line-height: 0.86;
}

.season-metrics span {
	color: var(--muted);
	display: block;
	font-size: 0.76rem;
	font-weight: 900;
	margin-top: 0.25rem;
	text-transform: uppercase;
}

.btn {
	align-items: center;
	border: 1px solid var(--ink);
	border-radius: 999px 999px 999px 30px;
	display: inline-flex;
	font-weight: 950;
	justify-content: center;
	min-height: 3.15rem;
	overflow: hidden;
	padding: 0.9rem 1.1rem;
	position: relative;
	text-transform: uppercase;
}

.btn::before {
	background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.35), transparent);
	content: "";
	height: 100%;
	left: -130%;
	position: absolute;
	top: 0;
	transform: skewX(-20deg);
	transition: left 520ms ease;
	width: 90%;
}

.btn:hover::before,
.btn:focus-visible::before {
	left: 140%;
}

.btn-primary {
	background: var(--red);
	color: #fff;
}

.btn-ghost {
	background: var(--gold);
	color: var(--black);
}

.btn-mini {
	background: var(--gold);
	color: var(--black);
	font-size: 0.82rem;
	min-height: 2.6rem;
	padding: 0.72rem 0.9rem;
	width: max-content;
}

.hero-card {
	align-self: end;
	background: #fff7e6;
	border: 2px solid var(--black);
	border-radius: 36px 18px 48px 20px;
	box-shadow: var(--shadow);
	overflow: hidden;
	transform: rotate(2.5deg);
	transform-style: preserve-3d;
}

.poster-canvas {
	aspect-ratio: 4 / 4.6;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.22), transparent),
		linear-gradient(135deg, var(--red) 0 28%, var(--pink) 28% 50%, var(--gold) 50% 73%, var(--orange) 73% 100%);
	clip-path: polygon(0 0, 100% 0, 100% 90%, 78% 96%, 48% 88%, 22% 100%, 0 91%);
	min-height: 330px;
	overflow: hidden;
	position: relative;
}

.poster-canvas::after {
	animation: color-scan 6s ease-in-out infinite alternate;
	background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.48), transparent);
	content: "";
	inset: 0 auto 0 -60%;
	position: absolute;
	transform: skewX(-18deg);
	width: 48%;
}

.sun {
	background: var(--acid);
	border-radius: 50%;
	filter: blur(1px);
	height: 46%;
	left: 27%;
	position: absolute;
	top: 21%;
	width: 46%;
}

.mask {
	background: var(--black);
	border-radius: 50% 50% 42% 42%;
	height: 38%;
	position: absolute;
	top: 29%;
	width: 24%;
}

.mask::before {
	background: var(--violet);
	border-radius: 999px;
	content: "";
	height: 16px;
	position: absolute;
	top: 34%;
	width: 34px;
}

.mask-left {
	left: 16%;
	transform: rotate(-18deg);
}

.mask-left::before {
	right: -14px;
}

.mask-right {
	right: 16%;
	transform: rotate(18deg);
}

.mask-right::before {
	left: -14px;
}

.poster-badge {
	animation: badge-breathe 2.8s ease-in-out infinite;
	background: var(--red);
	border-radius: 999px;
	box-shadow: var(--shadow);
	font-size: clamp(1.5rem, 6vw, 3rem);
	font-weight: 950;
	left: 50%;
	padding: 0.7rem 1rem;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%) rotate(-8deg);
}

.poster-content {
	padding: 1.3rem;
}

.poster-content h2 {
	font-size: clamp(1.6rem, 5vw, 2.5rem);
	letter-spacing: -0.05em;
	line-height: 0.95;
	margin: 0.4rem 0 0;
}

.poster-content p {
	color: var(--muted);
	line-height: 1.58;
	margin-bottom: 0;
}

.section {
	padding-bottom: clamp(3.5rem, 7vw, 7rem);
	padding-top: clamp(3.5rem, 7vw, 7rem);
}

.section-head {
	margin-bottom: clamp(1.5rem, 4vw, 3rem);
	position: relative;
}

.section-head.wide {
	max-width: 980px;
}

.section-scribble {
	color: var(--red);
	font-family: Georgia, "Times New Roman", serif;
	font-size: clamp(2rem, 8vw, 6.4rem);
	font-style: italic;
	font-weight: 950;
	letter-spacing: -0.08em;
	line-height: 0.72;
	margin: -1rem 0 1.2rem auto;
	max-width: 420px;
	opacity: 0.9;
	text-align: right;
	text-shadow: 4px 4px 0 var(--gold);
	transform: rotate(-8deg);
}

.section-scribble-right {
	color: var(--violet);
	margin-left: 0;
	margin-right: auto;
	text-align: left;
	text-shadow: 4px 4px 0 var(--gold);
	transform: rotate(6deg);
}

.split-section {
	position: relative;
}

.split-section::before {
	background: linear-gradient(180deg, var(--red), var(--pink));
	content: "";
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	transform: skewX(-16deg) translateX(-82%);
	width: 45vw;
	z-index: -1;
}

.cards-grid,
.show-grid,
.info-grid {
	container-type: inline-size;
	display: grid;
	gap: clamp(1rem, 3vw, 2rem);
}

.event-card,
.show-card,
.info-card {
	background: rgba(255, 247, 230, 0.78);
	border: 2px solid rgba(16, 11, 15, 0.12);
	border-radius: 34px 18px 44px 22px;
	box-shadow: 0 18px 60px rgba(0, 0, 0, 0.24);
	transform-style: preserve-3d;
}

@container (max-width: 360px) {
	.event-card {
		grid-template-columns: 1fr;
	}

	.date-block {
		height: auto;
		min-height: 4.7rem;
		width: 100%;
	}
}

.event-card {
	display: grid;
	gap: 1rem;
	grid-template-columns: auto 1fr;
	padding: 1rem;
}

.event-card:nth-child(2n) {
	transform: rotate(-1deg);
}

.event-card:nth-child(3n) {
	transform: rotate(1.2deg) translateY(1.5rem);
}

.date-block {
	background: var(--blue);
	border-radius: 42% 58% 56% 44% / 46% 38% 62% 54%;
	color: #fff;
	display: grid;
	height: 5.3rem;
	place-items: center;
	width: 5.3rem;
}

.date-block span {
	font-size: 2rem;
	font-weight: 950;
	line-height: 0.8;
}

.date-block small {
	font-weight: 900;
	text-transform: uppercase;
}

.event-card h3,
.show-card h3,
.info-card h3 {
	font-size: clamp(1.45rem, 4vw, 2.35rem);
	font-style: italic;
	letter-spacing: -0.07em;
	line-height: 0.88;
	margin: 0.35rem 0;
}

.event-card p,
.show-card p,
.info-card p {
	color: var(--muted);
	line-height: 1.62;
	margin: 0 0 1rem;
}

.card-link {
	color: var(--red);
	font-weight: 950;
	text-transform: uppercase;
}

.marquee-section {
	overflow: hidden;
	position: relative;
}

.marquee {
	border-bottom: 1px solid var(--ink);
	border-top: 1px solid var(--ink);
	color: var(--red);
	display: flex;
	font-size: clamp(2.6rem, 10vw, 8rem);
	font-weight: 950;
	font-family: Georgia, "Times New Roman", serif;
	font-style: italic;
	gap: 1rem;
	left: 50%;
	letter-spacing: -0.07em;
	line-height: 1;
	margin-bottom: clamp(2rem, 6vw, 4rem);
	position: relative;
	text-transform: uppercase;
	transform: translateX(-50%) rotate(-2deg);
	width: 110vw;
	text-shadow: 4px 4px 0 var(--gold);
	-webkit-text-stroke: 0;
}

.marquee span {
	animation: marquee 24s linear infinite;
	flex: 0 0 auto;
	padding: 0.3rem 0;
}

.show-card {
	overflow: hidden;
}

.show-card:nth-child(odd) {
	transform: rotate(-1.4deg);
}

.show-card:nth-child(even) {
	transform: rotate(1deg) translateY(1.2rem);
}

.show-visual {
	aspect-ratio: 1 / 1;
	display: grid;
	min-height: 280px;
	overflow: hidden;
	place-items: center;
	position: relative;
}

.show-visual::before {
	background:
		repeating-linear-gradient(45deg, rgba(255, 255, 255, 0.16) 0 2px, transparent 2px 16px),
		radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.25), transparent 38%);
	content: "";
	inset: -20%;
	position: absolute;
	transform: rotate(12deg);
}

.show-visual span {
	border: 2px solid rgba(255, 255, 255, 0.7);
	border-radius: 999px 999px 999px 24px;
	font-size: 1.3rem;
	font-weight: 950;
	padding: 1rem 1.2rem;
	position: relative;
}

.ink-red { background: linear-gradient(135deg, #ff1238, #24060b); }
.ink-gold { background: linear-gradient(135deg, var(--gold), var(--orange)); }
.ink-blue { background: linear-gradient(135deg, var(--pink), var(--violet)); }

.show-body {
	display: grid;
	gap: 0.5rem;
	padding: 1.25rem;
}

.info-band {
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.54), transparent),
		#d7ff43;
	color: var(--black);
	position: relative;
}

.info-band::before {
	background: linear-gradient(90deg, var(--red), var(--pink), var(--gold));
	content: "";
	height: 2rem;
	left: 0;
	position: absolute;
	top: 0;
	transform: skewY(-1.5deg) translateY(-50%);
	width: 100%;
}

.info-band .kicker {
	color: var(--red);
}

.info-band .section-head p,
.info-card p {
	color: #4a4035;
}

.info-card {
	background: #fff7e6;
	border-color: rgba(7, 7, 7, 0.14);
	color: var(--black);
	padding: 1.25rem;
}

.info-card:nth-child(2) {
	transform: rotate(1.5deg) translateY(1rem);
}

.info-card:nth-child(3) {
	transform: rotate(-1deg);
}

.info-card > span {
	color: var(--red);
	font-size: 0.78rem;
	font-weight: 950;
	letter-spacing: 0.16em;
}

.partners,
.site-footer {
	background: #1a0710;
	color: var(--cream);
}

.partners {
	border-top: 1px solid var(--ink);
	padding: clamp(2rem, 5vw, 4rem) var(--space);
}

.partner-strip {
	align-items: center;
	display: grid;
	gap: clamp(1.2rem, 4vw, 3rem);
	grid-template-columns: repeat(2, minmax(0, 1fr));
	margin: 0 auto;
	max-width: 1040px;
}

.partner-logo {
	align-items: center;
	display: flex;
	justify-content: center;
	min-height: 4.6rem;
	padding: 0;
	transition: filter 220ms ease, opacity 220ms ease, transform 220ms ease;
}

.partner-logo:hover,
.partner-logo:focus-visible {
	filter: saturate(1.08) contrast(1.04);
	outline: 0;
	transform: translateY(-4px);
}

.partner-logo img {
	filter: drop-shadow(0 12px 22px rgba(0, 0, 0, 0.22));
	height: clamp(2.4rem, 5vw, 4.2rem);
	max-width: 100%;
	object-fit: contain;
	width: auto;
}

.site-footer {
	border-top: 1px solid var(--ink);
}

.footer-nav {
	display: grid;
	gap: 0.4rem;
	margin: 0 auto;
	max-width: var(--max);
	padding: 1rem var(--space);
}

.footer-nav a {
	border-radius: 999px;
	display: block;
	font-weight: 850;
	padding: 0.85rem;
	text-align: center;
}

.footer-nav a:hover,
.footer-nav a:focus-visible {
	background: rgba(255, 111, 177, 0.18);
	color: var(--gold);
	outline: 0;
}

.no-results {
	background: rgba(255, 36, 70, 0.16);
	border: 1px solid rgba(255, 18, 56, 0.4);
	border-radius: 8px;
	color: var(--cream);
	display: none;
	font-weight: 850;
	margin-top: 1.2rem;
	padding: 1rem;
}

.no-results.is-visible {
	display: block;
}

.results-status {
	clip: rect(0 0 0 0);
	height: 1px;
	overflow: hidden;
	position: absolute;
	width: 1px;
}

.is-hidden {
	display: none;
}

[data-reveal] {
	opacity: 0;
	transform: translateY(38px) scale(0.98);
	transition: opacity 700ms ease, transform 700ms cubic-bezier(0.2, 1, 0.2, 1);
}

[data-reveal].is-visible {
	opacity: 1;
	transform: translateY(0) scale(1);
}

.result-card {
	opacity: 0;
	transform: translateY(28px) scale(0.985);
	transition: opacity 260ms ease, transform 260ms ease, border-color 260ms ease;
}

.result-card.is-visible {
	opacity: 1;
	transform: translateY(0) scale(1);
}

.result-card:hover {
	border-color: rgba(244, 182, 66, 0.55);
}

@keyframes marquee {
	from { transform: translateX(0); }
	to { transform: translateX(calc(-100% - 1rem)); }
}

@keyframes drift-word {
	from { transform: translate3d(-1.2rem, 0, 0) rotate(-2deg); }
	to { transform: translate3d(1.2rem, -1rem, 0) rotate(2deg); }
}

@keyframes color-scan {
	from { left: -70%; }
	to { left: 120%; }
}

@keyframes badge-breathe {
	0%, 100% { transform: translate(-50%, -50%) rotate(-8deg) scale(1); }
	50% { transform: translate(-50%, -50%) rotate(-4deg) scale(1.06); }
}

@media (min-width: 680px) {
	.cards-grid,
	.show-grid,
	.info-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.partner-strip {
		grid-template-columns: repeat(5, minmax(0, 1fr));
	}

	.footer-nav {
		grid-template-columns: repeat(5, minmax(0, 1fr));
	}
}

@media (min-width: 1020px) {
	.header-inner {
		grid-template-columns: auto 1fr minmax(240px, 320px);
	}

	.menu-button {
		display: none;
	}

	.main-nav {
		background: transparent;
		clip-path: none;
		grid-column: auto;
		inset: auto;
		min-height: auto;
		opacity: 1;
		padding: 0;
		pointer-events: auto;
		position: static;
		transition: none;
	}

	.nav-list {
		align-items: center;
		display: flex;
		gap: 0.1rem;
		justify-content: center;
		padding: 0;
	}

	.nav-link {
		font-size: 0.86rem;
		letter-spacing: 0;
		line-height: 1;
		min-height: 3rem;
		padding: 0.76rem 0.62rem;
	}

	.has-submenu > .nav-link::after {
		content: "";
	}

	.submenu {
		background: rgba(255, 247, 230, 0.94);
		backdrop-filter: var(--blur);
		box-shadow: var(--shadow);
		display: none;
		left: 0;
		margin: 0;
		min-width: 235px;
		position: absolute;
		top: calc(100% + 0.4rem);
	}

	.nav-item:hover .submenu,
	.nav-item:focus-within .submenu {
		display: grid;
	}

	.search-shell {
		display: flex;
		grid-column: auto;
	}

	.search-form {
		width: 100%;
	}

	.hero-inner {
		grid-template-columns: minmax(0, 1.25fr) minmax(330px, 0.75fr);
	}

	.hero-card {
		max-width: 420px;
	}

	.cards-grid,
	.show-grid {
		grid-template-columns: repeat(12, minmax(0, 1fr));
	}

	.event-card {
		grid-column: span 4;
	}

	.event-card:nth-child(1) {
		grid-column: span 4;
	}

	.event-card:nth-child(3) {
		grid-column: span 4;
	}

	.show-card {
		grid-column: span 4;
	}

	.show-card:nth-child(1) {
		grid-column: span 4;
	}

	.show-card:nth-child(2) {
		grid-column: span 4;
	}

	.show-card:nth-child(3) {
		grid-column: span 4;
	}

	.info-layout {
		display: grid;
		gap: 2rem;
		grid-template-columns: minmax(0, 0.85fr) minmax(520px, 1fr);
	}

	.info-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.program-grid {
		grid-template-columns: repeat(12, minmax(0, 1fr));
	}

	.program-card {
		grid-column: span 4;
	}

	.program-card:nth-child(5n + 1) {
		grid-column: span 5;
	}

	.program-card:nth-child(5n + 2) {
		grid-column: span 3;
	}

	.program-card:nth-child(5n + 5) {
		grid-column: 2 / span 5;
	}
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		scroll-behavior: auto !important;
		transition-duration: 0.01ms !important;
	}

	.cursor-orbit {
		display: none;
	}
}

/* Simple rounded UI cards: events and shows share one clean visual language. */
.cards-grid .event-card,
.show-grid .show-card {
	background: rgba(255, 247, 252, 0.92);
	border: 1px solid rgba(111, 74, 168, 0.16);
	border-radius: 24px;
	box-shadow: 0 18px 42px rgba(67, 37, 92, 0.18);
	display: grid;
	gap: 0;
	grid-template-columns: 1fr;
	grid-template-rows: auto 1fr;
	overflow: hidden;
	padding: 0.9rem;
	transform: none;
}

.cards-grid .event-card:nth-child(n),
.show-grid .show-card:nth-child(n) {
	transform: none;
}

.cards-grid .date-block,
.show-grid .show-visual {
	aspect-ratio: 16 / 10;
	background:
		radial-gradient(circle at 24% 22%, rgba(255, 255, 255, 0.34), transparent 18%),
		linear-gradient(135deg, #d8a0ad, #f0c2b1);
	border-radius: 18px;
	color: #9c3fd3;
	display: grid;
	height: auto;
	min-height: 190px;
	overflow: hidden;
	place-items: center;
	position: relative;
	width: 100%;
}

.cards-grid .event-card:nth-child(2) .date-block,
.show-grid .show-card:nth-child(2) .show-visual {
	background:
		radial-gradient(circle at 24% 22%, rgba(255, 255, 255, 0.34), transparent 18%),
		linear-gradient(135deg, #c85b72, #e5a674);
}

.cards-grid .event-card:nth-child(3) .date-block,
.show-grid .show-card:nth-child(3) .show-visual {
	background:
		radial-gradient(circle at 24% 22%, rgba(255, 255, 255, 0.34), transparent 18%),
		linear-gradient(135deg, #7b2f49, #c99a42);
}

.cards-grid .date-block::before,
.show-grid .show-visual::before {
	background:
		linear-gradient(135deg, transparent 0 56%, rgba(111, 74, 168, 0.08) 56% 100%),
		radial-gradient(circle at 70% 68%, rgba(255, 255, 255, 0.28), transparent 22%);
	content: "";
	inset: 0;
	position: absolute;
}

.cards-grid .date-block::after,
.show-grid .show-visual::after {
	background: currentColor;
	border-radius: 16px;
	content: "";
	height: 3.5rem;
	position: absolute;
	width: 4.4rem;
}

.cards-grid .date-block span,
.show-grid .show-visual span {
	background: transparent;
	border: 0;
	color: rgba(255, 255, 255, 0.82);
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
	font-size: clamp(1rem, 3vw, 1.45rem);
	font-style: normal;
	font-weight: 950;
	line-height: 1;
	padding: 0;
	position: relative;
	text-align: center;
	z-index: 2;
}

.cards-grid .date-block small {
	display: none;
}

.cards-grid .event-card > div:last-child,
.show-grid .show-body {
	display: grid;
	gap: 0.45rem;
	padding: 1rem 0.25rem 0.15rem;
}

.cards-grid .event-card h3,
.show-grid .show-card h3 {
	color: #291525;
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
	font-size: clamp(1.22rem, 3vw, 1.55rem);
	font-style: normal;
	font-weight: 900;
	letter-spacing: -0.035em;
	line-height: 1.05;
	margin: 0.15rem 0;
}

.cards-grid .card-meta,
.show-grid .card-meta {
	color: #9b4770;
	font-size: 0.72rem;
	letter-spacing: 0.08em;
}

.cards-grid .event-card p,
.show-grid .show-card p {
	color: #6f5665;
	font-size: 0.95rem;
	line-height: 1.55;
	margin-bottom: 0.75rem;
}

.cards-grid .card-link,
.show-grid .btn-mini {
	background: transparent;
	color: var(--red);
	font-size: 0.8rem;
	min-height: auto;
	padding: 0;
	text-transform: uppercase;
	width: max-content;
}

.inner-page {
	background:
		radial-gradient(circle at 15% 12%, rgba(255, 111, 177, 0.28), transparent 25rem),
		radial-gradient(circle at 86% 22%, rgba(32, 200, 255, 0.24), transparent 24rem),
		var(--paper);
	min-height: 70dvh;
	padding: clamp(3rem, 7vw, 6rem) var(--space);
}

.inner-wrap {
	margin: 0 auto;
	max-width: var(--max);
}

.inner-hero {
	display: grid;
	gap: 1.25rem;
	margin-bottom: clamp(2rem, 5vw, 4rem);
}

.inner-hero h1 {
	color: var(--black);
	font-size: clamp(3rem, 12vw, 8rem);
	font-style: italic;
	font-weight: 950;
	letter-spacing: -0.105em;
	line-height: 0.74;
	margin: 0;
	max-width: 980px;
	text-wrap: balance;
}

.inner-hero p {
	color: var(--muted);
	font-size: clamp(1.05rem, 2vw, 1.3rem);
	line-height: 1.7;
	margin: 0;
	max-width: 760px;
}

.content-stack {
	display: grid;
	gap: 1rem;
}

.text-panel,
.notice-panel,
.newsletter-card {
	background: rgba(255, 247, 230, 0.82);
	border: 2px solid rgba(16, 11, 15, 0.12);
	border-radius: 38px 18px 48px 24px;
	box-shadow: var(--shadow);
	padding: clamp(1.1rem, 3vw, 2rem);
}

.text-panel h2,
.notice-panel h2,
.newsletter-card h2 {
	font-size: clamp(1.6rem, 5vw, 3.6rem);
	font-style: italic;
	letter-spacing: -0.085em;
	line-height: 0.82;
	margin: 0 0 1rem;
}

.text-panel h3 {
	color: var(--red);
	font-size: clamp(1.15rem, 3vw, 1.7rem);
	margin: 1.2rem 0 0.5rem;
}

.text-panel p,
.text-panel li,
.notice-panel p,
.newsletter-card p {
	color: var(--muted);
	font-size: 1rem;
	line-height: 1.7;
}

.text-panel strong {
	color: var(--black);
}

.program-grid {
	display: grid;
	gap: clamp(1rem, 3vw, 2.4rem);
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
}

.program-card {
	background: rgba(255, 247, 230, 0.84);
	border: 2px solid rgba(16, 11, 15, 0.12);
	border-radius: 36px 18px 48px 24px;
	box-shadow: var(--shadow);
	display: grid;
	gap: 1rem;
	overflow: hidden;
	padding: 1rem;
	position: relative;
}

.program-card:nth-child(4n + 1) {
	transform: rotate(-1.2deg);
}

.program-card:nth-child(4n + 2) {
	transform: rotate(1deg) translateY(1.2rem);
}

.program-card:nth-child(4n + 3) {
	transform: rotate(-0.5deg) translateY(-0.4rem);
}

.program-card::before {
	background: linear-gradient(90deg, var(--red), var(--pink), var(--gold));
	content: "";
	height: 7px;
	inset: 0 0 auto;
	position: absolute;
}

.program-card h2 {
	font-size: clamp(1.35rem, 4vw, 2.25rem);
	font-style: italic;
	letter-spacing: -0.07em;
	line-height: 0.88;
	margin: 0;
	padding-top: 0.75rem;
}

.program-date {
	color: var(--red);
	font-size: 0.78rem;
	font-weight: 950;
	letter-spacing: 0.11em;
	text-transform: uppercase;
}

.program-card p {
	color: var(--muted);
	line-height: 1.62;
	margin: 0;
}

.program-thumb {
	aspect-ratio: 4 / 3;
	background:
		radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.5), transparent 28%),
		linear-gradient(135deg, var(--pink), var(--gold), var(--orange));
	border-radius: 42% 58% 36% 64% / 52% 38% 62% 48%;
	display: grid;
	min-height: 170px;
	overflow: hidden;
	place-items: center;
}

.program-thumb span {
	background: var(--black);
	border-radius: 999px;
	color: var(--cream);
	font-size: 0.78rem;
	font-weight: 950;
	letter-spacing: 0.12em;
	padding: 0.65rem 0.8rem;
	text-transform: uppercase;
}

.mini-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-top: 1rem;
}

.empty-state {
	background: rgba(32, 200, 255, 0.16);
	border: 2px dashed rgba(24, 87, 255, 0.35);
	border-radius: 34px 18px 46px 22px;
	color: var(--black);
	font-size: 1.05rem;
	font-weight: 850;
	padding: 1.2rem;
}

.map-visual,
.brochure-visual {
	aspect-ratio: 4 / 3;
	background:
		linear-gradient(90deg, rgba(255, 255, 255, 0.8) 10px, transparent 10px 50px),
		linear-gradient(rgba(255, 255, 255, 0.8) 10px, transparent 10px 50px),
		linear-gradient(135deg, #f1c0ad, #ead09b);
	background-size: 62px 62px, 62px 62px, auto;
	border: 2px solid rgba(16, 11, 15, 0.12);
	border-radius: 44px 18px 60px 24px;
	box-shadow: var(--shadow);
	display: grid;
	min-height: 320px;
	place-items: center;
	position: relative;
}

.map-pin {
	background: var(--red);
	border: 5px solid var(--cream);
	border-radius: 50% 50% 50% 0;
	box-shadow: 0 14px 40px rgba(0, 0, 0, 0.22);
	height: 4.5rem;
	transform: rotate(-45deg);
	width: 4.5rem;
}

.map-pin::after {
	background: var(--cream);
	border-radius: 999px;
	content: "";
	height: 1.1rem;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 1.1rem;
}

.brochure-visual {
	background:
		radial-gradient(circle at 18% 18%, var(--red) 0 17%, transparent 17.5%),
		radial-gradient(circle at 35% 72%, rgba(255, 255, 255, 0.35) 0 20%, transparent 20.5%),
		radial-gradient(circle at 78% 58%, rgba(255, 210, 63, 0.85) 0 13%, transparent 13.5%),
		linear-gradient(135deg, #a86abc, #7b3bb3);
	color: #fff;
	font-size: clamp(2.5rem, 9vw, 6rem);
	font-weight: 950;
	letter-spacing: -0.07em;
	line-height: 0.82;
	padding: 2rem;
	text-align: center;
}

.form-row {
	display: grid;
	gap: 0.7rem;
}

.form-row input {
	background: #fff7e6;
	border: 2px solid rgba(16, 11, 15, 0.16);
	border-radius: 999px;
	font: inherit;
	padding: 1rem 1.1rem;
}

@media (min-width: 880px) {
	.two-col {
		align-items: start;
		display: grid;
		gap: 2rem;
		grid-template-columns: minmax(0, 0.9fr) minmax(320px, 0.7fr);
	}
}

/* Silo-inspired art direction: bold theatre poster system. */
:root {
	--silo-black: #050505;
	--silo-ink: #111111;
	--silo-paper: #f6f0dd;
	--silo-acid: #d8ff39;
	--silo-red: #ec1238;
	--silo-muted: #8d806b;
	--silo-line: rgba(246, 240, 221, 0.22);
}

body {
	background: var(--silo-black);
	color: var(--silo-paper);
}

body::before {
	background:
		radial-gradient(circle at var(--mx, 50%) var(--my, 20%), rgba(216, 255, 57, 0.16), transparent 22rem),
		linear-gradient(180deg, #050505 0%, #050505 58%, #17120d 100%);
}

body::after {
	background-image:
		linear-gradient(rgba(246, 240, 221, 0.045) 1px, transparent 1px),
		linear-gradient(90deg, rgba(246, 240, 221, 0.045) 1px, transparent 1px);
	opacity: 0.3;
}

.site-header {
	background: rgba(5, 5, 5, 0.88);
	border-bottom: 1px solid var(--silo-line);
}

.site-header.is-scrolled {
	background: rgba(5, 5, 5, 0.96);
	box-shadow: 0 18px 50px rgba(0, 0, 0, 0.36);
}

.logo {
	width: clamp(10rem, 16vw, 14rem);
}

.menu-button,
.search-form button,
.btn-primary {
	background: var(--silo-acid);
	border-color: var(--silo-acid);
	color: var(--silo-black);
}

.btn-ghost {
	background: transparent;
	border-color: var(--silo-paper);
	color: var(--silo-paper);
}

.nav-link {
	color: var(--silo-paper);
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
	font-size: 0.95rem;
	font-style: normal;
	font-weight: 900;
	letter-spacing: -0.02em;
	text-transform: uppercase;
}

.nav-link:hover,
.nav-link:focus-visible,
.submenu a:hover,
.submenu a:focus-visible {
	background: var(--silo-acid);
	color: var(--silo-black);
}

.submenu,
.search-panel {
	background: var(--silo-paper);
	color: var(--silo-black);
}

.search-form {
	background: var(--silo-paper);
	border-color: transparent;
}

.hero {
	background: var(--silo-black);
	min-height: min(920px, 92dvh);
}

.hero::before {
	background:
		linear-gradient(90deg, rgba(5, 5, 5, 0.35), rgba(5, 5, 5, 0.2)),
		radial-gradient(circle at 73% 48%, rgba(216, 255, 57, 0.95), rgba(216, 255, 57, 0.78) 20%, transparent 20.5%),
		var(--silo-black);
}

.hero::after {
	background: none;
}

.kinetic-words {
	color: transparent;
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
	font-size: clamp(4.5rem, 15vw, 15rem);
	font-style: normal;
	font-weight: 950;
	letter-spacing: -0.08em;
	opacity: 0.5;
	-webkit-text-stroke: 1px rgba(246, 240, 221, 0.18);
}

.hero-inner {
	grid-template-columns: minmax(0, 1fr);
	max-width: none;
	padding-inline: clamp(1rem, 4vw, 5rem);
}

.hero-copy {
	max-width: 1180px;
}

.kicker,
.card-meta {
	color: var(--silo-acid);
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
	letter-spacing: 0.12em;
}

.hero h1 {
	color: var(--silo-paper);
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
	font-size: clamp(4.2rem, 16vw, 14.5rem);
	font-style: normal;
	font-weight: 950;
	letter-spacing: -0.1em;
	line-height: 0.72;
	max-width: 1200px;
	text-transform: uppercase;
}

.hero h1 span:nth-child(n) {
	color: var(--silo-paper);
	text-shadow: none;
	transform: none;
}

.hero h1 span:nth-child(2) {
	color: var(--silo-acid);
}

.hero p {
	color: var(--silo-paper);
	font-size: clamp(1.1rem, 2vw, 1.55rem);
	max-width: 680px;
}

.season-metrics {
	max-width: 720px;
}

.season-metrics div {
	background: transparent;
	border: 1px solid var(--silo-line);
	border-radius: 999px;
	color: var(--silo-paper);
}

.season-metrics strong {
	color: var(--silo-acid);
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
	font-style: normal;
}

.season-metrics span {
	color: var(--silo-paper);
}

.hero-card {
	background: var(--silo-paper);
	border: 0;
	border-radius: 999px 999px 32px 32px;
	color: var(--silo-black);
	max-width: 430px;
	position: absolute;
	right: clamp(1rem, 6vw, 6rem);
	top: clamp(8rem, 16vw, 13rem);
	transform: rotate(-4deg);
	width: min(34vw, 430px);
}

.poster-canvas {
	background:
		radial-gradient(circle at 50% 50%, var(--silo-acid) 0 34%, transparent 34.5%),
		linear-gradient(135deg, var(--silo-red), #7c1224);
	clip-path: none;
}

.poster-badge {
	background: var(--silo-black);
	color: var(--silo-acid);
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
}

.poster-content h2 {
	color: var(--silo-black);
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
	font-style: normal;
	letter-spacing: -0.05em;
	text-transform: uppercase;
}

.poster-content p {
	color: #352e27;
}

.section {
	max-width: none;
	padding: clamp(4rem, 8vw, 7rem) clamp(1rem, 4vw, 5rem);
}

.split-section,
.marquee-section {
	background: var(--silo-paper);
	color: var(--silo-black);
}

.split-section::before {
	display: none;
}

.section-head,
.section-head.wide {
	border-top: 1px solid rgba(5, 5, 5, 0.22);
	display: grid;
	gap: 1rem;
	max-width: none;
	padding-top: 1.2rem;
}

.section-head h2 {
	color: var(--silo-black);
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
	font-size: clamp(4rem, 13vw, 12rem);
	font-style: normal;
	font-weight: 950;
	letter-spacing: -0.1em;
	line-height: 0.72;
	text-transform: uppercase;
}

.section-head p {
	color: #43372d;
	font-size: clamp(1rem, 1.6vw, 1.25rem);
}

.section-scribble {
	color: var(--silo-red);
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
	font-size: clamp(2rem, 6vw, 5.5rem);
	font-style: normal;
	letter-spacing: -0.08em;
	line-height: 0.8;
	text-shadow: none;
	text-transform: uppercase;
}

.marquee {
	background: var(--silo-black);
	border: 0;
	color: var(--silo-acid);
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
	font-style: normal;
	text-shadow: none;
	-webkit-text-stroke: 0;
}

.cards-grid,
.show-grid {
	gap: clamp(1rem, 2vw, 1.5rem);
}

.cards-grid .event-card,
.show-grid .show-card {
	background: #fbf5e7;
	border: 0;
	border-radius: 28px;
	box-shadow: 0 18px 50px rgba(5, 5, 5, 0.18);
	padding: 0.85rem;
}

.cards-grid .date-block,
.show-grid .show-visual {
	background:
		linear-gradient(135deg, rgba(216, 255, 57, 0.82), rgba(216, 255, 57, 0.5)),
		var(--silo-red);
	border-radius: 22px;
	color: var(--silo-black);
}

.cards-grid .event-card:nth-child(2) .date-block,
.show-grid .show-card:nth-child(2) .show-visual,
.cards-grid .event-card:nth-child(3) .date-block,
.show-grid .show-card:nth-child(3) .show-visual {
	background:
		linear-gradient(135deg, rgba(216, 255, 57, 0.82), rgba(216, 255, 57, 0.5)),
		var(--silo-red);
}

.cards-grid .date-block::before,
.cards-grid .date-block::after,
.show-grid .show-visual::before,
.show-grid .show-visual::after {
	display: none;
}

.cards-grid .date-block span,
.show-grid .show-visual span {
	background: transparent;
	color: var(--silo-black);
	font-size: clamp(1.5rem, 4vw, 3rem);
	text-transform: uppercase;
}

.cards-grid .event-card h3,
.show-grid .show-card h3 {
	color: var(--silo-black);
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
	font-size: clamp(1.45rem, 3vw, 2.15rem);
	font-style: normal;
	font-weight: 950;
	letter-spacing: -0.06em;
	text-transform: uppercase;
}

.cards-grid .card-meta,
.show-grid .card-meta {
	color: var(--silo-red);
}

.cards-grid .event-card p,
.show-grid .show-card p {
	color: #4c4035;
}

.cards-grid .card-link,
.show-grid .btn-mini {
	color: var(--silo-black);
	font-weight: 950;
}

.info-band {
	background: var(--silo-acid);
	color: var(--silo-black);
}

.info-band::before {
	background: var(--silo-black);
}

.info-card {
	background: var(--silo-black);
	border: 0;
	color: var(--silo-paper);
}

.info-card p,
.info-band .section-head p {
	color: rgba(246, 240, 221, 0.78);
}

.partners,
.site-footer {
	background: var(--silo-black);
	color: var(--silo-paper);
}

.partner-logo img {
	filter: none;
	max-height: 4.2rem;
}

@media (max-width: 1019px) {
	.main-nav {
		background: var(--silo-black);
		color: var(--silo-paper);
	}

	.hero-card {
		margin-top: 2rem;
		position: relative;
		right: auto;
		top: auto;
		width: min(100%, 420px);
	}
}

/* Internal pages follow the same Silo-inspired system. */
.inner-page {
	background: var(--silo-black);
	color: var(--silo-paper);
	min-height: 70dvh;
	padding: clamp(4rem, 8vw, 7rem) clamp(1rem, 4vw, 5rem);
}

.inner-wrap {
	margin: 0 auto;
	max-width: none;
}

.inner-hero {
	border-top: 1px solid var(--silo-line);
	display: grid;
	gap: 1rem;
	margin-bottom: clamp(2rem, 5vw, 4rem);
	padding-top: 1.2rem;
}

.inner-hero h1 {
	color: var(--silo-paper);
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
	font-size: clamp(4rem, 14vw, 13rem);
	font-style: normal;
	font-weight: 950;
	letter-spacing: -0.1em;
	line-height: 0.72;
	margin: 0;
	max-width: 1200px;
	text-transform: uppercase;
}

.inner-hero p {
	color: rgba(246, 240, 221, 0.78);
	font-size: clamp(1.08rem, 2vw, 1.45rem);
	line-height: 1.55;
	margin: 0;
	max-width: 760px;
}

.content-stack {
	display: grid;
	gap: 1rem;
}

.text-panel,
.notice-panel,
.newsletter-card {
	background: var(--silo-paper);
	border: 0;
	border-radius: 28px;
	box-shadow: 0 22px 70px rgba(0, 0, 0, 0.32);
	color: var(--silo-black);
	padding: clamp(1.2rem, 3vw, 2.2rem);
}

.text-panel h2,
.notice-panel h2,
.newsletter-card h2 {
	color: var(--silo-black);
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
	font-size: clamp(2rem, 7vw, 5rem);
	font-style: normal;
	font-weight: 950;
	letter-spacing: -0.08em;
	line-height: 0.82;
	margin: 0 0 1rem;
	text-transform: uppercase;
}

.text-panel h3 {
	color: var(--silo-red);
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
	font-size: clamp(1.15rem, 3vw, 1.75rem);
	font-style: normal;
	font-weight: 950;
	letter-spacing: -0.04em;
	margin: 1.2rem 0 0.5rem;
	text-transform: uppercase;
}

.text-panel p,
.text-panel li,
.notice-panel p,
.newsletter-card p {
	color: #3f352d;
	font-size: 1rem;
	line-height: 1.7;
}

.text-panel strong {
	color: var(--silo-black);
}

.program-grid {
	display: grid;
	gap: clamp(1rem, 2vw, 1.5rem);
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
}

.program-card {
	background: var(--silo-paper);
	border: 0;
	border-radius: 28px;
	box-shadow: 0 18px 50px rgba(0, 0, 0, 0.24);
	color: var(--silo-black);
	display: grid;
	gap: 0.75rem;
	overflow: hidden;
	padding: 0.85rem;
	position: relative;
	transform: none;
}

.program-card:nth-child(n) {
	transform: none;
}

.program-card::before {
	display: none;
}

.program-thumb {
	aspect-ratio: 16 / 10;
	background:
		linear-gradient(135deg, rgba(216, 255, 57, 0.82), rgba(216, 255, 57, 0.5)),
		var(--silo-red);
	border-radius: 22px;
	display: grid;
	min-height: 180px;
	overflow: hidden;
	place-items: center;
}

.program-thumb span {
	background: transparent;
	color: var(--silo-black);
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
	font-size: clamp(1.15rem, 3vw, 2rem);
	font-weight: 950;
	letter-spacing: -0.04em;
	padding: 0;
	text-transform: uppercase;
}

.program-date {
	color: var(--silo-red);
	font-size: 0.76rem;
	font-weight: 950;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.program-card h2 {
	color: var(--silo-black);
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
	font-size: clamp(1.45rem, 3vw, 2.2rem);
	font-style: normal;
	font-weight: 950;
	letter-spacing: -0.06em;
	line-height: 0.9;
	margin: 0;
	text-transform: uppercase;
}

.program-card p {
	color: #4c4035;
	line-height: 1.55;
	margin: 0;
}

.empty-state {
	background: var(--silo-paper);
	border: 0;
	border-radius: 28px;
	color: var(--silo-black);
	font-size: clamp(1.2rem, 3vw, 2rem);
	font-weight: 950;
	letter-spacing: -0.04em;
	padding: 1.4rem;
	text-transform: uppercase;
}

.map-visual,
.brochure-visual {
	background:
		linear-gradient(135deg, rgba(216, 255, 57, 0.82), rgba(216, 255, 57, 0.5)),
		var(--silo-red);
	border: 0;
	border-radius: 32px;
	box-shadow: 0 22px 70px rgba(0, 0, 0, 0.32);
	color: var(--silo-black);
	min-height: 360px;
}

.map-pin {
	background: var(--silo-black);
	border-color: var(--silo-paper);
}

.map-pin::after {
	background: var(--silo-acid);
}

.brochure-visual {
	font-family: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
	font-size: clamp(3rem, 10vw, 7rem);
	font-weight: 950;
	letter-spacing: -0.1em;
	line-height: 0.75;
	text-transform: uppercase;
}

.form-row input {
	background: #fff;
	border: 2px solid rgba(5, 5, 5, 0.12);
	border-radius: 999px;
	color: var(--silo-black);
}

@media (min-width: 880px) {
	.two-col {
		align-items: start;
		display: grid;
		gap: clamp(1.5rem, 4vw, 4rem);
		grid-template-columns: minmax(0, 1fr) minmax(320px, 0.55fr);
	}

	.program-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.program-card:nth-child(n) {
		grid-column: auto;
	}
}

/* WordPress dynamic theme layer. */
.custom-logo-link,
.custom-logo {
	display: block;
	height: auto;
	max-width: 100%;
}

.nav-list .menu-item {
	position: relative;
}

.nav-list .menu-item > a {
	align-items: center;
	border: 1px solid transparent;
	border-radius: 999px;
	color: var(--silo-paper);
	display: flex;
	font-weight: 950;
	gap: 0.4rem;
	padding: 0.85rem 0.95rem;
	text-transform: uppercase;
}

.nav-list .menu-item > a:hover,
.nav-list .menu-item > a:focus-visible {
	background: var(--silo-acid);
	color: var(--silo-black);
	outline: 0;
}

.nav-list .sub-menu {
	background: var(--silo-paper);
	border-radius: 22px;
	box-shadow: 0 18px 50px rgba(0, 0, 0, 0.24);
	display: none;
	left: 0;
	list-style: none;
	margin: 0;
	min-width: 230px;
	padding: 0.45rem;
	position: absolute;
	top: calc(100% + 0.5rem);
	z-index: 50;
}

.nav-list .menu-item:hover > .sub-menu,
.nav-list .menu-item:focus-within > .sub-menu {
	display: grid;
}

.nav-list .sub-menu a {
	border-radius: 14px;
	color: var(--silo-black);
	display: block;
	padding: 0.75rem 0.85rem;
}

.nav-list .sub-menu a:hover,
.nav-list .sub-menu a:focus-visible {
	background: var(--silo-acid);
	color: var(--silo-black);
}

.event-card-link,
.show-card a,
.program-card a,
.hero-card a {
	color: inherit;
	display: grid;
	height: 100%;
	text-decoration: none;
}

.event-card-link {
	gap: 1rem;
	grid-template-columns: auto 1fr;
}

.program-card a {
	gap: 0.75rem;
}

.program-thumb img,
.show-visual img,
.poster-canvas img,
.single-program-media img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.poster-canvas img {
	position: absolute;
	inset: 0;
}

.program-card:hover,
.event-card:hover,
.show-card:hover {
	transform: translateY(-6px);
	transition: transform 220ms ease, box-shadow 220ms ease;
}

.program-card:hover,
.event-card:hover,
.show-card:hover {
	box-shadow: 0 26px 70px rgba(0, 0, 0, 0.32);
}

.single-program {
	display: grid;
	gap: clamp(1.5rem, 4vw, 4rem);
}

.single-program-media {
	background: var(--silo-paper);
	border-radius: 30px;
	box-shadow: 0 22px 70px rgba(0, 0, 0, 0.32);
	overflow: hidden;
}

.single-program-media img {
	aspect-ratio: 4 / 5;
}

.single-program-content {
	display: grid;
	gap: 1rem;
}

.single-program-content .inner-hero {
	margin-bottom: 0;
}

.program-details {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 1rem clamp(1.5rem, 4vw, 3rem);
}

.program-details p {
	margin: 0;
}

.footer-inner {
	margin: 0 auto;
	max-width: var(--max);
	padding: 0 var(--space) clamp(2rem, 5vw, 4rem);
}

.site-footer .footer-nav {
	max-width: none;
	padding-left: 0;
	padding-right: 0;
}

.site-footer .partner-strip {
	padding-top: clamp(1.5rem, 4vw, 3rem);
}

.partner-strip img {
	display: block;
	filter: none;
	height: clamp(2.4rem, 5vw, 4.4rem);
	margin: 0 auto;
	max-width: 100%;
	object-fit: contain;
	width: auto;
}

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

.screen-reader-text:focus {
	background: var(--silo-acid);
	clip: auto;
	clip-path: none;
	color: var(--silo-black);
	display: block;
	font-weight: 950;
	height: auto;
	left: 1rem;
	padding: 1rem;
	top: 1rem;
	width: auto;
	z-index: 200;
}

@media (max-width: 1019px) {
	.nav-list .sub-menu {
		background: transparent;
		box-shadow: none;
		display: grid;
		min-width: 0;
		padding: 0 0 0 1rem;
		position: static;
	}

	.nav-list .sub-menu a {
		color: var(--silo-paper);
	}
}

@media (min-width: 920px) {
	.single-program {
		align-items: start;
		grid-template-columns: minmax(280px, 0.7fr) minmax(0, 1.3fr);
	}

	.single-program-media {
		position: sticky;
		top: 7rem;
	}
}

/* WordPress live header/footer fixes. */
body.admin-bar .site-header {
	top: 32px;
}

.site-header .header-inner {
	align-items: center;
	display: grid;
	gap: clamp(0.8rem, 2vw, 1.6rem);
	grid-template-columns: auto 1fr;
	max-width: none;
	padding: clamp(0.9rem, 2vw, 1.25rem) clamp(1rem, 4vw, 4rem);
}

.site-header .logo {
	background: transparent;
	justify-self: start;
	width: clamp(12rem, 20vw, 17rem);
}

.site-header .logo img,
.site-header .custom-logo {
	display: block;
	height: auto;
	width: 100%;
}

.site-header .search-shell {
	grid-column: 1 / -1;
	justify-self: stretch;
	max-width: min(100%, 360px);
	width: 100%;
}

.site-header .search-form {
	min-height: 3.25rem;
}

.site-header .search-form input {
	min-width: 0;
}

.site-header .main-nav {
	justify-self: end;
}

.site-header .nav-list {
	align-items: center;
	gap: clamp(0.2rem, 1vw, 0.7rem);
}

.site-header .nav-list .menu-item > a,
.site-header .nav-link {
	border-radius: 0;
	font-size: clamp(0.72rem, 0.9vw, 0.98rem);
	letter-spacing: -0.04em;
	line-height: 0.9;
	max-width: 8.5rem;
	padding: 0.45rem 0.25rem;
}

.site-footer {
	border-top: 1px solid var(--silo-line);
}

.site-footer .footer-inner {
	padding-top: clamp(2rem, 5vw, 4rem);
}

.site-footer .partner-strip {
	align-items: center;
	display: grid;
	gap: clamp(1.2rem, 4vw, 4rem);
	grid-template-columns: repeat(2, minmax(0, 1fr));
	justify-items: center;
	max-width: 1100px;
	min-height: 8rem;
}

.site-footer .partner-strip img {
	display: block;
	filter: none;
	height: auto;
	max-height: clamp(3rem, 6vw, 5.2rem);
	max-width: min(100%, 220px);
	object-fit: contain;
	width: auto;
}

.site-footer .partner-strip img:nth-child(4) {
	max-width: min(100%, 300px);
}

@media (min-width: 720px) {
	.site-footer .partner-strip {
		grid-template-columns: repeat(5, minmax(0, 1fr));
	}
}

@media (min-width: 1020px) {
	.site-header .header-inner {
		grid-template-columns: minmax(170px, 0.7fr) auto minmax(260px, 0.75fr);
	}

	.site-header .logo {
		justify-self: start;
	}

	.site-header .main-nav {
		grid-column: 2;
		grid-row: 1;
	}

	.site-header .search-shell {
		grid-column: 3;
		grid-row: 1;
		justify-self: end;
	}
}

/* Requested WordPress visual fixes. */
.site-header .logo {
	width: clamp(7.5rem, 10vw, 10.5rem);
}

.hero {
	background:
		linear-gradient(rgba(0, 0, 0, 0.25), rgba(0, 0, 0, 0.25)),
		url("img/background.png") center / cover no-repeat,
		var(--silo-black);
}

.hero::before {
	background: rgba(0, 0, 0, 0.25);
	inset: 0;
	position: absolute;
	z-index: 0;
}

.hero::after {
	display: none;
}

.hero-inner,
.kinetic-words {
	position: relative;
	z-index: 1;
}

.program-grid .program-card {
	background: var(--silo-paper);
	border-radius: 28px;
	padding: 0.85rem;
}

.program-grid .program-card a {
	display: grid;
	gap: 0.75rem;
}

.program-grid .program-thumb {
	aspect-ratio: 1587 / 2245;
	background: #efe6d2;
	border-radius: 22px;
	min-height: 0;
}

.program-grid .program-thumb img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.program-grid .program-date {
	color: var(--silo-red);
	font-size: 0.8rem;
	font-weight: 950;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.program-grid .program-card h2 {
	margin-bottom: 0.15rem;
}

.program-grid .program-card p {
	display: none;
}

.program-grid .program-card .btn-mini {
	background: var(--silo-red);
	border-color: var(--silo-red);
	color: #fff;
	justify-self: start;
	margin-top: 0.25rem;
	padding-inline: 1rem;
}

.single-program-media {
	aspect-ratio: 1587 / 2245;
	max-width: min(100%, 520px);
	width: 100%;
}

.single-program-media img,
.single-program-media .program-thumb {
	aspect-ratio: 1587 / 2245;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.site-footer .partner-strip {
	background: transparent;
	min-height: 10rem;
	opacity: 1;
	visibility: visible;
}

.site-footer .partner-strip img {
	background: transparent;
	display: block;
	opacity: 1;
	visibility: visible;
}

.site-footer .partner-strip img[src$="logo-paris-4.png"] {
	max-width: min(100%, 340px);
}

@media (min-width: 1020px) {
	.site-header .header-inner {
		grid-template-columns: minmax(120px, 0.45fr) auto minmax(260px, 0.75fr);
	}
}
