/* ============================================================
   CD - Creative Digitals | Premium Dark RTL Theme
   Black / White / Silver - futuristic digital-tech luxury UI
   ============================================================ */

:root {
	--cd-black: #050505;
	--cd-graphite: #111111;
	--cd-dark-gray: #1C1C1C;
	--cd-white: #FFFFFF;
	--cd-silver: #CFCFCF;
	--cd-gray-text: #AFAFAF;
	--cd-border: rgba(255, 255, 255, 0.16);
	--cd-border-soft: rgba(255, 255, 255, 0.08);
	--cd-glow: rgba(255, 255, 255, 0.10);
	--cd-glass: rgba(255, 255, 255, 0.04);
	--cd-font: "Assistant", "Heebo", "Arial", sans-serif;
	--cd-radius: 16px;
	--cd-ease: cubic-bezier(0.22, 1, 0.36, 1);
	--cd-dur: 450ms;
}

/* ---------- Base ---------- */

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

html {
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%;
}

body {
	margin: 0;
	background: var(--cd-black);
	color: var(--cd-silver);
	font-family: var(--cd-font);
	font-size: 18px;
	line-height: 1.7;
	direction: rtl;
	overflow-x: hidden;
	-webkit-font-smoothing: antialiased;
}

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

a {
	color: var(--cd-white);
	text-decoration: none;
	transition: color var(--cd-dur) var(--cd-ease), opacity var(--cd-dur) var(--cd-ease);
}

a:hover {
	color: var(--cd-silver);
}

h1, h2, h3, h4 {
	color: var(--cd-white);
	font-weight: 700;
	line-height: 1.25;
	margin: 0 0 0.5em;
}

p {
	margin: 0 0 1em;
}

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

.skip-link:focus {
	clip: auto;
	width: auto;
	height: auto;
	top: 8px;
	right: 8px;
	z-index: 9999;
	padding: 10px 18px;
	background: var(--cd-dark-gray);
	color: var(--cd-white);
	border-radius: 8px;
}

.cd-container {
	width: min(1200px, calc(100% - 48px));
	margin-inline: auto;
}

.cd-container-narrow {
	width: min(860px, calc(100% - 48px));
	margin-inline: auto;
}

.cd-main {
	position: relative;
	z-index: 1;
}

/* ============================================================
   Ambient background: network dots + slow glow blobs + grid
   ============================================================ */

.cd-network-bg {
	position: fixed;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	overflow: hidden;
	background:
		radial-gradient(1100px 500px at 85% -10%, rgba(255, 255, 255, 0.05), transparent 60%),
		radial-gradient(900px 500px at 10% 110%, rgba(255, 255, 255, 0.04), transparent 60%),
		var(--cd-black);
}

.cd-network-bg::before {
	content: "";
	position: absolute;
	inset: -60px;
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px);
	background-size: 64px 64px;
	mask-image: radial-gradient(ellipse 90% 70% at 50% 30%, #000 30%, transparent 75%);
	-webkit-mask-image: radial-gradient(ellipse 90% 70% at 50% 30%, #000 30%, transparent 75%);
	animation: cd-grid-drift 18s var(--cd-ease) infinite alternate;
}

@keyframes cd-grid-drift {
	from { transform: translate3d(0, 0, 0); }
	to   { transform: translate3d(24px, 18px, 0); }
}

.cd-net-dot {
	position: absolute;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--cd-silver);
	opacity: 0.28;
	box-shadow: 0 0 12px 2px rgba(255, 255, 255, 0.25);
	animation: cd-dot-float 14s ease-in-out infinite alternate;
}

.cd-net-dot::after {
	content: "";
	position: absolute;
	top: 2px;
	right: 2px;
	width: 180px;
	height: 1px;
	background: linear-gradient(to left, rgba(255, 255, 255, 0.14), transparent);
	transform-origin: right center;
	transform: rotate(-24deg);
}

.cd-net-dot-1 { top: 18%; right: 12%; animation-delay: 0s; }
.cd-net-dot-2 { top: 32%; right: 78%; animation-delay: -3s; }
.cd-net-dot-3 { top: 62%; right: 26%; animation-delay: -6s; }
.cd-net-dot-4 { top: 76%; right: 68%; animation-delay: -9s; }
.cd-net-dot-5 { top: 48%; right: 48%; animation-delay: -12s; }

.cd-net-dot-2::after { transform: rotate(18deg); width: 220px; }
.cd-net-dot-4::after { transform: rotate(-40deg); width: 150px; }

@keyframes cd-dot-float {
	from { transform: translate3d(0, 0, 0); }
	to   { transform: translate3d(-26px, 20px, 0); }
}

.cd-glow-blob {
	position: absolute;
	width: 520px;
	height: 520px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(255, 255, 255, 0.055), transparent 65%);
	filter: blur(10px);
	animation: cd-blob-drift 20s ease-in-out infinite alternate;
}

.cd-glow-blob-1 { top: -12%; left: -8%; }
.cd-glow-blob-2 { bottom: -18%; right: -10%; animation-delay: -10s; }

@keyframes cd-blob-drift {
	from { transform: translate3d(0, 0, 0) scale(1); }
	to   { transform: translate3d(60px, 40px, 0) scale(1.12); }
}

/* ============================================================
   Header - sticky dark glass
   ============================================================ */

.cd-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: rgba(5, 5, 5, 0.55);
	-webkit-backdrop-filter: blur(14px);
	backdrop-filter: blur(14px);
	border-bottom: 1px solid var(--cd-border-soft);
	transition: background var(--cd-dur) var(--cd-ease), border-color var(--cd-dur) var(--cd-ease), box-shadow var(--cd-dur) var(--cd-ease);
	animation: cd-header-in 700ms var(--cd-ease) both;
}

@keyframes cd-header-in {
	from { opacity: 0; transform: translateY(-16px); }
	to   { opacity: 1; transform: translateY(0); }
}

.cd-header-scrolled {
	background: rgba(5, 5, 5, 0.88);
	border-bottom-color: var(--cd-border);
	box-shadow: 0 8px 30px rgba(0, 0, 0, 0.45);
}

.cd-header-inner {
	display: flex;
	/* Logo on the left, actions (WhatsApp) on the right */
	flex-direction: row-reverse;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	min-height: 96px;
}

.cd-header-logo a {
	display: flex;
	align-items: center;
}

.cd-logo-img,
.cd-header-logo .custom-logo {
	width: auto;
	height: 88px;
	object-fit: contain;
	filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.12));
	transition: filter var(--cd-dur) var(--cd-ease), transform var(--cd-dur) var(--cd-ease);
}

.cd-header-logo a:hover .cd-logo-img,
.cd-header-logo a:hover .custom-logo {
	filter: drop-shadow(0 0 14px rgba(255, 255, 255, 0.28));
	transform: translateY(-1px);
}

/* Navigation */

.cd-nav-list {
	display: flex;
	align-items: center;
	gap: 6px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.cd-nav-list a {
	display: inline-block;
	padding: 8px 16px;
	border-radius: 10px;
	color: var(--cd-silver);
	font-weight: 600;
	font-size: 16px;
	position: relative;
	transition: color var(--cd-dur) var(--cd-ease), background var(--cd-dur) var(--cd-ease);
}

.cd-nav-list a::after {
	content: "";
	position: absolute;
	bottom: 4px;
	right: 16px;
	left: 16px;
	height: 1px;
	background: linear-gradient(to left, transparent, var(--cd-silver), transparent);
	transform: scaleX(0);
	transition: transform var(--cd-dur) var(--cd-ease);
}

.cd-nav-list a:hover,
.cd-nav-list .current-menu-item > a {
	color: var(--cd-white);
	background: rgba(255, 255, 255, 0.05);
}

.cd-nav-list a:hover::after,
.cd-nav-list .current-menu-item > a::after {
	transform: scaleX(1);
}

.cd-header-actions {
	display: flex;
	align-items: center;
	gap: 14px;
}

.cd-nav-mobile-cta {
	display: none;
}

/* Hamburger */

.cd-menu-toggle {
	display: none;
	background: transparent;
	border: 1px solid var(--cd-border);
	border-radius: 10px;
	padding: 10px;
	cursor: pointer;
	transition: border-color var(--cd-dur) var(--cd-ease), background var(--cd-dur) var(--cd-ease);
}

.cd-menu-toggle:hover {
	border-color: var(--cd-silver);
	background: rgba(255, 255, 255, 0.05);
}

.cd-burger {
	display: flex;
	flex-direction: column;
	gap: 5px;
	width: 22px;
}

.cd-burger i {
	display: block;
	height: 2px;
	border-radius: 2px;
	background: var(--cd-white);
	transition: transform 350ms var(--cd-ease), opacity 350ms var(--cd-ease);
}

.cd-menu-open .cd-burger i:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.cd-menu-open .cd-burger i:nth-child(2) { opacity: 0; }
.cd-menu-open .cd-burger i:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ============================================================
   Buttons - luxury silver / glass
   ============================================================ */

.cd-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	padding: 14px 30px;
	border-radius: 999px;
	font-family: var(--cd-font);
	font-size: 17px;
	font-weight: 700;
	line-height: 1;
	cursor: pointer;
	position: relative;
	overflow: hidden;
	isolation: isolate;
	transition: transform var(--cd-dur) var(--cd-ease), box-shadow var(--cd-dur) var(--cd-ease), background var(--cd-dur) var(--cd-ease), border-color var(--cd-dur) var(--cd-ease), color var(--cd-dur) var(--cd-ease);
	will-change: transform;
}

.cd-btn:hover {
	transform: translateY(-3px);
}

.cd-btn:active {
	transform: translateY(-1px);
}

.cd-btn-primary {
	background: linear-gradient(180deg, #FFFFFF 0%, #DADADA 55%, #BFBFBF 100%);
	color: #0A0A0A;
	border: 1px solid rgba(255, 255, 255, 0.7);
	box-shadow: 0 0 0 rgba(255, 255, 255, 0);
}

.cd-btn-primary:hover {
	color: #000000;
	box-shadow: 0 10px 34px rgba(255, 255, 255, 0.22);
}

.cd-btn-secondary {
	background: rgba(255, 255, 255, 0.03);
	color: var(--cd-white);
	border: 1px solid var(--cd-border);
}

.cd-btn-secondary:hover {
	border-color: rgba(255, 255, 255, 0.45);
	box-shadow: 0 8px 28px rgba(255, 255, 255, 0.10);
	color: var(--cd-white);
}

.cd-btn-sm {
	padding: 10px 20px;
	font-size: 15px;
}

.cd-btn-icon {
	flex: none;
}

/* Shine sweep */

.cd-shine::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background: linear-gradient(115deg, transparent 30%, rgba(255, 255, 255, 0.35) 50%, transparent 70%);
	transform: translateX(120%);
	transition: transform 700ms var(--cd-ease);
	pointer-events: none;
}

.cd-btn-secondary.cd-shine::before {
	background: linear-gradient(115deg, transparent 30%, rgba(255, 255, 255, 0.12) 50%, transparent 70%);
}

.cd-shine:hover::before {
	transform: translateX(-120%);
}

.cd-text-link {
	color: var(--cd-white);
	border-bottom: 1px solid var(--cd-border);
}

/* ============================================================
   Hero
   ============================================================ */

.cd-hero {
	position: relative;
	padding: 90px 0 100px;
	overflow: hidden;
}

.cd-floating-grid {
	position: relative;
}

.cd-floating-grid::before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background: radial-gradient(700px 320px at 78% 18%, rgba(255, 255, 255, 0.06), transparent 65%);
	animation: cd-hero-glow 12s ease-in-out infinite alternate;
}

@keyframes cd-hero-glow {
	from { opacity: 0.6; transform: translate3d(0, 0, 0); }
	to   { opacity: 1; transform: translate3d(-30px, 16px, 0); }
}

.cd-hero-grid {
	position: relative;
	display: grid;
	grid-template-columns: 1.08fr 0.92fr;
	gap: 56px;
	align-items: center;
}

.cd-hero-kicker {
	display: inline-block;
	padding: 6px 16px;
	margin-bottom: 18px;
	border: 1px solid var(--cd-border);
	border-radius: 999px;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.06em;
	color: var(--cd-gray-text);
	background: var(--cd-glass);
}

.cd-hero-title {
	font-size: clamp(42px, 6vw, 68px);
	font-weight: 800;
	letter-spacing: 0.01em;
	margin-bottom: 10px;
	background: linear-gradient(180deg, #FFFFFF 30%, #B9B9B9 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	text-shadow: 0 0 40px rgba(255, 255, 255, 0.08);
}

.cd-hero-subtitle {
	font-size: clamp(19px, 2.4vw, 23px);
	font-weight: 700;
	color: var(--cd-white);
	letter-spacing: 0.01em;
	margin: 14px 0 26px;
}

.cd-hero-desc {
	color: var(--cd-gray-text);
	font-size: 18px;
	max-width: 56ch;
}

.cd-hero-desc-secondary {
	color: var(--cd-silver);
}

/* Personal introduction paragraphs */

.cd-hero-intro {
	max-width: 58ch;
}

.cd-hero-intro p {
	color: var(--cd-gray-text);
	font-size: 17px;
	line-height: 1.75;
	margin: 0 0 14px;
}

.cd-hero-intro p:first-child {
	color: var(--cd-silver);
	font-size: 18px;
}

.cd-hero-closing {
	color: var(--cd-white) !important;
	font-weight: 700;
	font-size: 18px !important;
	margin-top: 4px !important;
}

.cd-hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	margin-top: 34px;
}

/* Hero video frame */

.cd-hero-video-frame {
	position: relative;
	border-radius: var(--cd-radius);
	border: 1px solid var(--cd-border);
	background: var(--cd-graphite);
	padding: 10px;
	box-shadow: 0 24px 70px rgba(0, 0, 0, 0.55), 0 0 40px rgba(255, 255, 255, 0.05);
	overflow: hidden;
	transition: transform var(--cd-dur) var(--cd-ease), box-shadow var(--cd-dur) var(--cd-ease), border-color var(--cd-dur) var(--cd-ease);
	will-change: transform;
}

.cd-hero-video-frame:hover {
	transform: translateY(-6px);
	border-color: rgba(255, 255, 255, 0.32);
	box-shadow: 0 30px 80px rgba(0, 0, 0, 0.6), 0 0 60px rgba(255, 255, 255, 0.10);
}

.cd-hero-video-frame::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(115deg, transparent 35%, rgba(255, 255, 255, 0.08) 50%, transparent 65%);
	transform: translateX(130%);
	animation: cd-frame-shine 9s var(--cd-ease) infinite;
	pointer-events: none;
}

@keyframes cd-frame-shine {
	0%, 62% { transform: translateX(130%); }
	78%, 100% { transform: translateX(-130%); }
}

.cd-frame-corner {
	position: absolute;
	width: 26px;
	height: 26px;
	border-color: var(--cd-silver);
	border-style: solid;
	opacity: 0.75;
	z-index: 2;
}

.cd-frame-corner-tl {
	top: 6px;
	right: 6px;
	border-width: 2px 2px 0 0;
	border-radius: 0 8px 0 0;
}

.cd-frame-corner-br {
	bottom: 6px;
	left: 6px;
	border-width: 0 0 2px 2px;
	border-radius: 0 0 0 8px;
}

/* True 9:16 portrait frame, centered in the hero column */

.cd-hero-media {
	display: flex;
	justify-content: center;
	align-items: center;
}

.cd-hero-video-frame {
	width: min(100%, 375px);
}

.cd-hero-video,
.cd-about-img {
	width: 100%;
	aspect-ratio: 9 / 16;
	object-fit: cover;
	border-radius: calc(var(--cd-radius) - 6px);
	display: block;
}

.cd-about-img {
	aspect-ratio: auto;
}

/* Sound toggle on the hero video */

.cd-sound-toggle {
	position: absolute;
	bottom: 22px;
	inset-inline-start: 22px;
	z-index: 3;
	display: grid;
	place-items: center;
	width: 46px;
	height: 46px;
	border-radius: 50%;
	border: 1px solid rgba(255, 255, 255, 0.4);
	background: rgba(5, 5, 5, 0.6);
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
	color: var(--cd-white);
	cursor: pointer;
	box-shadow: 0 0 24px rgba(255, 255, 255, 0.10);
	transition: transform var(--cd-dur) var(--cd-ease), background var(--cd-dur) var(--cd-ease), border-color var(--cd-dur) var(--cd-ease), box-shadow var(--cd-dur) var(--cd-ease);
}

.cd-sound-toggle:hover {
	transform: scale(1.08);
	background: rgba(255, 255, 255, 0.14);
	border-color: rgba(255, 255, 255, 0.6);
	box-shadow: 0 0 36px rgba(255, 255, 255, 0.20);
}

.cd-sound-toggle .cd-icon-sound {
	display: none;
}

/* Play/pause toggle: opposite corner from the sound toggle */
.cd-play-toggle {
	inset-inline-start: auto;
	inset-inline-end: 22px;
}

.cd-play-toggle .cd-icon-play {
	display: none;
	margin-inline-start: 2px;
}

.cd-play-toggle:not(.is-playing) .cd-icon-play {
	display: block;
}

.cd-play-toggle:not(.is-playing) .cd-icon-pause {
	display: none;
}

.cd-sound-toggle.is-on .cd-icon-sound {
	display: block;
}

.cd-sound-toggle.is-on .cd-icon-muted {
	display: none;
}

.cd-hero-video-placeholder {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 14px;
	aspect-ratio: 9 / 16;
	border-radius: calc(var(--cd-radius) - 6px);
	background:
		radial-gradient(circle at 50% 40%, rgba(255, 255, 255, 0.06), transparent 60%),
		var(--cd-dark-gray);
	color: var(--cd-gray-text);
	font-size: 18px;
	font-weight: 600;
	text-align: center;
	padding: 24px;
}

.cd-placeholder-icon {
	display: grid;
	place-items: center;
	width: 66px;
	height: 66px;
	border-radius: 50%;
	border: 1px solid var(--cd-border);
	color: var(--cd-silver);
	font-size: 20px;
	background: rgba(255, 255, 255, 0.04);
	box-shadow: 0 0 30px rgba(255, 255, 255, 0.08);
}

/* ============================================================
   Sections
   ============================================================ */

.cd-section {
	position: relative;
	padding: 90px 0;
}

.cd-section-graphite {
	background: linear-gradient(180deg, transparent, rgba(17, 17, 17, 0.85) 12%, rgba(17, 17, 17, 0.85) 88%, transparent);
}

.cd-section-head {
	text-align: center;
	max-width: 640px;
	margin: 0 auto 52px;
}

.cd-section-title {
	font-size: clamp(30px, 4vw, 42px);
	font-weight: 800;
	background: linear-gradient(180deg, #FFFFFF 40%, #C4C4C4 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}

.cd-section-subtitle {
	color: var(--cd-gray-text);
	font-size: 18px;
	margin: 8px 0 0;
}

.cd-section-line {
	display: block;
	width: 90px;
	height: 1px;
	margin: 22px auto 0;
	background: linear-gradient(to left, transparent, var(--cd-silver), transparent);
}

.cd-section-cta {
	display: flex;
	justify-content: center;
	gap: 16px;
	margin-top: 48px;
}

/* Grids */

.cd-grid {
	display: grid;
	gap: 26px;
}

.cd-grid-2 { grid-template-columns: repeat(2, 1fr); }
.cd-grid-3 { grid-template-columns: repeat(3, 1fr); }
.cd-grid-5 { grid-template-columns: repeat(5, 1fr); }

/* ============================================================
   Glass cards
   ============================================================ */

.cd-glass-card {
	background: linear-gradient(160deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.015));
	border: 1px solid var(--cd-border-soft);
	border-radius: var(--cd-radius);
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
	transition: transform var(--cd-dur) var(--cd-ease), border-color var(--cd-dur) var(--cd-ease), box-shadow var(--cd-dur) var(--cd-ease);
	will-change: transform;
}

.cd-hover-glow:hover {
	transform: translateY(-6px);
	border-color: rgba(255, 255, 255, 0.30);
	box-shadow: 0 18px 50px rgba(0, 0, 0, 0.5), 0 0 34px rgba(255, 255, 255, 0.08);
}

/* Service cards */

.cd-service-card {
	padding: 34px 28px;
	position: relative;
	overflow: hidden;
}

.cd-service-card::before {
	content: "";
	position: absolute;
	top: 0;
	right: 24px;
	left: 24px;
	height: 1px;
	background: linear-gradient(to left, transparent, rgba(255, 255, 255, 0.35), transparent);
	opacity: 0;
	transition: opacity var(--cd-dur) var(--cd-ease);
}

.cd-service-card:hover::before {
	opacity: 1;
}

.cd-service-icon {
	display: grid;
	place-items: center;
	width: 56px;
	height: 56px;
	margin-bottom: 20px;
	border-radius: 14px;
	border: 1px solid var(--cd-border);
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.09), rgba(255, 255, 255, 0.02));
	color: #E9E9E9;
	font-size: 22px;
	font-weight: 700;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14);
	transition: color var(--cd-dur) var(--cd-ease), box-shadow var(--cd-dur) var(--cd-ease), border-color var(--cd-dur) var(--cd-ease);
}

.cd-service-icon svg {
	width: 26px;
	height: 26px;
	display: block;
	filter: drop-shadow(0 0 6px rgba(255, 255, 255, 0.18));
}

.cd-service-card:hover .cd-service-icon {
	color: var(--cd-white);
	border-color: rgba(255, 255, 255, 0.34);
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 0 22px rgba(255, 255, 255, 0.10);
}

.cd-service-title {
	font-size: 22px;
	margin-bottom: 10px;
}

.cd-service-desc {
	color: var(--cd-gray-text);
	font-size: 16.5px;
}

.cd-service-desc p:last-child {
	margin-bottom: 0;
}

/* ============================================================
   Portfolio cards
   ============================================================ */

.cd-card {
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

.cd-portfolio-card:hover {
	transform: translateY(-6px);
	border-color: rgba(255, 255, 255, 0.28);
	box-shadow: 0 18px 50px rgba(0, 0, 0, 0.5), 0 0 34px rgba(255, 255, 255, 0.07);
}

.cd-card-media {
	position: relative;
	display: block;
	overflow: hidden;
	aspect-ratio: 3 / 2;
	background: var(--cd-dark-gray);
}

.cd-card-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 700ms var(--cd-ease);
	will-change: transform;
}

.cd-card:hover .cd-card-media img {
	transform: scale(1.06);
}

.cd-card-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(5, 5, 5, 0.65), transparent 55%);
	opacity: 0;
	transition: opacity var(--cd-dur) var(--cd-ease);
}

.cd-card:hover .cd-card-overlay {
	opacity: 1;
}

.cd-card-body {
	padding: 24px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	flex: 1;
}

.cd-card-tag {
	display: inline-block;
	align-self: flex-start;
	padding: 4px 14px;
	border: 1px solid var(--cd-border);
	border-radius: 999px;
	background: var(--cd-glass);
	color: var(--cd-silver);
	font-size: 13.5px;
	font-weight: 600;
}

.cd-card-title {
	font-size: 21px;
	margin: 0;
}

.cd-card-title a {
	color: var(--cd-white);
}

.cd-card-excerpt {
	color: var(--cd-gray-text);
	font-size: 16px;
	margin: 0;
}

.cd-card-link {
	margin-top: auto;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: var(--cd-white);
	font-weight: 700;
	font-size: 16px;
}

.cd-card-arrow {
	display: inline-block;
	transition: transform var(--cd-dur) var(--cd-ease);
}

.cd-card:hover .cd-card-arrow,
.cd-filter-card:hover .cd-card-arrow {
	transform: translateX(-6px);
}

/* Category cards */

.cd-filter-card {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 28px 22px;
	text-align: center;
	align-items: center;
}

.cd-filter-card-name {
	color: var(--cd-white);
	font-size: 18px;
	font-weight: 700;
}

.cd-filter-card-count {
	color: var(--cd-gray-text);
	font-size: 14px;
}

/* ============================================================
   Portfolio archive filter bar + swap animation
   ============================================================ */

.cd-filter-bar {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 12px;
	margin-bottom: 48px;
}

.cd-filter-btn {
	padding: 10px 24px;
	border-radius: 999px;
	border: 1px solid var(--cd-border);
	background: var(--cd-glass);
	color: var(--cd-silver);
	font-family: var(--cd-font);
	font-size: 16px;
	font-weight: 600;
	cursor: pointer;
	transition: color var(--cd-dur) var(--cd-ease), border-color var(--cd-dur) var(--cd-ease), background var(--cd-dur) var(--cd-ease), transform var(--cd-dur) var(--cd-ease), box-shadow var(--cd-dur) var(--cd-ease);
}

.cd-filter-btn:hover {
	color: var(--cd-white);
	border-color: rgba(255, 255, 255, 0.4);
	transform: translateY(-2px);
}

.cd-filter-btn.is-active {
	background: linear-gradient(180deg, #FFFFFF 0%, #D6D6D6 100%);
	color: #0A0A0A;
	border-color: rgba(255, 255, 255, 0.75);
	box-shadow: 0 6px 24px rgba(255, 255, 255, 0.16);
}

/* Card swap states */

#cd-portfolio-grid .cd-portfolio-card {
	transition: opacity 350ms var(--cd-ease), transform 350ms var(--cd-ease), border-color var(--cd-dur) var(--cd-ease), box-shadow var(--cd-dur) var(--cd-ease);
}

.cd-card-hidden {
	opacity: 0;
	transform: translateY(14px) scale(0.97);
	pointer-events: none;
}

.cd-card-gone {
	display: none !important;
}

.cd-filter-empty {
	text-align: center;
	color: var(--cd-gray-text);
	padding: 40px 0;
}

/* ============================================================
   Single portfolio
   ============================================================ */

.cd-page-hero {
	padding: 72px 0 46px;
	border-bottom: 1px solid var(--cd-border-soft);
	background: linear-gradient(180deg, rgba(17, 17, 17, 0.6), transparent);
}

.cd-page-title {
	font-size: clamp(32px, 5vw, 52px);
	font-weight: 800;
	margin: 12px 0 8px;
	background: linear-gradient(180deg, #FFFFFF 35%, #BEBEBE 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}

.cd-page-subtitle {
	color: var(--cd-gray-text);
	font-size: 19px;
	max-width: 62ch;
}

.cd-detail-grid {
	margin: 26px 0 46px;
}

.cd-detail-card {
	padding: 26px 24px;
}

.cd-detail-card h3 {
	font-size: 18px;
	color: var(--cd-silver);
	margin-bottom: 10px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--cd-border-soft);
}

.cd-detail-card p {
	color: var(--cd-gray-text);
	margin: 0;
	font-size: 16.5px;
}

.cd-results-card,
.cd-ai-explanation {
	margin-top: 40px;
}

/* Video frames */

.cd-video-frame {
	border-radius: var(--cd-radius);
	border: 1px solid var(--cd-border);
	background: var(--cd-graphite);
	padding: 10px;
	margin-bottom: 30px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5), 0 0 30px rgba(255, 255, 255, 0.04);
	overflow: hidden;
}

.cd-video-embed {
	position: relative;
	aspect-ratio: 16 / 9;
	border-radius: calc(var(--cd-radius) - 6px);
	overflow: hidden;
	background: var(--cd-black);
}

.cd-video-embed iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
}

.cd-native-video {
	width: 100%;
	max-height: 640px;
	border-radius: calc(var(--cd-radius) - 6px);
	background: var(--cd-black);
	display: block;
}

/* Gallery */

.cd-gallery {
	columns: 3;
	column-gap: 22px;
	margin-bottom: 30px;
}

.cd-gallery-item {
	position: relative;
	display: block;
	margin-bottom: 22px;
	border-radius: var(--cd-radius);
	border: 1px solid var(--cd-border-soft);
	overflow: hidden;
	break-inside: avoid;
	transition: transform var(--cd-dur) var(--cd-ease), border-color var(--cd-dur) var(--cd-ease), box-shadow var(--cd-dur) var(--cd-ease);
	will-change: transform;
}

.cd-gallery-item img {
	width: 100%;
	transition: transform 700ms var(--cd-ease);
	will-change: transform;
}

.cd-gallery-item:hover {
	transform: translateY(-4px);
	border-color: rgba(255, 255, 255, 0.32);
	box-shadow: 0 14px 40px rgba(0, 0, 0, 0.5), 0 0 26px rgba(255, 255, 255, 0.07);
}

.cd-gallery-item:hover img {
	transform: scale(1.045);
}

.cd-gallery-zoom {
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
	font-size: 34px;
	font-weight: 300;
	color: var(--cd-white);
	background: rgba(5, 5, 5, 0.45);
	opacity: 0;
	transition: opacity var(--cd-dur) var(--cd-ease);
}

.cd-gallery-item:hover .cd-gallery-zoom {
	opacity: 1;
}

/* Lightbox */

.cd-lightbox {
	position: fixed;
	inset: 0;
	z-index: 999;
	display: grid;
	place-items: center;
	padding: 40px;
	background: rgba(5, 5, 5, 0.92);
	-webkit-backdrop-filter: blur(8px);
	backdrop-filter: blur(8px);
	opacity: 0;
	visibility: hidden;
	transition: opacity 350ms var(--cd-ease), visibility 350ms var(--cd-ease);
}

.cd-lightbox.is-open {
	opacity: 1;
	visibility: visible;
}

.cd-lightbox img {
	max-width: min(1100px, 92vw);
	max-height: 86vh;
	width: auto;
	border-radius: 12px;
	border: 1px solid var(--cd-border);
	box-shadow: 0 30px 90px rgba(0, 0, 0, 0.7);
	transform: scale(0.96);
	transition: transform 350ms var(--cd-ease);
}

.cd-lightbox.is-open img {
	transform: scale(1);
}

.cd-lightbox-close {
	position: absolute;
	top: 22px;
	left: 26px;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	border: 1px solid var(--cd-border);
	background: rgba(255, 255, 255, 0.05);
	color: var(--cd-white);
	font-size: 26px;
	line-height: 1;
	cursor: pointer;
	transition: background var(--cd-dur) var(--cd-ease), transform var(--cd-dur) var(--cd-ease);
}

.cd-lightbox-close:hover {
	background: rgba(255, 255, 255, 0.14);
	transform: rotate(90deg);
}

/* SEO layout */

.cd-seo-layout {
	display: grid;
	grid-template-columns: 1fr 1.1fr;
	gap: 28px;
	align-items: start;
	margin-bottom: 30px;
}

.cd-seo-details {
	display: flex;
	flex-direction: column;
	gap: 12px;
	align-items: flex-start;
}

.cd-seo-keyword {
	color: var(--cd-silver);
}

.cd-seo-screenshot {
	border-radius: var(--cd-radius);
	border: 1px solid var(--cd-border);
	overflow: hidden;
	background: var(--cd-graphite);
	padding: 8px;
}

.cd-seo-screenshot img {
	border-radius: calc(var(--cd-radius) - 6px);
	width: 100%;
}

/* ============================================================
   Work process
   ============================================================ */

.cd-process-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 26px;
	position: relative;
}

.cd-process-step {
	position: relative;
	padding: 32px 26px;
	text-align: center;
}

.cd-process-number {
	display: inline-grid;
	place-items: center;
	width: 58px;
	height: 58px;
	margin-bottom: 18px;
	border-radius: 50%;
	border: 1px solid var(--cd-border);
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.10), rgba(255, 255, 255, 0.02));
	color: var(--cd-white);
	font-size: 19px;
	font-weight: 800;
	box-shadow: 0 0 24px rgba(255, 255, 255, 0.07), inset 0 1px 0 rgba(255, 255, 255, 0.16);
}

.cd-process-title {
	font-size: 20px;
	margin-bottom: 8px;
}

.cd-process-desc {
	color: var(--cd-gray-text);
	font-size: 16px;
	margin: 0;
}

.cd-process-connector {
	position: absolute;
	top: 61px;
	left: -26px;
	width: 26px;
	height: 1px;
	background: linear-gradient(to left, var(--cd-border), transparent);
}

.cd-process-step:last-child .cd-process-connector {
	display: none;
}

/* ============================================================
   Final CTA
   ============================================================ */

.cd-final-cta-box {
	position: relative;
	text-align: center;
	padding: 64px 40px;
	overflow: hidden;
}

.cd-final-cta-box::before {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(560px 240px at 50% 0%, rgba(255, 255, 255, 0.08), transparent 70%);
	animation: cd-cta-pulse 10s ease-in-out infinite alternate;
	pointer-events: none;
}

@keyframes cd-cta-pulse {
	from { opacity: 0.55; }
	to   { opacity: 1; }
}

.cd-final-cta-title {
	font-size: clamp(26px, 3.6vw, 38px);
	font-weight: 800;
}

.cd-final-cta-text {
	color: var(--cd-gray-text);
	font-size: 19px;
	max-width: 54ch;
	margin: 0 auto 8px;
}

.cd-final-cta-actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 16px;
	margin-top: 28px;
	position: relative;
}

/* ============================================================
   About page - premium presentation
   ============================================================ */

.cd-about-grid {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: 56px;
	align-items: center;
}

.cd-about-content .cd-hero-actions {
	margin-top: 26px;
}

.cd-about-hero {
	padding: 96px 0 60px;
}

.cd-about-title {
	font-size: clamp(44px, 7vw, 72px);
	letter-spacing: 0.01em;
	text-shadow: 0 0 60px rgba(255, 255, 255, 0.10);
}

.cd-about-section {
	padding-top: 70px;
}

/* Full-width HD banner frame */

.cd-about-banner {
	position: relative;
	border-radius: var(--cd-radius);
	border: 1px solid var(--cd-border);
	background: var(--cd-graphite);
	padding: 12px;
	margin: 0 0 64px;
	overflow: hidden;
	box-shadow: 0 30px 90px rgba(0, 0, 0, 0.6), 0 0 60px rgba(255, 255, 255, 0.06);
	transition: transform var(--cd-dur) var(--cd-ease), box-shadow var(--cd-dur) var(--cd-ease), border-color var(--cd-dur) var(--cd-ease);
	will-change: transform;
}

.cd-about-banner:hover {
	transform: translateY(-5px);
	border-color: rgba(255, 255, 255, 0.34);
	box-shadow: 0 36px 100px rgba(0, 0, 0, 0.65), 0 0 80px rgba(255, 255, 255, 0.10);
}

.cd-about-banner::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(115deg, transparent 35%, rgba(255, 255, 255, 0.07) 50%, transparent 65%);
	transform: translateX(130%);
	animation: cd-frame-shine 10s var(--cd-ease) infinite;
	pointer-events: none;
}

.cd-about-banner-img {
	width: 100%;
	display: block;
	border-radius: calc(var(--cd-radius) - 6px);
}

/* Larger, more readable About typography */

.cd-about-body {
	max-width: 840px;
	margin-inline: auto;
}

.cd-about-text {
	font-size: 19px;
	line-height: 1.85;
	color: var(--cd-silver);
	margin-bottom: 0;
}

.cd-about-text p {
	margin: 0 0 20px;
	color: var(--cd-gray-text);
}

.cd-about-text p:first-child {
	font-size: 22px;
	font-weight: 600;
	color: var(--cd-white);
}

.cd-about-text p:last-child {
	font-size: 21px;
	font-weight: 700;
	color: var(--cd-white);
	margin-bottom: 0;
}

.cd-about-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 18px;
	margin-top: 40px;
}

@media (max-width: 640px) {
	.cd-about-hero {
		padding: 64px 0 40px;
	}

	.cd-about-banner {
		padding: 8px;
		margin-bottom: 44px;
	}

	.cd-about-text {
		font-size: 17.5px;
	}

	.cd-about-text p:first-child {
		font-size: 20px;
	}

	.cd-about-actions .cd-btn {
		width: 100%;
	}
}

/* ============================================================
   Content / entry
   ============================================================ */

.cd-entry-content {
	color: var(--cd-silver);
	font-size: 18px;
	margin-bottom: 40px;
}

.cd-entry-content a {
	border-bottom: 1px solid var(--cd-border);
}

.cd-entry-content img {
	border-radius: var(--cd-radius);
	border: 1px solid var(--cd-border-soft);
}

.cd-page-thumb {
	border-radius: var(--cd-radius);
	border: 1px solid var(--cd-border);
	overflow: hidden;
	margin-bottom: 36px;
	background: var(--cd-graphite);
	padding: 8px;
}

.cd-page-thumb img {
	border-radius: calc(var(--cd-radius) - 6px);
	width: 100%;
}

.cd-empty-state {
	text-align: center;
	padding: 60px 30px;
	color: var(--cd-gray-text);
}

.cd-pagination {
	margin-top: 48px;
	text-align: center;
}

.cd-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	height: 44px;
	padding: 0 14px;
	margin: 0 4px;
	border-radius: 12px;
	border: 1px solid var(--cd-border);
	color: var(--cd-silver);
	background: var(--cd-glass);
	transition: border-color var(--cd-dur) var(--cd-ease), color var(--cd-dur) var(--cd-ease);
}

.cd-pagination .page-numbers.current,
.cd-pagination .page-numbers:hover {
	color: var(--cd-white);
	border-color: rgba(255, 255, 255, 0.45);
}

/* ============================================================
   Footer
   ============================================================ */

.cd-footer {
	position: relative;
	z-index: 1;
	margin-top: 40px;
	border-top: 1px solid var(--cd-border-soft);
	background: rgba(10, 10, 10, 0.75);
	-webkit-backdrop-filter: blur(10px);
	backdrop-filter: blur(10px);
	padding: 64px 0 0;
}

.cd-footer-grid {
	display: grid;
	grid-template-columns: 1.2fr 0.8fr 1fr;
	gap: 48px;
	padding-bottom: 48px;
}

.cd-footer-logo {
	height: 84px;
	width: auto;
	object-fit: contain;
	margin-bottom: 16px;
	filter: drop-shadow(0 0 10px rgba(255, 255, 255, 0.10));
}

.cd-footer-desc {
	color: var(--cd-gray-text);
	font-size: 16px;
	max-width: 42ch;
}

.cd-footer-title {
	font-size: 17px;
	color: var(--cd-white);
	margin-bottom: 16px;
	letter-spacing: 0.04em;
}

.cd-footer-menu,
.cd-footer .cd-nav-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.cd-footer-menu a,
.cd-footer .cd-nav-list a {
	color: var(--cd-gray-text);
	font-size: 16px;
	padding: 2px 0;
}

.cd-footer-menu a:hover,
.cd-footer .cd-nav-list a:hover {
	color: var(--cd-white);
	background: transparent;
}

.cd-footer .cd-nav-list a::after {
	display: none;
}

.cd-footer-cta {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 12px;
}

.cd-footer-phone {
	margin-top: 14px;
	font-size: 18px;
	font-weight: 700;
}

.cd-footer-phone a {
	color: var(--cd-silver);
	letter-spacing: 0.05em;
}

.cd-footer-bottom {
	border-top: 1px solid var(--cd-border-soft);
	padding: 22px 0;
	text-align: center;
	color: var(--cd-gray-text);
	font-size: 15px;
}

.cd-footer-bottom p {
	margin: 0;
}

/* ============================================================
   Reveal system (IntersectionObserver adds cd-reveal-visible)
   ============================================================ */

.cd-reveal {
	opacity: 0;
	transform: translateY(26px);
	transition: opacity 700ms var(--cd-ease), transform 700ms var(--cd-ease);
	transition-delay: var(--cd-delay, 0ms);
	will-change: opacity, transform;
}

.cd-reveal-visible {
	opacity: 1;
	transform: translateY(0);
}

/* Page-load entrance (hero) */

.cd-load-right,
.cd-load-left,
.cd-load-up {
	animation-duration: 850ms;
	animation-timing-function: var(--cd-ease);
	animation-fill-mode: both;
}

.cd-load-right { animation-name: cd-in-right; }
.cd-load-left  { animation-name: cd-in-left; animation-delay: 150ms; }
.cd-load-up    { animation-name: cd-in-up; animation-delay: 300ms; }

@keyframes cd-in-right {
	from { opacity: 0; transform: translateX(36px); }
	to   { opacity: 1; transform: translateX(0); }
}

@keyframes cd-in-left {
	from { opacity: 0; transform: translateX(-36px); }
	to   { opacity: 1; transform: translateX(0); }
}

@keyframes cd-in-up {
	from { opacity: 0; transform: translateY(22px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   Responsive
   ============================================================ */

@media (max-width: 1080px) {
	.cd-grid-5 { grid-template-columns: repeat(3, 1fr); }
	.cd-process-grid { grid-template-columns: repeat(2, 1fr); }
	.cd-process-connector { display: none; }
	.cd-gallery { columns: 2; }
}

@media (max-width: 900px) {
	.cd-hero { padding: 56px 0 70px; }

	.cd-hero-grid,
	.cd-about-grid {
		grid-template-columns: 1fr;
		gap: 40px;
	}

	/* Mobile: text first, video under it */
	.cd-hero-text  { order: 1; }
	.cd-hero-media { order: 2; }

	/* Mobile: keep the true 9:16 portrait frame, centered */
	.cd-hero-video-frame {
		width: min(100%, 340px);
		margin-inline: auto;
	}

	.cd-hero-video,
	.cd-hero-video-placeholder {
		aspect-ratio: 9 / 16;
		width: 100%;
	}

	.cd-grid-3 { grid-template-columns: repeat(2, 1fr); }
	.cd-grid-2 { grid-template-columns: 1fr; }
	.cd-seo-layout { grid-template-columns: 1fr; }

	/* Mobile nav */
	.cd-menu-toggle { display: inline-flex; }
	.cd-header-wa span { display: none; }
	.cd-header-wa { padding: 10px 12px; }

	.cd-logo-img,
	.cd-header-logo .custom-logo {
		height: 64px;
	}

	.cd-header-inner {
		min-height: 78px;
	}

	/* ============================================================
	   Mobile navigation: NO hamburger, NO overlay, NO tricks.
	   All 5 menu buttons are ALWAYS VISIBLE in the header bar
	   itself, as a compact wrapped pill row under the logo line.
	   Nothing to open, nothing that can break.
	   ============================================================ */

	/* Kill the hamburger completely on mobile */
	.cd-menu-toggle {
		display: none !important;
	}

	/* Header becomes two rows: (logo + WhatsApp) then (nav pills) */
	.cd-header-inner {
		flex-wrap: wrap;
		min-height: 0;
		padding: 10px 0 12px;
		gap: 10px 16px;
	}

	/* Nav sits inline as the full-width second row */
	.cd-nav {
		position: static;
		order: 3;
		width: 100%;
		background: none;
		padding: 0;
		display: block;
		opacity: 1;
		visibility: visible;
		transform: none;
	}

	.cd-nav .cd-nav-list {
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: center;
		gap: 6px;
	}

	.cd-nav .cd-nav-list a {
		display: inline-block;
		font-size: 13.5px;
		font-weight: 700;
		padding: 8px 13px;
		border: 1px solid var(--cd-border-soft);
		border-radius: 999px;
		background: rgba(255, 255, 255, 0.04);
		color: var(--cd-silver);
		white-space: nowrap;
	}

	.cd-nav .cd-nav-list a::after {
		display: none;
	}

	.cd-nav .cd-nav-list .current-menu-item > a,
	.cd-nav .cd-nav-list a:active {
		background: rgba(255, 255, 255, 0.12);
		color: var(--cd-white);
		border-color: rgba(255, 255, 255, 0.3);
	}

	/* The overlay-only CTA block is not needed - WhatsApp is in the bar */
	.cd-nav-mobile-cta {
		display: none;
	}

	/* Portfolio tabs: wrap into a clean grid - NO horizontal scroll */
	.cd-tabs-bar {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 10px;
		overflow: visible;
	}

	.cd-tabs-bar .cd-tab-btn {
		width: 100%;
		min-height: 48px;
		justify-content: center;
		white-space: normal;
		padding: 11px 12px;
		font-size: 15.5px;
	}

	/* Odd last button spans the full row, centered */
	.cd-tabs-bar .cd-tab-btn:last-child:nth-child(odd) {
		grid-column: 1 / -1;
	}
}

@media (max-width: 640px) {
	body { font-size: 17px; }

	.cd-container,
	.cd-container-narrow {
		width: calc(100% - 36px);
	}

	.cd-section { padding: 64px 0; }

	.cd-grid-3,
	.cd-grid-5,
	.cd-process-grid {
		grid-template-columns: 1fr;
	}

	.cd-gallery { columns: 1; }

	.cd-hero-actions .cd-btn,
	.cd-final-cta-actions .cd-btn {
		width: 100%;
		padding: 17px 24px;
		font-size: 18px;
	}

	.cd-footer-grid {
		grid-template-columns: 1fr;
		gap: 36px;
		text-align: center;
	}

	.cd-footer-logo { margin-inline: auto; }
	.cd-footer-desc { margin-inline: auto; }
	.cd-footer-cta { align-items: center; }

	.cd-filter-bar { gap: 8px; }
	.cd-filter-btn { padding: 9px 18px; font-size: 15px; }

	.cd-final-cta-box { padding: 48px 22px; }

	.cd-glow-blob { width: 320px; height: 320px; }
}

/* ============================================================
   Portfolio v2: interactive tabs (סרטונים / תמונות / קמפיינים)
   ============================================================ */

.cd-tabs-bar {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 14px;
	margin-bottom: 54px;
}

.cd-tab-btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 14px 34px;
	border-radius: 999px;
	border: 1px solid var(--cd-border);
	background: linear-gradient(160deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.01));
	color: var(--cd-silver);
	font-family: var(--cd-font);
	font-size: 18px;
	font-weight: 700;
	cursor: pointer;
	position: relative;
	overflow: hidden;
	isolation: isolate;
	transition: color var(--cd-dur) var(--cd-ease), border-color var(--cd-dur) var(--cd-ease), background var(--cd-dur) var(--cd-ease), transform var(--cd-dur) var(--cd-ease), box-shadow var(--cd-dur) var(--cd-ease);
	will-change: transform;
}

.cd-tab-btn:hover {
	color: var(--cd-white);
	border-color: rgba(255, 255, 255, 0.42);
	transform: translateY(-3px) scale(1.03);
	box-shadow: 0 10px 32px rgba(255, 255, 255, 0.10);
	background: linear-gradient(160deg, rgba(255, 255, 255, 0.10), rgba(255, 255, 255, 0.02));
}

.cd-tab-btn.is-active {
	background: linear-gradient(180deg, #FFFFFF 0%, #D6D6D6 100%);
	color: #0A0A0A;
	border-color: rgba(255, 255, 255, 0.78);
	box-shadow: 0 8px 30px rgba(255, 255, 255, 0.18);
}

.cd-tab-icon {
	font-size: 14px;
	opacity: 0.85;
}

/* Panels: fade + slight slide on switch */

.cd-tab-panel {
	display: none;
}

.cd-tab-panel.is-active {
	display: block;
}

.cd-tab-anim {
	animation: cd-tab-in 480ms var(--cd-ease) both;
}

@keyframes cd-tab-in {
	from { opacity: 0; transform: translateY(18px); }
	to   { opacity: 1; transform: translateY(0); }
}

.cd-tab-intro {
	text-align: center;
	margin-bottom: 36px;
}

.cd-tab-heading {
	font-size: clamp(24px, 3vw, 32px);
	font-weight: 800;
	background: linear-gradient(180deg, #FFFFFF 40%, #C4C4C4 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	margin-bottom: 4px;
}

.cd-tab-sub {
	color: var(--cd-gray-text);
	font-size: 17px;
	margin: 0;
}

/* ============================================================
   Horizontal scroll carousels (9:16 / 1:1 / 4:5)
   ============================================================ */

.cd-carousel-section {
	margin-bottom: 56px;
}

.cd-carousel-section:last-child {
	margin-bottom: 0;
}

.cd-carousel-head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 20px;
	margin-bottom: 22px;
}

.cd-carousel-title {
	font-size: 22px;
	font-weight: 800;
	margin: 0 0 4px;
	color: var(--cd-white);
	position: relative;
	padding-right: 16px;
}

.cd-carousel-title::before {
	content: "";
	position: absolute;
	right: 0;
	top: 6px;
	bottom: 6px;
	width: 3px;
	border-radius: 3px;
	background: linear-gradient(180deg, var(--cd-white), rgba(255, 255, 255, 0.15));
	box-shadow: 0 0 12px rgba(255, 255, 255, 0.35);
}

.cd-carousel-desc {
	color: var(--cd-gray-text);
	font-size: 15.5px;
	margin: 0;
	padding-right: 16px;
}

.cd-carousel-arrows {
	display: flex;
	gap: 10px;
	flex: none;
}

.cd-car-btn {
	width: 46px;
	height: 46px;
	border-radius: 50%;
	border: 1px solid var(--cd-border);
	background: rgba(255, 255, 255, 0.04);
	color: var(--cd-white);
	font-size: 24px;
	line-height: 1;
	cursor: pointer;
	display: grid;
	place-items: center;
	padding-bottom: 4px;
	transition: border-color var(--cd-dur) var(--cd-ease), background var(--cd-dur) var(--cd-ease), transform var(--cd-dur) var(--cd-ease), box-shadow var(--cd-dur) var(--cd-ease);
}

.cd-car-btn:hover {
	border-color: rgba(255, 255, 255, 0.45);
	background: rgba(255, 255, 255, 0.09);
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(255, 255, 255, 0.10);
}

/* Track */

.cd-carousel {
	display: flex;
	gap: 20px;
	overflow-x: auto;
	overscroll-behavior-x: contain;
	scroll-snap-type: x mandatory;
	padding: 6px 2px 18px;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
	scrollbar-color: rgba(255, 255, 255, 0.18) transparent;
}

.cd-carousel::-webkit-scrollbar {
	height: 6px;
}

.cd-carousel::-webkit-scrollbar-track {
	background: rgba(255, 255, 255, 0.04);
	border-radius: 6px;
}

.cd-carousel::-webkit-scrollbar-thumb {
	background: rgba(255, 255, 255, 0.18);
	border-radius: 6px;
}

.cd-carousel::-webkit-scrollbar-thumb:hover {
	background: rgba(255, 255, 255, 0.32);
}

.cd-carousel-item {
	flex: none;
	scroll-snap-align: start;
}

/* Ratio cards */

.cd-ratio-card {
	position: relative;
	display: block;
	border-radius: var(--cd-radius);
	border: 1px solid var(--cd-border-soft);
	background: var(--cd-graphite);
	overflow: hidden;
	transition: transform var(--cd-dur) var(--cd-ease), border-color var(--cd-dur) var(--cd-ease), box-shadow var(--cd-dur) var(--cd-ease);
	will-change: transform;
}

.cd-ratio-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 700ms var(--cd-ease);
	will-change: transform;
}

.cd-ratio-card:hover {
	transform: translateY(-5px);
	border-color: rgba(255, 255, 255, 0.34);
	box-shadow: 0 16px 44px rgba(0, 0, 0, 0.55), 0 0 30px rgba(255, 255, 255, 0.09);
}

.cd-ratio-card:hover img {
	transform: scale(1.055);
}

.cd-ratio-9-16 { width: 250px; aspect-ratio: 9 / 16; }
.cd-ratio-1-1  { width: 300px; aspect-ratio: 1 / 1; }
.cd-ratio-4-5  { width: 290px; aspect-ratio: 4 / 5; }

.cd-ratio-card-title {
	position: absolute;
	right: 0;
	left: 0;
	bottom: 0;
	padding: 26px 16px 12px;
	background: linear-gradient(to top, rgba(5, 5, 5, 0.82), transparent);
	color: var(--cd-white);
	font-size: 15px;
	font-weight: 600;
	opacity: 0;
	transform: translateY(8px);
	transition: opacity var(--cd-dur) var(--cd-ease), transform var(--cd-dur) var(--cd-ease);
}

.cd-ratio-card:hover .cd-ratio-card-title {
	opacity: 1;
	transform: translateY(0);
}

/* ============================================================
   Video cards
   ============================================================ */

.cd-video-card {
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

.cd-video-card-media {
	position: relative;
	display: block;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: var(--cd-dark-gray);
}

.cd-video-card-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 700ms var(--cd-ease);
	will-change: transform;
}

.cd-video-card:hover .cd-video-card-media img {
	transform: scale(1.06);
}

.cd-play-badge {
	position: absolute;
	top: 50%;
	right: 50%;
	transform: translate(50%, -50%);
	display: grid;
	place-items: center;
	width: 62px;
	height: 62px;
	border-radius: 50%;
	border: 1px solid rgba(255, 255, 255, 0.4);
	background: rgba(5, 5, 5, 0.55);
	-webkit-backdrop-filter: blur(6px);
	backdrop-filter: blur(6px);
	color: var(--cd-white);
	font-size: 18px;
	padding-right: 4px;
	box-shadow: 0 0 30px rgba(255, 255, 255, 0.12);
	transition: transform var(--cd-dur) var(--cd-ease), background var(--cd-dur) var(--cd-ease), box-shadow var(--cd-dur) var(--cd-ease);
	z-index: 2;
}

.cd-video-card:hover .cd-play-badge {
	transform: translate(50%, -50%) scale(1.1);
	background: rgba(255, 255, 255, 0.16);
	box-shadow: 0 0 44px rgba(255, 255, 255, 0.22);
}

/* ============================================================
   Campaign cards
   ============================================================ */

.cd-campaign-card {
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

.cd-campaign-platforms {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.cd-platform-chip {
	display: inline-block;
	padding: 4px 14px;
	border-radius: 999px;
	border: 1px solid var(--cd-border);
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02));
	color: var(--cd-silver);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.02em;
}

.cd-campaign-meta {
	list-style: none;
	margin: 4px 0 6px;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 6px;
	color: var(--cd-gray-text);
	font-size: 15.5px;
}

.cd-campaign-meta strong {
	color: var(--cd-silver);
	font-weight: 700;
}

.cd-campaign-btn {
	margin-top: auto;
	align-self: flex-start;
}

/* ============================================================
   Placeholder cards (until real content is uploaded)
   ============================================================ */

.cd-card-placeholder {
	border-style: dashed;
	border-color: var(--cd-border);
}

.cd-card-placeholder .cd-placeholder-title {
	color: var(--cd-silver);
}

.cd-placeholder-media {
	display: grid;
	place-items: center;
	background:
		radial-gradient(circle at 50% 45%, rgba(255, 255, 255, 0.05), transparent 60%),
		var(--cd-dark-gray);
}

.cd-ratio-card.cd-card-placeholder {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 14px;
	background:
		radial-gradient(circle at 50% 42%, rgba(255, 255, 255, 0.05), transparent 60%),
		var(--cd-dark-gray);
}

.cd-ratio-placeholder-label {
	color: var(--cd-gray-text);
	font-size: 15px;
	font-weight: 600;
	text-align: center;
	padding: 0 14px;
}

/* ============================================================
   Portfolio tabs: responsive
   ============================================================ */

@media (max-width: 900px) {
	.cd-carousel-head {
		flex-direction: column;
		align-items: flex-start;
	}

	.cd-carousel-arrows {
		align-self: flex-end;
	}

	.cd-ratio-9-16 { width: 210px; }
	.cd-ratio-1-1  { width: 250px; }
	.cd-ratio-4-5  { width: 240px; }
}

@media (max-width: 640px) {
	/* Tab bar: 2-column grid, all buttons visible, no horizontal scroll */
	.cd-tabs-bar {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 10px;
		overflow: visible;
		padding-bottom: 0;
		margin-bottom: 36px;
	}

	.cd-tab-btn {
		width: 100%;
		min-height: 48px;
		justify-content: center;
		white-space: normal;
		padding: 11px 10px;
		font-size: 15px;
	}

	.cd-tabs-bar .cd-tab-btn:last-child:nth-child(odd) {
		grid-column: 1 / -1;
	}

	.cd-ratio-9-16 { width: 182px; }
	.cd-ratio-1-1  { width: 216px; }
	.cd-ratio-4-5  { width: 208px; }

	.cd-car-btn { width: 42px; height: 42px; }
}

/* ============================================================
   Accessibility: reduced motion
   ============================================================ */

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

	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}

	/* Keep content visible - simple opacity only */
	.cd-reveal {
		opacity: 1;
		transform: none;
		transition: opacity 200ms ease;
	}

	.cd-load-right,
	.cd-load-left,
	.cd-load-up {
		animation: none;
		opacity: 1;
		transform: none;
	}

	.cd-network-bg::before,
	.cd-net-dot,
	.cd-glow-blob,
	.cd-hero-video-frame::after,
	.cd-floating-grid::before,
	.cd-final-cta-box::before {
		animation: none;
	}

	.cd-btn:hover,
	.cd-glass-card:hover,
	.cd-hover-glow:hover,
	.cd-card:hover {
		transform: none;
	}
}

/* =========================================================
   Premium Mobile Optimization - CD Creative Digitals
   Desktop styles above are untouched; everything below is
   additive, scoped to media queries / touch devices only.
   ========================================================= */

/* ---------- Global overflow protection ---------- */
/* overflow-x: clip does NOT create a scroll container,
   so the sticky header keeps working. */
html,
body {
	overflow-x: clip;
}

@supports not (overflow: clip) {
	html,
	body {
		overflow-x: hidden;
	}
}

img,
video,
iframe,
embed,
object {
	max-width: 100%;
}

.cd-entry-content,
.cd-card-excerpt,
.cd-detail-card p,
.cd-about-text,
.cd-campaign-meta {
	overflow-wrap: break-word;
	word-break: break-word;
}

/* ---------- Touch devices: no sticky hover states ---------- */
@media (hover: none) {
	.cd-btn:hover,
	.cd-glass-card:hover,
	.cd-hover-glow:hover,
	.cd-card:hover,
	.cd-portfolio-card:hover,
	.cd-ratio-card:hover,
	.cd-tab-btn:hover,
	.cd-car-btn:hover,
	.cd-about-banner:hover,
	.cd-hero-video-frame:hover {
		transform: none;
	}

	.cd-card:hover .cd-card-media img,
	.cd-video-card:hover .cd-video-card-media img,
	.cd-ratio-card:hover img,
	.cd-gallery-item:hover img {
		transform: none;
	}

	.cd-shine::before {
		display: none;
	}

	/* Keep card titles readable without hover on touch */
	.cd-ratio-card-title {
		opacity: 1;
		transform: none;
		font-size: 13.5px;
		padding: 20px 12px 10px;
	}
}

/* ---------- 1024px: small laptops / large tablets ---------- */
@media (max-width: 1024px) {
	.cd-section {
		padding: 78px 0;
	}

	.cd-hero-grid {
		gap: 44px;
	}

	.cd-hero-title {
		font-size: clamp(40px, 5.6vw, 56px);
	}

	.cd-section-title {
		font-size: clamp(28px, 3.6vw, 36px);
	}
}

/* ---------- 768px: tablets ---------- */
@media (max-width: 768px) {
	body {
		font-size: 17px;
	}

	.cd-section {
		padding: 64px 0;
	}

	.cd-page-hero {
		padding: 56px 0 38px;
	}

	/* Typography scale */
	.cd-hero-title {
		font-size: clamp(36px, 9vw, 46px);
	}

	.cd-page-title {
		font-size: clamp(30px, 7vw, 40px);
	}

	.cd-about-title {
		font-size: clamp(38px, 10vw, 52px);
	}

	.cd-section-title {
		font-size: clamp(26px, 5.5vw, 32px);
	}

	.cd-tab-heading {
		font-size: clamp(22px, 5vw, 26px);
	}

	.cd-hero-subtitle {
		font-size: clamp(17px, 4.4vw, 20px);
	}

	.cd-hero-intro p,
	.cd-about-text {
		font-size: 16.5px;
		line-height: 1.8;
	}

	.cd-about-text p:first-child {
		font-size: 19px;
	}

	.cd-about-text p:last-child {
		font-size: 18.5px;
	}

	/* Calm the ambient background on tablets/phones (performance) */
	.cd-network-bg::before {
		animation: none;
	}

	.cd-glow-blob {
		animation: none;
	}

	.cd-glow-blob-2 {
		display: none;
	}

	.cd-net-dot::after {
		width: 90px;
	}

	/* Frame shine sweeps: slower + rarer on mobile */
	.cd-hero-video-frame::after,
	.cd-about-banner::after {
		animation-duration: 14s;
	}
}

/* ---------- 576px: large phones ---------- */
@media (max-width: 576px) {
	.cd-container,
	.cd-container-narrow {
		width: calc(100% - 32px);
	}

	.cd-section {
		padding: 56px 0;
	}

	.cd-section-head {
		margin-bottom: 40px;
	}

	/* Header: tighter but still premium */
	.cd-logo-img,
	.cd-header-logo .custom-logo {
		height: 56px;
	}

	.cd-header-inner {
		min-height: 72px;
		gap: 12px;
	}


	/* Touch-friendly buttons (min ~48px tap area) */
	.cd-btn {
		min-height: 48px;
		padding: 13px 26px;
		font-size: 17px;
	}

	.cd-btn-sm {
		min-height: 44px;
	}

	.cd-hero-actions,
	.cd-final-cta-actions,
	.cd-about-actions,
	.cd-footer-cta {
		gap: 14px;
	}

	.cd-about-actions .cd-btn,
	.cd-hero-actions .cd-btn,
	.cd-final-cta-actions .cd-btn {
		width: 100%;
	}

	/* Hero: comfortable vertical rhythm */
	.cd-hero {
		padding: 44px 0 60px;
	}

	.cd-hero-grid {
		gap: 36px;
	}

	.cd-hero-subtitle {
		margin: 10px 0 20px;
	}

	.cd-hero-intro p {
		margin-bottom: 12px;
	}

	.cd-hero-actions {
		margin-top: 26px;
	}

	/* Tabs: guaranteed tap size */
	.cd-tab-btn {
		min-height: 46px;
	}

	.cd-filter-btn {
		min-height: 44px;
	}

	/* Cards breathing room in single column */
	.cd-grid {
		gap: 20px;
	}

	.cd-card-body {
		padding: 20px;
	}

	.cd-service-card {
		padding: 28px 22px;
	}

	.cd-process-step {
		padding: 28px 22px;
	}

	/* Single portfolio media */
	.cd-video-frame {
		padding: 8px;
	}

	.cd-detail-grid {
		margin: 20px 0 36px;
	}

	/* Lightbox comfortable on phones */
	.cd-lightbox {
		padding: 18px;
	}

	.cd-lightbox img {
		max-width: 94vw;
		max-height: 78vh;
	}

	.cd-lightbox-close {
		top: 14px;
		left: 16px;
		width: 44px;
		height: 44px;
	}

	/* Footer spacing */
	.cd-footer {
		padding-top: 48px;
	}

	.cd-footer-grid {
		gap: 32px;
		padding-bottom: 38px;
	}

	.cd-footer-menu a,
	.cd-footer .cd-nav-list a {
		display: inline-block;
		padding: 6px 0;
	}
}

/* ---------- 430px: iPhone Pro Max class ---------- */
@media (max-width: 430px) {
	.cd-container,
	.cd-container-narrow {
		width: calc(100% - 28px);
	}

	.cd-hero-title {
		font-size: clamp(34px, 10.5vw, 40px);
	}

	.cd-section-title {
		font-size: 26px;
	}

	.cd-final-cta-title {
		font-size: 24px;
	}

	.cd-final-cta-box {
		padding: 40px 18px;
	}

	.cd-final-cta-text {
		font-size: 17px;
	}

	/* Carousels sized for phone swipe */
	.cd-ratio-9-16 { width: 168px; }
	.cd-ratio-1-1  { width: 200px; }
	.cd-ratio-4-5  { width: 190px; }

	.cd-carousel {
		gap: 14px;
	}

	.cd-carousel-title {
		font-size: 19px;
	}

	.cd-carousel-desc {
		font-size: 14.5px;
	}

	.cd-process-number {
		width: 52px;
		height: 52px;
		font-size: 17px;
	}

	.cd-play-badge {
		width: 54px;
		height: 54px;
		font-size: 16px;
	}

	.cd-hero-video-placeholder {
		font-size: 16px;
	}
}

/* ---------- 390px: standard modern phones ---------- */
@media (max-width: 390px) {
	.cd-logo-img,
	.cd-header-logo .custom-logo {
		height: 50px;
	}

	.cd-header-inner {
		min-height: 66px;
	}


	.cd-header-wa {
		padding: 9px 11px;
	}

	.cd-hero-title {
		font-size: 34px;
	}

	.cd-hero-subtitle {
		font-size: 16.5px;
		letter-spacing: 0;
	}

	.cd-tab-btn {
		padding: 11px 20px;
		font-size: 15px;
	}

	.cd-ratio-9-16 { width: 156px; }
	.cd-ratio-1-1  { width: 186px; }
	.cd-ratio-4-5  { width: 176px; }
}

/* ---------- 360px and below: compact phones ---------- */
@media (max-width: 360px) {
	.cd-container,
	.cd-container-narrow {
		width: calc(100% - 24px);
	}

	body {
		font-size: 16px;
	}

	.cd-hero-title {
		font-size: 31px;
	}

	.cd-page-title {
		font-size: 28px;
	}

	.cd-about-title {
		font-size: 34px;
	}

	.cd-section-title {
		font-size: 24px;
	}

	.cd-hero-intro p,
	.cd-about-text {
		font-size: 16px;
	}

	.cd-btn {
		padding: 13px 20px;
		font-size: 16px;
	}

	.cd-card-body {
		padding: 18px;
	}

	.cd-service-icon {
		width: 48px;
		height: 48px;
		font-size: 19px;
	}

	.cd-ratio-9-16 { width: 146px; }
	.cd-ratio-1-1  { width: 172px; }
	.cd-ratio-4-5  { width: 164px; }

	.cd-car-btn {
		width: 40px;
		height: 40px;
		font-size: 20px;
	}

	.cd-footer-logo {
		height: 68px;
	}
}

/* =========================================================
   Premium Life Motion Effects - CD Creative Digitals
   Additive layer only: no layout, color or typography change.
   ========================================================= */

/* ---------- 1. Slow-moving light beams (background) ---------- */

.cd-light-beam {
	position: absolute;
	top: -20%;
	width: 1px;
	height: 140%;
	background: linear-gradient(180deg,
		transparent,
		rgba(255, 255, 255, 0.05) 38%,
		rgba(255, 255, 255, 0.11) 50%,
		rgba(255, 255, 255, 0.05) 62%,
		transparent);
	animation: cd-beam-drift 26s ease-in-out infinite alternate;
	will-change: transform, opacity;
}

.cd-light-beam-1 {
	right: 16%;
	--cd-beam-rot: 22deg;
	transform: rotate(22deg);
}

.cd-light-beam-2 {
	right: 62%;
	--cd-beam-rot: -16deg;
	transform: rotate(-16deg);
	animation-delay: -13s;
}

@keyframes cd-beam-drift {
	from { transform: translateX(0) rotate(var(--cd-beam-rot, 22deg)); opacity: 0.45; }
	to   { transform: translateX(-70px) rotate(var(--cd-beam-rot, 22deg)); opacity: 1; }
}

/* ---------- 2. Floating digital particles ---------- */

.cd-particle {
	position: absolute;
	width: 3px;
	height: 3px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.34);
	box-shadow: 0 0 8px 1px rgba(255, 255, 255, 0.22);
	animation: cd-particle-float 17s ease-in-out infinite alternate;
	will-change: transform, opacity;
}

.cd-particle-1 { top: 12%; right: 34%; animation-delay: 0s; }
.cd-particle-2 { top: 26%; right: 88%; animation-delay: -3s; }
.cd-particle-3 { top: 44%; right: 8%;  animation-delay: -6s; width: 2px; height: 2px; }
.cd-particle-4 { top: 58%; right: 55%; animation-delay: -9s; }
.cd-particle-5 { top: 74%; right: 20%; animation-delay: -12s; width: 2px; height: 2px; }
.cd-particle-6 { top: 86%; right: 76%; animation-delay: -15s; }

@keyframes cd-particle-float {
	0%   { transform: translate3d(0, 0, 0); opacity: 0.15; }
	50%  { opacity: 0.45; }
	100% { transform: translate3d(20px, -34px, 0); opacity: 0.2; }
}

/* ---------- 3. Hero life: title sheen, frame glow pulse, corners ---------- */

@media (prefers-reduced-motion: no-preference) {
	.cd-hero-title {
		background-size: 220% 220%;
		animation: cd-title-sheen 11s ease-in-out infinite alternate;
	}
}

@keyframes cd-title-sheen {
	from { background-position: 0% 0%; }
	to   { background-position: 60% 45%; }
}

.cd-hero-media {
	position: relative;
}

.cd-hero-media::before {
	content: "";
	position: absolute;
	inset: -34px;
	border-radius: 50%;
	background: radial-gradient(closest-side, rgba(255, 255, 255, 0.075), transparent);
	animation: cd-glow-pulse 8s ease-in-out infinite alternate;
	pointer-events: none;
	z-index: -1;
}

@keyframes cd-glow-pulse {
	from { opacity: 0.45; transform: scale(0.96); }
	to   { opacity: 1; transform: scale(1.03); }
}

.cd-frame-corner {
	animation: cd-corner-pulse 4.5s ease-in-out infinite alternate;
}

.cd-frame-corner-br {
	animation-delay: -2.2s;
}

@keyframes cd-corner-pulse {
	from { opacity: 0.45; }
	to   { opacity: 0.95; }
}

/* ---------- 4. Mouse-follow glow (desktop only, JS-created) ---------- */

.cd-mouse-glow {
	position: fixed;
	top: 0;
	left: 0;
	width: 460px;
	height: 460px;
	margin: -230px 0 0 -230px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(255, 255, 255, 0.045), transparent 65%);
	pointer-events: none;
	z-index: 0;
	opacity: 0;
	transition: opacity 700ms var(--cd-ease);
	will-change: transform;
}

.cd-mouse-glow.is-active {
	opacity: 1;
}

/* ---------- 5. Card hover life: icon motion + inner reflection ---------- */

.cd-service-icon,
.cd-process-number {
	transition: transform var(--cd-dur) var(--cd-ease), color var(--cd-dur) var(--cd-ease), box-shadow var(--cd-dur) var(--cd-ease), border-color var(--cd-dur) var(--cd-ease);
	will-change: transform;
}

.cd-service-card:hover .cd-service-icon {
	transform: translateY(-4px);
}

.cd-process-step:hover .cd-process-number {
	transform: translateY(-3px) scale(1.05);
	box-shadow: 0 0 30px rgba(255, 255, 255, 0.14), inset 0 1px 0 rgba(255, 255, 255, 0.2);
}

.cd-glass-card:hover {
	box-shadow: 0 18px 50px rgba(0, 0, 0, 0.5), 0 0 34px rgba(255, 255, 255, 0.07), inset 0 1px 0 rgba(255, 255, 255, 0.10);
}

.cd-filter-card:hover .cd-filter-card-name {
	text-shadow: 0 0 18px rgba(255, 255, 255, 0.35);
}

/* ---------- 6. Luxury animated section dividers ---------- */

.cd-main .cd-section:not(:first-child)::before {
	content: "";
	position: absolute;
	top: 0;
	right: 8%;
	left: 8%;
	height: 1px;
	background: linear-gradient(to left, transparent, var(--cd-border) 30%, var(--cd-border) 70%, transparent);
	pointer-events: none;
}

.cd-main .cd-section:not(:first-child)::after {
	content: "";
	position: absolute;
	top: 0;
	right: 8%;
	width: 130px;
	height: 1px;
	background: linear-gradient(to left, transparent, rgba(255, 255, 255, 0.55), transparent);
	animation: cd-divider-run 13s linear infinite;
	pointer-events: none;
	will-change: transform, opacity;
}

@keyframes cd-divider-run {
	0%   { transform: translateX(0); opacity: 0; }
	8%   { opacity: 0.9; }
	46%  { opacity: 0.9; }
	54%  { transform: translateX(calc(-84vw + 130px)); opacity: 0; }
	100% { transform: translateX(calc(-84vw + 130px)); opacity: 0; }
}

/* ---------- 7. Final CTA floating light ---------- */

.cd-final-cta-box::after {
	content: "";
	position: absolute;
	inset: 0;
	background:
		radial-gradient(3px 3px at 18% 30%, rgba(255, 255, 255, 0.30), transparent 60%),
		radial-gradient(2px 2px at 76% 22%, rgba(255, 255, 255, 0.26), transparent 60%),
		radial-gradient(3px 3px at 62% 78%, rgba(255, 255, 255, 0.22), transparent 60%),
		radial-gradient(2px 2px at 30% 70%, rgba(255, 255, 255, 0.24), transparent 60%);
	animation: cd-cta-particles 14s ease-in-out infinite alternate;
	pointer-events: none;
}

@keyframes cd-cta-particles {
	from { transform: translate3d(0, 0, 0); opacity: 0.5; }
	to   { transform: translate3d(-14px, 10px, 0); opacity: 1; }
}

.cd-final-cta-actions {
	position: relative;
	z-index: 1;
}

/* ---------- Mobile: keep the life layer light ---------- */

@media (max-width: 768px) {
	.cd-light-beam,
	.cd-particle-3,
	.cd-particle-5,
	.cd-particle-6 {
		display: none;
	}

	.cd-particle {
		animation-duration: 22s;
	}

	.cd-hero-media::before {
		animation: none;
		opacity: 0.6;
	}

	.cd-main .cd-section:not(:first-child)::after {
		display: none;
	}

	.cd-final-cta-box::after {
		animation: none;
		opacity: 0.6;
	}
}

/* ---------- Reduced motion: strip the life layer ---------- */

@media (prefers-reduced-motion: reduce) {
	.cd-light-beam,
	.cd-particle,
	.cd-mouse-glow {
		display: none;
	}

	.cd-hero-title {
		animation: none;
		background-size: 100% 100%;
	}

	.cd-hero-media::before,
	.cd-frame-corner,
	.cd-main .cd-section:not(:first-child)::after,
	.cd-final-cta-box::after {
		animation: none;
	}
}

/* =========================================================
   Marketing Atmosphere Layer - CD Creative Digitals
   Floating metric texts + mini growth graphs, background only.
   Generated once by JS; animated purely with CSS transform/opacity.
   ========================================================= */

.cd-marketing-bg-layer {
	position: fixed;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	overflow: hidden;
}

.cd-bg-metric,
.cd-bg-graph {
	position: absolute;
	color: #FFFFFF;
	opacity: 0;
	animation: cd-bg-float var(--cd-bg-dur, 20s) ease-in-out infinite;
	will-change: transform, opacity;
}

.cd-bg-metric {
	font-family: var(--cd-font);
	font-weight: 600;
	font-size: var(--cd-bg-size, 15px);
	letter-spacing: 0.07em;
	white-space: nowrap;
	direction: ltr;
	text-shadow: 0 0 14px rgba(255, 255, 255, 0.25);
}

.cd-bg-graph svg {
	display: block;
	filter: drop-shadow(0 0 6px rgba(255, 255, 255, 0.18));
}

@keyframes cd-bg-float {
	0%   { transform: translate3d(0, 12px, 0); opacity: 0; }
	14%  { opacity: var(--cd-bg-o, 0.10); }
	50%  { transform: translate3d(-12px, -22px, 0); opacity: calc(var(--cd-bg-o, 0.10) * 0.55); }
	86%  { opacity: var(--cd-bg-o, 0.10); }
	100% { transform: translate3d(8px, -46px, 0); opacity: 0; }
}

@media (max-width: 768px) {
	.cd-bg-metric {
		text-shadow: none;
	}

	.cd-bg-graph svg {
		filter: none;
	}
}

@media (prefers-reduced-motion: reduce) {
	.cd-marketing-bg-layer {
		display: none;
	}
}

/* =========================================================
   Reviews System - CD Creative Digitals
   Review cards, monochrome stars, and the submission form.
   ========================================================= */

/* ---------- Review cards ---------- */

.cd-review-card {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 14px;
	padding: 30px 26px;
	overflow: hidden;
}

.cd-review-quote {
	position: absolute;
	top: 6px;
	left: 18px;
	font-size: 84px;
	line-height: 1;
	font-weight: 800;
	color: rgba(255, 255, 255, 0.06);
	pointer-events: none;
}

.cd-stars {
	display: inline-flex;
	gap: 4px;
	color: var(--cd-silver);
	direction: ltr;
}

.cd-star-filled {
	filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.25));
}

.cd-star-empty {
	opacity: 0.45;
}

.cd-review-text {
	color: var(--cd-gray-text);
	font-size: 16.5px;
	line-height: 1.75;
	margin: 0;
	flex: 1;
}

.cd-review-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding-top: 14px;
	border-top: 1px solid var(--cd-border-soft);
}

.cd-review-name {
	color: var(--cd-white);
	font-weight: 700;
	font-size: 16px;
}

.cd-review-date {
	color: var(--cd-gray-text);
	font-size: 13.5px;
}

.cd-reviews-cta {
	flex-wrap: wrap;
}

.cd-reviews-invite {
	text-align: center;
	color: var(--cd-gray-text);
	font-size: 15.5px;
	margin: 14px 0 0;
}

/* ---------- Submission form ---------- */

.cd-review-form-section {
	margin-top: 64px;
}

.cd-review-form-wrap {
	max-width: 640px;
	margin-inline: auto;
	padding: 40px 34px;
}

.cd-review-form-title {
	font-size: 24px;
	font-weight: 800;
	text-align: center;
	margin-bottom: 24px;
	background: linear-gradient(180deg, #FFFFFF 40%, #C4C4C4 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}

.cd-form-notice {
	padding: 14px 18px;
	border-radius: 12px;
	margin-bottom: 20px;
	font-weight: 600;
	font-size: 15.5px;
	border: 1px solid var(--cd-border);
}

.cd-form-notice-success {
	background: rgba(255, 255, 255, 0.07);
	color: var(--cd-white);
	border-color: rgba(255, 255, 255, 0.35);
}

.cd-form-notice-error {
	background: rgba(120, 30, 30, 0.18);
	color: #F2C7C7;
	border-color: rgba(220, 120, 120, 0.35);
}

.cd-form-field {
	margin: 0 0 20px;
}

.cd-form-field label,
.cd-form-label {
	display: block;
	color: var(--cd-white);
	font-weight: 600;
	font-size: 15.5px;
	margin-bottom: 8px;
}

.cd-review-form input[type="text"],
.cd-review-form textarea {
	width: 100%;
	padding: 13px 16px;
	border-radius: 12px;
	border: 1px solid var(--cd-border);
	background: rgba(5, 5, 5, 0.55);
	color: var(--cd-white);
	font-family: var(--cd-font);
	font-size: 16px;
	line-height: 1.6;
	transition: border-color var(--cd-dur) var(--cd-ease), box-shadow var(--cd-dur) var(--cd-ease);
}

.cd-review-form input[type="text"]:focus,
.cd-review-form textarea:focus {
	outline: none;
	border-color: rgba(255, 255, 255, 0.5);
	box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.08);
}

.cd-review-form textarea {
	resize: vertical;
	min-height: 120px;
}

/* Honeypot: hidden from humans */
.cd-hp {
	position: absolute !important;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(1px, 1px, 1px, 1px);
	margin: 0;
}

/* Star selector */

.cd-star-select {
	display: inline-flex;
	gap: 6px;
	direction: ltr;
}

.cd-star-btn {
	position: relative;
	width: 40px;
	height: 40px;
	display: grid;
	place-items: center;
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid var(--cd-border);
	border-radius: 10px;
	color: var(--cd-silver);
	cursor: pointer;
	transition: transform var(--cd-dur) var(--cd-ease), border-color var(--cd-dur) var(--cd-ease), background var(--cd-dur) var(--cd-ease);
}

.cd-star-btn:hover {
	transform: translateY(-2px);
	border-color: rgba(255, 255, 255, 0.4);
}

.cd-star-btn svg {
	width: 20px;
	height: 20px;
}

.cd-star-btn .cd-star-filled {
	display: none;
}

.cd-star-btn.is-filled {
	background: rgba(255, 255, 255, 0.10);
	border-color: rgba(255, 255, 255, 0.45);
	color: var(--cd-white);
}

.cd-star-btn.is-filled .cd-star-filled {
	display: block;
}

.cd-star-btn.is-filled .cd-star-empty {
	display: none;
}

.cd-review-submit {
	width: 100%;
	margin-top: 6px;
}

/* ---------- Responsive ---------- */

@media (max-width: 640px) {
	.cd-review-form-wrap {
		padding: 30px 20px;
	}

	.cd-star-btn {
		width: 46px;
		height: 46px;
	}
}

/* =========================================================
   Monochrome SVG icons everywhere (no emoji rendering)
   ========================================================= */

.cd-tab-icon svg {
	width: 15px;
	height: 15px;
	display: block;
}

.cd-play-badge {
	padding-right: 0;
}

.cd-play-badge svg {
	width: 22px;
	height: 22px;
	display: block;
	margin-inline-start: 3px;
}

.cd-placeholder-icon svg {
	width: 26px;
	height: 26px;
	display: block;
}

/* =========================================================
   Portfolio uniform media boxes (display-style control)
   Every card in a category shares one ratio; different image
   sizes are cropped/fitted cleanly inside a premium dark box.
   ========================================================= */

.cd-card-media.cd-ar-1-1  { aspect-ratio: 1 / 1; }
.cd-card-media.cd-ar-16-9 { aspect-ratio: 16 / 9; }
.cd-card-media.cd-ar-4-3  { aspect-ratio: 4 / 3; }
.cd-card-media.cd-ar-9-16 { aspect-ratio: 9 / 16; }

.cd-card-media.cd-ar-1-1 img,
.cd-card-media.cd-ar-16-9 img,
.cd-card-media.cd-ar-4-3 img,
.cd-card-media.cd-ar-9-16 img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* "Full fit, no crop" - show the whole image on a premium dark backdrop */
.cd-card-media.cd-ar-contain {
	aspect-ratio: 16 / 9;
	background:
		radial-gradient(circle at 50% 40%, rgba(255, 255, 255, 0.04), transparent 60%),
		var(--cd-dark-gray);
}

.cd-card-media.cd-ar-contain img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

/* Portfolio image sub-group titles + single-project image frame */
.cd-subgroup-title {
	font-size: 20px;
	font-weight: 700;
	color: var(--cd-white);
	margin: 40px 0 18px;
	padding-right: 16px;
	position: relative;
}
.cd-subgroup-title:first-child { margin-top: 0; }
.cd-subgroup-title::before {
	content: "";
	position: absolute;
	right: 0;
	top: 4px;
	bottom: 4px;
	width: 3px;
	border-radius: 3px;
	background: linear-gradient(180deg, var(--cd-white), rgba(255, 255, 255, 0.15));
	box-shadow: 0 0 12px rgba(255, 255, 255, 0.35);
}
.cd-single-image {
	border-radius: var(--cd-radius);
	border: 1px solid var(--cd-border);
	overflow: hidden;
	background: var(--cd-graphite);
	padding: 8px;
	margin-bottom: 30px;
}
.cd-single-image img {
	width: 100%;
	border-radius: calc(var(--cd-radius) - 6px);
	display: block;
}
.cd-single-actions { margin-top: 8px; }

/* Self-hosted uploaded video preview (first frame) inside portfolio cards */
.cd-portfolio-video-preview {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	border-radius: inherit;
	background: #111111;
	pointer-events: none;
}
.cd-video-card:hover .cd-portfolio-video-preview,
.cd-card:hover .cd-portfolio-video-preview {
	transform: scale(1.06);
	transition: transform 700ms var(--cd-ease);
}

/* =========================================================
   Image work cards + Mini lightbox (תמונות category)
   ========================================================= */

/* Image trigger is a <button> styled exactly like a card-media link */
.cd-image-work-trigger {
	border: 0;
	margin: 0;
	padding: 0;
	background: var(--cd-dark-gray);
	cursor: pointer;
	width: 100%;
	display: block;
	font: inherit;
	color: inherit;
}
.cd-image-work-trigger .cd-image-preview {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Mini lightbox: centered premium box, NOT aggressive fullscreen */
.cd-lightbox-overlay {
	position: absolute;
	inset: 0;
	z-index: 1;
}
.cd-lightbox-content {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;
	max-width: min(880px, 80vw);
	transform: scale(0.96);
	transition: transform 350ms var(--cd-ease);
}
.cd-lightbox.is-open .cd-lightbox-content {
	transform: scale(1);
}
.cd-lightbox .cd-lightbox-image,
.cd-lightbox-content img {
	width: auto;
	height: auto;
	max-width: 80vw;
	max-height: 82vh;
	object-fit: contain;
	border-radius: 14px;
	border: 1px solid var(--cd-border);
	box-shadow: 0 30px 90px rgba(0, 0, 0, 0.7), 0 0 40px rgba(255, 255, 255, 0.06);
	display: block;
}
.cd-lightbox-caption {
	text-align: center;
	max-width: 640px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
}
.cd-lightbox-title {
	color: var(--cd-white);
	font-size: 20px;
	font-weight: 700;
	margin: 0;
}
.cd-lightbox-desc {
	color: var(--cd-gray-text);
	font-size: 15.5px;
	margin: 0;
}
.cd-lightbox-link {
	margin-top: 4px;
}

@media (max-width: 768px) {
	.cd-lightbox-content {
		max-width: 92vw;
	}
	.cd-lightbox .cd-lightbox-image,
	.cd-lightbox-content img {
		max-width: 92vw;
		max-height: 80vh;
	}
	.cd-lightbox-title { font-size: 18px; }
}

/* Outside portfolio card previews - always uniform, cropped (never tall) */
.cd-portfolio-card-media,
.cd-work-card-media,
.cd-image-preview {
	width: 100%;
	overflow: hidden;
	border-radius: inherit;
	background: #111111;
}
.cd-work-card-media img,
.cd-portfolio-card-media img,
img.cd-image-preview {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
	display: block;
}

/* =========================================================
   Mobile UX fixes: hero top spacing
   ========================================================= */

/* Comfortable clearance below the sticky header on phones */
@media (max-width: 640px) {
	.cd-page-hero {
		padding-top: 46px;
	}

	.cd-hero {
		padding-top: 38px;
	}
}
