@font-face {
	font-family: "MADE Evolve Sans EVO";
	src: url("../fonts/made-evolve-sans-evo/MADE_Evolve_Sans_Medium_EVO__PERSONAL_USE_.otf") format("opentype");
	font-weight: 500;
	font-style: normal;
	font-display: swap;
}

.ce-cavanilles-page {
	background: #0a0a0a;
	color: #f4f4f5;
	font-family: Manrope, system-ui, sans-serif;
	min-height: 100vh;
	overflow: hidden;
}

.ce-cavanilles-hero {
	isolation: isolate;
	min-height: 92vh;
	padding: clamp(7rem, 12vw, 10rem) clamp(1.25rem, 5vw, 5rem) clamp(3rem, 7vw, 6rem);
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
	align-items: end;
	gap: clamp(2rem, 6vw, 5rem);
}

.ce-cavanilles-hero__bg {
	position: absolute;
	inset: 0;
	z-index: -2;
	background: #0a0a0a;
}

.ce-cavanilles-hero__bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: .62;
	filter: saturate(1.05) contrast(1.08);
}

.ce-cavanilles-hero::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background:
		radial-gradient(circle at 78% 12%, rgba(101, 217, 203, .28), transparent 34rem),
		linear-gradient(90deg, rgba(0, 0, 0, .9), rgba(0, 0, 0, .62) 45%, rgba(0, 0, 0, .18)),
		linear-gradient(0deg, #0a0a0a 0%, rgba(10, 10, 10, .15) 40%, rgba(10, 10, 10, .56) 100%);
}

.ce-cavanilles-hero__content {
	max-width: 970px;
}

.ce-cavanilles-kicker {
	color: #65d9cb;
	font-family: Epilogue, Manrope, system-ui, sans-serif;
	font-size: .78rem;
	font-weight: 900;
	letter-spacing: .18em;
	margin: 0 0 1rem;
	text-transform: uppercase;
}

.ce-cavanilles-hero h1 {
	font-family: Epilogue, Manrope, system-ui, sans-serif;
	font-weight: 800;
	font-size: clamp(2.6rem, 5.8vw, 5.7rem);
	line-height: .98;
	letter-spacing: -.055em;
	margin: 0;
	max-width: 14ch;
	text-transform: uppercase;
	text-wrap: balance;
}

.ce-cavanilles-hero__lead {
	color: rgba(247, 247, 242, .84);
	font-size: clamp(1.12rem, 2vw, 1.45rem);
	line-height: 1.55;
	margin: 1.5rem 0 0;
	max-width: 760px;
}

.ce-cavanilles-actions,
.ce-cavanilles-section-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
}

.ce-cavanilles-actions {
	justify-content: flex-start;
	margin-top: 2rem;
}

.ce-cavanilles-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid #65d9cb;
	border-radius: 6px;
	background: #65d9cb;
	color: #06110f;
	font-family: Epilogue, Manrope, system-ui, sans-serif;
	font-size: .84rem;
	font-weight: 900;
	letter-spacing: .08em;
	padding: 1rem 1.35rem;
	text-decoration: none;
	text-transform: uppercase;
	transition: transform .18s ease, background .18s ease, color .18s ease;
}

.ce-cavanilles-button:hover {
	transform: translateY(-2px);
}

.ce-cavanilles-button--ghost {
	background: rgba(10, 10, 10, .44);
	color: #f4f4f5;
}

.ce-cavanilles-button--compact {
	padding: .8rem 1.05rem;
}

.ce-cavanilles-date-card {
	backdrop-filter: blur(20px);
	background: rgba(10, 10, 10, .72);
	border: 1px solid rgba(101, 217, 203, .34);
	border-radius: 8px;
	box-shadow: 0 32px 80px rgba(0, 0, 0, .38);
	padding: 1.3rem;
}

.ce-cavanilles-date-card p {
	color: #65d9cb;
	font-family: Epilogue, Manrope, system-ui, sans-serif;
	font-weight: 900;
	letter-spacing: .12em;
	margin: 0 0 .9rem;
	text-transform: uppercase;
}

.ce-cavanilles-date-card div {
	border-top: 1px solid rgba(255, 255, 255, .14);
	padding: 1rem 0;
}

.ce-cavanilles-date-card span {
	display: block;
	color: rgba(247, 247, 242, .58);
	font-size: .8rem;
	font-weight: 800;
	letter-spacing: .08em;
	text-transform: uppercase;
}

.ce-cavanilles-date-card strong {
	display: block;
	margin-top: .35rem;
	font-family: Epilogue, Manrope, system-ui, sans-serif;
	font-weight: 800;
	font-size: clamp(1rem, 1.8vw, 1.28rem);
	line-height: 1.22;
}

.ce-cavanilles-intro,
.ce-cavanilles-rules,
.ce-cavanilles-archive,
.ce-cavanilles-collab {
	padding: clamp(4rem, 8vw, 7rem) clamp(1.25rem, 5vw, 5rem);
}

.ce-cavanilles-intro {
	display: grid;
	grid-template-columns: minmax(0, .8fr) minmax(0, 1fr);
	gap: clamp(2rem, 6vw, 5rem);
	background: #1a1a1a;
}

.ce-cavanilles-intro h2,
.ce-cavanilles-section-head h2,
.ce-cavanilles-collab h2 {
	font-family: Epilogue, Manrope, system-ui, sans-serif;
	font-weight: 800;
	font-size: clamp(2.2rem, 5vw, 5rem);
	line-height: .98;
	letter-spacing: -.055em;
	margin: 0;
	text-transform: uppercase;
}

.ce-cavanilles-rules .ce-cavanilles-section-head h2 {
	font-family: "MADE Evolve Sans EVO", Epilogue, Manrope, system-ui, sans-serif;
	font-weight: 500;
	letter-spacing: -.025em;
}

.ce-cavanilles-prose {
	color: rgba(247, 247, 242, .78);
	font-size: clamp(1rem, 1.25vw, 1.16rem);
	line-height: 1.75;
}

.ce-cavanilles-prose p {
	margin: 0 0 1.15rem;
}

.ce-cavanilles-prose strong,
.ce-cavanilles-prose b {
	color: #f4f4f5;
	font-weight: 900;
}

.ce-cavanilles-prose a {
	color: #65d9cb;
	font-weight: 800;
}

.ce-cavanilles-rules {
	background:
		radial-gradient(circle at 14% 0%, rgba(101, 217, 203, .18), transparent 24rem),
		#0a0a0a;
}

.ce-cavanilles-section-head {
	margin-bottom: 2rem;
}

.ce-cavanilles-rules__intro {
	border: 1px solid rgba(255, 255, 255, .12);
	border-radius: 8px;
	background: rgba(255, 255, 255, .045);
	padding: clamp(1.25rem, 3vw, 2rem);
	margin-bottom: 1rem;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, .08);
}

.ce-cavanilles-rules__intro h2 {
	color: #f4f4f5;
	font-family: Epilogue, Manrope, system-ui, sans-serif;
	font-weight: 800;
	font-size: clamp(1.7rem, 3vw, 2.7rem);
	line-height: 1.08;
	margin: 0 0 1rem;
	text-transform: uppercase;
}

.ce-cavanilles-rules__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr));
	gap: 1rem;
	align-items: start;
}

.ce-cavanilles-rule-card {
	display: grid;
	grid-template-columns: 3rem minmax(0, 1fr);
	gap: 1rem;
	min-height: 100%;
	border: 1px solid rgba(255, 255, 255, .12);
	border-radius: 8px;
	background: linear-gradient(135deg, rgba(255, 255, 255, .065), rgba(255, 255, 255, .03));
	padding: clamp(1rem, 2vw, 1.35rem);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, .06);
}

.ce-cavanilles-rule-card__icon {
	display: grid;
	place-items: center;
	width: 3rem;
	height: 3rem;
	border: 1px solid rgba(101, 217, 203, .42);
	border-radius: 6px;
	background: rgba(101, 217, 203, .08);
	color: #65d9cb;
}

.ce-cavanilles-rule-icon {
	width: 1.55rem;
	height: 1.55rem;
}

.ce-cavanilles-rule-card h3 {
	color: #f4f4f5;
	font-family: Epilogue, Manrope, system-ui, sans-serif;
	font-size: clamp(1.05rem, 1.8vw, 1.35rem);
	font-weight: 800;
	letter-spacing: -.025em;
	line-height: 1.15;
	margin: .15rem 0 .8rem;
	text-transform: uppercase;
}

.ce-cavanilles-archive {
	background: #101010;
}

.ce-cavanilles-archive__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
	gap: 1.25rem;
}

.ce-cavanilles-archive-card,
.ce-cavanilles-archive__empty {
	border: 1px solid rgba(255, 255, 255, .12);
	border-radius: 8px;
	background: rgba(255, 255, 255, .05);
	overflow: hidden;
}

.ce-cavanilles-archive-card img {
	width: 100%;
	height: 220px;
	object-fit: cover;
}

.ce-cavanilles-archive-card > div {
	padding: 1.25rem;
}

.ce-cavanilles-archive-card span {
	color: #65d9cb;
	font-size: .78rem;
	font-weight: 900;
	letter-spacing: .12em;
	text-transform: uppercase;
}

.ce-cavanilles-archive-card h3 {
	font-family: Epilogue, Manrope, system-ui, sans-serif;
	font-size: 1.7rem;
	font-weight: 800;
	letter-spacing: -.045em;
	margin: .45rem 0 1rem;
	text-transform: uppercase;
}

.ce-cavanilles-archive__empty {
	color: rgba(247, 247, 242, .72);
	font-size: 1.1rem;
	padding: 2rem;
}

.ce-cavanilles-collab {
	display: grid;
	grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
	gap: clamp(2rem, 6vw, 5rem);
	background:
		radial-gradient(circle at 82% 20%, rgba(101, 217, 203, .16), transparent 24rem),
		linear-gradient(180deg, #111 0%, #0a0a0a 100%);
	color: #f4f4f5;
	border-top: 1px solid rgba(255, 255, 255, .1);
}

.ce-cavanilles-collab .ce-cavanilles-kicker,
.ce-cavanilles-collab .ce-cavanilles-prose a {
	color: #65d9cb;
}

.ce-cavanilles-collab .ce-cavanilles-prose {
	color: rgba(244, 244, 245, .76);
}

.ce-cavanilles-collab .ce-cavanilles-prose strong {
	color: #f4f4f5;
}

.ce-cavanilles-logos {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
	gap: .85rem;
	align-content: start;
}

.ce-cavanilles-logos figure {
	display: grid;
	place-items: center;
	min-height: 130px;
	margin: 0;
	border: 1px solid rgba(255, 255, 255, .14);
	border-radius: 8px;
	background: rgba(244, 244, 245, .06);
	padding: 1rem;
}

.ce-cavanilles-logos img {
	max-width: 100%;
	max-height: 90px;
	object-fit: contain;
}

@media (max-width: 900px) {
	.ce-cavanilles-hero,
	.ce-cavanilles-intro,
	.ce-cavanilles-collab {
		grid-template-columns: 1fr;
	}

	.ce-cavanilles-hero {
		min-height: auto;
	}

	.ce-cavanilles-date-card {
		max-width: 100%;
	}
}
