/*
 * Dreamcolor Industry   global styles
 * Mobile-first, white / light theme, soft brand accents.
 */

:root {
	--dc-bg: #ffffff;
	--dc-bg-soft: #f7f8fa;
	--dc-bg-2: #eef0f4;
	--dc-surface: rgba(255, 255, 255, 1);
	--dc-line: rgba(18, 20, 28, 0.09);
	--dc-fg: #12141a;
	--dc-muted: #5c6370;
	/* Brand: red + silver on white */
	--dc-accent: #c81f2e;
	--dc-accent-2: #d62839;
	--dc-accent-soft: rgba(200, 31, 46, 0.1);
	--dc-silver-strong: #8b939e;
	--dc-silver-hi: #d1d6de;
	--dc-charcoal: #2e3138;
	--dc-amber: #c9a227;
	--dc-radius: 20px;
	--dc-radius-sm: 12px;
	--dc-space: clamp(1.25rem, 3vw, 2.5rem);
	--dc-container: 1320px;
	--dc-header-h: 76px;
	--dc-font: "Manrope", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
	--dc-display: "Outfit", var(--dc-font);
	--dc-ease: cubic-bezier(0.22, 1, 0.36, 1);
}

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

html {
	scroll-behavior: auto;
}

body {
	margin: 0;
	font-family: var(--dc-font);
	font-size: 1rem;
	line-height: 1.6;
	color: var(--dc-fg);
	background: radial-gradient(1100px 720px at 12% -8%, rgba(200, 31, 46, 0.06), transparent 58%),
		radial-gradient(900px 640px at 94% 4%, rgba(200, 208, 220, 0.35), transparent 55%),
		var(--dc-bg);
	min-height: 100vh;
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}

img,
video {
	max-width: 100%;
	height: auto;
	display: block;
}

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

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

.dc-skip-link:focus {
	clip: auto;
	clip-path: none;
	height: auto;
	width: auto;
	left: 1rem;
	top: 1rem;
	z-index: 99999;
	padding: 0.75rem 1rem;
	background: #000;
	color: #fff;
}

.dc-container {
	width: min(100% - var(--dc-space) * 2, var(--dc-container));
	margin-inline: auto;
}

.dc-section {
	padding-block: clamp(3.5rem, 8vw, 7rem);
}

.dc-section--tight {
	padding-block: clamp(2.5rem, 6vw, 4rem);
}

.dc-section--flush {
	padding-block: 0;
}

.dc-eyebrow {
	font-size: 0.78rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--dc-muted);
	margin: 0 0 0.75rem;
}

.dc-h2,
.dc-h3,
.dc-display {
	font-family: var(--dc-display);
	font-weight: 700;
	letter-spacing: -0.02em;
	line-height: 1.05;
	margin: 0 0 1rem;
}

.dc-h2 {
	font-size: clamp(1.75rem, 4vw, 3rem);
}

.dc-h3 {
	font-size: clamp(1.35rem, 2.5vw, 1.75rem);
}

.dc-display {
	font-size: clamp(2.25rem, 6vw, 4.25rem);
}

.dc-lead {
	font-size: clamp(1.05rem, 2vw, 1.25rem);
	color: var(--dc-muted);
	max-width: 52ch;
}

.dc-section-head {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1.5rem;
	margin-bottom: clamp(2rem, 5vw, 3rem);
}

.dc-section-head--center {
	flex-direction: column;
	align-items: center;
	text-align: center;
}

.glass-card,
.glass-header {
	background: var(--dc-surface);
	border: 1px solid var(--dc-line);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	border-radius: var(--dc-radius);
	box-shadow: 0 10px 48px rgba(15, 18, 28, 0.06);
}

.glass-header {
	border-radius: 999px;
}

.dc-input {
	width: 100%;
	border-radius: 999px;
	border: 1px solid var(--dc-line);
	background: #ffffff;
	color: var(--dc-fg);
	padding: 0.85rem 1.1rem;
	font: inherit;
	outline: none;
	transition: border-color 0.25s var(--dc-ease), box-shadow 0.25s var(--dc-ease);
}

.dc-input:focus {
	border-color: rgba(214, 40, 57, 0.42);
	box-shadow: 0 0 0 3px rgba(214, 40, 57, 0.1);
}

.dc-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.95rem 1.35rem;
	border-radius: 999px;
	font-weight: 600;
	font-size: 0.95rem;
	border: 1px solid transparent;
	cursor: pointer;
	transition: transform 0.35s var(--dc-ease), box-shadow 0.35s var(--dc-ease), background 0.25s;
	will-change: transform;
}

.dc-btn--primary {
	background: linear-gradient(120deg, var(--dc-accent), var(--dc-accent-2));
	color: #ffffff;
	box-shadow: 0 12px 36px rgba(200, 31, 46, 0.22);
}

.dc-btn--ghost {
	border-color: var(--dc-line);
	background: rgba(255, 255, 255, 0.95);
	color: var(--dc-fg);
}

.dc-btn--light {
	background: #ffffff;
	color: var(--dc-fg);
	border: 1px solid var(--dc-line);
}

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

.dc-btn:hover {
	transform: translateY(-2px);
}

.dc-btn--sm {
	padding: 0.65rem 1rem;
	font-size: 0.88rem;
}

.dc-text-link {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-weight: 600;
	color: var(--dc-accent);
}

.dc-pill {
	display: inline-flex;
	align-items: center;
	padding: 0.35rem 0.75rem;
	border-radius: 999px;
	font-size: 0.72rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	border: 1px solid var(--dc-line);
	background: var(--dc-bg-soft);
}

.dc-pill--accent {
	border-color: rgba(200, 31, 46, 0.28);
	color: var(--dc-accent);
	background: var(--dc-accent-soft);
}

.dc-pill--glass {
	border-color: rgba(255, 255, 255, 0.28);
	background: rgba(255, 255, 255, 0.1);
	color: #fff;
	backdrop-filter: blur(10px);
}

/* Cursor glow */
.dc-cursor-glow {
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: 5;
	background: radial-gradient(420px circle at var(--mx, 50%) var(--my, 50%), rgba(200, 31, 46, 0.05), transparent 55%);
	opacity: 1;
	mix-blend-mode: multiply;
}

@media (max-width: 900px) {
	.dc-cursor-glow {
		display: none;
	}
}

/* Header */
.dc-header {
	position: sticky;
	top: 0.75rem;
	z-index: 100;
	padding-inline: var(--dc-space);
}

.dc-header__bar {
	padding: 0.45rem 0.55rem 0.45rem 0.85rem;
	transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.5s;
	overflow: visible;
}

.dc-header.is-scrolled .glass-header {
	transform: scale(0.985);
	box-shadow: 0 8px 36px rgba(15, 18, 28, 0.1);
}

@media (max-width: 980px) {
	.dc-header.is-scrolled .glass-header {
		transform: none;
	}
}

.dc-header__inner {
	display: grid;
	/* Cap column 1 so large SVG / PNG logos cannot blow up the bar (was crushing nav into a column). */
	grid-template-columns: minmax(0, min(200px, 46vw)) minmax(0, 1fr) auto;
	align-items: center;
	gap: 0.75rem 1rem;
	min-height: var(--dc-header-h);
}

.dc-header__bar {
	position: relative;
}

.dc-header__inner > .dc-nav {
	min-width: 0;
	width: 100%;
}

.dc-nav__item--has-mega {
	position: static;
}

.dc-nav__link--has-mega {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
}

.dc-nav__mega-toggle {
	display: none;
	align-items: center;
	justify-content: center;
	margin-left: 0.15rem;
	padding: 0.35rem;
	border: 0;
	background: transparent;
	color: var(--dc-muted);
	border-radius: 8px;
	cursor: pointer;
	transition: transform 0.25s var(--dc-ease), color 0.2s;
}

.dc-nav__item--has-mega.is-mega-open .dc-nav__mega-toggle {
	transform: rotate(180deg);
	color: var(--dc-accent);
}

.dc-logo {
	display: inline-flex;
	align-items: center;
	justify-content: flex-start;
	gap: 0.65rem;
	min-width: 0;
	max-width: 100%;
	overflow: hidden;
}

.dc-logo__mark {
	width: 38px;
	height: 38px;
	border-radius: 12px;
	background: conic-gradient(from 210deg, var(--dc-accent), var(--dc-accent-2), var(--dc-silver-strong), var(--dc-silver-hi), var(--dc-accent));
	box-shadow: 0 10px 30px rgba(214, 40, 57, 0.22);
}

.dc-logo__text {
	display: flex;
	flex-direction: column;
	line-height: 1;
	font-family: var(--dc-display);
	font-weight: 800;
	letter-spacing: -0.03em;
}

.dc-logo__tag {
	font-size: 0.7rem;
	font-weight: 600;
	color: var(--dc-muted);
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.dc-nav-toggle {
	display: none;
	border: 1px solid var(--dc-line);
	background: var(--dc-bg-soft);
	border-radius: 999px;
	padding: 0.55rem 0.65rem;
	color: var(--dc-fg);
}

.dc-nav__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.25rem 1.25rem;
	flex-wrap: wrap;
}

.dc-nav__list > li {
	position: relative;
}

.dc-nav__list a {
	padding: 0.45rem 0.5rem;
	font-weight: 600;
	font-size: 0.92rem;
	color: var(--dc-muted);
	transition: color 0.2s;
}
.dc-mega__catalog-btn{
	color: #fff !important;
}
.dc-nav__list a:hover,
.dc-nav__list .current-menu-item > a {
	color: var(--dc-fg);
}

.dc-nav__list .sub-menu {
	position: absolute;
	left: 0;
	top: 100%;
	min-width: 200px;
	padding: 0.5rem;
	margin: 0;
	list-style: none;
	background: #ffffff;
	border: 1px solid var(--dc-line);
	border-radius: var(--dc-radius-sm);
	box-shadow: 0 16px 48px rgba(15, 18, 28, 0.1);
	opacity: 0;
	pointer-events: none;
	transform: translateY(6px);
	transition: opacity 0.2s, transform 0.25s var(--dc-ease);
}

.dc-nav__list li:hover > .sub-menu {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
}

.dc-header__actions {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	flex-shrink: 0;
	justify-self: end;
}

@media (max-width: 980px) {
	.dc-header__inner {
		display: flex;
		flex-wrap: nowrap;
		align-items: center;
		justify-content: space-between;
		gap: 0.5rem;
		min-height: var(--dc-header-h);
	}

	.dc-header__inner > .dc-nav {
		display: none;
		width: auto;
		min-width: 0;
	}

	.dc-logo {
		flex: 1 1 auto;
		min-width: 0;
	}

	.dc-nav-toggle {
		display: inline-flex;
		flex-shrink: 0;
	}

	.dc-header__actions {
		flex-shrink: 0;
	}

	body.dc-nav-open,
	body.dc-scroll-lock {
		overflow: hidden;
	}

	body.dc-nav-open::before {
		content: '';
		position: fixed;
		inset: 0;
		z-index: 180;
		background: rgba(12, 14, 20, 0.45);
	}

	/*
	 * Mobile menu: height must follow content   do NOT set top+bottom together or iPad/iPhone
	 * shows a full-height white sheet with empty space below the links.
	 */
	.dc-nav.dc-nav--portal {
		display: block;
		position: fixed;
		z-index: 190;
		left: var(--dc-space);
		right: var(--dc-space);
		top: calc(0.75rem + var(--dc-header-h) + 0.65rem + env(safe-area-inset-top, 0px));
		max-height: calc(
			100dvh - 0.75rem - var(--dc-header-h) - 1.25rem - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px)
		);
		height: auto;
		margin: 0;
		padding: 1.25rem 1.15rem 1.5rem;
		border-radius: 20px;
		background: #ffffff;
		border: 1px solid var(--dc-line);
		box-shadow: 0 24px 64px rgba(15, 18, 28, 0.18);
		-webkit-overflow-scrolling: touch;
		overflow-x: hidden;
		overflow-y: auto;
		overscroll-behavior: contain;
		visibility: hidden;
		opacity: 0;
		pointer-events: none;
		transform: translateY(-12px);
		transition: opacity 0.28s ease, transform 0.32s var(--dc-ease), visibility 0.28s;
	}

	body.dc-nav-open .dc-nav.dc-nav--portal {
		visibility: visible;
		opacity: 1;
		pointer-events: auto;
		transform: translateY(0);
	}

	.dc-nav--portal .dc-nav__list {
		flex-direction: column;
		align-items: stretch;
		width: 100%;
		gap: 0.15rem;
	}

	.dc-nav--portal .dc-nav__list > li {
		width: 100%;
	}

	.dc-nav--portal .dc-nav__list a,
	.dc-nav--portal .dc-nav__link {
		display: block;
		padding: 0.65rem 0.5rem;
		font-size: 1.05rem;
		line-height: 1.3;
	}

	.dc-nav--portal .dc-nav__list .sub-menu {
		position: static;
		opacity: 1;
		pointer-events: auto;
		transform: none;
		background: transparent;
		border: 0;
		padding: 0 0 0 0.75rem;
	}

}

/* Hero   cinematic video background */
.dc-hero {
	position: relative;
	min-height: 100vh;
	min-height: 100svh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding-block: clamp(10rem, 14vw, 8rem) clamp(4.5rem, 10vw, 6rem);
	padding-inline: 20px;
	overflow: hidden;
	color: #fff;
	margin-top: -100px;
}

.dc-hero:not(.dc-hero--video) {
	background: radial-gradient(ellipse 120% 80% at 20% 0%, rgba(200, 31, 46, 0.2), transparent 55%),
		linear-gradient(165deg, #1a1c22 0%, #12141a 45%, #2e3138 100%);
}

.dc-hero__media {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
}

.dc-hero__video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transform: scale(1.03);
}

.dc-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
			105deg,
			rgba(8, 9, 12, 0.88) 0%,
			rgba(18, 20, 28, 0.55) 42%,
			rgba(200, 31, 46, 0.35) 100%
		),
		linear-gradient(180deg, rgba(8, 9, 12, 0.35) 0%, rgba(8, 9, 12, 0.75) 100%);
}

.dc-hero__grain {
	position: absolute;
	inset: 0;
	opacity: 0.12;
	background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
	mix-blend-mode: overlay;
}

.dc-hero__bg {
	position: absolute;
	inset: 0;
	pointer-events: none;
	display: none;
}

.dc-hero__glow {
	position: absolute;
	border-radius: 50%;
	filter: blur(90px);
	opacity: 0.6;
}

.dc-hero__glow--red {
	width: min(560px, 75vw);
	height: min(560px, 75vw);
	top: -10%;
	left: -12%;
	background: radial-gradient(circle, rgba(200, 31, 46, 0.38), transparent 68%);
}

.dc-hero__glow--silver {
	width: min(500px, 70vw);
	height: min(500px, 70vw);
	right: -8%;
	bottom: -15%;
	background: radial-gradient(circle, rgba(184, 192, 204, 0.5), transparent 70%);
}

.dc-hero__gradient {
	position: absolute;
	inset: -20%;
	background: radial-gradient(closest-side at 18% 28%, rgba(200, 31, 46, 0.14), transparent 58%),
		radial-gradient(closest-side at 88% 18%, rgba(200, 31, 46, 0.1), transparent 52%),
		radial-gradient(closest-side at 55% 95%, rgba(200, 208, 220, 0.2), transparent 55%);
}

.dc-hero__mesh {
	position: absolute;
	inset: 0;
	background-image: linear-gradient(rgba(18, 20, 28, 0.045) 1px, transparent 1px),
		linear-gradient(90deg, rgba(18, 20, 28, 0.045) 1px, transparent 1px);
	background-size: 52px 52px;
	mask-image: radial-gradient(ellipse 80% 70% at 50% 40%, #000, transparent 78%);
}

.dc-hero__grid {
	position: absolute;
	inset: 0;
	background-image: linear-gradient(rgba(18, 20, 28, 0.05) 1px, transparent 1px),
		linear-gradient(90deg, rgba(18, 20, 28, 0.05) 1px, transparent 1px);
	background-size: 64px 64px;
	mask-image: radial-gradient(circle at 50% 30%, black, transparent 72%);
	opacity: 0.4;
}

.dc-hero__paint {
	position: absolute;
	width: clamp(160px, 22vw, 300px);
	height: clamp(160px, 22vw, 300px);
	border-radius: 50%;
	filter: blur(48px);
	opacity: 0.4;
	mix-blend-mode: multiply;
	animation: dc-float 14s ease-in-out infinite;
}

.dc-hero__paint--1 {
	left: 4%;
	bottom: 8%;
	background: var(--dc-accent);
}

.dc-hero__paint--2 {
	right: 2%;
	top: 12%;
	background: var(--dc-accent-2);
	animation-delay: -4s;
}

.dc-hero__paint--3 {
	left: 38%;
	top: 4%;
	background: var(--dc-silver-strong);
	animation-delay: -7s;
}

@keyframes dc-float {
	0%,
	100% {
		transform: translate3d(0, 0, 0) scale(1);
	}
	50% {
		transform: translate3d(20px, -30px, 0) scale(1.08);
	}
}

.dc-hero__content {
	position: relative;
	z-index: 2;
	/* width: 100%; */
}

.dc-hero__inner {
	max-width: 720px;
}

.dc-hero__kicker {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 1.35rem;
}

.dc-pill--live {
	border-color: rgba(255, 255, 255, 0.35);
	background: rgba(255, 255, 255, 0.14);
	font-weight: 700;
	color: #fff;
	backdrop-filter: blur(10px);
}

.dc-pill__dot {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: #D52738;
	box-shadow: 0 0 0 3px rgba(213, 39, 56, 0.25);
	animation: dc-pulse-dot 2s ease-in-out infinite;
	margin-right: 10px;
}

@keyframes dc-pulse-dot {
	0%,
	100% {
		opacity: 1;
	}
	50% {
		opacity: 0.55;
	}
}

.dc-hero__title {
	font-family: var(--dc-display);
	font-weight: 800;
	font-size: clamp(2.75rem, 6.5vw, 5.4rem);
	line-height: 0.92;
	letter-spacing: -0.045em;
	margin: 0 0 1.35rem;
}

.dc-hero__line {
	display: block;
}

.dc-hero__line--accent {
	color: var(--dc-accent-2);
	text-shadow: 0 0 40px rgba(214, 40, 57, 0.45);
}

.dc-hero__lead {
	max-width: 44ch;
	color: rgba(255, 255, 255, 0.82);
	font-size: clamp(1.02rem, 2vw, 1.18rem);
	line-height: 1.65;
	margin-bottom: 1.85rem;
}

.dc-hero__cta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-bottom: 2rem;
}

.dc-hero .dc-btn--primary {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding-inline: 1.35rem 1.15rem;
	box-shadow: 0 12px 36px rgba(200, 31, 46, 0.45);
}

.dc-hero__cta .dc-btn--primary svg {
	transition: transform 0.35s var(--dc-ease);
}

.dc-hero__cta .dc-btn--primary:hover svg {
	transform: translateX(4px);
}

.dc-hero__meta {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0.65rem;
	max-width: 100%;
}

.dc-hero__meta-item {
	padding: 0.85rem 1rem;
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-top: 3px solid var(--dc-accent);
	background: rgba(255, 255, 255, 0.08);
	backdrop-filter: blur(14px);
	transition: transform 0.35s var(--dc-ease), background 0.35s var(--dc-ease);
}

.dc-hero__meta-item:hover {
	transform: translateY(-3px);
	background: rgba(255, 255, 255, 0.14);
}

.dc-hero__meta-label {
	margin: 0;
	font-size: 0.68rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.62);
}

.dc-hero__meta-value {
	margin: 0.2rem 0 0;
	font-weight: 800;
	font-size: 0.95rem;
	color: #fff;
}

.dc-hero__scroll {
	position: absolute;
	left: 50%;
	bottom: 1.25rem;
	transform: translateX(-50%);
	z-index: 3;
	width: 44px;
	height: 72px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.28);
	background: rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(12px);
	box-shadow: 0 8px 28px rgba(0, 0, 0, 0.2);
	cursor: pointer;
}

.dc-hero__scroll-line {
	position: absolute;
	left: 50%;
	top: 14px;
	width: 3px;
	height: 18px;
	border-radius: 99px;
	background: linear-gradient(var(--dc-accent), transparent);
	transform: translateX(-50%);
	animation: dc-scroll 1.6s ease-in-out infinite;
}

@keyframes dc-scroll {
	0% {
		opacity: 0;
		transform: translate(-50%, 0);
	}
	40% {
		opacity: 1;
	}
	100% {
		opacity: 0;
		transform: translate(-50%, 22px);
	}
}

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

	.dc-hero__title {
		font-size: clamp(2.35rem, 11vw, 3.25rem);
	}
}

@media (prefers-reduced-motion: reduce) {
	.dc-hero__video {
		display: none;
	}

	.dc-pill__dot,
	.dc-hero__scroll-line {
		animation: none;
	}
}

/* Marquee */
.dc-marquee {
	border-block: 1px solid var(--dc-line);
	background: var(--dc-bg-soft);
	overflow: hidden;
}

.dc-marquee__track {
	display: flex;
	width: max-content;
	gap: 2rem;
	padding-block: 1rem;
	animation: dc-marquee 120s linear infinite;
}

.dc-marquee__group {
	display: flex;
	align-items: center;
	gap: 2rem;
	white-space: nowrap;
	font-family: var(--dc-display);
	font-weight: 800;
	font-size: clamp(1.25rem, 3vw, 2rem);
	letter-spacing: -0.02em;
}

.dc-marquee__dot {
	color: var(--dc-accent);
	font-size: 0.65rem;
}

@keyframes dc-marquee {
	0% {
		transform: translateX(0);
	}
	100% {
		transform: translateX(-50%);
	}
}

/* Featured slider   manual loop, no scrollbar, no autoplay */
.dc-featured__viewport {
	overflow-x: auto;
	overflow-y: hidden;
	padding-inline: var(--dc-space);
	scrollbar-width: none;
	-ms-overflow-style: none;
	-webkit-overflow-scrolling: touch;
}

.dc-featured__viewport::-webkit-scrollbar {
	display: none;
	width: 0;
	height: 0;
}

.dc-featured__track {
	display: flex;
	flex-wrap: nowrap;
	gap: 1.25rem;
	width: max-content;
	padding-bottom: 0.35rem;
}

.dc-featured__nav {
	display: flex;
	gap: 0.5rem;
}

.dc-icon-btn {
	width: 44px;
	height: 44px;
	border-radius: 999px;
	border: 1px solid var(--dc-line);
	background: var(--dc-bg-soft);
	color: var(--dc-fg);
	cursor: pointer;
}

.dc-product-card {
	display: flex;
	flex-direction: column;
	flex: 0 0 min(320px, 80vw);
	overflow: hidden;
	scroll-snap-align: start;
}

.dc-product-card__link {
	display: flex;
	flex-direction: column;
	flex: 1 1 auto;
	color: inherit;
}

.dc-product-card__actions {
	padding: 0 1rem 1rem;
	margin-top: auto;
}

.dc-product-card__media {
	position: relative;
	aspect-ratio: 4 / 5;
	background: var(--dc-bg-soft);
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}

.dc-product-card__thumb-link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	color: inherit;
	padding: 1rem 1.15rem;
	box-sizing: border-box;
}

.dc-product-card__actions .dc-btn {
	width: 100%;
}

/* Static showcase cards (no shop) */
.dc-showcase-card .dc-product-card__body {
	padding: 1rem 1rem 0;
}

.dc-showcase-card__swatch {
	position: absolute;
	inset: 0;
	background: linear-gradient(145deg, var(--dc-bg-2), var(--dc-silver-hi));
}

.dc-showcase-card[data-tone="red"] .dc-showcase-card__swatch {
	background: linear-gradient(145deg, rgba(200, 31, 46, 0.35), rgba(214, 40, 57, 0.08) 55%, var(--dc-bg-soft));
}

.dc-showcase-card[data-tone="silver"] .dc-showcase-card__swatch {
	background: linear-gradient(145deg, rgba(139, 147, 158, 0.45), rgba(209, 214, 222, 0.2) 55%, var(--dc-bg-soft));
}

.dc-showcase-card[data-tone="graphite"] .dc-showcase-card__swatch {
	background: linear-gradient(145deg, rgba(46, 49, 56, 0.55), rgba(46, 49, 56, 0.12) 55%, var(--dc-bg-soft));
}

.dc-showcase-card[data-tone="warm"] .dc-showcase-card__swatch {
	background: linear-gradient(145deg, rgba(201, 162, 39, 0.4), rgba(201, 162, 39, 0.1) 55%, var(--dc-bg-soft));
}

.dc-showcase-card__tag {
	position: absolute;
	top: 0.85rem;
	left: 0.85rem;
	z-index: 2;
	font-size: 0.72rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-weight: 700;
	padding: 0.35rem 0.65rem;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.88);
	border: 1px solid var(--dc-line);
}

.dc-collection-card .dc-cat-card__media {
	min-height: 150px;
}

.dc-collection-card__wash {
	position: absolute;
	inset: 0;
	opacity: 0.55;
}

.dc-collection-card[data-tone="red"] .dc-collection-card__wash {
	background: linear-gradient(160deg, rgba(200, 31, 46, 0.35), transparent 70%);
}

.dc-collection-card[data-tone="silver"] .dc-collection-card__wash {
	background: linear-gradient(160deg, rgba(139, 147, 158, 0.4), transparent 70%);
}

.dc-collection-card[data-tone="graphite"] .dc-collection-card__wash {
	background: linear-gradient(160deg, rgba(46, 49, 56, 0.45), transparent 70%);
}

.dc-collection-card[data-tone="warm"] .dc-collection-card__wash {
	background: linear-gradient(160deg, rgba(201, 162, 39, 0.35), transparent 70%);
}

.dc-featured__all {
	margin: 0 0 1rem;
}

.dc-product-card__img {
	width: auto;
	height: auto;
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
	object-position: center;
}

.dc-product-watermark {
	position: absolute;
	width: 50px;
	right: 20px;
	top: 50px;
	z-index: 1;
	pointer-events: none;
}
.dc-product-watermark.dc-product-watermark--lg{
	width: 100px;
}

.dc-product-watermark__img {
	width: min(62%, 200px);
	height: auto;
	max-height: 42%;
	object-fit: contain;
	opacity: 0.44;
	filter: drop-shadow(0 1px 2px rgba(255, 255, 255, 0.55)) drop-shadow(0 0 1px rgba(0, 0, 0, 0.12));
}

.dc-product-watermark--sm {
	padding: 18%;
}

.dc-product-watermark--sm .dc-product-watermark__img {
	width: min(72%, 88px);
	max-height: 50%;
	opacity: 0.38;
}


.dc-product-watermark--lg .dc-product-watermark__img {
	width: min(56%, 280px);
	max-height: 38%;
	opacity: 0.4;
}

.dc-product-card__title a {
	color: inherit;
}

.dc-product-card__title a:hover {
	color: var(--dc-accent);
}

.dc-product-card--grid {
	flex: none;
	width: auto;
	scroll-snap-align: unset;
}

/* Products mega menu   desktop dropdown shell */
@media (min-width: 981px) {
	.dc-mega {
		position: absolute;
		left: 50%;
		top: calc(100% + 0.5rem);
		width: min(1180px, calc(100vw - 2.5rem));
		transform: translateX(-50%) translateY(10px);
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
		z-index: 120;
		transition: opacity 0.28s var(--dc-ease), transform 0.35s var(--dc-ease), visibility 0.28s;
	}

	.dc-nav__item--has-mega:hover .dc-mega,
	.dc-nav__item--has-mega.is-mega-open .dc-mega,
	.dc-mega:hover,
	.dc-nav__item--has-mega:focus-within .dc-mega {
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
		transform: translateX(-50%) translateY(0);
	}

	.dc-nav__item--has-mega::after {
		content: '';
		position: absolute;
		left: -20%;
		right: -20%;
		top: 100%;
		height: 14px;
	}

	.dc-mega__layout {
		display: grid;
		grid-template-columns: minmax(200px, 240px) minmax(0, 1fr);
		min-height: 320px;
		max-height: min(72vh, 520px);
	}
}

.dc-mega__panel {
	padding: 0;
	overflow: hidden;
	border-radius: var(--dc-radius);
	box-shadow: 0 28px 80px rgba(15, 18, 28, 0.14);
}

.dc-mega__sidebar {
	padding: 1.25rem 1rem 1.25rem 1.25rem;
	border-right: 1px solid var(--dc-line);
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.6), rgba(248, 249, 252, 0.9));
}

.dc-mega__eyebrow {
	margin: 0 0 0.75rem;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--dc-muted);
}

.dc-mega__cat-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.2rem;
}

.dc-mega__cat-link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem;
	width: 100%;
	padding: 0.5rem 0.65rem;
	border: 0;
	border-radius: 10px;
	font-size: 0.88rem;
	font-weight: 600;
	font-family: inherit;
	text-align: left;
	color: var(--dc-muted);
	background: transparent;
	cursor: pointer;
	transition: background 0.2s, color 0.2s;
}

.dc-mega__cat-link:hover,
.dc-mega__cat-link.is-active {
	background: rgba(214, 40, 57, 0.08);
	color: var(--dc-fg);
}

.dc-mega__cat-count {
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--dc-accent);
}

.dc-mega__catalog-btn {
	width: 100%;
	margin-top: 1rem;
	justify-content: center;
}

.dc-mega__main {
	display: flex;
	flex-direction: column;
	min-width: 0;
	padding: 1rem 1.15rem 1.15rem;
}

.dc-mega__head {
	margin-bottom: 0.75rem;
}

.dc-mega__title {
	margin: 0;
	font-family: var(--dc-display);
	font-size: 1.15rem;
	font-weight: 800;
}

.dc-mega__sub {
	margin: 0.2rem 0 0;
	font-size: 0.85rem;
	color: var(--dc-muted);
}

.dc-mega__scroll {
	flex: 1;
	overflow: auto;
	max-height:200px;
	overscroll-behavior: contain;
	padding-right: 0.25rem;
}

.dc-mega__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(108px, 1fr));
	gap: 0.65rem;
}

.dc-mega__product {
	display: flex;
	flex-direction: column;
	gap: 0.45rem;
	padding: 0.45rem;
	border-radius: 12px;
	border: 1px solid transparent;
	transition: border-color 0.2s, background 0.2s, transform 0.25s var(--dc-ease);
}

.dc-mega__product:hover {
	border-color: var(--dc-line);
	background: rgba(255, 255, 255, 0.7);
	transform: translateY(-2px);
}

.dc-mega__product-media {
	display: block;
	aspect-ratio: 1;
	border-radius: 10px;
	overflow: hidden;
	background: var(--dc-bg-2);
	position: relative;
}

.dc-mega__product-media[data-tone="red"] {
	background: linear-gradient(145deg, rgba(200, 31, 46, 0.15), var(--dc-bg-2));
}

.dc-mega__product-media[data-tone="silver"] {
	background: linear-gradient(145deg, rgba(139, 147, 158, 0.2), var(--dc-bg-2));
}

.dc-mega__product-media[data-tone="graphite"] {
	background: linear-gradient(145deg, rgba(46, 49, 56, 0.18), var(--dc-bg-2));
}

.dc-mega__product-media[data-tone="warm"] {
	background: linear-gradient(145deg, rgba(201, 162, 39, 0.18), var(--dc-bg-2));
}

.dc-mega__product-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.dc-mega__product-placeholder {
	display: block;
	width: 100%;
	height: 100%;
}

.dc-mega__product-name {
	font-size: 0.78rem;
	font-weight: 700;
	line-height: 1.25;
	color: var(--dc-fg);
}

.dc-mega__product.is-mega-filtered-out {
	display: none;
}

.dc-mega__no-results {
	margin: 0.5rem 0 0;
	font-size: 0.88rem;
	color: var(--dc-muted);
}

.dc-mega__no-results[hidden] {
	display: none;
}

.dc-mega__empty {
	margin: 0;
	color: var(--dc-muted);
	font-size: 0.9rem;
}

/* Products mega menu   mobile (must come after desktop mega rules) */
@media (max-width: 980px) {
	.dc-nav__item--has-mega {
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		align-content: flex-start;
		column-gap: 0.35rem;
		row-gap: 0;
		width: 100%;
		position: relative;
	}

	.dc-nav__item--has-mega > .dc-nav__link {
		flex: 1 1 auto;
		min-width: 0;
		display: inline-flex;
		align-items: center;
		width: auto;
	}

	.dc-nav__mega-toggle {
		display: inline-flex;
		flex: 0 0 auto;
		align-items: center;
		justify-content: center;
		align-self: center;
		margin-left: 0;
	}

	.dc-nav__item--has-mega > .dc-mega {
		flex: 0 0 100%;
		width: 100%;
	}

	.dc-mega {
		display: none;
		position: static !important;
		left: auto !important;
		right: auto !important;
		top: auto !important;
		width: 100% !important;
		max-width: 100% !important;
		margin: 0.5rem 0 0 !important;
		padding: 0;
		transform: none !important;
		opacity: 1 !important;
		visibility: visible !important;
		pointer-events: auto !important;
		z-index: 1;
		overflow: visible;
	}

	.dc-nav__item--has-mega.is-mega-open .dc-mega {
		display: flex;
		flex-direction: column;
		max-height: min(50dvh, 420px);
		overflow: hidden;
		margin-top: 0.5rem;
	}
	a.dc-btn.dc-btn--primary.dc-btn--sm.dc-mega__catalog-btn.magnetic-wrap{
		text-align: center;
	}
	.dc-mega__panel {
		width: 100%;
		max-width: 100%;
		flex: 1;
		min-height: 0;
		display: flex;
		flex-direction: column;
		overflow: hidden;
		box-shadow: none;
		border: 1px solid var(--dc-line);
		border-radius: var(--dc-radius-sm);
	}

	.dc-mega__layout {
		display: flex !important;
		flex-direction: column;
		flex: 1;
		min-height: 0;
		grid-template-columns: none !important;
		max-height: none !important;
		overflow-x: hidden;
		overflow-y: auto;
		overscroll-behavior-y: contain;
		-webkit-overflow-scrolling: touch;
		touch-action: pan-y;
	}

	.dc-mega__sidebar {
		width: 100%;
		flex-shrink: 0;
		padding: 1rem;
		border-right: 0;
		border-bottom: 1px solid var(--dc-line);
	}

	.dc-mega__main {
		width: 100%;
		min-width: 0;
		flex-shrink: 0;
		padding: 0.75rem 1rem 1.25rem;
	}

	.dc-mega__scroll {
		max-height: none;
		overflow: visible;
	}

	.dc-mega__cat-list {
		display: flex;
		flex-wrap: wrap;
		gap: 0.35rem;
	}

	.dc-mega__cat-list li {
		width: auto;
		max-width: 100%;
	}

	.dc-mega__cat-link {
		width: auto;
		font-size: 0.82rem;
		padding: 0.4rem 0.7rem;
	}

	.dc-mega__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		gap: 0.5rem;
	}

	.dc-mega__product-name {
		font-size: 0.72rem;
	}

	.dc-mega__catalog-btn {
		width: 100%;
		margin-top: 0.75rem;
	}
}

/* Products catalog + archive */
.dc-catalog__head {
	margin-bottom: clamp(1.25rem, 3vw, 2rem);
}

.dc-catalog__lead {
	max-width: 42rem;
}

.dc-catalog__toolbar {
	padding: clamp(1rem, 2.5vw, 1.35rem);
	margin-bottom: clamp(1.25rem, 3vw, 2rem);
	display: grid;
	gap: 1rem;
}

.dc-catalog__search-wrap {
	position: relative;
}

.dc-catalog__search-icon {
	position: absolute;
	left: 1rem;
	top: 50%;
	transform: translateY(-50%);
	font-size: 1.1rem;
	color: var(--dc-muted);
	pointer-events: none;
}

.dc-catalog__search {
	width: 100%;
	padding: 0.9rem 1rem 0.9rem 2.75rem;
	border: 1px solid var(--dc-line);
	border-radius: 999px;
	background: var(--dc-bg-soft);
	font-size: 1rem;
	font-family: inherit;
	transition: border-color 0.2s, box-shadow 0.25s;
}

.dc-catalog__search:focus {
	outline: none;
	border-color: rgba(214, 40, 57, 0.45);
	box-shadow: 0 0 0 4px rgba(214, 40, 57, 0.1);
}

.dc-catalog__filters {
	display: grid;
	gap: 0.85rem;
}

.dc-catalog__filter-row {
	display: grid;
	gap: 0.5rem;
}

.dc-catalog__filter-row--sort {
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 0.75rem 1rem;
}

.dc-catalog__filter-label {
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--dc-muted);
}

.dc-catalog__pills {
	display: flex;
	flex-wrap: wrap;
	gap: 0.45rem;
}

.dc-catalog__pill {
	border: 1px solid var(--dc-line);
	background: var(--dc-bg-soft);
	color: var(--dc-muted);
	padding: 0.45rem 0.9rem;
	border-radius: 999px;
	font-size: 0.85rem;
	font-weight: 700;
	font-family: inherit;
	cursor: pointer;
	transition: background 0.2s, color 0.2s, border-color 0.2s, transform 0.2s var(--dc-ease);
}

.dc-catalog__pill:hover {
	border-color: rgba(214, 40, 57, 0.35);
	color: var(--dc-fg);
}

.dc-catalog__pill.is-active {
	background: var(--dc-accent);
	border-color: var(--dc-accent);
	color: #fff;
	transform: translateY(-1px);
}

.dc-catalog__sort-wrap {
	position: relative;
	min-width: 0;
}

.dc-catalog__sort {
	width: 100%;
	min-width: 180px;
	padding: 0.55rem 2rem 0.55rem 0.85rem;
	border: 1px solid var(--dc-line);
	border-radius: 12px;
	background: var(--dc-bg-soft);
	font-family: inherit;
	font-weight: 600;
	font-size: 0.9rem;
	appearance: none;
	background-image: linear-gradient(45deg, transparent 50%, var(--dc-muted) 50%), linear-gradient(135deg, var(--dc-muted) 50%, transparent 50%);
	background-position: calc(100% - 18px) calc(50% + 2px), calc(100% - 12px) calc(50% + 2px);
	background-size: 6px 6px, 6px 6px;
	background-repeat: no-repeat;
}

.dc-catalog__clear[hidden] {
	display: none;
}

.dc-catalog__meta {
	margin: 0;
	font-size: 0.88rem;
	color: var(--dc-muted);
}

.dc-catalog__grid {
	transition: opacity 0.25s;
}

.dc-catalog.is-filtering .dc-catalog__grid {
	opacity: 0.55;
}

.dc-catalog__grid .dc-product-card.is-filtered-out {
	display: none;
}

.dc-catalog__empty {
	margin-top: 1rem;
	padding: 2rem;
	text-align: center;
}

.dc-catalog__empty[hidden] {
	display: none;
}

.dc-catalog__empty-title {
	margin: 0 0 0.35rem;
	font-size: 1.2rem;
	font-weight: 800;
}

.dc-catalog__empty-text {
	margin: 0 0 1rem;
	color: var(--dc-muted);
}

@media (max-width: 720px) {
	.dc-catalog__filter-row--sort {
		grid-template-columns: 1fr;
	}

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

@media (max-width: 380px) {
	.dc-mega__grid {
		grid-template-columns: 1fr 1fr;
	}
}

/* Products archive & single */
.dc-products-archive__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 1rem;
}

.dc-products-archive__grid--related {
	margin-top: 1rem;
}

.dc-product-single__breadcrumb {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: clamp(1.5rem, 4vw, 2.5rem);
	font-size: 0.88rem;
	color: var(--dc-muted);
}

.dc-product-single__breadcrumb .dc-text-link {
	color: var(--dc-muted);
}

.dc-product-single__layout {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: start;
}

.dc-product-single__media {
	position: relative;
	overflow: hidden;
	padding: 0;
}

.dc-product-single__figure {
	position: relative;
	margin: 0;
	aspect-ratio: 4 / 5;
	overflow: hidden;
}

.dc-product-single__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.dc-product-single__placeholder {
	display: block;
	min-height: 420px;
}

.dc-product-single__media-glow {
	position: absolute;
	inset: -20%;
	pointer-events: none;
	opacity: 0.5;
}

.dc-product-single[data-tone="red"] .dc-product-single__media-glow {
	background: radial-gradient(circle at 30% 20%, rgba(200, 31, 46, 0.2), transparent 65%);
}

.dc-product-single[data-tone="silver"] .dc-product-single__media-glow {
	background: radial-gradient(circle at 30% 20%, rgba(139, 147, 158, 0.28), transparent 65%);
}

.dc-product-single[data-tone="graphite"] .dc-product-single__media-glow {
	background: radial-gradient(circle at 30% 20%, rgba(46, 49, 56, 0.35), transparent 65%);
}

.dc-product-single[data-tone="warm"] .dc-product-single__media-glow {
	background: radial-gradient(circle at 30% 20%, rgba(201, 162, 39, 0.25), transparent 65%);
}

.dc-product-single__tag {
	position: static;
	display: inline-block;
	margin-bottom: 0.75rem;
}

.dc-product-single__title {
	font-family: var(--dc-display);
	font-size: clamp(2rem, 5vw, 3rem);
	font-weight: 800;
	line-height: 1.05;
	margin: 0 0 0.75rem;
}

.dc-product-single__lead {
	font-size: 1.1rem;
	color: var(--dc-muted);
	margin: 0 0 1.25rem;
	max-width: 52ch;
}

.dc-product-single__body {
	margin-bottom: 1.5rem;
}

.dc-product-single__specs {
	padding: 1.25rem 1.35rem;
	margin-bottom: 1.5rem;
}

.dc-product-single__specs .dc-h3 {
	margin: 0 0 0.75rem;
	font-size: 1.1rem;
}

.dc-product-single__specs-body {
	color: var(--dc-muted);
	font-size: 0.95rem;
}

.dc-product-single__specs-body p {
	margin: 0 0 0.5rem;
}

.dc-product-single__cta {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.dc-product-single__block {
	padding: 1.25rem 1.35rem;
	margin-bottom: 1.5rem;
}

.dc-product-single__block .dc-h3 {
	margin: 0 0 0.85rem;
	font-size: 1.1rem;
}

.dc-product-single__block p,
.dc-product-single__note {
	color: var(--dc-muted);
	font-size: 0.95rem;
}

.dc-product-single__note {
	margin: 0.85rem 0 0;
}

.dc-product-specs {
	display: grid;
	gap: 0.55rem;
	margin: 0;
}

.dc-product-specs__row {
	display: grid;
	grid-template-columns: minmax(8rem, 34%) 1fr;
	gap: 0.75rem 1rem;
	padding-bottom: 0.55rem;
	border-bottom: 1px solid var(--dc-line);
}

.dc-product-specs__row:last-child {
	padding-bottom: 0;
	border-bottom: 0;
}

.dc-product-specs dt {
	margin: 0;
	font-size: 0.82rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--dc-muted);
}

.dc-product-specs dd {
	margin: 0;
	font-size: 0.95rem;
}

.dc-product-list {
	margin: 0;
	padding-left: 1.1rem;
	color: var(--dc-muted);
}

.dc-product-list li + li {
	margin-top: 0.45rem;
}

.dc-product-single__related {
	margin-top: clamp(3rem, 8vw, 5rem);
	padding-top: clamp(2rem, 5vw, 3rem);
	border-top: 1px solid var(--dc-line);
}

.dc-section-head--tight {
	margin-bottom: 1.25rem;
}

.dc-pagination {
	margin-top: 2.5rem;
}

.dc-pagination .nav-links {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.5rem;
}

.dc-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 42px;
	height: 42px;
	padding: 0 0.75rem;
	border-radius: 999px;
	border: 1px solid var(--dc-line);
	background: var(--dc-bg-soft);
	color: var(--dc-fg);
}

.dc-pagination .page-numbers.current {
	background: var(--dc-accent);
	border-color: var(--dc-accent);
	color: #fff;
}

/* Product gallery (ACF) */
.dc-product-single__gallery-wrap {
	position: sticky;
	top: calc(var(--dc-header-h) + 1rem);
}

.dc-pg {
	overflow: hidden;
	padding: 0;
}

.dc-pg__stage {
	position: relative;
	width: 100%;
	aspect-ratio: 4 / 5;
	min-height: 280px;
	background: var(--dc-bg-soft);
	overflow: hidden;
	cursor: grab;
	touch-action: manipulation;
	user-select: none;
	isolation: isolate;
}

.dc-pg__stage.is-dragging {
	cursor: grabbing;
}

.dc-pg__stage.is-dragging .dc-pg__slide {
	pointer-events: none;
}

.dc-pg__glow {
	position: absolute;
	inset: -20%;
	pointer-events: none;
	background: radial-gradient(circle at 25% 15%, rgba(200, 31, 46, 0.12), transparent 55%),
		radial-gradient(circle at 85% 80%, rgba(200, 208, 220, 0.35), transparent 50%);
	z-index: 1;
}

.dc-pg__slides {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	z-index: 2;
}

.dc-pg__slide {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	margin: 0;
	opacity: 0;
	z-index: 1;
	transform: scale(1.02);
	transition: opacity 0.4s var(--dc-ease), transform 0.5s var(--dc-ease);
	pointer-events: none;
}

.dc-pg__slide.is-active {
	opacity: 1;
	transform: scale(1);
	pointer-events: auto;
	z-index: 4;
}

.dc-pg__img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
	display: block;
}

.dc-pg__nav-row {
	position: absolute;
	inset: 0;
	z-index: 5;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 0.75rem;
	pointer-events: none;
	opacity: 0;
	transition: opacity 0.3s var(--dc-ease);
}

.dc-pg__stage:hover .dc-pg__nav-row,
.dc-pg__nav-row:focus-within {
	opacity: 1;
}

.dc-pg__nav {
	position: static;
	flex-shrink: 0;
	pointer-events: auto;
	transition: background 0.25s var(--dc-ease), border-color 0.25s var(--dc-ease), box-shadow 0.25s var(--dc-ease);
}

.dc-pg__nav:hover {
	background: #fff;
	border-color: rgba(200, 31, 46, 0.25);
	box-shadow: 0 8px 24px rgba(15, 18, 28, 0.12);
}

.dc-pg__meta {
	position: absolute;
	left: 0.75rem;
	right: 0.75rem;
	bottom: 0.75rem;
	z-index: 5;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
}

.dc-pg__counter {
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	padding: 0.4rem 0.7rem;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.92);
	border: 1px solid var(--dc-line);
	backdrop-filter: blur(8px);
}

.dc-pg__zoom {
	width: 42px;
	height: 42px;
	border-radius: 999px;
	border: 1px solid var(--dc-line);
	background: rgba(255, 255, 255, 0.92);
	cursor: pointer;
	font-size: 1.15rem;
	line-height: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: transform 0.3s var(--dc-ease), background 0.3s;
}

.dc-pg__zoom:hover {
	transform: scale(1.06);
	background: #fff;
}

.dc-pg__thumbs {
	display: flex;
	gap: 0.55rem;
	padding: 0.85rem;
	overflow-x: auto;
	scrollbar-width: none;
	border-top: 1px solid var(--dc-line);
	background: rgba(255, 255, 255, 0.65);
	cursor: grab;
	scroll-snap-type: x proximity;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
}

.dc-pg__thumbs.is-dragging {
	cursor: grabbing;
	scroll-behavior: auto;
}

.dc-pg__thumbs::-webkit-scrollbar {
	display: none;
}

.dc-pg__thumb {
	position: relative;
	z-index: 2;
	flex: 0 0 72px;
	width: 72px;
	height: 72px;
	padding: 0;
	border: 2px solid transparent;
	border-radius: var(--dc-radius-sm);
	overflow: hidden;
	cursor: pointer;
	background: var(--dc-bg-2);
	transition: border-color 0.3s var(--dc-ease), transform 0.3s var(--dc-ease);
	scroll-snap-align: center;
	touch-action: manipulation;
	-webkit-tap-highlight-color: transparent;
}

.dc-pg__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	pointer-events: none;
}

.dc-pg__thumb:focus-visible {
	outline: 2px solid var(--dc-accent);
	outline-offset: 2px;
}

.dc-pg__thumb-ring {
	position: absolute;
	inset: 0;
	border-radius: inherit;
	box-shadow: inset 0 0 0 2px transparent;
	transition: box-shadow 0.3s var(--dc-ease);
	pointer-events: none;
}

.dc-pg__thumb.is-active {
	border-color: var(--dc-accent);
	transform: translateY(-2px);
}

.dc-pg__thumb.is-active .dc-pg__thumb-ring {
	box-shadow: inset 0 0 0 2px rgba(200, 31, 46, 0.35);
}

.dc-pg-lightbox {
	position: fixed;
	inset: 0;
	z-index: 999999;
	display: grid;
	place-items: center;
	padding: clamp(1rem, 4vw, 2rem);
	isolation: isolate;
}

.dc-pg-lightbox[hidden] {
	display: none !important;
}

.dc-pg-lightbox__backdrop {
	position: absolute;
	inset: 0;
	z-index: 0;
	background: #0c0e14;
}

.dc-pg-lightbox__dialog {
	position: relative;
	z-index: 1;
	width: min(100%, 1100px);
	max-height: 100%;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	pointer-events: none;
}

.dc-pg-lightbox__figure {
	position: relative;
	margin: 0;
	width: 100%;
	max-height: min(82vh, 820px);
	display: flex;
	align-items: center;
	justify-content: center;
	pointer-events: auto;
}

.dc-pg-lightbox__figure .dc-product-watermark {
	position: absolute;
	inset: 0;
}

.dc-pg-lightbox__img {
	display: block;
	max-width: min(100%, 1100px);
	max-height: min(82vh, 820px);
	width: auto;
	height: auto;
	object-fit: contain;
	border-radius: var(--dc-radius-sm);
	box-shadow: 0 24px 80px rgba(0, 0, 0, 0.5);
}

.dc-pg-lightbox__caption {
	margin: 0.85rem 0 0;
	max-width: 42ch;
	color: rgba(255, 255, 255, 0.72);
	font-size: 0.9rem;
	text-align: center;
	pointer-events: auto;
}

.dc-pg-lightbox__close {
	position: fixed;
	top: max(1rem, env(safe-area-inset-top, 0px));
	right: max(1rem, env(safe-area-inset-right, 0px));
	z-index: 2;
	font-size: 1.5rem;
	pointer-events: auto;
}

.dc-pg-lightbox__nav {
	position: fixed;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
	pointer-events: auto;
}

.dc-pg-lightbox__nav--prev {
	left: max(0.75rem, env(safe-area-inset-left, 0px));
}

.dc-pg-lightbox__nav--next {
	right: max(0.75rem, env(safe-area-inset-right, 0px));
}

body.dc-pg-lightbox-open {
	overflow: hidden;
}

body.dc-pg-lightbox-open .dc-header,
body.dc-pg-lightbox-open .dc-main,
body.dc-pg-lightbox-open .dc-footer {
	visibility: hidden;
}

@media (max-width: 900px) {
	.dc-product-single__layout {
		grid-template-columns: 1fr;
		gap: 1.25rem;
	}

	.dc-product-single__gallery-wrap {
		position: static;
		width: 100%;
		min-width: 0;
	}

	.dc-pg {
		overflow: visible;
		border-radius: var(--dc-radius);
	}

	.dc-pg__stage {
		aspect-ratio: 1 / 1;
		min-height: min(78vw, 400px);
		max-height: min(72vh, 480px);
	}

	.dc-pg__img {
		object-fit: contain;
		padding: 0.5rem;
		box-sizing: border-box;
	}

	.dc-pg__meta {
		left: 0.5rem;
		right: 0.5rem;
		bottom: 0.5rem;
	}

	.dc-pg__nav-row {
		opacity: 1;
	}

	.dc-pg__nav {
		width: 40px;
		height: 40px;
	}

	.dc-pg__thumbs {
		padding: 0.65rem;
		gap: 0.45rem;
		-webkit-overflow-scrolling: touch;
		overscroll-behavior-x: contain;
	}

	.dc-pg__thumb {
		flex: 0 0 60px;
		width: 60px;
		height: 60px;
	}

	.dc-product-single__breadcrumb {
		font-size: 0.82rem;
		margin-bottom: 1rem;
	}

	.dc-product-single__title {
		font-size: clamp(1.65rem, 7vw, 2.25rem);
	}
}

@media (max-width: 480px) {
	.dc-pg__stage {
		min-height: min(85vw, 360px);
		max-height: 65vh;
	}

	.dc-pg__thumb {
		flex: 0 0 54px;
		width: 54px;
		height: 54px;
	}

	.dc-pg__counter {
		font-size: 0.72rem;
		padding: 0.3rem 0.55rem;
	}

	.dc-pg__zoom {
		width: 38px;
		height: 38px;
	}
}

.dc-product-card__media img {
	width: auto;
	height: auto;
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
	object-position: center;
	transition: transform 0.8s var(--dc-ease);
}

.dc-product-card:hover .dc-product-card__media img {
	transform: none;
}

.dc-product-card__shine {
	position: absolute;
	inset: -40%;
	background: linear-gradient(120deg, transparent 40%, rgba(255, 255, 255, 0.12), transparent 60%);
	transform: translateX(-40%);
	transition: transform 0.9s var(--dc-ease);
}

.dc-product-card:hover .dc-product-card__shine {
	transform: translateX(40%);
}

.dc-product-card__body {
	padding: 1rem 1.1rem 1.25rem;
}

.dc-product-card__title {
	margin: 0 0 0.35rem;
	font-size: 1.05rem;
	font-weight: 700;
}

.dc-product-card__price {
	margin: 0;
	color: var(--dc-accent);
	font-weight: 700;
}

/* Categories */
.dc-cats__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 1rem;
}

.dc-cat-card {
	overflow: hidden;
	display: flex;
	flex-direction: column;
	min-height: 280px;
}

.dc-cat-card__media {
	position: relative;
	flex: 1;
	min-height: 160px;
}

.dc-cat-card__img,
.dc-cat-card__placeholder {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.dc-cat-card__placeholder {
	display: block;
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(214, 40, 57, 0.12), rgba(200, 208, 220, 0.2));
}

.dc-collection-card .dc-cat-card__placeholder {
	background: var(--dc-bg-2);
}

.dc-cat-card__wash {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 30%, rgba(255, 255, 255, 0.96));
}

.dc-cat-card__body {
	padding: 1rem 1.1rem 1.25rem;
	position: relative;
}

.dc-cat-card__title {
	margin: 0 0 0.25rem;
	font-size: 1.1rem;
}

.dc-cat-card__count {
	margin: 0;
	font-size: 0.85rem;
	color: var(--dc-muted);
}

/* Story */
.dc-story__layout {
	display: grid;
	grid-template-columns: 1fr 1.1fr;
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: center;
}

.dc-story__visual {
	min-height: 320px;
	position: relative;
	overflow: hidden;
}

.dc-story__video {
	display: block;
	width: 100%;
	height: 100%;
	min-height: 320px;
	object-fit: cover;
	background: var(--dc-surface-2);
}

@media (max-width: 900px) {
	.dc-story__layout {
		grid-template-columns: 1fr;
	}
}

/* Why grid */
.dc-why__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1rem;
}

.dc-why-card {
	padding: 1.25rem;
	position: relative;
	overflow: hidden;
}

.dc-why-card__index {
	font-family: var(--dc-display);
	font-size: 2.5rem;
	font-weight: 800;
	color: rgba(18, 20, 28, 0.06);
	position: absolute;
	right: 1rem;
	top: 0.5rem;
}

.dc-why-card__title {
	margin: 0 0 0.5rem;
	font-size: 1.15rem;
}

.dc-why-card__text {
	margin: 0;
	color: var(--dc-muted);
}

/* Surfaces */
.dc-surfaces__row {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 1rem;
}

.dc-surface-tile {
	padding: 1.5rem 1.25rem;
	position: relative;
	overflow: hidden;
}

.dc-surface-tile__ring {
	position: absolute;
	inset: -40%;
	border-radius: 50%;
	opacity: 0.35;
	filter: blur(50px);
	background: var(--dc-accent);
}

.dc-surface-tile[data-tone="red"] .dc-surface-tile__ring {
	background: var(--dc-accent);
}

.dc-surface-tile[data-tone="silver"] .dc-surface-tile__ring {
	background: var(--dc-silver-strong);
}

.dc-surface-tile[data-tone="graphite"] .dc-surface-tile__ring {
	background: var(--dc-charcoal);
}

.dc-surface-tile[data-tone="warm"] .dc-surface-tile__ring {
	background: var(--dc-amber);
}

.dc-surface-tile__label {
	position: relative;
	margin: 0 0 0.35rem;
	font-size: 1.35rem;
	font-family: var(--dc-display);
}

.dc-surface-tile__hint {
	position: relative;
	margin: 0;
	color: var(--dc-muted);
	font-size: 0.9rem;
}

/* Stats */
.dc-stats__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 1px;
	padding: 0;
	overflow: hidden;
}

.dc-stat {
	padding: 1.5rem 1.25rem;
	background: var(--dc-bg-soft);
}

.dc-stat__value {
	display: flex;
	align-items: baseline;
	gap: 0.15rem;
	font-family: var(--dc-display);
	font-size: clamp(2rem, 4vw, 3rem);
	font-weight: 800;
}

.dc-stat__suffix {
	font-size: 1.25rem;
	color: var(--dc-accent);
}

.dc-stat__label {
	margin: 0.5rem 0 0;
	color: var(--dc-muted);
	font-size: 0.92rem;
}

/* Testimonials */
.dc-testi {
	position: relative;
	overflow: hidden;
}

.dc-testi__atmosphere {
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 0;
}

.dc-testi__orb {
	position: absolute;
	border-radius: 50%;
	filter: blur(80px);
	opacity: 0.45;
}

.dc-testi__orb--a {
	width: min(420px, 55vw);
	height: min(420px, 55vw);
	top: -8%;
	left: -6%;
	background: rgba(200, 31, 46, 0.14);
}

.dc-testi__orb--b {
	width: min(360px, 48vw);
	height: min(360px, 48vw);
	right: -4%;
	bottom: 10%;
	background: rgba(200, 208, 220, 0.55);
}

.dc-testi .dc-container {
	position: relative;
	z-index: 1;
}

.dc-testi__head {
	display: grid;
	grid-template-columns: minmax(0, 1.2fr) minmax(240px, 0.75fr);
	gap: clamp(1.25rem, 3vw, 2rem);
	align-items: end;
	margin-bottom: clamp(2rem, 5vw, 3rem);
}

.dc-testi__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 1.25rem;
}

.dc-testi__score {
	padding: 1.25rem 1.35rem;
	align-self: stretch;
}

.dc-testi__score-main {
	display: flex;
	align-items: center;
	gap: 1rem;
}

.dc-testi__score-value {
	font-family: var(--dc-display);
	font-size: clamp(2.5rem, 5vw, 3.25rem);
	font-weight: 800;
	line-height: 1;
	color: var(--dc-accent);
}

.dc-testi__score-label {
	margin: 0.35rem 0 0;
	font-size: 0.88rem;
	color: var(--dc-muted);
}

.dc-testi__score-note {
	margin: 1rem 0 0;
	padding-top: 0.85rem;
	border-top: 1px solid var(--dc-line);
	font-size: 0.9rem;
	color: var(--dc-muted);
}

.dc-stars {
	display: inline-flex;
	gap: 0.12rem;
	line-height: 1;
}

.dc-stars--lg .dc-stars__star {
	font-size: 1.05rem;
}

.dc-stars__star {
	color: rgba(18, 20, 28, 0.12);
	font-size: 0.9rem;
}

.dc-stars__star--on {
	color: var(--dc-amber);
}

.dc-testi__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
}

.dc-testi-card {
	margin: 0;
	padding: clamp(1.25rem, 2.5vw, 1.75rem);
	position: relative;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	min-height: 100%;
	border: 1px solid var(--dc-line);
	transition: transform 0.45s var(--dc-ease), box-shadow 0.45s var(--dc-ease), border-color 0.45s var(--dc-ease);
	cursor: pointer;
}

.dc-testi-card--featured:first-child {
	grid-column: span 2;
}

.dc-testi-card.is-active {
	border-color: rgba(200, 31, 46, 0.28);
	box-shadow: 0 18px 56px rgba(200, 31, 46, 0.1), 0 10px 48px rgba(15, 18, 28, 0.06);
	transform: translateY(-4px);
}

.dc-testi-card__glow {
	position: absolute;
	inset: -30%;
	border-radius: 50%;
	opacity: 0;
	transition: opacity 0.45s var(--dc-ease);
	pointer-events: none;
}

.dc-testi-card[data-tone="red"] .dc-testi-card__glow {
	background: radial-gradient(circle, rgba(200, 31, 46, 0.2), transparent 68%);
}

.dc-testi-card[data-tone="silver"] .dc-testi-card__glow {
	background: radial-gradient(circle, rgba(139, 147, 158, 0.28), transparent 68%);
}

.dc-testi-card[data-tone="warm"] .dc-testi-card__glow {
	background: radial-gradient(circle, rgba(201, 162, 39, 0.22), transparent 68%);
}

.dc-testi-card.is-active .dc-testi-card__glow,
.dc-testi-card:hover .dc-testi-card__glow {
	opacity: 1;
}

.dc-testi-card__top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	margin-bottom: 0.85rem;
	position: relative;
	z-index: 1;
}

.dc-testi-card__tag {
	font-size: 0.72rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	padding: 0.35rem 0.65rem;
	border-radius: 999px;
	background: var(--dc-accent-soft);
	color: var(--dc-accent);
	font-weight: 700;
}

.dc-testi-card__mark {
	position: absolute;
	top: 0.35rem;
	right: 1rem;
	margin: 0;
	font-family: var(--dc-display);
	font-size: clamp(4rem, 10vw, 6.5rem);
	line-height: 1;
	color: rgba(18, 20, 28, 0.05);
	pointer-events: none;
	user-select: none;
}

.dc-testi-card__quote {
	position: relative;
	z-index: 1;
	margin: 0;
	font-size: clamp(1.02rem, 1.8vw, 1.15rem);
	line-height: 1.65;
	flex: 1 1 auto;
}

.dc-testi-card--featured .dc-testi-card__quote {
	font-size: clamp(1.12rem, 2vw, 1.28rem);
}

.dc-testi-card__footer {
	display: flex;
	align-items: center;
	gap: 0.85rem;
	margin-top: 1.25rem;
	position: relative;
	z-index: 1;
}

.dc-testi-card__avatar {
	flex: 0 0 auto;
	width: 46px;
	height: 46px;
	border-radius: 50%;
	display: grid;
	place-items: center;
	font-family: var(--dc-display);
	font-weight: 800;
	font-size: 0.82rem;
	letter-spacing: 0.04em;
	background: linear-gradient(145deg, var(--dc-bg-soft), #fff);
	border: 1px solid var(--dc-line);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.dc-testi-card[data-tone="red"] .dc-testi-card__avatar {
	color: var(--dc-accent);
}

.dc-testi-card[data-tone="silver"] .dc-testi-card__avatar {
	color: var(--dc-silver-strong);
}

.dc-testi-card[data-tone="warm"] .dc-testi-card__avatar {
	color: var(--dc-amber);
}

.dc-testi-card__who {
	min-width: 0;
}

.dc-testi-card__name {
	display: block;
	font-style: normal;
	font-weight: 700;
	font-size: 0.98rem;
}

.dc-testi-card__role {
	display: block;
	margin-top: 0.15rem;
	color: var(--dc-muted);
	font-size: 0.86rem;
}

.dc-testi__nav {
	display: none;
	justify-content: center;
	gap: 0.65rem;
	margin-top: 1.25rem;
}

.dc-testi-dot {
	width: 12px;
	height: 12px;
	padding: 0;
	border: 0;
	border-radius: 50%;
	background: rgba(18, 20, 28, 0.12);
	cursor: pointer;
	position: relative;
	transition: transform 0.25s var(--dc-ease), background 0.25s var(--dc-ease);
}

.dc-testi-dot__ring {
	position: absolute;
	inset: -5px;
	border-radius: inherit;
	border: 1px solid transparent;
	transition: border-color 0.25s var(--dc-ease);
}

.dc-testi-dot.is-active {
	background: var(--dc-accent);
	transform: scale(1.15);
}

.dc-testi-dot.is-active .dc-testi-dot__ring {
	border-color: rgba(200, 31, 46, 0.35);
}

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

	.dc-testi-card--featured:first-child {
		grid-column: span 2;
	}
}

@media (max-width: 900px) {
	.dc-testi__head {
		grid-template-columns: 1fr;
	}

	.dc-testi__grid {
		display: flex;
		overflow-x: auto;
		scroll-snap-type: x mandatory;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		gap: 1rem;
		padding-bottom: 0.25rem;
	}

	.dc-testi__grid::-webkit-scrollbar {
		display: none;
	}

	.dc-testi-card,
	.dc-testi-card--featured {
		flex: 0 0 min(88vw, 360px);
		grid-row: auto;
		grid-column: auto;
		min-height: 280px;
		scroll-snap-align: center;
	}

	.dc-testi__nav {
		display: flex;
	}
}

@media (hover: hover) {
	.dc-testi-card:hover {
		transform: translateY(-3px);
	}
}

/* CTA */
.dc-cta__grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: 1rem;
}

.dc-cta__panel {
	padding: clamp(1.5rem, 4vw, 2.5rem);
	position: relative;
	overflow: hidden;
}

.dc-cta__panel--primary {
	background: linear-gradient(135deg, rgba(214, 40, 57, 0.14), rgba(200, 208, 220, 0.12));
}

.dc-cta__splash {
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at 80% 20%, rgba(255, 255, 255, 0.5), transparent 55%);
	pointer-events: none;
}

@media (max-width: 900px) {
	.dc-cta__grid {
		grid-template-columns: 1fr;
	}
}

/* Gallery   static premium showcase */
.dc-gallery {
	position: relative;
	overflow: hidden;
}

.dc-gallery__bg {
	position: absolute;
	inset: 0;
	pointer-events: none;
	z-index: 0;
}

.dc-gallery__glow {
	position: absolute;
	border-radius: 50%;
	filter: blur(80px);
	opacity: 0.55;
}

.dc-gallery__glow--red {
	width: min(520px, 70vw);
	height: min(520px, 70vw);
	top: -12%;
	left: -8%;
	background: radial-gradient(circle, rgba(200, 31, 46, 0.35), transparent 68%);
}

.dc-gallery__glow--silver {
	width: min(480px, 65vw);
	height: min(480px, 65vw);
	right: -6%;
	bottom: -18%;
	background: radial-gradient(circle, rgba(184, 192, 204, 0.55), transparent 70%);
}

.dc-gallery__mesh {
	position: absolute;
	inset: 0;
	background-image: linear-gradient(rgba(18, 20, 28, 0.04) 1px, transparent 1px),
		linear-gradient(90deg, rgba(18, 20, 28, 0.04) 1px, transparent 1px);
	background-size: 48px 48px;
	mask-image: linear-gradient(180deg, #000 0%, transparent 92%);
}

.dc-gallery .dc-container {
	position: relative;
	z-index: 1;
}

.dc-gallery__showcase {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(1.25rem, 3vw, 2.25rem);
	align-items: stretch;
	padding: clamp(1.35rem, 3vw, 2rem);
	border: 1px solid rgba(200, 31, 46, 0.14);
	background: linear-gradient(145deg, rgba(255, 255, 255, 0.96), rgba(247, 248, 250, 0.92));
	box-shadow: 0 24px 70px rgba(15, 18, 28, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.dc-gallery__copy {
	width: 100%;
	min-width: 0;
}

.dc-eyebrow--accent {
	color: var(--dc-accent);
	font-weight: 700;
}

.dc-gallery__title {
	margin: 0 0 0.85rem;
	background: linear-gradient(120deg, var(--dc-fg) 0%, var(--dc-charcoal) 55%, var(--dc-accent) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

.dc-gallery__lead {
	margin: 0 0 1.35rem;
	max-width: 42ch;
	color: var(--dc-muted);
	font-size: 1.05rem;
	line-height: 1.65;
}

.dc-gallery__chips {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 0.65rem;
	margin: 0 0 1.5rem;
	padding: 0;
	list-style: none;
}

.dc-gallery__chip {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0.4rem 0.75rem 0.4rem 0.45rem;
	border-radius: 999px;
	border: 1px solid var(--dc-line);
	background: #fff;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	color: var(--dc-charcoal);
	box-shadow: 0 4px 14px rgba(15, 18, 28, 0.04);
}

.dc-gallery__chip-dot {
	width: 14px;
	height: 14px;
	border-radius: 50%;
	background: var(--dc-chip, var(--dc-accent));
	border: 2px solid rgba(255, 255, 255, 0.9);
	box-shadow: 0 0 0 1px rgba(18, 20, 28, 0.08), inset 0 -2px 4px rgba(0, 0, 0, 0.12);
}

.dc-gallery__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.85rem 1.25rem;
}

.dc-gallery__handle {
	font-size: 0.88rem;
	font-weight: 700;
	color: var(--dc-muted);
	letter-spacing: 0.06em;
}

.dc-gallery__frame {
	display: flex;
	flex-direction: column;
	width: 100%;
	max-width: 100%;
	min-width: 0;
	border-radius: calc(var(--dc-radius) - 4px);
	overflow: hidden;
	border: 1px solid var(--dc-line);
	background: #fff;
	box-shadow: 0 16px 48px rgba(15, 18, 28, 0.07);
}

.dc-gallery__frame-bar {
	display: flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.65rem 0.85rem;
	background: linear-gradient(90deg, var(--dc-fg), #2a2d35);
	border-bottom: 3px solid var(--dc-accent);
}

.dc-gallery__frame-bar span {
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.28);
}

.dc-gallery__frame-bar span:first-child {
	background: var(--dc-accent);
	box-shadow: 0 0 12px rgba(200, 31, 46, 0.65);
}

.dc-gallery__instagram {
	width: 100%;
	max-width: 100%;
	min-width: 0;
	padding: 0.85rem;
	background: linear-gradient(180deg, #fafbfc, #fff);
	overflow: hidden;
}

.dc-gallery__instagram .instagram-media,
.dc-gallery__instagram iframe,
.dc-gallery__instagram > div {
	width: 100% !important;
	max-width: 100% !important;
	min-width: 0 !important;
	margin: 0 auto !important;
	border-radius: 12px !important;
	box-sizing: border-box !important;
}

.dc-gallery__instagram iframe {
	display: block !important;
	min-height: 480px;
}

.dc-gallery__spectrum {
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	gap: 0.45rem;
	margin-top: 1rem;
}

.dc-gallery__spectrum-cell {
	position: relative;
	min-height: 72px;
	border-radius: var(--dc-radius-sm);
	background: var(--dc-spectrum, var(--dc-accent));
	border: 1px solid rgba(255, 255, 255, 0.35);
	box-shadow: inset 0 -12px 24px rgba(0, 0, 0, 0.12), 0 8px 24px rgba(15, 18, 28, 0.08);
	overflow: hidden;
}

.dc-gallery__spectrum-cell::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(160deg, rgba(255, 255, 255, 0.22), transparent 45%);
	pointer-events: none;
}

.dc-gallery__spectrum-label {
	position: absolute;
	left: 0.55rem;
	right: 0.55rem;
	bottom: 0.5rem;
	font-size: 0.62rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #fff;
	text-shadow: 0 1px 8px rgba(0, 0, 0, 0.45);
}

.dc-gallery__spectrum-cell:nth-child(4) .dc-gallery__spectrum-label {
	color: var(--dc-charcoal);
	text-shadow: none;
}

@media (max-width: 980px) {
	.dc-gallery__showcase {
		grid-template-columns: 1fr;
	}

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

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

	.dc-gallery__spectrum-cell {
		min-height: 64px;
	}
}

/* Newsletter band */
.dc-news__inner {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: 1.5rem;
	align-items: center;
	padding: clamp(1.5rem, 4vw, 2.25rem);
}

.dc-newsletter-form--inline {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.dc-newsletter-form--inline .dc-input {
	flex: 1 1 200px;
}

@media (max-width: 800px) {
	.dc-news__inner {
		grid-template-columns: 1fr;
	}
}

/* Footer */
.dc-footer {
	position: relative;
	padding-block: clamp(3.25rem, 7vw, 5.5rem);
	margin-top: clamp(2rem, 5vw, 3.5rem);
	overflow: clip;
	background: linear-gradient(180deg, var(--dc-bg) 0%, var(--dc-bg-soft) 100%);
}

.dc-footer__splash {
	position: absolute;
	inset: -15% -5% auto;
	height: 70%;
	background:
		radial-gradient(closest-side at 18% 35%, rgba(200, 31, 46, 0.09), transparent 68%),
		radial-gradient(closest-side at 82% 20%, rgba(201, 162, 39, 0.06), transparent 55%);
	pointer-events: none;
}

.dc-footer__line {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--dc-line) 15%, rgba(200, 31, 46, 0.35) 50%, var(--dc-line) 85%, transparent);
	pointer-events: none;
}

.dc-footer__grid {
	display: grid;
	grid-template-columns: minmax(0, 1.4fr) minmax(0, 1.15fr) minmax(0, 0.9fr);
	gap: clamp(0.85rem, 2vw, 1.15rem);
	align-items: stretch;
}

.dc-footer__brand,
.dc-footer__col {
	padding: clamp(1.15rem, 2.5vw, 1.5rem);
	border-radius: var(--dc-radius);
	transition: border-color 0.3s ease, box-shadow 0.35s ease, transform 0.35s var(--dc-ease);
}

@media (hover: hover) {
	.dc-footer__brand:hover,
	.dc-footer__col:hover {
		border-color: rgba(200, 31, 46, 0.18);
		box-shadow: 0 20px 48px rgba(18, 20, 28, 0.08);
	}
}

.dc-logo--footer .dc-logo__mark {
	width: 44px;
	height: 44px;
}

.dc-footer__tagline {
	margin: 0.85rem 0 0;
	color: var(--dc-muted);
	font-size: 0.9375rem;
	line-height: 1.6;
	max-width: 36ch;
}

.dc-footer__social {
	display: flex;
	flex-wrap: wrap;
	gap: 0.55rem;
	margin-top: 1.25rem;
}

.dc-footer__social-link {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0.5rem 0.85rem;
	border-radius: 999px;
	border: 1px solid var(--dc-line);
	background: var(--dc-surface);
	color: var(--dc-fg);
	font-size: 0.8125rem;
	font-weight: 700;
	text-decoration: none;
	transition: transform 0.22s var(--dc-ease), border-color 0.22s ease, background 0.22s ease, color 0.22s ease;
}

.dc-footer__social-link svg {
	flex-shrink: 0;
	opacity: 0.85;
}

.dc-footer__social-link:hover {
	transform: translateY(-2px);
	color: #fff;
	border-color: transparent;
}

.dc-footer__social-link--ig:hover {
	background: linear-gradient(135deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888);
}

.dc-footer__social-link--fb:hover {
	background: #1877f2;
}

.dc-footer__social-menu {
	margin-top: 0.65rem;
}

.dc-footer__social-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: 0.65rem;
	flex-wrap: wrap;
}

.dc-footer__social-list a {
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--dc-muted);
}

.dc-footer__social-list a:hover {
	color: var(--dc-accent);
}

.dc-footer__heading {
	margin: 0 0 1rem;
	font-family: var(--dc-display);
	font-size: 0.78rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--dc-accent);
	font-weight: 800;
}

.dc-footer__contact-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 1rem;
}

.dc-footer__contact-item {
	display: flex;
	gap: 0.75rem;
	align-items: flex-start;
}

.dc-footer__contact-icon {
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	display: grid;
	place-items: center;
	border-radius: 12px;
	background: var(--dc-accent-soft);
	color: var(--dc-accent);
}

.dc-footer__contact-label {
	display: block;
	font-size: 0.7rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--dc-muted);
	font-weight: 700;
	margin-bottom: 0.2rem;
}

.dc-footer__contact-item a,
.dc-footer__address {
	margin: 0;
	font-style: normal;
	font-size: 0.9375rem;
	font-weight: 600;
	line-height: 1.5;
	color: var(--dc-fg);
	text-decoration: none;
	word-break: break-word;
}

.dc-footer__contact-item a:hover {
	color: var(--dc-accent);
}

.dc-footer__phones,
.dc-contact-card__phones {
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
}

.dc-footer__menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.5rem;
}

.dc-footer__menu a {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	color: var(--dc-muted);
	font-weight: 600;
	font-size: 0.9375rem;
	text-decoration: none;
	transition: color 0.2s ease, transform 0.2s ease;
}

.dc-footer__menu a::before {
	content: "";
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--dc-accent);
	opacity: 0;
	transform: scale(0);
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.dc-footer__menu a:hover {
	color: var(--dc-fg);
	transform: translateX(3px);
}

.dc-footer__menu a:hover::before {
	opacity: 1;
	transform: scale(1);
}

.dc-footer__bottom {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 0.75rem;
	margin-top: clamp(1.75rem, 4vw, 2.5rem);
	padding-top: 1.35rem;
	border-top: 1px solid var(--dc-line);
	font-size: 0.85rem;
	color: var(--dc-muted);
}

.dc-footer__copy a {
	color: var(--dc-fg);
	font-weight: 700;
	text-decoration: none;
}

.dc-footer__copy a:hover {
	color: var(--dc-accent);
}

.dc-footer__credit {
	margin: 0;
	text-align: right;
}

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

	.dc-footer__brand {
		grid-column: 1 / -1;
	}
}

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

	.dc-footer__bottom {
		flex-direction: column;
		text-align: center;
	}

	.dc-footer__credit {
		text-align: center;
	}

	.dc-footer__tagline {
		max-width: none;
	}
}

/* Pages */
.dc-page-head {
	margin-bottom: 2rem;
}

.dc-page-head__title {
	font-family: var(--dc-display);
	font-size: clamp(2rem, 5vw, 3.25rem);
	font-weight: 800;
	letter-spacing: -0.03em;
	margin: 0;
}

.dc-page-head__sub {
	color: var(--dc-muted);
	max-width: 60ch;
}

.dc-page__content--elementor {
	max-width: none;
	width: 100%;
	padding: 0;
}

.dc-post-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 1rem;
}

.dc-blog-card {
	overflow: hidden;
}

.dc-blog-card__link {
	display: flex;
	flex-direction: column;
	height: 100%;
	color: inherit;
}

.dc-blog-card__media {
	aspect-ratio: 16 / 10;
	overflow: hidden;
}

.dc-blog-card__img,
.dc-blog-card__placeholder {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.dc-blog-card__placeholder {
	background: linear-gradient(135deg, rgba(214, 40, 57, 0.14), rgba(200, 208, 220, 0.1));
}

.dc-blog-card__body {
	padding: 1rem 1.1rem 1.25rem;
}

.dc-blog-card__date {
	font-size: 0.8rem;
	color: var(--dc-muted);
	margin: 0 0 0.35rem;
}

.dc-blog-card__title {
	margin: 0 0 0.35rem;
	font-size: 1.15rem;
}

.dc-blog-card__excerpt {
	margin: 0;
	color: var(--dc-muted);
	font-size: 0.95rem;
}

.dc-about-brand-img {
	display: block;
	width: 100%;
	height: auto;
	max-height: min(360px, 55vh);
	object-fit: contain;
	padding: clamp(1rem, 3vw, 2rem);
}

.dc-about-hero__video-wrap {
	width: 100%;
	padding: clamp(0.65rem, 2vw, 1.35rem);
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 200px;
}

.dc-about-hero__video {
	display: block;
	width: 100%;
	max-width: 100%;
	height: auto;
	max-height: min(420px, 58vh);
	border-radius: var(--dc-radius-sm, 12px);
	background: radial-gradient(circle at 50% 30%, rgba(255, 255, 255, 0.08), #0f1114);
}
.dc-about-hero__grid {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: center;
}

.dc-contact__grid {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: start;
}

.dc-about-hero__visual {
	min-height: 280px;
	position: relative;
	overflow: hidden;
}

.dc-spray-orbit {
	position: absolute;
	inset: 12%;
	border-radius: 50%;
	border: 1px dashed rgba(18, 20, 28, 0.15);
	animation: dc-spin 22s linear infinite;
	box-shadow: inset 0 0 60px rgba(214, 40, 57, 0.1);
}

.dc-spray-orbit::after {
	content: "";
	position: absolute;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: var(--dc-accent-2);
	top: 8%;
	left: 50%;
	transform: translateX(-50%);
	box-shadow: 0 0 28px rgba(214, 40, 57, 0.45);
}

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

.dc-split {
	display: grid;
	grid-template-columns: 0.9fr 1.1fr;
	gap: clamp(1.25rem, 3vw, 2.5rem);
	align-items: start;
}

.dc-split__sticky {
	position: sticky;
	top: 6rem;
	padding: 1.25rem;
}

@media (max-width: 900px) {
	.dc-about-hero__grid,
	.dc-contact__grid,
	.dc-split {
		grid-template-columns: 1fr;
	}

	.dc-split__sticky {
		position: static;
	}
}

.dc-contact__facts {
	margin: 1rem 0 0;
	padding-left: 1.1rem;
	color: var(--dc-muted);
}

.dc-contact__panel {
	padding: clamp(1.25rem, 3vw, 2rem);
}

.dc-contact__hint {
	margin-top: 1rem;
	color: var(--dc-muted);
	font-size: 0.95rem;
}

/* 404 */
.dc-404 {
	min-height: 70vh;
	display: grid;
	place-items: center;
}

.dc-404__inner {
	padding: clamp(2rem, 5vw, 3rem);
	text-align: center;
	max-width: 560px;
}

.dc-404__title {
	font-family: var(--dc-display);
	font-size: clamp(4rem, 14vw, 8rem);
	margin: 0.5rem 0;
	line-height: 1;
	display: inline-block;
	background-image: linear-gradient(120deg, var(--dc-accent) 0%, #e84d5c 45%, var(--dc-accent-2) 100%);
	background-size: 100% 100%;
	background-repeat: no-repeat;
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
}

.dc-404__title .dc-split-char {
	background-image: linear-gradient(120deg, var(--dc-accent) 0%, #e84d5c 45%, var(--dc-accent-2) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
}

@supports not (background-clip: text) {
	.dc-404__title,
	.dc-404__title .dc-split-char {
		background: none;
		-webkit-text-fill-color: currentColor;
		color: var(--dc-accent);
	}
}

.dc-404__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	justify-content: center;
	margin-top: 1.5rem;
}

/* Split text helper */
.dc-split-char {
	display: inline-block;
	transform-origin: 50% 90%;
	will-change: transform, opacity;
}

/* Magnetic wrap target */
.magnetic-wrap {
	position: relative;
}

/* Admin bar offset */
body.admin-bar .dc-header {
	top: 2rem;
}

@media (max-width: 782px) {
	body.admin-bar .dc-header {
		top: 2.75rem;
	}
}

/* Pagination */
.navigation.pagination {
	display: flex;
	justify-content: center;
	gap: 0.35rem;
	margin-top: 2rem;
}

.navigation.pagination a,
.navigation.pagination span {
	min-width: 40px;
	height: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	border: 1px solid var(--dc-line);
	color: var(--dc-muted);
}

.navigation.pagination .current {
	color: var(--dc-fg);
	border-color: rgba(214, 40, 57, 0.42);
}

/* Home   empty states + product grid */
.dc-home-empty {
	padding: clamp(1.5rem, 4vw, 2.25rem);
	text-align: center;
	max-width: 520px;
	margin-inline: auto;
}

.dc-home-empty__title {
	font-family: var(--dc-display);
	font-weight: 700;
	font-size: 1.25rem;
	margin: 0 0 0.5rem;
}

.dc-home-empty__text {
	color: var(--dc-muted);
	margin: 0 0 1.25rem;
	font-size: 0.95rem;
}

.dc-home-empty .dc-btn {
	margin: 0.25rem;
}

.dc-section-head .dc-btn {
	align-self: center;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.001ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.001ms !important;
		scroll-behavior: auto !important;
	}

	.dc-marquee__track {
		animation: none;
	}
}

/* Brand logo image   hard cap (SVGs ignore HTML width/height without this) */
.dc-logo__img {
	display: block;
	width: auto;
	height: auto;
	max-height: 44px;
	max-width: 100%;
	object-fit: contain;
	object-position: left center;
}

.dc-logo--footer .dc-logo__img {
	max-height: 52px;
}

/* About page   extended */
.dc-about-band {
	padding-block: clamp(2.5rem, 6vw, 4rem);
	border-block: 1px solid var(--dc-line);
	background: var(--dc-bg-soft);
}

.dc-about-values {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1rem;
}

.dc-about-value {
	padding: 1.25rem;
}

.dc-about-value h3 {
	margin: 0 0 0.5rem;
	font-size: 1.1rem;
	font-family: var(--dc-display);
}

.dc-about-value p {
	margin: 0;
	color: var(--dc-muted);
	font-size: 0.95rem;
}

.dc-about-timeline {
	display: grid;
	gap: 1rem;
	max-width: 720px;
}

.dc-about-tl-item {
	display: grid;
	grid-template-columns: 88px 1fr;
	gap: 1rem;
	align-items: baseline;
	padding: 1rem 0;
	border-bottom: 1px solid var(--dc-line);
}

.dc-about-tl-year {
	font-family: var(--dc-display);
	font-weight: 800;
	color: var(--dc-accent-2);
}

.dc-about-tl-item p {
	margin: 0.35rem 0 0;
	color: var(--dc-muted);
	font-size: 0.95rem;
}

.dc-about-cta {
	text-align: center;
	padding: clamp(2rem, 5vw, 3rem);
}

.dc-about-hero__tagline {
	font-size: clamp(1.05rem, 2.2vw, 1.35rem);
	color: var(--dc-muted);
	margin: 0.75rem 0 1.25rem;
	line-height: 1.45;
}

.dc-about-roles {
	display: flex;
	flex-wrap: wrap;
	gap: 0.55rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.dc-about-role {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0.45rem 0.75rem;
	font-size: 0.82rem;
	font-weight: 600;
	letter-spacing: 0.02em;
}

.dc-about-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	color: var(--dc-accent-2);
}

.dc-about-icon--section {
	margin-bottom: 0.35rem;
}

.dc-about-icon--lg {
	width: 3rem;
	height: 3rem;
	border-radius: 999px;
	background: rgba(214, 40, 57, 0.1);
	border: 1px solid rgba(214, 40, 57, 0.22);
}

.dc-about-icon--cap {
	width: 2.5rem;
	height: 2.5rem;
	border-radius: 12px;
	background: rgba(214, 40, 57, 0.08);
	border: 1px solid rgba(214, 40, 57, 0.16);
	margin-bottom: 0.65rem;
}

.dc-about-overview {
	display: grid;
	gap: clamp(1.25rem, 3vw, 2rem);
}

.dc-about-overview__copy p {
	margin: 0 0 1rem;
	color: var(--dc-muted);
	line-height: 1.65;
}

.dc-about-overview__copy p:last-child {
	margin-bottom: 0;
}

.dc-about-capabilities {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
	gap: 0.75rem;
}

.dc-about-cap {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	padding: 1rem;
	font-size: 0.92rem;
	font-weight: 600;
	line-height: 1.35;
}

.dc-about-sourcing {
	padding: 1rem 1.15rem;
}

.dc-about-sourcing__head {
	display: flex;
	align-items: center;
	gap: 0.55rem;
	margin-bottom: 0.75rem;
	font-family: var(--dc-display);
	font-size: 0.95rem;
}

.dc-about-sourcing__list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem 1.25rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.dc-about-sourcing__list li {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-size: 0.9rem;
	color: var(--dc-muted);
}

.dc-about-vm {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: clamp(1rem, 3vw, 1.5rem);
}

.dc-about-vm__card {
	padding: clamp(1.25rem, 3vw, 1.75rem);
}

.dc-about-vm__icon {
	margin-bottom: 0.75rem;
}

.dc-about-vm__card .dc-h3 {
	margin: 0.35rem 0 0.75rem;
}

.dc-about-vm__card p {
	margin: 0;
	color: var(--dc-muted);
	line-height: 1.6;
}

.dc-about-journey {
	display: grid;
	gap: 0.85rem;
	max-width: 860px;
}

.dc-about-journey__step {
	display: grid;
	grid-template-columns: 96px 1fr;
	gap: 1rem;
	align-items: start;
	padding: 1.15rem 1.25rem;
}

.dc-about-journey__year {
	font-family: var(--dc-display);
	font-weight: 800;
	font-size: 0.95rem;
	color: var(--dc-accent-2);
	line-height: 1.2;
}

.dc-about-journey__step .dc-h3 {
	margin: 0 0 0.45rem;
	font-size: 1.05rem;
}

.dc-about-journey__step p {
	margin: 0;
	color: var(--dc-muted);
	font-size: 0.95rem;
	line-height: 1.55;
}

.dc-about-leaders {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: clamp(1rem, 3vw, 1.5rem);
}

.dc-about-leader {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	padding: 1.15rem;
	align-items: start;
}

.dc-about-leader--next {
	grid-template-columns: 140px 1fr;
}

.dc-about-leader__photo {
	aspect-ratio: 1;
	border-radius: var(--dc-radius-sm, 12px);
	overflow: hidden;
	background: radial-gradient(circle at 50% 20%, rgba(255, 255, 255, 0.08), rgba(15, 17, 20, 0.85));
	border: 1px solid var(--dc-line);
}

.dc-about-leader__photo img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.dc-about-leader__placeholder {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	width: 100%;
	height: 100%;
	min-height: 120px;
	color: var(--dc-muted);
	text-align: center;
	padding: 0.75rem;
}

.dc-about-leader__photo-hint {
	font-size: 0.68rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	line-height: 1.3;
	max-width: 8rem;
}

.dc-about-leader__body .dc-h3 {
	margin: 0 0 0.25rem;
	font-size: 1.1rem;
}

.dc-about-leader__role {
	margin: 0 0 0.65rem;
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--dc-accent-2);
}

.dc-about-leader__body p {
	margin: 0;
	color: var(--dc-muted);
	font-size: 0.95rem;
	line-height: 1.55;
}

.dc-about-leader__edu {
	margin: 0 0 0.75rem;
	padding: 0;
	list-style: none;
	display: grid;
	gap: 0.2rem;
	font-size: 0.88rem;
	color: var(--dc-fg);
}

.dc-about-leader__edu li {
	position: relative;
	padding-left: 1.1rem;
}

.dc-about-leader__edu li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.55em;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--dc-accent-2);
}

@media (max-width: 900px) {
	.dc-about-vm,
	.dc-about-leaders {
		grid-template-columns: 1fr;
	}

	.dc-about-journey__step,
	.dc-about-leader,
	.dc-about-leader--next {
		grid-template-columns: 1fr;
	}

	.dc-about-journey__year {
		margin-bottom: -0.35rem;
	}
}

@media (max-width: 520px) {
	.dc-about-role {
		flex: 1 1 calc(50% - 0.55rem);
		justify-content: center;
	}
}

/* Contact   details + form */
.dc-contact-cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 0.75rem;
	margin-top: 1.5rem;
}

.dc-contact-card {
	padding: 1rem 1.1rem;
	font-size: 0.95rem;
}

.dc-contact-card strong {
	display: block;
	font-size: 0.72rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--dc-muted);
	margin-bottom: 0.35rem;
}

.dc-contact-card a {
	color: var(--dc-accent-2);
	font-weight: 600;
}

.dc-contact__form-title {
	margin: 0 0 0.5rem;
}

.dc-contact__form-lead {
	margin: 0 0 1.25rem;
	font-size: 0.95rem;
	color: var(--dc-muted);
	line-height: 1.55;
}

.dc-contact__editor {
	margin-bottom: 1.5rem;
}

.dc-contact-form-wrap {
	margin-top: 0;
}

/* Contact Form 7 — compact theme styling */
.dc-cf7-form .wpcf7 {
	margin: 0;
}

/* Hide honeypot, hidden fields, empty rows, default empty message box */
.dc-cf7-form .hidden-fields-container,
.dc-cf7-form .akismet-fields-container,
.dc-cf7-form .wpcf7-form-control-wrap._wpcf7_hp,
.dc-cf7-form .wpcf7-form > p:empty,
.dc-cf7-form .wpcf7-form > p:has(.wpcf7-form-control-wrap:empty) {
	display: none !important;
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
}

.dc-cf7-form .wpcf7-response-output {
	display: none !important;
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
	min-height: 0 !important;
}

.dc-cf7-form .wpcf7 form.sent .wpcf7-response-output,
.dc-cf7-form .wpcf7 form.invalid .wpcf7-response-output,
.dc-cf7-form .wpcf7 form.failed .wpcf7-response-output,
.dc-cf7-form .wpcf7 form.aborted .wpcf7-response-output,
.dc-cf7-form .wpcf7 form.spam .wpcf7-response-output,
.dc-cf7-form .wpcf7 form.unaccepted .wpcf7-response-output,
.dc-cf7-form .wpcf7 form.payment-required .wpcf7-response-output {
	display: block !important;
	margin: 1rem 0 0 !important;
	padding: 0.75rem 0.9rem !important;
	border-radius: 12px !important;
	border: 1px solid var(--dc-line) !important;
	font-size: 0.875rem !important;
	font-weight: 600;
	line-height: 1.45;
}

/* Har field apni line — ek column, full width */
.dc-cf7-form .wpcf7-form {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}

.dc-cf7-form .wpcf7-form > p {
	margin: 0;
	padding: 0;
	border: none;
	background: transparent;
	width: 100%;
}

.dc-cf7-form .wpcf7-form label {
	display: block;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--dc-muted);
	margin: 0 0 0.3rem;
	line-height: 1.3;
}

.dc-cf7-form .wpcf7-form-control-wrap {
	display: block;
	width: 100%;
	margin: 0;
}

.dc-cf7-form .wpcf7-form-control:not(.wpcf7-submit):not(.wpcf7-file) {
	display: block;
	width: 100%;
	max-width: 100%;
	height: 2.5rem;
	min-height: 0;
	margin: 0;
	padding: 0 0.65rem;
	border-radius: 8px;
	border: 1px solid var(--dc-line);
	background: #fff;
	color: var(--dc-fg);
	font: inherit;
	font-size: 0.85rem;
	line-height: 1.35;
	outline: none;
	box-sizing: border-box;
	box-shadow: none;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.dc-cf7-form textarea.wpcf7-form-control {
	height: auto;
	min-height: 4.5rem;
	height: 15rem !important;
	padding: 0.55rem 0.75rem;
	resize: vertical;
	border-radius: 10px;
	font-size: 0.85rem;
}

.dc-cf7-form select.wpcf7-form-control {
	appearance: auto;
	cursor: pointer;
	padding-right: 2rem;
}

.dc-cf7-form .wpcf7-form-control:focus {
	border-color: rgba(200, 31, 46, 0.5);
	box-shadow: 0 0 0 2px rgba(200, 31, 46, 0.1);
}

.dc-cf7-form .wpcf7-form-control.wpcf7-not-valid {
	border-color: rgba(200, 31, 46, 0.7);
}

.dc-cf7-form .wpcf7-not-valid-tip {
	display: block;
	margin-top: 0.25rem;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--dc-accent);
	line-height: 1.3;
}

.dc-cf7-form .wpcf7-form > p:has(.wpcf7-submit) {
	margin-top: 0.1rem;
}

.dc-cf7-form .wpcf7-submit,
.dc-cf7-form input[type="submit"].wpcf7-form-control {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: auto;
	min-height: 2.5rem;
	margin: 0;
	padding: 0.65rem 1.1rem;
	border: none;
	border-radius: 999px;
	font: inherit;
	font-weight: 700;
	font-size: 0.9rem;
	line-height: 1.2;
	cursor: pointer;
	color: #fff;
	background: linear-gradient(120deg, var(--dc-accent), var(--dc-accent-2));
	box-shadow: 0 8px 24px rgba(200, 31, 46, 0.2);
	transition: transform 0.25s var(--dc-ease), box-shadow 0.25s ease, opacity 0.2s ease;
}

.dc-cf7-form .wpcf7-submit:hover,
.dc-cf7-form input[type="submit"].wpcf7-form-control:hover {
	transform: translateY(-1px);
	box-shadow: 0 10px 28px rgba(200, 31, 46, 0.26);
}

.dc-cf7-form .wpcf7-submit:disabled,
.dc-cf7-form input[type="submit"].wpcf7-form-control:disabled {
	opacity: 0.65;
	cursor: wait;
	transform: none;
}

.dc-cf7-form .wpcf7-spinner {
	margin: 0.5rem auto 0;
	display: block;
}

.dc-cf7-form .wpcf7 form.sent .wpcf7-response-output {
	background: rgba(200, 31, 46, 0.08);
	border-color: rgba(200, 31, 46, 0.22) !important;
	color: var(--dc-fg);
}

.dc-cf7-form .wpcf7 form.invalid .wpcf7-response-output,
.dc-cf7-form .wpcf7 form.failed .wpcf7-response-output,
.dc-cf7-form .wpcf7 form.aborted .wpcf7-response-output,
.dc-cf7-form .wpcf7 form.spam .wpcf7-response-output,
.dc-cf7-form .wpcf7 form.unaccepted .wpcf7-response-output {
	background: rgba(232, 184, 109, 0.1);
	border-color: rgba(232, 184, 109, 0.3) !important;
	color: var(--dc-fg);
}

.dc-cf7-form .wpcf7-list-item {
	margin: 0.25rem 0 0;
	display: block;
}

.dc-cf7-form .wpcf7-list-item label {
	display: inline-flex;
	align-items: flex-start;
	gap: 0.45rem;
	font-size: 0.85rem;
	font-weight: 500;
	text-transform: none;
	letter-spacing: 0;
	color: var(--dc-fg);
	cursor: pointer;
}

.dc-cf7-form .wpcf7-list-item input[type="checkbox"],
.dc-cf7-form .wpcf7-list-item input[type="radio"] {
	width: auto;
	height: auto;
	margin-top: 0.15rem;
	accent-color: var(--dc-accent);
}


.dc-notice {
	padding: 0.85rem 1rem;
	border-radius: 14px;
	margin-bottom: 1rem;
	font-size: 0.95rem;
	font-weight: 600;
}

.dc-notice--success {
	background: rgba(214, 40, 57, 0.12);
	border: 1px solid rgba(214, 40, 57, 0.28);
	color: var(--dc-fg);
}

.dc-notice--error {
	background: rgba(232, 184, 109, 0.1);
	border: 1px solid rgba(232, 184, 109, 0.35);
	color: var(--dc-fg);
}

.dc-contact-map {
	margin-top: 2rem;
	padding: 1.25rem;
	font-size: 0.95rem;
	color: var(--dc-muted);
}

.dc-contact-map a {
	color: var(--dc-accent-2);
	font-weight: 600;
}
.our_missions_content , .main_timeline{
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}
.our_missions_content img, .main_timeline_img img{
	width: 100%;
	max-width: 500px;
	height: auto;
	object-fit: contain;
	border-radius: 20px;
}