﻿:root {
	--cream: #f5f0ea;
	--text: #40190f;
	--muted: #8a5f52;
	--maroon: #3c1214;
	--maroon-2: #52191f;
	--chip: #f0dfd2;
	--white: #fff;
	--radius: 24px;
	--container: min(1300px, calc(100vw - 2rem));
	/* --container: 100%; */
}

* {
	box-sizing: border-box
}

html,
body {
	margin: 0;
	padding: 0
}

body {
	font-family: "Satoshi", "General Sans", "Inter", sans-serif;
	background: var(--cream);
	color: var(--text);
	line-height: 1.5
}

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

img {
	max-width: 100%;
	display: block
}

h1,
h2,
h3,
h4 {
	font-family: "Clash Display", "Space Grotesk", sans-serif;
	letter-spacing: -.02em;
	line-height: 1.06;
	margin: 0 0 .7rem
}

h1 {
	font-size: clamp(2.3rem, 8vw, 5.2rem)
}

h2 {
	font-size: clamp(2rem, 5vw, 3.4rem)
}

h3 {
	font-size: clamp(1.6rem, 3vw, 2.35rem)
}

.container {
	width: var(--container);
	margin-inline: auto
}

.section {
	padding: clamp(3rem, 6vw, 6rem) 0
}

.section-lead {
	max-width: 720px;
	color: var(--muted);
	margin: 0 auto 2rem;
	text-align: center
}

.site-header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	background: transparent;
	backdrop-filter: none;
	z-index: 400;
	border-bottom: 0;
	transition: background .3s ease, box-shadow .3s ease;
}

/* Sit below the WP admin bar when logged in */
.admin-bar .site-header {
	top: 32px;
}

@media screen and (max-width: 782px) {
	.admin-bar .site-header {
		top: 46px;
	}
}

.header-inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0
}

.site-title {
	font-weight: 700
}

.custom-logo {
	width: min(300px, 42vw);
	height: auto;
	padding: 5px 10px 20px 20px;
}
.custom-logo img {
	margin-top: 9px;
	margin-bottom: -16px;
}

.menu-list {
	display: flex;
	gap: 1.2rem;
	list-style: none;
	padding: 0;
	margin: 0;
	font-weight: 600;
	font-size: .92rem
}

.menu-list a {
	color: #fff
}

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: .78rem 1.2rem;
	border-radius: 999px;
	font-weight: 700;
	font-size: .92rem;
	transition: .28s transform ease
}

.btn:hover {
	transform: translate3d(0, -2px, 0)
}

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

.btn-pill {
	background: #fff;
	color: var(--text);
	border: 1px solid rgba(80, 35, 20, .25)
}

.hero-clean {
	background-color: #fff;
	position: relative;
	overflow: hidden;
	min-height: 100vh;
	min-height: 100svh; /* clips browser chrome on mobile */
	display: flex;
	align-items: center;
	width: 100%;
	margin: 0;
	padding-inline: clamp(1.2rem, 2.4vw, 2.2rem);
	padding-top: 0;
	padding-bottom: 0
}

.hero-clean.section {
	padding: 0
}

/* .hero-clean::before,
.hero-clean::after {
	content: "";
	position: absolute;
	pointer-events: none;
	background: url("../images/8e69dce432f247c18f6e51d13aa5f3636d98b944.png") no-repeat center/contain;
	z-index: 1
} */

.hero-clean::before {
  width: min(38vw, 538px);
  height: min(40vw, 743px);
  top: -320px;
  left: 809px;
  transform: rotate(301deg) scaleX(-1.5);
}

.hero-clean::after {
	width: min(60vw, 790px);
	height: min(60vw, 790px);
	right: -250px;
	top: 84px;
	transform: rotate(12deg)
}

.hero-feather-layer {
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 1;
}

.hero-feather-layer .feather {
	position: absolute;
	display: block;
	background: url("../images/8e69dce432f247c18f6e51d13aa5f3636d98b944.png") no-repeat center/contain;
}

.hero-feather-layer-top .feather-t1 {
  width: min(28vw, 460px);
  height: min(30vw, 460px);
  top: -236px;
  left: 317px;
  transform: rotate(281deg);
}

.hero-feather-layer-top .feather-t2 {
  width: min(26vw, 396px);
  height: min(47vw, 410px);
  top: -194px;
  left: 584px;
  transform: rotate(286deg) scaleX(-1.5);
  opacity: 0.95;
}
.hero-feather-layer-top .feather-t3 {
  width: min(52vw, 345px);
  height: min(24vw, 428px);
  top: -146px;
  left: 1150px;
  transform: rotate(280deg) scaleX(-1.5);
  opacity: 0.95;
}
.hero-feather-layer-top .feather-t4 {
	width: min(20vw, 330px);
	height: min(20vw, 330px);
	top: -115px;
	left: 705px;
	transform: rotate(296deg) scaleX(-1);
	opacity: 0.95;
}
.hero-feather-layer-top .feather-t5 {
	width: min(20vw, 330px);
	height: min(20vw, 330px);
	top: -115px;
	left: 805px;
	transform: rotate(296deg) scaleX(-1);
	opacity: 0.95;
}
.hero-feather-layer-right .feather-r1 {
	width: min(54vw, 760px);
	height: min(54vw, 760px);
	right: -338px;
	top: -38px;
	transform: rotate(16deg);
}

.hero-feather-layer-right .feather-r2 {
	width: min(49vw, 680px);
	height: min(49vw, 680px);
	right: -300px;
	top: 232px;
	transform: rotate(30deg);
	opacity: 0.96;
}

.hero-feather-layer-right .feather-r3 {
	width: min(36vw, 500px);
	height: min(36vw, 500px);
	right: -205px;
	bottom: -168px;
	transform: rotate(20deg);
	opacity: 0.95;
}

.hero-feature-bottom {
	position: absolute;
	left: -20px;
	bottom: -300px;
	width: min(80vw, 1060px);
	height: min(80vw, 1060px);
	pointer-events: none;
	background: url("../images/8e69dce432f247c18f6e51d13aa5f3636d98b944.png") no-repeat center/contain;
	transform: rotate(-66deg);
	z-index: 1
}

.hero-content-clean {
  /* clamp(min, preferred, max) — min must be ≤ max */
  padding-top: clamp(6rem, 14vh, 10rem);
  padding-bottom: clamp(5rem, 10vh, 8rem);
  position: relative;
  z-index: 2;
  padding-left: clamp(0px, 8vh, 9rem);
}

.hero-content-clean h1 {
	font-size: clamp(2.7rem, 7.2vw, 6.05rem);
	max-width: 640px;
	line-height: .98;
	color: #84290b;
	letter-spacing: -.03em;
	margin-bottom: 1.8rem
	
}

.hero-text {
	max-width: 560px;
	color: var(--muted)
}

.hero-actions {
	display: flex;
	gap: .8rem;
	margin-top: 1.2rem
}

.hero-feather {
	position: absolute;
	opacity: .95;
	pointer-events: none
}

.hero-feather img {
	width: min(43vw, 500px);
	height: auto;
	object-fit: cover;
	filter: saturate(1.07)
}

.hero-feather-top {
	top: -4rem;
	right: -7rem
}

.hero-feather-bottom {
	left: -8rem;
	bottom: -5rem;
	transform: rotate(160deg)
}

.header-cta {
	padding: .88rem 1.35rem;
	background: #4e1709;
	font-size: .94rem;
	gap: .45rem
}

.hero-actions .btn {
	padding: .88rem 1.45rem;
	font-size: 1.02rem;
	font-weight: 700;
	gap: .5rem
}

.hero-actions .btn-primary {
	background: #4e1709
}

.hero-actions .btn-primary span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.4rem;
	height: 1.4rem;
	border-radius: 50%;
	background: #fff;
	color: #4e1709;
	font-size: .85rem;
	line-height: 1
}

.hero-actions .btn-pill {
	background: #fefefe;
	border: 2px solid #7a411a;
	box-shadow: 0 7px 14px rgba(48, 25, 13, .18);
	color: #5f2b10
}

.services-intro h2,
.clients h2,
.recent-work h2 {
	text-align: center
}

.services-intro {
	background: #efefef;
	padding-top: clamp(5.2rem, 10vw, 7.5rem);
	padding-bottom: clamp(0rem, 1vw, .7rem)
}

.services-intro-heading {
	display: flex;
	align-items: flex-end;
	justify-content: center;
	gap: .85rem
}

.services-intro-heading h2 {
	font-size: clamp(2.45rem, 5vw, 4.15rem);
	line-height: .98;
	letter-spacing: -.02em;
	color: #4b140b;
	margin: 0
}

.services-intro-heading img {
	width: clamp(62px, 7vw, 90px);
	height: auto;
	object-fit: contain;
	transform: translateY(4px)
}

.services-intro .section-lead {
	max-width: 690px;
	margin-inline: auto;
	margin-top: .8rem;
	color: #8c361e;
	font-size: clamp(.95rem, 1.5vw, 1.08rem)
}

.feature-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(1.2rem, 3.2vw, 4rem);
	align-items: stretch
}

.feature-copy {
	background: linear-gradient(165deg, #48171c, #5f1e25);
	color: #fff;
	padding: 3.8rem 4.5rem 9.8rem;
	border-radius: 0px 200px 0 0;
	min-height: 515px;
	display: flex;
	flex-direction: column;
	justify-content: flex-end
}

.feature-copy p {
	color: #f0d8d1;
	max-width: 540px;
	font-size: 1.03rem;
	line-height: 1.72
}

.feature-icon {
	display: inline-flex;
	width: 72px;
	height: 72px;
	border-radius: 16px;
	background: #fff;
	color: #f65f57;
	align-items: center;
	justify-content: center;
	margin-bottom: 1.65rem;
	box-shadow: 0 10px 18px rgba(36, 10, 8, .15)
}

.feature-icon svg {
	width: 32px;
	height: 32px
}

.feature-copy h3 {
	font-size: clamp(2.35rem, 3.8vw, 4rem);
	line-height: 1.02;
	margin-bottom: 1.2rem
}

.feature-media {
	margin: 0;
	border-radius: 20px;
	overflow: hidden;
	/* box-shadow: 0 18px 40px rgba(21, 11, 9, .22);
	background: radial-gradient(circle at 30% 10%, #2f3843 0%, #242830 53%, #4f2a1a 100%); */
	display: flex;
	align-items: stretch
}

.feature-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center
}

.tag-list {
	display: flex;
	gap: .6rem;
	flex-wrap: wrap;
	list-style: none;
	padding: 0;
	margin: 1.4rem 0 0
}

.tag-list li {
	background: #f6f0ea;
	padding: .48rem 1rem;
	border-radius: 999px;
	font-size: 1.1rem;
	color: #53251b
}

.service-rows {
	display: grid;
	gap: 2rem
}

.service-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.4rem;
	align-items: center
}

.service-row.is-reverse .service-row-copy {
	order: 2
}

.service-row.is-reverse .service-row-media {
	order: 1
}

.service-row-media {
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 12px 30px rgba(0, 0, 0, .12)
}

.service-row-media img {
	width: 100%;
	height: 100%;
	max-height: 340px;
	object-fit: cover
}

.recent-work {
	background: var(--maroon);
	color: #fff
}

.recent-work .section-lead {
	color: #e4b8ab
}

.recent-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem
}

.recent-card {
	border-radius: 14px;
	overflow: hidden;
	background: #2b0c10;
	box-shadow: 0 14px 30px rgba(0, 0, 0, .26)
}

.recent-card img {
	width: 100%;
	height: 280px;
	object-fit: cover
}

.clients-section {
	background: #fff;
	padding: 4rem 0;
	overflow: hidden
}

.clients-marquee-row {
	overflow: hidden;
	width: 100%;
	-webkit-mask-image: linear-gradient(to right, transparent 0%, #000 8%, #000 92%, transparent 100%);
	mask-image: linear-gradient(to right, transparent 0%, #000 8%, #000 92%, transparent 100%)
}

.clients-track {
	display: flex;
	align-items: flex-end;
	gap: 1rem;
	width: max-content;
	padding: 1rem 0
}

.clients-track--fwd {
	animation: clients-scroll-left 32s linear infinite
}

.clients-track--rev {
	animation: clients-scroll-right 28s linear infinite
}

@keyframes clients-scroll-left {
	from { transform: translateX(0) }
	to   { transform: translateX(-50%) }
}

@keyframes clients-scroll-right {
	from { transform: translateX(-50%) }
	to   { transform: translateX(0) }
}

@keyframes spin {
	to { transform: rotate(360deg) }
}

.clients-marquee-row:hover .clients-track {
	animation-play-state: paused
}

.clients-heading {
	text-align: center;
	padding: 3.5rem 1rem
}

.clients-card {
	display: flex;
	align-items: center;
	justify-content: center;
	background: #fff;
	border: 1px solid #f0dfd2;
	border-radius: 18px;
	box-shadow: 0 6px 22px rgba(120, 66, 48, .09);
	padding: 1.25rem 1.75rem;
	min-width: 110px;
	flex-shrink: 0
}

.clients-card:nth-child(5n+1) { height: 130px }
.clients-card:nth-child(5n+2) { height: 105px }
.clients-card:nth-child(5n+3) { height: 148px }
.clients-card:nth-child(5n+4) { height: 95px  }
.clients-card:nth-child(5n+5) { height: 120px }

.clients-card img {
	max-width: 120px;
	max-height: 64px;
	width: auto;
	height: auto;
	object-fit: contain
}

.clients-card-label {
	font-weight: 700;
	font-size: 1.1rem;
	color: var(--text);
	white-space: nowrap
}

.branding-kit {
	padding: 0;
}

.brand-banner {
	position: relative;
	background: radial-gradient(ellipse at 78% 88%, #d87c3a 0%, #7a2b10 38%, #2a0d08 66%);
	color: #fff;
	border-radius: 0;
	padding: 5rem max(2rem, calc((100vw - 1300px) / 2)) 5rem max(1rem, calc((100vw - 1300px) / 2));
	display: grid;
	grid-template-columns: 1fr 1fr;
	align-items: center;
	min-height: 420px;
	overflow: hidden;
}

/* Dot-grid decoration (bottom-left) */
.brand-banner::before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 220px;
	height: 200px;
	background-image: radial-gradient(circle, rgba(190, 90, 30, 0.45) 1px, transparent 1px);
	background-size: 14px 14px;
	pointer-events: none
}

/* ── Left: text content ──────────────────────────────── */
.brand-content {
	position: relative;
	z-index: 2
}

.brand-eyebrow {
	font-size: 0.72rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: #e8a04a;
	font-weight: 600;
	margin: 0 0 1.1rem
}

.brand-heading {
	font-size: clamp(2.2rem, 4.2vw, 3.4rem);
	line-height: 1.06;
	color: #fff;
	margin: 0 0 1.5rem
}

.brand-heading-accent {
	color: #e8a04a;
	display: block
}

.brand-divider {
	display: flex;
	align-items: center;
	gap: 0.7rem;
	margin-bottom: 1.3rem
}

.brand-divider-line {
	display: block;
	width: 72px;
	height: 1px;
	background: rgba(255, 255, 255, 0.35)
}

.brand-divider-cross {
	font-size: 1rem;
	color: rgba(255, 255, 255, 0.5);
	line-height: 1
}

.brand-description {
	max-width: 380px;
	color: rgba(255, 255, 255, 0.72);
	font-size: 0.97rem;
	line-height: 1.65;
	margin: 0
}

/* ── Right: orbital circles + arrow ─────────────────── */
.brand-visual {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	min-height: 340px
}

.brand-circles-svg {
	position: absolute;
	left: 380px;
	top: 50%;
	transform: translateY(-50%);
	width: 440px;
	height: 440px;
	pointer-events: none
}

/* ── Contact Section ─────────────────────────────────── */
.contact-block {
	padding: 0;
	overflow: hidden;
}
.contact-block::before {
	content: "";
	position: absolute;
	top: 0;
	right: 42%;
	width: 700px;
	height: 100%;
	/* background: #f3f3f3; */
	border-radius: 0 100% 100% 0;
	z-index: 1;
}


.contact-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	align-items: center;
}

.contact-copy {
	padding: 4rem 3rem 4rem max(1rem, calc((100vw - 1300px) / 2));
	display: flex;
	flex-direction: column;
}

.contact-copy h2 {
	font-size: clamp(2.4rem, 5vw, 3.8rem);
	color: var(--text);
	margin-bottom: 1rem;
}

.contact-copy > p {
	color: var(--muted);
	max-width: 34ch;
	line-height: 1.65;
	margin-bottom: 2.5rem;
}

.contact-image {
	max-width: 340px;
}

.contact-image img {
	width: 100%;
	height: auto;
}

.contact-feather {
	display: block;
	width: min(320px, 55%);
	aspect-ratio: 1;
	background: url("../images/8e69dce432f247c18f6e51d13aa5f3636d98b944.png") no-repeat center / contain;
	margin-top: 1rem;
}

.contact-form-wrap {
	background: radial-gradient(ellipse at 38% 22%, #8b3d1e 0%, #4a1a0a 45%, #2a0e08 100%);
	color: #fff;
	border-radius: 300px 0 0 300px;
	padding: 7.5rem 3rem 7.5rem 6.5rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.contact-form-wrap h3 {
	font-size: clamp(1.4rem, 2.5vw, 1.9rem);
	color: #d08060;
	margin-bottom: .35rem;
}

.contact-form {
	display: flex;
	flex-direction: column;
}

.cf-field {
	display: flex;
	flex-direction: column;
	gap: .3rem;
	margin-bottom: .85rem;
}

.contact-form label {
	font-size: .8rem;
	font-weight: 500;
	color: #c09070;
}

.cf-required {
	color: #e05a30;
}

.cta-compact {
	background: linear-gradient(145deg, #552218, #3e1611);
	color: #fff;
	border-radius: 16px;
	text-align: center;
	padding: 2.3rem 1.2rem
}

.cta-compact p {
	max-width: 650px;
	margin: 0 auto 1rem;
	color: #e7cabf
}

.site-footer {
	background: #2b0d10;
	color: #f8dfd5;
	padding: 5rem 0 0
}

.footer-top {
	display: grid;
	grid-template-columns: 1.1fr 2fr;
	gap: 2rem;
	padding-bottom: 3.5rem
}

.footer-brand {
	display: flex;
	flex-direction: column;
	gap: 1rem
}

.footer-logo {
	display: inline-flex;
	align-items: center;
	gap: .55rem;
	text-decoration: none;
	color: #fff;
	font-size: 1.15rem;
	font-weight: 700
}

.footer-logo-img {
	width: 36px;
	height: 36px;
	object-fit: contain;
	display: block
}

.footer-tagline {
	font-size: .85rem;
	color: rgba(248, 223, 213, .7);
	line-height: 1.6;
	max-width: 260px;
	margin: 0
}

.footer-cols {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1rem
}

.footer-cols h4 {
	font-size: .88rem;
	font-weight: 700;
	color: #fff;
	margin-bottom: 1rem;
	letter-spacing: .02em
}

.footer-cols a {
	display: block;
	color: rgba(248, 223, 213, .65);
	font-size: .84rem;
	margin: .42rem 0;
	text-decoration: none;
	transition: color .2s
}

.footer-cols a:hover {
	color: #fff
}

.footer-divider {
	border-top: 1px solid rgba(255, 255, 255, .12)
}

.footer-bottom {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 1.2rem 0;
	font-size: .78rem;
	color: rgba(248, 223, 213, .5)
}

.footer-bottom p {
	margin: 0
}

.footer-bottom div {
	display: flex;
	gap: 1.5rem
}

.footer-bottom a {
	color: rgba(248, 223, 213, .5);
	text-decoration: none;
	transition: color .2s
}

.footer-bottom a:hover {
	color: #fff
}

.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0)
}

@media (max-width:980px) {
	/* Hide desktop nav links; hamburger (overlayMenu:mobile) remains visible */
	.primary-nav .wp-block-navigation__container {
		display: none
	}

	/* Keep CTA button on tablet, shrink on mobile */
	.header-cta .wp-block-button__link {
		font-size: .82rem;
		padding: .6rem 1rem
	}

	.feature-grid,
	.service-row,
	.contact-grid,
	.footer-top {
		grid-template-columns: 1fr
	}

	.services-intro-heading {
		align-items: center;
		gap: .55rem
	}

	.services-intro-heading h2 {
		font-size: clamp(2rem, 8vw, 2.8rem)
	}

	.services-intro-heading img {
		width: clamp(48px, 13vw, 70px)
	}

	.feature-copy {
		min-height: auto;
		padding: 2rem 1.5rem 1.4rem;
		border-radius: 36px 72px 0 0
	}

	.feature-copy h3 {
		font-size: clamp(1.95rem, 8.4vw, 2.5rem)
	}

	.feature-copy p {
		font-size: .98rem;
		line-height: 1.65
	}

	.feature-icon {
		width: 50px;
		height: 50px;
		border-radius: 12px;
		margin-bottom: 1rem
	}

	.feature-icon svg {
		width: 24px;
		height: 24px
	}

	.service-row.is-reverse .service-row-copy,
	.service-row.is-reverse .service-row-media {
		order: initial
	}

	.recent-grid {
		grid-template-columns: 1fr 1fr
	}

	.logo-cloud {
		grid-template-columns: 1fr 1fr
	}

	.contact-form-wrap {
		border-radius: 20px;
		padding: 2rem 1.4rem
	}

	.contact-copy {
		padding: 2.5rem 1.5rem 1.5rem 1.5rem;
	}

	.brand-banner {
		grid-template-columns: 1fr;
		gap: 1.5rem;
		padding: 3rem 1.5rem;
	}

	.brand-visual {
		min-height: 220px
	}

	.brand-circles-svg {
		left: 50%;
		transform: translate(-50%, -50%);
		width: 320px;
		height: 320px
	}

	.hero-feather-top {
		right: -10rem
	}

	.hero-feather-bottom {
		left: -10rem
	}

	.hero-clean {
		min-height: 100vh;
		min-height: 100svh;
	}

	.hero-content-clean {
		padding-top: clamp(5rem, 16vh, 9rem);
	}

	.hero-clean::before {
		width: 620px;
		height: 620px;
		left: 30px;
		top: -250px
	}

	.hero-clean::after {
		width: 650px;
		height: 650px;
		right: -300px;
		top: 160px
	}

	.hero-feather-layer-top .feather-t1 {
		width: 330px;
		height: 330px;
		top: -132px;
		left: 168px;
	}

	.hero-feather-layer-top .feather-t2 {
		width: 255px;
		height: 255px;
		top: -88px;
		left: 330px;
	}

	.hero-feather-layer-right .feather-r1 {
		width: 560px;
		height: 560px;
		right: -292px;
		top: 10px;
	}

	.hero-feather-layer-right .feather-r2 {
		width: 530px;
		height: 530px;
		right: -292px;
		top: 245px;
	}

	.hero-feather-layer-right .feather-r3 {
		width: 390px;
		height: 390px;
		right: -168px;
		bottom: -126px;
	}

	.hero-feature-bottom {
		left: -120px;
		bottom: -320px;
		width: 880px;
		height: 880px
	}

	/* header is always fixed:top:0 — no override needed here */
}

@media (max-width:640px) {
	.recent-grid {
		grid-template-columns: 1fr
	}

	.hero-actions {
		flex-wrap: wrap
	}

	.hero-content-clean h1 {
		max-width: 100%
	}

	.hero-clean::before {
		width: 430px;
		height: 430px;
		left: -44px;
		top: -178px
	}

	.hero-clean::after {
		width: 470px;
		height: 470px;
		right: -270px;
		top: 250px
	}

	.hero-feather-layer-top .feather-t1 {
		width: 230px;
		height: 230px;
		top: -88px;
		left: 88px;
	}

	.hero-feather-layer-top .feather-t2 {
		width: 180px;
		height: 180px;
		top: -70px;
		left: 228px;
	}

	.hero-feather-layer-right .feather-r1 {
		width: 420px;
		height: 420px;
		right: -252px;
		top: 170px;
	}

	.hero-feather-layer-right .feather-r2 {
		width: 380px;
		height: 380px;
		right: -234px;
		top: 370px;
	}

	.hero-feather-layer-right .feather-r3 {
		width: 290px;
		height: 290px;
		right: -136px;
		bottom: -84px;
	}

	.hero-feature-bottom {
		left: -130px;
		bottom: -220px;
		width: 610px;
		height: 610px
	}

	.footer-cols {
		grid-template-columns: 1fr 1fr
	}

	.footer-bottom {
		flex-direction: column;
		align-items: flex-start;
		gap: .45rem
	}
}

/* Responsive reinforcement for blocks across mobile, tablet, laptop, and desktop */
.recent-grid {
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.logo-cloud {
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}

.footer-cols {
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}

@media (max-width:980px) {
	.recent-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.logo-cloud {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width:820px) {
	.brand-banner {
		padding: 2.5rem 2rem;
		min-height: auto;
	}

	.tag-list li {
		font-size: .95rem;
	}

	.custom-logo {
		padding: 16px 8px 12px 12px;
	}
}

@media (max-width:640px) {
	.logo-cloud {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width:480px) {
	:root {
		--container: min(1300px, calc(100vw - 1.25rem));
	}

	.hero-actions {
		flex-direction: column;
		align-items: stretch;
	}

	.hero-actions .btn {
		width: 100%;
	}

	.recent-grid,
	.logo-cloud,
	.footer-cols {
		grid-template-columns: 1fr;
	}

	.brand-banner {
		padding: 2rem 1rem;
	}

	.contact-form-wrap {
		padding: 1.25rem;
	}

	.contact-form-wrap {
		border-radius: 28px;
	}
}
.hero-actions .wp-block-button.header-cta {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.hero-actions .wp-block-button.header-cta .wp-block-button__link {
  background: #4e1709 !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: .88rem 1.45rem !important;
  border-radius: 999px !important;
  color: #fff !important;
  font-weight: 700 !important;
}

/* Cinematic Services — Pinned Content Swap */
.services-cinematic {
	background: #f2f2f2;
	overflow: hidden;
	padding-top: 0;
	padding-bottom: 0;
	height: 100vh;
	display: flex;
	flex-direction: column;
}

.services-cinematic-intro {
	text-align: center;
	max-width: 860px;
	margin-bottom: 0;
	padding: clamp(1.2rem, 2vw, 2rem) clamp(1.5rem, 4vw, 4.5rem);
	flex-shrink: 0;
	position: relative;
}

.services-cinematic-intro p {
	color: #9b3918;
	margin: 0;
}

.services-cinematic-intro h2 {
	color: #4f180d;
	font-size: clamp(2.4rem, 6.2vw, 4.6rem);
}

.services-cinematic-intro::after {
	content: "";
	position: absolute;
	right: 2.5rem;
	top: .4rem;
	width: clamp(52px, 9vw, 110px);
	height: clamp(52px, 10vw, 145px);
	background: url("../images/8e69dce432f247c18f6e51d13aa5f3636d98b944.png") no-repeat center/contain;
	transform: rotate(16deg);
	left: 50.3rem;
}

/* ── Desktop: pinned two-column layout ─────────────────── */
.services-cinematic-stage {
	position: relative;
	width: 100%;
	flex: 1;
	min-height: 0;
}

.sc-layout {
	display: grid;
	grid-template-columns: 1fr minmax(300px, .72fr);
	grid-template-rows: 1fr;
	gap: clamp(7rem, 2.5vw, 2.5rem);
	align-items: stretch;
	height: 100%;
	padding: 0 clamp(1.5rem, 4vw, 4.5rem) clamp(.8rem, 1.5vw, 1.2rem) 0;
}

.sc-info-card {
	background: #3d1213;
	border-radius: 0 clamp(80px, 12vw, 180px) 0 0;
	height: 100%;
	padding: clamp(1.8rem, 3.5vw, 3rem);
	display: flex;
	flex-direction: column;
	position: relative;
	overflow: hidden;
}

.sc-content-wrap {
	display: flex;
	flex-direction: column;
	flex: 1;
	gap: clamp(.9rem, 1.5vw, 1.5rem);
}

.sc-icon-wrap {
	width: 64px;
	height: 64px;
	background: #fff;
	border-radius: 16px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #d4494a;
	flex-shrink: 0;
}

.sc-icon-wrap svg {
	width: 28px;
	height: 28px;
}

.sc-title {
	font-size: clamp(2.2rem, 4.5vw, 4rem);
	color: #fff;
	line-height: 1.02;
	margin: 0;
}

.sc-desc {
	font-size: clamp(.95rem, 1.1vw, 1.15rem);
	color: rgba(255, 255, 255, .82);
	max-width: 46ch;
	margin: 0;
}

.sc-tags {
	display: flex;
	flex-wrap: wrap;
	gap: .5rem;
	padding: 0;
	margin: 0;
	list-style: none;
}

.sc-tags li {
	font-size: .85rem;
	padding: .48rem 1.1rem;
	border-radius: 999px;
	border: 1.5px solid rgba(255, 255, 255, .45);
	color: rgba(255, 255, 255, .9);
	background: transparent;
	white-space: nowrap;
}

.sc-progress-line {
	position: absolute;
	bottom: 2rem;
	left: clamp(1.8rem, 3.5vw, 3.5rem);
	width: 110px;
	height: 2.5px;
	background: rgba(255, 255, 255, .18);
	border-radius: 2px;
}

.sc-progress-fill {
	height: 100%;
	background: rgba(255, 255, 255, .75);
	border-radius: 2px;
	width: 0%;
	transition: width .5s cubic-bezier(.4, 0, .2, 1);
}

.sc-media-card {
	position: relative;
	border-radius: 20px;
	overflow: hidden;
	height: 100%;
	background: #1a1414;
	box-shadow: 0 20px 40px rgba(30, 10, 10, .22);
	margin: 0;
}

.sc-media-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.sc-media-label {
	position: absolute;
	bottom: 1.4rem;
	left: 1.4rem;
	background: rgba(255, 255, 255, .92);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	border-radius: 999px;
	padding: .55rem 1.3rem;
	font-size: .85rem;
	font-weight: 600;
	color: #2a1010;
}

/* ── Mobile: stacked cards ──────────────────────────────── */
.sc-mobile-list {
	display: none;
}

@media (max-width: 991px) {
	.services-cinematic-stage {
		display: none;
	}

	.sc-mobile-list {
		display: flex;
		flex-direction: column;
		gap: 1rem;
		padding: 0 1rem 2rem;
	}

	.sc-mobile-card {
		background: #3d1213;
		border-radius: 20px;
		overflow: hidden;
	}

	.sc-mobile-card-content {
		padding: 1.6rem;
		display: flex;
		flex-direction: column;
		gap: .8rem;
	}

	.sc-mobile-card h3 {
		font-size: clamp(1.6rem, 7vw, 2.4rem);
		color: #fff;
		margin: 0;
		line-height: 1.05;
	}

	.sc-mobile-card p {
		font-size: .95rem;
		color: rgba(255, 255, 255, .8);
		margin: 0;
	}

	.sc-mobile-card .sc-tags li {
		border-color: rgba(255, 255, 255, .35);
	}

	.sc-mobile-card-media {
		margin: 0;
	}

	.sc-mobile-card-media img {
		width: 100%;
		height: min(50vw, 260px);
		object-fit: cover;
		display: block;
	}

	.sc-icon-sm {
		width: 52px;
		height: 52px;
	}

	.services-cinematic-intro::after {
		right: .8rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.sc-progress-fill {
		transition: none !important;
	}
}

/* ── Recent Work card overlay ─────────────────────────── */
.recent-card {
	position: relative;
	cursor: pointer;
}

.recent-card-link,
.recent-card-label {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: .85rem 1.1rem;
	background: linear-gradient(transparent, rgba(18,5,5,.72));
	color: #fff;
	font-size: .88rem;
	font-weight: 600;
	letter-spacing: .01em;
	transition: opacity .3s ease;
	text-decoration: none;
	display: block;
}

.recent-card-link {
	opacity: 0;
}

.recent-card:hover .recent-card-link {
	opacity: 1;
}

/* ── Branding Kit arrow ───────────────────────────────── */
.brand-arrow-link {
	position: relative;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 96px;
	height: 96px;
	border-radius: 50%;
	background: rgba(232, 160, 74, 0.12);
	border: 1.5px solid rgba(232, 160, 74, 0.35);
	color: #e8a04a;
	flex-shrink: 0;
	transition: background .3s ease, transform .3s ease, border-color .3s ease;
}

.brand-arrow-link:hover {
	background: rgba(232, 160, 74, 0.22);
	border-color: rgba(232, 160, 74, 0.6);
	transform: translateX(6px);
}

/* ── Contact form inputs ─────────────────────────────── */
.form-sub {
	font-size: .88rem;
	color: #c0907a;
	margin: 0 0 1.2rem;
}

.cf-input-wrap,
.cf-select-wrap {
	position: relative;
	display: flex;
	align-items: center;
	width: 100%;
}

.cf-input-icon,
.cf-select-icon {
	position: absolute;
	pointer-events: none;
	color: #8a7060;
}

.cf-input-icon {
	left: .85rem;
}

.cf-select-icon {
	right: .85rem;
}

.contact-form input,
.contact-form select,
.contact-form textarea {
	width: 100%;
	border: 0;
	border-radius: 10px;
	padding: .75rem .9rem;
	font-family: inherit;
	font-size: .95rem;
	background: rgba(255,255,255,.93);
	color: #2d1009;
	outline: none;
	transition: box-shadow .2s ease;
}

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
	box-shadow: 0 0 0 2.5px rgba(212,149,106,.55);
}

.cf-input-wrap input {
	padding-left: 2.6rem;
}

.contact-form select {
	appearance: none;
	cursor: pointer;
	padding-right: 2.4rem;
}

.contact-form textarea {
	resize: vertical;
	min-height: 115px;
}

.cf-submit {
	margin-top: .7rem;
	width: 100%;
	justify-content: center;
	gap: .5rem;
	background: #fdf0e6;
	color: #4e1a0a;
	border: none;
	font-size: .95rem;
	padding: .9rem 1.5rem;
	font-weight: 600;
	border-radius: 999px;
}

.cf-submit:hover {
	background: #f6e2d2;
	transform: translateY(-1px);
}

.contact-success {
	display: flex;
	align-items: center;
	gap: .5rem;
	background: rgba(255,255,255,.15);
	border: 1px solid rgba(255,255,255,.35);
	color: #fff;
	padding: .75rem 1rem;
	border-radius: 10px;
	margin-bottom: 1rem;
	font-size: .93rem;
}

.contact-error {
	background: rgba(255,80,50,.2);
	border: 1px solid rgba(255,100,60,.4);
	color: #ffe0d8;
	padding: .75rem 1rem;
	border-radius: 10px;
	margin-bottom: 1rem;
	font-size: .93rem;
}

/* ── wp:group.site-main reset ─────────────────────────── */
.wp-block-group.site-main {
	padding: 0 !important;
	margin: 0 !important;
	max-width: none !important;
	gap: 0 !important;
}

/* Kill any WordPress-injected block margin between sections */
.wp-block-group.site-main > * {
	margin-block: 0 !important;
}

/* ── Logo cloud item with image support ───────────────── */
.logo-cloud-item {
	display: flex;
	align-items: center;
	justify-content: center;
	background: #fff;
	padding: 1rem;
	border-radius: 14px;
	border: 1px solid #f3e6de;
	box-shadow: 0 7px 14px rgba(120,66,48,.1);
	min-height: 62px;
	font-weight: 700;
	color: #7a4a3a;
}

.logo-cloud-item img {
	max-height: 36px;
	width: auto;
	object-fit: contain;
}

/* ── Extra responsive breakpoints ────────────────────── */

/* Tablet landscape / small laptop (1024px) */
@media (max-width: 1024px) {
	.service-panel {
		grid-template-columns: minmax(300px, .9fr) minmax(320px, 1fr);
		gap: clamp(1rem, 3vw, 2.5rem);
	}
}
@media (min-width: 1920px) {
  .container {
    max-width: 1600px;
  }
}
/* Tablet portrait (768px) */
@media (max-width: 1280) {
	.brand-circles-svg {
		position: absolute;
		left: 289px;
		top: 50%;
		transform: translateY(-50%);
		width: 440px;
		height: 440px;
		pointer-events: none;
	}
}
@media (max-width: 768px) {
	.contact-grid {
		grid-template-columns: 1fr;
	}

	.contact-form-wrap {
		border-radius: 28px;
		padding: 1.6rem;
	}

	.brand-banner {
		grid-template-columns: 1fr;
		gap: 1.4rem;
		padding: 2.5rem 1.25rem;
	}

	.brand-visual {
		min-height: 200px;
	}

	.brand-circles-svg {
		width: 280px;
		height: 280px;
	}

	.footer-top {
		grid-template-columns: 1fr;
	}
}

/* Small mobile (480px) */
@media (max-width: 480px) {
	.service-icon-wrap {
		width: 44px;
		height: 44px;
		border-radius: 10px;
		margin-bottom: 1rem;
	}

	.service-panel-content h3 {
		font-size: clamp(1.6rem, 9vw, 2.2rem);
	}

	.recent-card img {
		height: 220px;
	}

	.contact-form-wrap {
		padding: 1.25rem;
	}

	h2 {
		font-size: clamp(1.7rem, 8.5vw, 2.6rem);
	}
}

/* Services empty state */
.services-empty {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 200px;
	width: 100vw;
	color: #888;
	font-size: 1rem;
}

.services-empty a {
	color: #84290b;
	text-decoration: underline;
}

/* ═══════════════════════════════════════════════════════════
   MOBILE NAVIGATION  (WordPress overlayMenu:"mobile")
   ═══════════════════════════════════════════════════════════ */

/* Hamburger open button */
.wp-block-navigation__responsive-container-open {
	background: transparent;
	border: 2px solid rgba(255,255,255,.55);
	border-radius: 8px;
	padding: .42rem .55rem;
	cursor: pointer;
	color: #fff;
	display: none; /* shown only via WP core breakpoint */
	align-items: center;
	justify-content: center;
	transition: background .2s ease;
}

.wp-block-navigation__responsive-container-open:hover {
	background: rgba(255,255,255,.12);
}

.wp-block-navigation__responsive-container-open svg {
	width: 22px;
	height: 22px;
}

/* Mobile overlay panel */
.wp-block-navigation__responsive-container {
	position: fixed;
	inset: 0;
	z-index: 9999;
	background: #1e0a09;
	padding: 2rem 1.5rem;
	overflow-y: auto;
	transform: translateX(-100%);
	transition: transform .32s cubic-bezier(.4,0,.2,1);
}

.wp-block-navigation__responsive-container.is-menu-open {
	transform: translateX(0);
}

/* Close button inside overlay */
.wp-block-navigation__responsive-container-close {
	position: absolute;
	top: 1.2rem;
	right: 1.2rem;
	background: rgba(255,255,255,.1);
	border: none;
	border-radius: 8px;
	color: #fff;
	padding: .4rem .5rem;
	cursor: pointer;
	transition: background .2s;
}

.wp-block-navigation__responsive-container-close:hover {
	background: rgba(255,255,255,.2);
}

/* Nav links inside overlay */
.wp-block-navigation__responsive-container .wp-block-navigation__container {
	display: flex;
	flex-direction: column;
	gap: .2rem;
	margin-top: 3.5rem;
	padding: 0;
	list-style: none;
}

.wp-block-navigation__responsive-container .wp-block-navigation-item__content {
	display: block;
	padding: .9rem 1rem;
	color: #f5e8e0;
	font-size: 1.2rem;
	font-weight: 600;
	border-radius: 10px;
	transition: background .18s ease;
}

.wp-block-navigation__responsive-container .wp-block-navigation-item__content:hover {
	background: rgba(255,255,255,.08);
	color: #fff;
}

/* Show hamburger on mobile */
@media (max-width: 980px) {
	.wp-block-navigation__responsive-container-open {
		display: flex;
	}
}

/* ═══════════════════════════════════════════════════════════
   STICKY HEADER (scrolled state)
   ═══════════════════════════════════════════════════════════ */

/* Scrolled: reveal the opaque white background */
.site-header.is-scrolled {
	background: rgba(255,255,255,.96);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	border-bottom: 1px solid rgba(74,24,25,.1);
	box-shadow: 0 2px 18px rgba(0,0,0,.06);
}

.site-header.is-scrolled .menu-list a,
.site-header.is-scrolled .wp-block-navigation__container a {
	color: #40190f;
}

.site-header.is-scrolled .wp-block-navigation__responsive-container-open {
	border-color: rgba(74,24,25,.35);
	color: #40190f;
}

.site-header.is-scrolled .header-cta .wp-block-button__link {
	background: #4e1709 !important;
	color: #fff !important;
}

/* ═══════════════════════════════════════════════════════════
   COMPREHENSIVE RESPONSIVE FIXES
   ═══════════════════════════════════════════════════════════ */

/* ── 1440px + (large desktop): give content more room ──── */
@media (min-width: 1440px) {
	.service-panel-content {
		max-width: 640px;
	}

	.service-panel {
		padding-inline: clamp(3rem, 6vw, 7rem);
	}
}

/* ── 1200px (laptop) ──────────────────────────────────── */
@media (max-width: 1200px) {
	.service-panel {
		grid-template-columns: minmax(300px, 1fr) minmax(320px, 1.1fr);
	}
}

/* ── 991px and below: vertical service panels ─────────── */
@media (max-width: 991px) {
	.service-panel-content {
		max-width: 100%;
		border-radius: 20px 20px 0 0;
	}

	/* Stack: image first on mobile, then content */
	.service-panel {
		grid-template-areas: "media" "content";
	}

	.service-panel-content { grid-area: content; }
	.service-panel-media   { grid-area: media; }
}

/* ── 768px (tablet portrait) ─────────────────────────── */
@media (max-width: 768px) {
	.hero-content-clean {
		padding-left: clamp(1rem, 5vw, 2rem);
		padding-right: clamp(1rem, 5vw, 2rem);
	}

	.services-cinematic-intro {
		padding-inline: 1rem;
		text-align: left;
	}

	.services-cinematic-intro h2 {
		font-size: clamp(2rem, 7vw, 3.2rem);
	}

	.sc-mobile-list {
		padding-inline: 1rem;
	}

	.recent-work .container,
	.clients .container,
	.contact-block .container {
		padding-inline: 1rem;
	}
}

/* ── 600px ────────────────────────────────────────────── */
@media (max-width: 600px) {
	.header-cta {
		display: none !important;
	}

	.hero-content-clean h1 {
		font-size: clamp(2.1rem, 10vw, 3.2rem);
		letter-spacing: -.04em;
	}

	.service-panel {
		padding: .75rem;
	}

	.service-panel-content {
		padding: 1.5rem 1.2rem;
	}

	.section {
		padding: clamp(2rem, 5vw, 4rem) 0;
	}

	.contact-form-wrap {
		border-radius: 20px;
	}

	.contact-grid {
		grid-template-columns: 1fr;
		gap: 0;
	}

	.contact-copy {
		padding-bottom: 1.5rem;
	}
}

/* ── 390px (iPhone 14/15 size) ───────────────────────── */
@media (max-width: 390px) {
	:root {
		--container: min(1300px, calc(100vw - 1rem));
	}

	h1 { font-size: clamp(1.9rem, 10.5vw, 2.8rem); }
	h2 { font-size: clamp(1.6rem, 9vw, 2.2rem); }

	.hero-content-clean {
		padding-top: clamp(7rem, 22vh, 9rem);
	}

	.recent-grid {
		grid-template-columns: 1fr;
	}

	.logo-cloud {
		grid-template-columns: repeat(2, 1fr);
	}

	.footer-cols {
		grid-template-columns: 1fr 1fr;
	}
}

/* ── Service panel image: cap at desktop only ──────────── */
@media (max-width: 991px) {
	.service-panel-media img {
		width: 100%;
		margin-left: 0;
		height: clamp(220px, 48vw, 420px);
	}
}

/* ── Ensure hero buttons wrap on very small screens ─────── */
@media (max-width: 360px) {
	.hero-actions {
		flex-direction: column;
		align-items: stretch;
	}

	.hero-actions .btn {
		width: 100%;
		justify-content: center;
	}
}

/* ═══════════════════════════════════════════════════════════
   RECENT WORK — Cinematic Horizontal Showcase (Figma-matched)
   ═══════════════════════════════════════════════════════════ */

/* ── Section ──────────────────────────────────────────────── */
.rw-showcase {
	position: relative;
	height: 100vh;
	overflow: hidden;
	/* Brand brownish-maroon with warm radial gradient centre */
	background: radial-gradient(ellipse 85% 60% at 50% 30%,
		#3e1409 0%, #1e0907 42%, #0c0403 100%);
	display: flex;
	flex-direction: column;
}

/* ── Header row: [feather] [title+sub] [feather] ─────────── */
.rw-header {
	position: relative;
	z-index: 3;
	flex-shrink: 0;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	gap: clamp(.8rem, 2vw, 2rem);
	padding: clamp(2rem, 4vh, 3.5rem) clamp(1rem, 3vw, 3rem)
	         clamp(1rem, 2vh, 1.8rem);
}

/* Feathers */
.rw-feather {
	flex-shrink: 0;
	pointer-events: none;
	width: clamp(100px, 13vw, 200px);
}

.rw-feather img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: contain;
}

.rw-feather--left  { transform: rotate(-22deg) translateY(-12px); }
.rw-feather--right { transform: scaleX(-1) rotate(-22deg) translateY(-12px); }

/* Title + subtitle */
.rw-header-center {
	flex: 1;
	max-width: 620px;
	text-align: center;
}

.rw-title {
	font-family: "Clash Display", "Space Grotesk", sans-serif;
	font-size: clamp(2.6rem, 6vw, 5rem);
	font-weight: 700;
	letter-spacing: -.028em;
	line-height: 1.03;
	color: #fff;
	margin: 0 0 .7rem;
}

.rw-subtitle {
	font-size: clamp(.86rem, 1.15vw, 1.02rem);
	color: rgba(255, 255, 255, .52);
	line-height: 1.68;
	margin: 0;
}

/* ── Horizontal track ─────────────────────────────────────── */
.rw-track-wrap {
	flex: 1;
	min-height: 0;
	overflow: hidden;
	position: relative;
	z-index: 2;
}

.rw-track {
	display: flex;
	align-items: center;
	height: 100%;
	padding: clamp(.8rem, 1.5vh, 1.5rem) clamp(2rem, 5vw, 5rem);
	will-change: transform;
}

/* ── Cards ────────────────────────────────────────────────── */
.rw-card {
	flex-shrink: 0;
	width: clamp(260px, 26vw, 400px);
	height: clamp(360px, calc(100% - 1.5rem), 550px);
	position: relative;
	border-radius: 22px;
	overflow: hidden;
	/* Card bg: warm dark maroon with radial glow matching design images */
	background: radial-gradient(circle at 50% 36%, #3c1708 0%, #150705 100%);
	border: 1px solid rgba(255, 255, 255, .07);
	box-shadow: 0 22px 55px rgba(0, 0, 0, .55);
	cursor: pointer;
	margin-right: clamp(1rem, 1.8vw, 1.5rem);
	transition:
		transform .5s cubic-bezier(.25, .46, .45, .94),
		box-shadow .5s ease;
}

.rw-card:hover {
	transform: translateY(-10px) scale(1.022);
	box-shadow:
		0 38px 75px rgba(0, 0, 0, .65),
		0 0 50px rgba(200, 80, 20, .18);
}

/* Full-bleed image (Layer 2 — sits above glow, below content) */
.rw-card-img-wrap {
	position: absolute;
	inset: 0;
	z-index: 2;
	overflow: hidden;
	will-change: transform, filter, opacity;
}

.rw-card-img-wrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .65s cubic-bezier(.25, .46, .45, .94);
}

.rw-card:hover .rw-card-img-wrap img {
	transform: scale(1.05);
}

/* ── Layer 1: Ambient glow (animates first) ───────────────── */
.rw-card-glow {
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	background: radial-gradient(ellipse at 50% 55%,
		rgba(200, 80, 20, .38) 0%,
		rgba(120, 40, 8, .18) 45%,
		transparent 72%
	);
	will-change: opacity;
}

/* ── Layer 3-6: Text content overlay ─────────────────────── */
.rw-card-content {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 3;
	padding: clamp(1.8rem, 3vh, 2.4rem) 1.5rem 1.5rem;
	background: linear-gradient(
		to top,
		rgba(10, 4, 2, .97) 0%,
		rgba(10, 4, 2, .70) 52%,
		transparent 100%
	);
	display: flex;
	flex-direction: column;
	gap: .42rem;
}

/* Layer 3: Category chip */
.rw-card-category {
	display: inline-block;
	align-self: flex-start;
	font-size: .67rem;
	font-weight: 600;
	letter-spacing: .13em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, .72);
	background: rgba(255, 255, 255, .08);
	border: 1px solid rgba(255, 255, 255, .14);
	padding: .26rem .78rem;
	border-radius: 999px;
	will-change: transform, filter, opacity;
}

/* Layer 4: Title */
.rw-card-title {
	font-family: "Clash Display", "Space Grotesk", sans-serif;
	font-size: clamp(1rem, 1.4vw, 1.28rem);
	font-weight: 700;
	color: #fff;
	line-height: 1.18;
	margin: 0;
	letter-spacing: -.015em;
	will-change: transform, filter, opacity;
}

/* Layer 5: Description */
.rw-card-desc {
	font-size: .78rem;
	color: rgba(255, 255, 255, .48);
	line-height: 1.62;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	will-change: transform, opacity;
}

/* Layer 6: CTA arrow */
.rw-card-cta {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	font-size: .8rem;
	font-weight: 700;
	color: #d96730;
	text-decoration: none;
	margin-top: .2rem;
	will-change: transform, opacity;
}

.rw-card-cta svg {
	flex-shrink: 0;
	transition: transform .28s ease;
}

.rw-card-cta:hover {
	color: #f08248;
}

.rw-card-cta:hover svg {
	transform: translateX(4px);
}

/* ── Text slides — large italic taglines between cards ─────── */
.rw-text-slide {
	flex-shrink: 0;
	width: clamp(220px, 24vw, 380px);
	display: flex;
	align-items: center;
	justify-content: flex-start;
	padding: 0 clamp(.8rem, 1.5vw, 1.5rem);
	margin-right: clamp(1rem, 1.8vw, 1.5rem);
}

.rw-text-slide p {
	font-family: "Clash Display", "Space Grotesk", sans-serif;
	font-size: clamp(1.7rem, 3.2vw, 3rem);
	font-weight: 800;
	font-style: italic;
	line-height: 1.1;
	color: #fff;
	margin: 0;
	letter-spacing: -.025em;
}

/* ── Mobile: vertical stack, text slides hidden ───────────── */
@media (max-width: 768px) {
	.rw-showcase {
		height: auto;
		overflow: visible;
		padding-bottom: 3rem;
	}

	.rw-header {
		flex-wrap: wrap;
		padding: 2.5rem 1.2rem 1.2rem;
		gap: .6rem;
	}

	.rw-feather {
		width: clamp(70px, 18vw, 120px);
	}

	.rw-header-center {
		flex: 0 0 100%;
		order: 1;
	}

	.rw-feather--left  { order: 0; transform: rotate(-18deg) translateY(-8px); }
	.rw-feather--right { order: 2; transform: scaleX(-1) rotate(-18deg) translateY(-8px); }

	.rw-track-wrap {
		overflow: visible;
		flex: none;
	}

	.rw-track {
		flex-direction: column;
		align-items: stretch;
		height: auto;
		padding: .5rem 1rem;
		transform: none !important;
	}

	.rw-card {
		width: 100%;
		aspect-ratio: 4 / 3;
		height: auto;
		margin-right: 0;
		margin-bottom: 1rem;
	}

	.rw-card-link {
		opacity: 1;
	}

	.rw-text-slide {
		display: none;
	}
}

@media (max-width: 480px) {
	.rw-card {
		aspect-ratio: 3 / 2;
	}

	.rw-title {
		font-size: clamp(2.1rem, 9vw, 3rem);
	}
}

@media (prefers-reduced-motion: reduce) {
	.rw-card,
	.rw-card-img-wrap img,
	.rw-card-link {
		transition: none;
	}
}
