/*  -----------------------------------------------------------------
    CarterWare · iOS 26 Liquid Glass Theme — v3
    Built for an Apple-quality feel: SF Pro typography, restrained
    color, deliberate motion, and Liquid Glass surfaces.
    ----------------------------------------------------------------- */

/* ======================== TOKENS ======================== */

:root {
	/* ---- Brand spectrum ---- */
	--cw-purple:        #A78BFA;
	--cw-violet:        #7C3AED;
	--cw-blue:          #5AC8FA;
	--cw-blue-deep:     #0A84FF;
	--cw-cyan:          #64D2FF;
	--cw-mint:          #63E6E2;
	--cw-green:         #30D158;
	--cw-yellow:        #FFD60A;
	--cw-orange:        #FF9F0A;
	--cw-pink:          #FF375F;
	--cw-red:           #FF453A;

	/* ---- Light theme — Apple.com style ---- */
	--cw-bg:            #FBFBFD;
	--cw-bg-elevated:   #FFFFFF;
	--cw-bg-soft:       #F5F5F7;
	--cw-bg-deep:       #F0F0F3;
	--cw-fg:            #1D1D1F;
	--cw-fg-muted:      #6E6E73;
	--cw-fg-subtle:     #86868B;
	--cw-border:        rgba(0, 0, 0, 0.08);
	--cw-border-strong: rgba(0, 0, 0, 0.14);
	--cw-glass-bg:      rgba(255, 255, 255, 0.65);
	--cw-glass-bg-strong: rgba(255, 255, 255, 0.80);
	--cw-glass-border:  rgba(255, 255, 255, 0.7);
	--cw-glass-shadow:  0 1px 0 rgba(255,255,255,0.85) inset, 0 0 0 1px rgba(0,0,0,0.04);
	--cw-card-bg:       rgba(255, 255, 255, 0.78);
	--cw-card-bg-flat:  #FFFFFF;
	--cw-shadow-xs:     0 1px 2px rgba(0, 0, 0, 0.04);
	--cw-shadow-sm:     0 4px 12px -4px rgba(0, 0, 0, 0.08);
	--cw-shadow-md:     0 14px 38px -18px rgba(0, 0, 0, 0.18), 0 2px 6px rgba(0, 0, 0, 0.04);
	--cw-shadow-lg:     0 30px 80px -28px rgba(0, 0, 0, 0.22), 0 6px 18px rgba(0, 0, 0, 0.06);
	--cw-shadow-glow:   0 0 0 1px rgba(122, 102, 250, 0.18), 0 18px 60px -22px rgba(122, 102, 250, 0.45);
	--cw-grain-opacity: 0.040;
	--cw-mesh-opacity:  0.55;

	/* ---- Type scale (clamp, fluid) ---- */
	--cw-fs-eyebrow: clamp(11px, 0.7vw + 9px, 13px);
	--cw-fs-body:    clamp(15.5px, 0.4vw + 14px, 18px);
	--cw-fs-lead:    clamp(18px, 0.6vw + 15px, 23px);
	--cw-fs-h6:      clamp(15px, 0.4vw + 13px, 17px);
	--cw-fs-h5:      clamp(18px, 0.55vw + 15px, 22px);
	--cw-fs-h4:      clamp(22px, 0.8vw + 18px, 30px);
	--cw-fs-h3:      clamp(26px, 1.2vw + 20px, 38px);
	--cw-fs-h2:      clamp(34px, 2.4vw + 22px, 64px);
	--cw-fs-h1:      clamp(46px, 4.4vw + 28px, 104px);
	--cw-fs-display: clamp(60px, 6vw + 30px, 132px);

	--cw-tracking-tight:   -0.022em;
	--cw-tracking-tighter: -0.030em;
	--cw-tracking-display: -0.040em;
	--cw-tracking-eyebrow: 0.06em;

	--cw-line-tight:   1.04;
	--cw-line-snug:    1.15;
	--cw-line-normal:  1.5;
	--cw-line-loose:   1.65;

	/* ---- Layout ---- */
	--cw-container:     1180px;
	--cw-container-wide:1320px;
	--cw-container-narrow: 880px;
	--cw-radius-xs:     8px;
	--cw-radius-sm:     12px;
	--cw-radius-md:     20px;
	--cw-radius-lg:     28px;
	--cw-radius-xl:     36px;
	--cw-radius-2xl:    44px;
	--cw-radius-pill:   999px;
	--cw-gutter:        clamp(22px, 4vw, 56px);
	--cw-section-gap:   clamp(80px, 10vw, 168px);

	/* ---- Motion ---- */
	--cw-spring:    cubic-bezier(0.22, 1, 0.36, 1);
	--cw-ease:      cubic-bezier(0.4, 0, 0.2, 1);
	--cw-ease-out:  cubic-bezier(0.16, 1, 0.3, 1);
	--cw-bounce:    cubic-bezier(0.34, 1.56, 0.64, 1);

	/* ---- Fonts ---- */
	--cw-font-sans: -apple-system, BlinkMacSystemFont, "SF Pro Display",
		"SF Pro Text", "Inter", "Helvetica Neue", "Helvetica", "Arial", system-ui,
		"Segoe UI", Roboto, sans-serif;
	--cw-font-mono: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Monaco,
		Consolas, "Liberation Mono", "Courier New", monospace;
}

/* Dark theme — iOS 26 / Apple.com dark */
:root[data-theme="dark"],
:root.cw-dark {
	--cw-bg:            #000000;
	--cw-bg-elevated:   #0E0E12;
	--cw-bg-soft:       #14141A;
	--cw-bg-deep:       #1B1B22;
	--cw-fg:            #F5F5F7;
	--cw-fg-muted:      #A1A1A6;
	--cw-fg-subtle:     #6E6E73;
	--cw-border:        rgba(255, 255, 255, 0.10);
	--cw-border-strong: rgba(255, 255, 255, 0.18);
	--cw-glass-bg:      rgba(20, 20, 26, 0.55);
	--cw-glass-bg-strong: rgba(28, 28, 36, 0.78);
	--cw-glass-border:  rgba(255, 255, 255, 0.12);
	--cw-glass-shadow:  0 1px 0 rgba(255,255,255,0.07) inset, 0 0 0 1px rgba(0,0,0,0.4);
	--cw-card-bg:       rgba(22, 22, 28, 0.65);
	--cw-card-bg-flat:  #14141A;
	--cw-shadow-xs:     0 1px 2px rgba(0, 0, 0, 0.4);
	--cw-shadow-sm:     0 4px 14px -4px rgba(0, 0, 0, 0.55);
	--cw-shadow-md:     0 14px 38px -18px rgba(0, 0, 0, 0.65), 0 2px 6px rgba(0, 0, 0, 0.35);
	--cw-shadow-lg:     0 30px 80px -28px rgba(0, 0, 0, 0.9), 0 6px 18px rgba(0, 0, 0, 0.45);
	--cw-shadow-glow:   0 0 0 1px rgba(122, 102, 250, 0.30), 0 18px 60px -22px rgba(122, 102, 250, 0.55);
	--cw-grain-opacity: 0.06;
	--cw-mesh-opacity:  0.65;
}

@media (prefers-color-scheme: dark) {
	:root:not([data-theme="light"]) {
		--cw-bg:            #000000;
		--cw-bg-elevated:   #0E0E12;
		--cw-bg-soft:       #14141A;
		--cw-bg-deep:       #1B1B22;
		--cw-fg:            #F5F5F7;
		--cw-fg-muted:      #A1A1A6;
		--cw-fg-subtle:     #6E6E73;
		--cw-border:        rgba(255, 255, 255, 0.10);
		--cw-border-strong: rgba(255, 255, 255, 0.18);
		--cw-glass-bg:      rgba(20, 20, 26, 0.55);
		--cw-glass-bg-strong: rgba(28, 28, 36, 0.78);
		--cw-glass-border:  rgba(255, 255, 255, 0.12);
		--cw-glass-shadow:  0 1px 0 rgba(255,255,255,0.07) inset, 0 0 0 1px rgba(0,0,0,0.4);
		--cw-card-bg:       rgba(22, 22, 28, 0.65);
		--cw-card-bg-flat:  #14141A;
		--cw-shadow-xs:     0 1px 2px rgba(0, 0, 0, 0.4);
		--cw-shadow-sm:     0 4px 14px -4px rgba(0, 0, 0, 0.55);
		--cw-shadow-md:     0 14px 38px -18px rgba(0, 0, 0, 0.65), 0 2px 6px rgba(0, 0, 0, 0.35);
		--cw-shadow-lg:     0 30px 80px -28px rgba(0, 0, 0, 0.9), 0 6px 18px rgba(0, 0, 0, 0.45);
		--cw-shadow-glow:   0 0 0 1px rgba(122, 102, 250, 0.30), 0 18px 60px -22px rgba(122, 102, 250, 0.55);
		--cw-grain-opacity: 0.06;
		--cw-mesh-opacity:  0.65;
	}
}

/* ======================== RESET ======================== */

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } *, *::before, *::after { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; } }

body {
	margin: 0;
	font-family: var(--cw-font-sans);
	font-size: var(--cw-fs-body);
	line-height: var(--cw-line-normal);
	color: var(--cw-fg);
	background: var(--cw-bg);
	overflow-x: hidden;
	font-feature-settings: "ss01", "cv11";
	letter-spacing: -0.011em;
	transition: background 0.3s var(--cw-ease), color 0.3s var(--cw-ease);
}
img, svg, video, canvas, picture { display: block; max-width: 100%; height: auto; }
button { font-family: inherit; }
::selection { background: rgba(122, 102, 250, 0.32); color: var(--cw-fg); }

a { color: inherit; text-decoration: none; }
p { margin: 0 0 1em; }

.cw-ic { width: 18px; height: 18px; flex: 0 0 18px; }

:focus-visible {
	outline: 2px solid var(--cw-blue-deep);
	outline-offset: 3px;
	border-radius: 6px;
}
.cw-skip {
	position: absolute; left: -9999px; top: 0; padding: 12px 18px;
	background: var(--cw-fg); color: var(--cw-bg); border-radius: 0 0 12px 0; z-index: 1000;
}
.cw-skip:focus { left: 0; }

/* ======================== BACKGROUND LAYERS ======================== */

.cw-bg-grain {
	position: fixed; inset: 0; pointer-events: none; z-index: 0;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.05' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1   0 0 0 0 1   0 0 0 0 1   0 0 0 0.55 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
	background-size: 240px 240px;
	opacity: var(--cw-grain-opacity);
	mix-blend-mode: overlay;
}

/* ======================== TYPOGRAPHY ======================== */

.cw-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: var(--cw-fs-eyebrow);
	letter-spacing: var(--cw-tracking-eyebrow);
	text-transform: uppercase;
	color: var(--cw-fg-muted);
	font-weight: 600;
	margin-bottom: 18px;
}
.cw-eyebrow::before {
	content: '';
	width: 6px; height: 6px; border-radius: 50%;
	background: linear-gradient(135deg, var(--cw-purple), var(--cw-blue));
	box-shadow: 0 0 12px rgba(122, 102, 250, 0.6);
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--cw-font-sans);
	font-weight: 700;
	letter-spacing: var(--cw-tracking-tight);
	line-height: var(--cw-line-snug);
	color: var(--cw-fg);
	margin: 0 0 0.4em;
	text-wrap: balance;
}

.cw-h1, h1 {
	font-size: var(--cw-fs-h1);
	line-height: var(--cw-line-tight);
	letter-spacing: var(--cw-tracking-display);
	font-weight: 700;
}
.cw-h2, h2 {
	font-size: var(--cw-fs-h2);
	line-height: var(--cw-line-tight);
	letter-spacing: var(--cw-tracking-display);
	font-weight: 700;
}
.cw-h3, h3 {
	font-size: var(--cw-fs-h3);
	letter-spacing: var(--cw-tracking-tighter);
	font-weight: 700;
}
.cw-h4, h4 {
	font-size: var(--cw-fs-h4);
	letter-spacing: var(--cw-tracking-tighter);
	font-weight: 600;
}
.cw-h5, h5 { font-size: var(--cw-fs-h5); font-weight: 600; }
.cw-h6, h6 { font-size: var(--cw-fs-h6); font-weight: 600; }

.lead, .cw-lead {
	font-size: var(--cw-fs-lead);
	line-height: var(--cw-line-loose);
	color: var(--cw-fg-muted);
	font-weight: 400;
	letter-spacing: -0.013em;
	max-width: 62ch;
	text-wrap: pretty;
}

.cw-display {
	font-size: var(--cw-fs-display);
	line-height: 0.96;
	letter-spacing: -0.045em;
	font-weight: 700;
}

.cw-grad-text {
	background: linear-gradient(120deg, var(--cw-purple) 0%, var(--cw-blue) 50%, var(--cw-mint) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
}
.cw-grad-warm {
	background: linear-gradient(120deg, var(--cw-pink) 0%, var(--cw-orange) 60%, var(--cw-yellow) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
}

/* ======================== LAYOUT ======================== */

.cw-main {
	position: relative;
	z-index: 1;
	padding-top: 0;
}
.cw-container {
	width: 100%;
	max-width: var(--cw-container);
	margin: 0 auto;
	padding-left: var(--cw-gutter);
	padding-right: var(--cw-gutter);
	position: relative;
}
.cw-container--wide   { max-width: var(--cw-container-wide); }
.cw-container--narrow { max-width: var(--cw-container-narrow); }

.cw-section {
	padding: var(--cw-section-gap) 0;
	position: relative;
}
.cw-section--top    { padding-top: calc(var(--cw-section-gap) + 60px); }
.cw-section--tight  { padding: clamp(60px, 7vw, 116px) 0; }
.cw-section--flush  { padding: 0; }
.cw-section--soft   { background: var(--cw-bg-soft); }

.cw-section-head {
	max-width: 760px;
	margin: 0 auto clamp(40px, 5vw, 80px);
	text-align: center;
}
.cw-section-head .cw-eyebrow { justify-content: center; }
.cw-section-head h2 { margin-bottom: 16px; }
.cw-section-head p { color: var(--cw-fg-muted); font-size: var(--cw-fs-lead); margin: 0 auto; max-width: 60ch; }

.cw-grid { display: grid; gap: clamp(20px, 2vw, 28px); }
.cw-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.cw-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.cw-grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
@media (max-width: 920px) {
	.cw-grid-3, .cw-grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
	.cw-grid-2, .cw-grid-3, .cw-grid-4 { grid-template-columns: 1fr; }
}

.cw-center { text-align: center; }
.cw-stack-sm > * + * { margin-top: 12px; }
.cw-stack-md > * + * { margin-top: 20px; }
.cw-stack-lg > * + * { margin-top: 32px; }

/* ======================== LIQUID GLASS ======================== */

.cw-glass {
	background: var(--cw-glass-bg);
	-webkit-backdrop-filter: blur(34px) saturate(180%);
	backdrop-filter: blur(34px) saturate(180%);
	border: 1px solid var(--cw-glass-border);
	box-shadow: var(--cw-glass-shadow);
}
.cw-glass-strong {
	background: var(--cw-glass-bg-strong);
	-webkit-backdrop-filter: blur(50px) saturate(200%);
	backdrop-filter: blur(50px) saturate(200%);
	border: 1px solid var(--cw-glass-border);
	box-shadow: var(--cw-glass-shadow), var(--cw-shadow-md);
}

/* ======================== NAV ======================== */

.cw-nav {
	position: sticky;
	top: 0;
	z-index: 100;
	padding: 14px var(--cw-gutter);
	transition: padding 0.4s var(--cw-spring);
}
.cw-nav[data-state="scrolled"] { padding: 8px var(--cw-gutter); }

.cw-nav-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	max-width: var(--cw-container-wide);
	margin: 0 auto;
	padding: 10px 14px 10px 18px;
	border-radius: var(--cw-radius-pill);
	transition: padding 0.4s var(--cw-spring), border-radius 0.4s var(--cw-spring);
}
.cw-nav[data-state="scrolled"] .cw-nav-inner { padding: 8px 12px 8px 16px; }

.cw-brand {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-weight: 600;
	letter-spacing: -0.018em;
	font-size: 17px;
	color: var(--cw-fg);
}
.cw-brand-mark { display: inline-flex; width: 28px; height: 28px; }
.cw-brand-mark svg { width: 100%; height: 100%; }
.cw-brand-word { font-weight: 700; letter-spacing: -0.022em; }
.cw-brand--lg { font-size: 20px; }
.cw-brand--lg .cw-brand-mark { width: 36px; height: 36px; }

.cw-menu {
	list-style: none;
	display: flex;
	align-items: center;
	gap: 4px;
	margin: 0;
	padding: 0;
}
.cw-menu li a {
	display: inline-flex;
	align-items: center;
	padding: 8px 14px;
	font-size: 14.5px;
	font-weight: 500;
	letter-spacing: -0.005em;
	color: var(--cw-fg-muted);
	border-radius: var(--cw-radius-pill);
	transition: color 0.2s var(--cw-ease), background 0.2s var(--cw-ease), transform 0.2s var(--cw-ease);
}
.cw-menu li a:hover { color: var(--cw-fg); background: rgba(0,0,0,0.05); }
:root[data-theme="dark"] .cw-menu li a:hover,
:root.cw-dark .cw-menu li a:hover { background: rgba(255,255,255,0.08); }
@media (prefers-color-scheme: dark) {
	:root:not([data-theme="light"]) .cw-menu li a:hover { background: rgba(255,255,255,0.08); }
}
.cw-menu li.current-menu-item a,
.cw-menu li[aria-current] a,
.cw-menu li a[aria-current] { color: var(--cw-fg); background: rgba(0,0,0,0.06); }
:root[data-theme="dark"] .cw-menu li.current-menu-item a,
:root.cw-dark .cw-menu li.current-menu-item a { background: rgba(255,255,255,0.10); }

.cw-nav-actions { display: flex; align-items: center; gap: 8px; }

.cw-theme-toggle {
	width: 36px; height: 36px;
	border-radius: 50%;
	border: 1px solid var(--cw-border);
	background: transparent;
	color: var(--cw-fg);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s var(--cw-ease), border-color 0.2s var(--cw-ease), transform 0.3s var(--cw-spring);
}
.cw-theme-toggle:hover { background: rgba(0,0,0,0.05); transform: rotate(15deg); }
.cw-theme-toggle .cw-ic-sun { display: none; }
.cw-theme-toggle .cw-ic-moon { display: block; }
:root[data-theme="dark"] .cw-theme-toggle .cw-ic-sun,
:root.cw-dark .cw-theme-toggle .cw-ic-sun { display: block; }
:root[data-theme="dark"] .cw-theme-toggle .cw-ic-moon,
:root.cw-dark .cw-theme-toggle .cw-ic-moon { display: none; }
@media (prefers-color-scheme: dark) {
	:root:not([data-theme="light"]) .cw-theme-toggle .cw-ic-sun { display: block; }
	:root:not([data-theme="light"]) .cw-theme-toggle .cw-ic-moon { display: none; }
}

.cw-burger { display: none; width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--cw-border); background: transparent; color: var(--cw-fg); cursor: pointer; padding: 0; position: relative; }
.cw-burger span { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 14px; height: 1.5px; background: currentColor; border-radius: 1px; transition: transform 0.3s var(--cw-spring), opacity 0.3s var(--cw-ease); }
.cw-burger span:nth-child(1) { transform: translate(-50%, calc(-50% - 5px)); }
.cw-burger span:nth-child(3) { transform: translate(-50%, calc(-50% + 5px)); }
.cw-burger[aria-expanded="true"] span:nth-child(1) { transform: translate(-50%, -50%) rotate(45deg); }
.cw-burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.cw-burger[aria-expanded="true"] span:nth-child(3) { transform: translate(-50%, -50%) rotate(-45deg); }

.cw-mobile-menu {
	position: fixed;
	left: 0; right: 0; top: 64px;
	max-height: calc(100vh - 64px);
	overflow: auto;
	padding: 12px var(--cw-gutter) 24px;
	background: var(--cw-glass-bg-strong);
	-webkit-backdrop-filter: blur(40px) saturate(200%);
	backdrop-filter: blur(40px) saturate(200%);
	border-bottom: 1px solid var(--cw-border);
	transform: translateY(-12px);
	opacity: 0;
	pointer-events: none;
	transition: transform 0.4s var(--cw-spring), opacity 0.3s var(--cw-ease);
	z-index: 99;
	display: none;
}
.cw-mobile-menu[aria-hidden="false"] { transform: translateY(0); opacity: 1; pointer-events: auto; }
.cw-mobile-inner { max-width: var(--cw-container); margin: 0 auto; padding-top: 18px; }
.cw-mobile-list { list-style: none; padding: 0; margin: 0 0 18px; }
.cw-mobile-list li { border-bottom: 1px solid var(--cw-border); }
.cw-mobile-list li:last-child { border-bottom: 0; }
.cw-mobile-list li a { display: block; padding: 16px 6px; font-size: 22px; font-weight: 600; letter-spacing: -0.018em; color: var(--cw-fg); }

@media (max-width: 820px) {
	.cw-nav-menu { display: none; }
	.cw-burger { display: inline-flex; }
	.cw-btn-sm.cw-btn-primary { display: none; }
	.cw-mobile-menu { display: block; }
}

/* ======================== BUTTONS ======================== */

.cw-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 14px 24px;
	border-radius: var(--cw-radius-pill);
	font-size: 15px;
	font-weight: 600;
	letter-spacing: -0.008em;
	line-height: 1;
	cursor: pointer;
	border: 1px solid transparent;
	transition: transform 0.2s var(--cw-spring), background 0.2s var(--cw-ease), color 0.2s var(--cw-ease), box-shadow 0.3s var(--cw-ease), border-color 0.2s var(--cw-ease);
	user-select: none;
	white-space: nowrap;
	position: relative;
}
.cw-btn .arrow,
.cw-btn .cw-ic { transition: transform 0.3s var(--cw-spring); }
.cw-btn:hover .arrow,
.cw-btn:hover .cw-ic { transform: translateX(4px); }
.cw-btn:active { transform: scale(0.97); }
.cw-btn-sm { padding: 10px 18px; font-size: 14px; }
.cw-btn-block { display: flex; width: 100%; }

.cw-btn-primary {
	background: var(--cw-fg);
	color: var(--cw-bg);
	box-shadow: 0 1px 0 rgba(255,255,255,0.18) inset, 0 8px 24px -10px rgba(0,0,0,0.25);
}
.cw-btn-primary:hover {
	background: linear-gradient(120deg, var(--cw-violet), var(--cw-blue-deep));
	color: #fff;
	box-shadow: var(--cw-shadow-glow);
}

.cw-btn-ghost {
	background: transparent;
	color: var(--cw-fg);
	border-color: var(--cw-border-strong);
}
.cw-btn-ghost:hover {
	background: var(--cw-fg);
	color: var(--cw-bg);
	border-color: var(--cw-fg);
}

.cw-btn-glass {
	background: var(--cw-glass-bg-strong);
	-webkit-backdrop-filter: blur(20px) saturate(180%);
	backdrop-filter: blur(20px) saturate(180%);
	border-color: var(--cw-glass-border);
	color: var(--cw-fg);
}

.cw-pill {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 7px 12px;
	border-radius: var(--cw-radius-pill);
	font-size: 13px;
	font-weight: 500;
	border: 1px solid var(--cw-border-strong);
	background: var(--cw-bg-elevated);
	color: var(--cw-fg);
	transition: background 0.2s var(--cw-ease), color 0.2s var(--cw-ease), transform 0.2s var(--cw-spring);
}
.cw-pill:hover { background: var(--cw-fg); color: var(--cw-bg); transform: translateY(-1px); }
.cw-pill .cw-ic { width: 14px; height: 14px; }

/* ======================== HERO ======================== */

.cw-hero {
	position: relative;
	padding: clamp(76px, 12vw, 160px) 0 clamp(60px, 9vw, 116px);
	overflow: hidden;
}
.cw-hero-orb {
	position: absolute;
	pointer-events: none;
	border-radius: 50%;
	filter: blur(90px);
	opacity: 0.55;
	z-index: 0;
	will-change: transform;
}
.cw-hero-orb--a { width: 620px; height: 620px; left: -180px; top: -180px; background: radial-gradient(closest-side, var(--cw-purple), transparent 70%); }
.cw-hero-orb--b { width: 720px; height: 720px; right: -240px; top: 60px; background: radial-gradient(closest-side, var(--cw-blue), transparent 70%); opacity: 0.45; }
.cw-hero-orb--c { width: 540px; height: 540px; left: 30%; bottom: -260px; background: radial-gradient(closest-side, var(--cw-mint), transparent 70%); opacity: 0.36; }

.cw-hero-inner { position: relative; z-index: 1; max-width: 1100px; margin: 0 auto; text-align: center; }
.cw-hero-inner h1 { margin: 0 auto 28px; max-width: 17ch; }
.cw-hero-inner .lead { margin: 0 auto 38px; max-width: 56ch; }

.cw-hero-ctas { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }

.cw-hero-stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
	margin-top: clamp(56px, 7vw, 92px);
	max-width: 1080px;
	margin-left: auto; margin-right: auto;
	position: relative;
	z-index: 1;
}
.cw-stat {
	padding: 24px 24px;
	border-radius: var(--cw-radius-md);
	text-align: left;
	display: flex;
	flex-direction: column;
	gap: 8px;
	transition: transform 0.4s var(--cw-spring), border-color 0.3s var(--cw-ease);
}
.cw-stat:hover { transform: translateY(-3px); border-color: var(--cw-border-strong); }
.cw-stat .num { font-size: clamp(34px, 3.2vw, 48px); line-height: 1; font-weight: 700; letter-spacing: -0.035em; }
.cw-stat .label { color: var(--cw-fg-muted); font-size: 13px; line-height: 1.45; letter-spacing: -0.005em; }

@media (max-width: 720px) { .cw-hero-stats { grid-template-columns: repeat(2, 1fr); } }

/* Marquee logos */
.cw-marquee {
	margin-top: 60px;
	padding: 24px 0;
	border-top: 1px solid var(--cw-border);
	border-bottom: 1px solid var(--cw-border);
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 36px;
	justify-content: space-around;
	color: var(--cw-fg-subtle);
	font-size: 13px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

/* ======================== CARDS ======================== */

.cw-card {
	position: relative;
	padding: 32px 32px 28px;
	border-radius: var(--cw-radius-lg);
	background: var(--cw-card-bg);
	border: 1px solid var(--cw-border);
	transition: transform 0.5s var(--cw-spring), box-shadow 0.5s var(--cw-ease), border-color 0.3s var(--cw-ease);
	overflow: hidden;
	height: 100%;
	display: flex;
	flex-direction: column;
	-webkit-backdrop-filter: blur(20px) saturate(160%);
	backdrop-filter: blur(20px) saturate(160%);
}
.cw-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--cw-shadow-lg);
	border-color: var(--cw-border-strong);
}
.cw-card .cw-card-bg {
	position: absolute; inset: 0;
	background: radial-gradient(circle at var(--mx, 50%) var(--my, 0%), rgba(122,102,250,0.18), transparent 60%);
	opacity: 0;
	transition: opacity 0.4s var(--cw-ease);
	pointer-events: none;
	z-index: 0;
}
.cw-card:hover .cw-card-bg { opacity: 1; }
.cw-card > * { position: relative; z-index: 1; }

.cw-card-icon {
	width: 56px;
	height: 56px;
	border-radius: 16px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--cw-purple) 0%, var(--cw-blue) 100%);
	color: #fff;
	margin-bottom: 24px;
	box-shadow: 0 1px 0 rgba(255,255,255,0.25) inset, 0 10px 26px -10px rgba(122, 102, 250, 0.55);
}
.cw-card-icon svg { width: 28px; height: 28px; stroke-width: 1.7; }
.cw-card[data-tone="b"] .cw-card-icon { background: linear-gradient(135deg, var(--cw-blue) 0%, var(--cw-mint) 100%); box-shadow: 0 1px 0 rgba(255,255,255,0.25) inset, 0 10px 26px -10px rgba(90, 200, 250, 0.55); }
.cw-card[data-tone="c"] .cw-card-icon { background: linear-gradient(135deg, var(--cw-pink) 0%, var(--cw-orange) 100%); box-shadow: 0 1px 0 rgba(255,255,255,0.25) inset, 0 10px 26px -10px rgba(255, 55, 95, 0.55); }
.cw-card[data-tone="d"] .cw-card-icon { background: linear-gradient(135deg, var(--cw-mint) 0%, var(--cw-green) 100%); box-shadow: 0 1px 0 rgba(255,255,255,0.25) inset, 0 10px 26px -10px rgba(48, 209, 88, 0.55); }

.cw-card-title { font-size: var(--cw-fs-h4); margin: 0 0 12px; letter-spacing: var(--cw-tracking-tighter); }
.cw-card-desc  { color: var(--cw-fg-muted); margin: 0 0 20px; line-height: var(--cw-line-loose); }
.cw-card-points { list-style: none; padding: 0; margin: auto 0 0; display: flex; flex-direction: column; gap: 10px; }
.cw-card-points li { display: flex; gap: 10px; align-items: flex-start; font-size: 14.5px; color: var(--cw-fg-muted); }
.cw-card-points li .cw-ic { color: var(--cw-green); margin-top: 3px; }

.cw-project-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 20px; }
.cw-tag { display: inline-block; padding: 5px 11px; font-size: 11.5px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; border-radius: 999px; border: 1px solid var(--cw-border-strong); color: var(--cw-fg-muted); background: var(--cw-bg-elevated); }
.cw-badge {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 5px 11px; font-size: 11px; font-weight: 600; letter-spacing: 0.04em;
	border-radius: 999px; color: var(--cw-orange);
	background: rgba(255, 159, 10, 0.12);
	border: 1px solid rgba(255, 159, 10, 0.25);
}
.cw-badge::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--cw-orange); box-shadow: 0 0 0 0 currentColor; animation: cw-pulse 2.4s ease-out infinite; }
@keyframes cw-pulse { 0% { box-shadow: 0 0 0 0 rgba(255,159,10,0.7); } 100% { box-shadow: 0 0 0 8px rgba(255,159,10,0); } }

.cw-project-card .cw-card-title { font-size: var(--cw-fs-h4); }
.cw-card-links { display: flex; flex-wrap: wrap; gap: 8px; margin-top: auto; padding-top: 12px; }

/* Project card art block */
.cw-project-card { padding-top: 0; }
.cw-project-card .cw-project-art {
	margin: 0 -32px 24px;
	height: 132px;
	border-radius: 0;
	position: relative;
	overflow: hidden;
}
.cw-project-card .cw-project-art::before {
	content: '';
	position: absolute; inset: 0;
	opacity: 0.92;
}
.cw-project-card[data-tone="a"] .cw-project-art::before { background: linear-gradient(135deg, #A78BFA 0%, #5AC8FA 100%); }
.cw-project-card[data-tone="b"] .cw-project-art::before { background: linear-gradient(135deg, #5AC8FA 0%, #63E6E2 100%); }
.cw-project-card[data-tone="c"] .cw-project-art::before { background: linear-gradient(135deg, #FF375F 0%, #FF9F0A 100%); }
.cw-project-card[data-tone="d"] .cw-project-art::before { background: linear-gradient(135deg, #63E6E2 0%, #30D158 100%); }
.cw-project-card .cw-project-art::after {
	content: '';
	position: absolute; inset: 0;
	background:
		radial-gradient(circle at 80% 20%, rgba(255,255,255,0.42), transparent 50%),
		radial-gradient(circle at 20% 90%, rgba(0,0,0,0.45), transparent 60%);
	mix-blend-mode: overlay;
}
.cw-project-card .cw-project-art-icon {
	position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
	width: 44px; height: 44px; color: rgba(255,255,255,0.92);
	z-index: 2;
	filter: drop-shadow(0 2px 8px rgba(0,0,0,0.25));
}
.cw-project-card .cw-project-art-icon svg { width: 100%; height: 100%; stroke-width: 1.4; }

/* Featured (large) project card */
.cw-feature-card {
	position: relative;
	padding: clamp(28px, 4vw, 48px);
	border-radius: var(--cw-radius-xl);
	background: var(--cw-card-bg);
	border: 1px solid var(--cw-border);
	overflow: hidden;
	display: grid;
	grid-template-columns: 1.05fr 1fr;
	gap: clamp(28px, 4vw, 60px);
	align-items: center;
	-webkit-backdrop-filter: blur(20px);
	backdrop-filter: blur(20px);
}
.cw-feature-card .cw-tag { background: rgba(255,255,255,0.06); }
.cw-feature-card h3 { font-size: var(--cw-fs-h2); margin: 14px 0 16px; letter-spacing: var(--cw-tracking-display); }
.cw-feature-card .lead { margin-bottom: 22px; }
.cw-feature-card .cw-feature-art { aspect-ratio: 4 / 3; border-radius: var(--cw-radius-lg); position: relative; overflow: hidden; background: linear-gradient(135deg, var(--cw-purple) 0%, var(--cw-blue) 60%, var(--cw-cyan) 100%); }
.cw-feature-card .cw-feature-art::before { content: ''; position: absolute; inset: 0; background: radial-gradient(at 20% 0%, rgba(255,255,255,0.45), transparent 50%), radial-gradient(at 90% 100%, rgba(0,0,0,0.4), transparent 60%); }

/* Meta strip on feature card */
.cw-feature-meta {
	list-style: none;
	padding: 0;
	margin: 0 0 24px;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 14px;
	border-top: 1px solid var(--cw-border);
	padding-top: 22px;
}
.cw-feature-meta li {
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.cw-feature-meta .k {
	font-size: 11px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--cw-fg-subtle);
	font-weight: 600;
}
.cw-feature-meta .v {
	font-size: 14px;
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--cw-fg);
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.cw-status-dot {
	width: 7px; height: 7px; border-radius: 50%;
	background: var(--cw-green);
	box-shadow: 0 0 8px var(--cw-green);
	animation: cw-pulse-soft 2.4s ease-out infinite;
}
@keyframes cw-pulse-soft {
	0%, 100% { opacity: 0.85; }
	50% { opacity: 1; }
}
@media (max-width: 480px) {
	.cw-feature-meta { grid-template-columns: 1fr 1fr; }
}

/* Panel mockup inside featured card */
.cw-feature-art--panel { padding: 28px; display: flex; align-items: center; justify-content: center; }
.cw-panel-mock {
	width: 92%;
	max-width: 400px;
	border-radius: 16px;
	overflow: hidden;
	background: rgba(8, 8, 12, 0.85);
	border: 1px solid rgba(255,255,255,0.14);
	box-shadow: 0 30px 60px -20px rgba(0,0,0,0.55);
	-webkit-backdrop-filter: blur(20px);
	backdrop-filter: blur(20px);
	position: relative;
	z-index: 2;
}
.cw-panel-bar { display: flex; gap: 6px; padding: 11px 14px; background: rgba(255,255,255,0.06); border-bottom: 1px solid rgba(255,255,255,0.09); }
.cw-panel-bar span { width: 10px; height: 10px; border-radius: 50%; background: rgba(255,255,255,0.18); }
.cw-panel-bar span:first-child { background: #FF5F57; }
.cw-panel-bar span:nth-child(2) { background: #FEBC2E; }
.cw-panel-bar span:nth-child(3) { background: #28C840; }
.cw-panel-body { padding: 14px; display: flex; flex-direction: column; gap: 10px; }
.cw-panel-row { display: flex; align-items: center; gap: 10px; padding: 9px 11px; background: rgba(255,255,255,0.04); border-radius: 9px; border: 1px solid rgba(255,255,255,0.07); }
.cw-panel-row .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--cw-mint); flex: 0 0 7px; box-shadow: 0 0 8px var(--cw-mint); }
.cw-panel-row .dot-b { background: var(--cw-yellow); box-shadow: 0 0 8px var(--cw-yellow); }
.cw-panel-row .dot-c { background: var(--cw-blue); box-shadow: 0 0 8px var(--cw-blue); }
.cw-panel-row .line { height: 8px; background: rgba(255,255,255,0.18); border-radius: 4px; flex: 1; }
.cw-panel-row .line.w70 { max-width: 70%; }
.cw-panel-row .line.w66 { max-width: 66%; }
.cw-panel-row .line.w62 { max-width: 62%; }
.cw-panel-row .line.w55 { max-width: 55%; }
.cw-panel-row .line.w48 { max-width: 48%; }
.cw-panel-row .badge { font-size: 9px; font-weight: 700; letter-spacing: 0.06em; padding: 3px 7px; border-radius: 999px; background: rgba(48,209,88,0.18); color: #66E296; border: 1px solid rgba(48,209,88,0.35); text-transform: uppercase; }
.cw-panel-row .badge.badge-b { background: rgba(255,214,10,0.18); color: #FFD66B; border-color: rgba(255,214,10,0.35); }
.cw-panel-row .badge.badge-c { background: rgba(255,255,255,0.10); color: rgba(255,255,255,0.65); border-color: rgba(255,255,255,0.18); }
@media (max-width: 820px) { .cw-feature-card { grid-template-columns: 1fr; } }

/* ======================== GAME CARDS ======================== */

.cw-game-card {
	position: relative;
	overflow: hidden;
	border-radius: var(--cw-radius-xl);
	padding: clamp(32px, 4vw, 56px);
	color: #fff;
	min-height: 400px;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	background: var(--game-bg, linear-gradient(135deg, var(--cw-purple), var(--cw-blue)));
	transition: transform 0.5s var(--cw-spring), box-shadow 0.5s var(--cw-ease);
	isolation: isolate;
}
.cw-game-card::before {
	content: '';
	position: absolute; inset: 0;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1   0 0 0 0 1   0 0 0 0 1   0 0 0 0.7 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
	opacity: 0.18;
	mix-blend-mode: overlay;
	pointer-events: none;
	z-index: 0;
}
.cw-game-card::after {
	content: '';
	position: absolute; inset: 0;
	background: radial-gradient(circle at 30% 100%, rgba(0,0,0,0.40), transparent 60%);
	pointer-events: none;
	z-index: 0;
}
.cw-game-card > * { position: relative; z-index: 1; }
.cw-game-card:hover { transform: translateY(-6px) scale(1.005); box-shadow: var(--cw-shadow-lg); }
.cw-game-card h3 { color: #fff; font-size: clamp(28px, 3vw, 44px); letter-spacing: -0.035em; margin-bottom: 10px; }
.cw-game-card p { color: rgba(255,255,255,0.88); margin: 0; max-width: 50ch; line-height: 1.55; }
.cw-game-card .cw-tag { background: rgba(255,255,255,0.20); border-color: rgba(255,255,255,0.32); color: #fff; align-self: flex-start; margin-bottom: 12px; backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); }

/* ======================== TRUST / STAT BAR ======================== */

.cw-trust {
	position: relative;
	padding: clamp(44px, 5.5vw, 72px) clamp(36px, 5vw, 64px);
	border-radius: var(--cw-radius-2xl);
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: clamp(28px, 4vw, 60px);
	align-items: center;
	text-align: center;
	overflow: hidden;
	isolation: isolate;
}
.cw-trust::before {
	content: '';
	position: absolute; inset: -2px;
	background:
		radial-gradient(at 0% 0%, rgba(167, 139, 250, 0.20) 0, transparent 55%),
		radial-gradient(at 100% 100%, rgba(90, 200, 250, 0.20) 0, transparent 55%);
	z-index: -1;
}
.cw-trust .item { display: flex; flex-direction: column; align-items: center; gap: 12px; position: relative; }
.cw-trust .item + .item::before {
	content: ''; position: absolute; left: clamp(-30px, -2vw, -14px); top: 14%; bottom: 14%;
	width: 1px; background: linear-gradient(to bottom, transparent, var(--cw-border-strong), transparent);
}
.cw-trust .num {
	font-size: clamp(56px, 5.5vw, 88px);
	font-weight: 700;
	letter-spacing: -0.05em;
	line-height: 1;
	background: linear-gradient(120deg, var(--cw-purple) 0%, var(--cw-blue) 50%, var(--cw-mint) 100%);
	background-size: 200% 100%;
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	animation: cw-shimmer 9s ease-in-out infinite;
}
@keyframes cw-shimmer {
	0%, 100% { background-position: 0% 50%; }
	50% { background-position: 100% 50%; }
}
.cw-trust .label { color: var(--cw-fg-muted); font-size: 14.5px; max-width: 28ch; line-height: 1.55; letter-spacing: -0.005em; }
@media (max-width: 720px) {
	.cw-trust { grid-template-columns: 1fr; gap: 36px; }
	.cw-trust .item + .item::before { display: none; }
}

/* ======================== CTA BLOCK ======================== */

.cw-cta {
	position: relative;
	padding: clamp(56px, 7vw, 100px) clamp(36px, 5vw, 80px);
	border-radius: var(--cw-radius-2xl);
	text-align: center;
	overflow: hidden;
	background: radial-gradient(ellipse at 30% 0%, #1A1126 0%, #0E0E12 50%, #050507 100%);
	color: #fff;
	isolation: isolate;
}
.cw-cta::before {
	content: '';
	position: absolute; inset: -2px;
	background:
		radial-gradient(60% 60% at 20% 20%, rgba(167, 139, 250, 0.40) 0%, transparent 60%),
		radial-gradient(60% 60% at 80% 80%, rgba(90, 200, 250, 0.32) 0%, transparent 60%);
	filter: blur(40px);
	opacity: 0.85;
	z-index: -1;
}
.cw-cta::after {
	content: '';
	position: absolute; inset: 0;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.05' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1   0 0 0 0 1   0 0 0 0 1   0 0 0 0.55 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
	opacity: 0.08;
	mix-blend-mode: overlay;
	pointer-events: none;
	z-index: -1;
}
.cw-cta h2 { color: #fff; max-width: 22ch; margin-left: auto; margin-right: auto; margin-bottom: 18px; letter-spacing: var(--cw-tracking-display); }
.cw-cta p  { color: rgba(255,255,255,0.78); max-width: 56ch; margin: 0 auto 32px; font-size: var(--cw-fs-lead); }
.cw-cta .cw-eyebrow { color: rgba(255,255,255,0.78); justify-content: center; }
.cw-cta .cw-hero-ctas { justify-content: center; }
.cw-cta .cw-btn-ghost { color: #fff; border-color: rgba(255,255,255,0.3); }
.cw-cta .cw-btn-ghost:hover { background: #fff; color: #000; border-color: #fff; }
.cw-cta .cw-btn-primary { background: #fff; color: #000; box-shadow: 0 1px 0 rgba(255,255,255,0.4) inset, 0 8px 24px -10px rgba(255,255,255,0.4); }
.cw-cta .cw-btn-primary:hover { background: linear-gradient(120deg, var(--cw-purple), var(--cw-blue)); color: #fff; }

/* ======================== MESH BACKGROUND ======================== */

.cw-mesh {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	opacity: var(--cw-mesh-opacity);
}
.cw-mesh--a {
	background:
		radial-gradient(at 20% 0%, rgba(167, 139, 250, 0.35) 0px, transparent 50%),
		radial-gradient(at 80% 0%, rgba(90, 200, 250, 0.30) 0px, transparent 50%),
		radial-gradient(at 0% 50%, rgba(99, 230, 226, 0.20) 0px, transparent 50%),
		radial-gradient(at 100% 100%, rgba(255, 55, 95, 0.18) 0px, transparent 50%);
}

/* ======================== SCROLL REVEAL ======================== */

.cw-reveal {
	opacity: 0;
	transform: translateY(28px);
	transition: opacity 0.9s var(--cw-spring), transform 0.9s var(--cw-spring);
	will-change: transform, opacity;
}
.cw-reveal.is-in { opacity: 1; transform: translateY(0); }
.no-js .cw-reveal { opacity: 1; transform: none; }
@media (scripting: none) { .cw-reveal { opacity: 1; transform: none; } }
.cw-reveal[data-delay="1"] { transition-delay: 0.06s; }
.cw-reveal[data-delay="2"] { transition-delay: 0.12s; }
.cw-reveal[data-delay="3"] { transition-delay: 0.18s; }
.cw-reveal[data-delay="4"] { transition-delay: 0.24s; }
.cw-reveal[data-delay="5"] { transition-delay: 0.30s; }
@media (prefers-reduced-motion: reduce) {
	.cw-reveal { opacity: 1; transform: none; transition: none; }
}

/* ======================== PROSE ======================== */

.cw-prose { color: var(--cw-fg); font-size: var(--cw-fs-body); line-height: var(--cw-line-loose); }
.cw-prose > * + * { margin-top: 1em; }
.cw-prose h2, .cw-prose h3 { margin-top: 1.6em; }
.cw-prose ul, .cw-prose ol { padding-left: 1.4em; }
.cw-prose a { color: var(--cw-blue-deep); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
.cw-prose code { font-family: var(--cw-font-mono); background: var(--cw-bg-soft); padding: 2px 6px; border-radius: 6px; font-size: 0.9em; }
.cw-prose blockquote { border-left: 3px solid var(--cw-fg); padding-left: 18px; margin: 1.5em 0; color: var(--cw-fg-muted); font-style: italic; }

.cw-page-head { text-align: center; max-width: 760px; margin: 0 auto clamp(36px, 4vw, 64px); }
.cw-page-head h1 { margin-bottom: 16px; }
.cw-page-head .lead { margin-left: auto; margin-right: auto; }

/* ======================== FORMS ======================== */

.cw-form {
	display: grid;
	gap: 18px;
	padding: clamp(28px, 4vw, 44px);
	border-radius: var(--cw-radius-xl);
}
.cw-form-row { display: grid; gap: 18px; grid-template-columns: 1fr 1fr; }
@media (max-width: 720px) { .cw-form-row { grid-template-columns: 1fr; } }

.cw-field { display: flex; flex-direction: column; gap: 6px; }
.cw-field label { font-size: 13px; font-weight: 500; color: var(--cw-fg-muted); letter-spacing: -0.005em; }
.cw-field label .req { color: var(--cw-pink); margin-left: 2px; }
.cw-field input, .cw-field select, .cw-field textarea {
	width: 100%;
	padding: 14px 16px;
	border-radius: var(--cw-radius-sm);
	border: 1px solid var(--cw-border-strong);
	background: var(--cw-bg-elevated);
	color: var(--cw-fg);
	font-family: inherit;
	font-size: 15px;
	letter-spacing: -0.005em;
	transition: border-color 0.2s var(--cw-ease), box-shadow 0.2s var(--cw-ease), background 0.2s var(--cw-ease);
	-webkit-appearance: none;
	appearance: none;
}
:root[data-theme="dark"] .cw-field input,
:root[data-theme="dark"] .cw-field select,
:root[data-theme="dark"] .cw-field textarea,
:root.cw-dark .cw-field input,
:root.cw-dark .cw-field select,
:root.cw-dark .cw-field textarea {
	background: rgba(255, 255, 255, 0.04);
	border-color: rgba(255, 255, 255, 0.12);
}
@media (prefers-color-scheme: dark) {
	:root:not([data-theme="light"]) .cw-field input,
	:root:not([data-theme="light"]) .cw-field select,
	:root:not([data-theme="light"]) .cw-field textarea {
		background: rgba(255, 255, 255, 0.04);
		border-color: rgba(255, 255, 255, 0.12);
	}
}
.cw-field input:hover, .cw-field select:hover, .cw-field textarea:hover {
	border-color: var(--cw-fg-muted);
}
.cw-field input:focus, .cw-field select:focus, .cw-field textarea:focus {
	outline: none;
	border-color: var(--cw-violet);
	box-shadow: 0 0 0 4px rgba(124, 58, 237, 0.18);
	background: var(--cw-bg-elevated);
}
:root[data-theme="dark"] .cw-field input:focus,
:root[data-theme="dark"] .cw-field select:focus,
:root[data-theme="dark"] .cw-field textarea:focus,
:root.cw-dark .cw-field input:focus,
:root.cw-dark .cw-field select:focus,
:root.cw-dark .cw-field textarea:focus {
	background: rgba(255,255,255,0.07);
}
.cw-field select { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23A1A1A6' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 40px; }
.cw-field textarea { min-height: 140px; resize: vertical; }

.cw-form-status {
	border-radius: var(--cw-radius-sm);
	padding: 14px 16px;
	font-size: 14.5px;
	display: none;
}
.cw-form-status.is-success { display: block; background: rgba(48, 209, 88, 0.12); color: #246B3A; border: 1px solid rgba(48, 209, 88, 0.3); }
.cw-form-status.is-error { display: block; background: rgba(255, 69, 58, 0.12); color: #B0322A; border: 1px solid rgba(255, 69, 58, 0.3); }
:root[data-theme="dark"] .cw-form-status.is-success,
:root.cw-dark .cw-form-status.is-success { color: #66E296; }
:root[data-theme="dark"] .cw-form-status.is-error,
:root.cw-dark .cw-form-status.is-error { color: #FF8A80; }

/* ======================== FOOTER ======================== */

.cw-footer {
	margin-top: clamp(80px, 10vw, 160px);
	padding: clamp(56px, 7vw, 100px) 0 36px;
	border-top: 1px solid var(--cw-border);
	background: var(--cw-bg-soft);
	position: relative;
	z-index: 1;
}
.cw-footer-top {
	display: grid;
	grid-template-columns: 1.5fr 2fr;
	gap: clamp(36px, 5vw, 80px);
	margin-bottom: clamp(36px, 5vw, 56px);
}
.cw-footer-brand p { color: var(--cw-fg-muted); margin-top: 16px; max-width: 36ch; line-height: 1.55; }
.cw-footer-nav { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.cw-footer-nav h4 { font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--cw-fg-subtle); font-weight: 600; margin: 0 0 18px; }
.cw-footer-nav ul { list-style: none; padding: 0; margin: 0; }
.cw-footer-nav li { margin-bottom: 12px; }
.cw-footer-nav a { color: var(--cw-fg); font-size: 14.5px; transition: color 0.2s var(--cw-ease); }
.cw-footer-nav a:hover { color: var(--cw-violet); }
.cw-footer-bottom { display: flex; flex-wrap: wrap; gap: 12px 24px; justify-content: space-between; padding-top: 24px; border-top: 1px solid var(--cw-border); font-size: 13px; color: var(--cw-fg-subtle); }
.cw-footer-bottom a { color: var(--cw-fg-subtle); }
.cw-footer-bottom a:hover { color: var(--cw-fg); }
.cw-footer-tag { font-weight: 500; letter-spacing: -0.005em; color: var(--cw-fg-muted); }
.cw-footer-tag .cw-grad-text { font-weight: 700; }

.cw-founder-tags { display: flex; flex-wrap: wrap; gap: 8px; }

@media (max-width: 820px) {
	.cw-footer-top { grid-template-columns: 1fr; }
	.cw-footer-nav { grid-template-columns: repeat(2, 1fr); }
}

/* ======================== INFO STRIPS / PROCESS ======================== */

.cw-process { display: grid; gap: clamp(20px, 2vw, 28px); }
.cw-step {
	display: grid;
	grid-template-columns: 80px 1fr;
	gap: clamp(20px, 2vw, 32px);
	align-items: start;
	padding: clamp(24px, 3vw, 36px);
	border-radius: var(--cw-radius-lg);
	background: var(--cw-card-bg);
	border: 1px solid var(--cw-border);
	transition: border-color 0.3s var(--cw-ease), transform 0.4s var(--cw-spring);
	-webkit-backdrop-filter: blur(20px) saturate(160%);
	backdrop-filter: blur(20px) saturate(160%);
}
.cw-step:hover { border-color: var(--cw-border-strong); transform: translateY(-3px); }
.cw-step-num {
	font-size: 60px;
	font-weight: 700;
	letter-spacing: -0.045em;
	line-height: 1;
	background: linear-gradient(120deg, var(--cw-purple), var(--cw-blue));
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}
.cw-step h4 { font-size: var(--cw-fs-h4); margin: 0 0 8px; letter-spacing: var(--cw-tracking-tighter); }
.cw-step p  { color: var(--cw-fg-muted); margin: 0; }
@media (max-width: 640px) { .cw-step { grid-template-columns: 1fr; gap: 8px; } .cw-step-num { font-size: 44px; } }

/* ======================== FAQ-STYLE LIST ======================== */

.cw-list-row {
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: 24px;
	align-items: center;
	padding: 22px 4px;
	border-bottom: 1px solid var(--cw-border);
}
.cw-list-row:last-child { border-bottom: 0; }
.cw-list-row .num { font-family: var(--cw-font-mono); color: var(--cw-fg-subtle); font-size: 13px; }
.cw-list-row .title { font-weight: 600; letter-spacing: -0.014em; font-size: 18px; }
.cw-list-row .meta { color: var(--cw-fg-muted); font-size: 14px; }

/* ======================== UTILS ======================== */

.cw-divider { height: 1px; background: var(--cw-border); margin: clamp(48px, 6vw, 80px) 0; }
.cw-hide-mobile { display: initial; }
@media (max-width: 720px) { .cw-hide-mobile { display: none; } }
.cw-flex { display: flex; }
.cw-items-center { align-items: center; }
.cw-justify-between { justify-content: space-between; }
.cw-gap-8 { gap: 8px; }
.cw-gap-16 { gap: 16px; }
.cw-mt-24 { margin-top: 24px; }
.cw-mt-40 { margin-top: 40px; }

/* ======================== ABOUT — FOUNDER PROFILE ======================== */

.cw-founder {
	display: grid;
	grid-template-columns: 1fr 1.1fr;
	gap: clamp(36px, 5vw, 80px);
	align-items: center;
}
.cw-founder-art {
	aspect-ratio: 4 / 5;
	border-radius: var(--cw-radius-xl);
	background: linear-gradient(135deg, var(--cw-purple), var(--cw-blue) 50%, var(--cw-mint));
	position: relative;
	overflow: hidden;
	box-shadow: var(--cw-shadow-lg);
}
.cw-founder-art::before {
	content: '';
	position: absolute; inset: 0;
	background:
		radial-gradient(at 20% 30%, rgba(255,255,255,0.45) 0, transparent 40%),
		radial-gradient(at 80% 90%, rgba(0,0,0,0.45) 0, transparent 60%);
}
.cw-founder-art::after {
	content: '';
	position: absolute; inset: 0;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1   0 0 0 0 1   0 0 0 0 1   0 0 0 0.55 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
	mix-blend-mode: overlay;
	opacity: 0.25;
}
.cw-founder-art .cw-founder-mark { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); font-size: clamp(80px, 12vw, 150px); font-weight: 700; letter-spacing: -0.06em; color: rgba(255,255,255,0.92); line-height: 1; z-index: 2; text-shadow: 0 8px 32px rgba(0,0,0,0.25); font-feature-settings: "ss01"; }
@media (max-width: 820px) { .cw-founder { grid-template-columns: 1fr; } }

/* ======================== CONTACT INFO ROW ======================== */

.cw-contact-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: clamp(28px, 4vw, 60px); align-items: start; }
@media (max-width: 820px) { .cw-contact-grid { grid-template-columns: 1fr; } }

.cw-contact-info { display: flex; flex-direction: column; gap: 14px; }
.cw-contact-info a { display: inline-flex; align-items: center; gap: 14px; padding: 16px 20px; border-radius: var(--cw-radius-md); background: var(--cw-card-bg); border: 1px solid var(--cw-border); transition: transform 0.3s var(--cw-spring), border-color 0.2s var(--cw-ease); -webkit-backdrop-filter: blur(20px); backdrop-filter: blur(20px); }
.cw-contact-info a:hover { transform: translateY(-2px); border-color: var(--cw-border-strong); }
.cw-contact-info .ic { width: 44px; height: 44px; border-radius: 12px; display: inline-flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--cw-purple), var(--cw-blue)); color: #fff; flex: 0 0 44px; box-shadow: 0 1px 0 rgba(255,255,255,0.25) inset, 0 8px 20px -8px rgba(122, 102, 250, 0.5); }
.cw-contact-info .label { font-size: 12px; color: var(--cw-fg-muted); letter-spacing: 0.05em; text-transform: uppercase; }
.cw-contact-info .value { font-weight: 600; letter-spacing: -0.012em; }

/* ======================== RIBBON ANNOUNCEMENT ======================== */

.cw-ribbon {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 6px 14px 6px 8px;
	border-radius: 999px;
	background: var(--cw-glass-bg-strong);
	border: 1px solid var(--cw-border);
	font-size: 13px;
	margin-bottom: 28px;
	-webkit-backdrop-filter: blur(20px);
	backdrop-filter: blur(20px);
	color: var(--cw-fg);
}
.cw-ribbon .tag { padding: 4px 10px; border-radius: 999px; background: linear-gradient(135deg, var(--cw-violet), var(--cw-blue-deep)); color: #fff; font-weight: 600; font-size: 11px; letter-spacing: 0.04em; text-transform: uppercase; }
.cw-ribbon .ar { color: var(--cw-fg-muted); transition: transform 0.3s var(--cw-spring); }
.cw-ribbon:hover .ar { transform: translateX(3px); }

/* ======================== CHIP ROW ======================== */

.cw-chip-row { display: flex; flex-wrap: wrap; gap: 8px; }
.cw-chip { display: inline-flex; align-items: center; gap: 6px; padding: 7px 13px; border-radius: 999px; font-size: 13px; font-weight: 500; background: var(--cw-bg-soft); border: 1px solid var(--cw-border); color: var(--cw-fg-muted); }

/* ======================== DEVICE MOCKUP ======================== */

.cw-device {
	position: relative;
	border-radius: 36px;
	padding: 14px;
	background: linear-gradient(135deg, #1A1A1F, #050505);
	box-shadow: 0 30px 60px -20px rgba(0,0,0,0.5);
	max-width: 320px;
	margin: 0 auto;
	aspect-ratio: 9 / 19;
}
.cw-device::before {
	content: '';
	position: absolute; top: 14px; left: 50%; transform: translateX(-50%);
	width: 100px; height: 28px; background: #050505; border-radius: 0 0 18px 18px; z-index: 2;
}
.cw-device-screen {
	height: 100%;
	border-radius: 24px;
	background: linear-gradient(160deg, var(--cw-purple), var(--cw-blue) 50%, var(--cw-mint));
	overflow: hidden;
	position: relative;
}

/* ======================== KILLER FEATURES ROW ======================== */

.cw-feat-row {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(20px, 2vw, 28px);
}
@media (max-width: 820px) { .cw-feat-row { grid-template-columns: 1fr; } }
.cw-feat {
	padding: clamp(24px, 3vw, 32px);
	border-radius: var(--cw-radius-lg);
	background: var(--cw-card-bg);
	border: 1px solid var(--cw-border);
	-webkit-backdrop-filter: blur(20px) saturate(160%);
	backdrop-filter: blur(20px) saturate(160%);
	transition: border-color 0.3s var(--cw-ease), transform 0.4s var(--cw-spring);
}
.cw-feat:hover { border-color: var(--cw-border-strong); transform: translateY(-3px); }
.cw-feat .cw-ic-circ {
	width: 48px; height: 48px;
	border-radius: 14px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	background: linear-gradient(135deg, var(--cw-purple) 0%, var(--cw-blue) 100%);
	margin-bottom: 18px;
	box-shadow: 0 1px 0 rgba(255,255,255,0.25) inset, 0 8px 22px -10px rgba(122, 102, 250, 0.5);
}
.cw-feat .cw-ic-circ svg { width: 22px; height: 22px; stroke-width: 1.7; }
.cw-feat:nth-child(2) .cw-ic-circ { background: linear-gradient(135deg, var(--cw-blue) 0%, var(--cw-mint) 100%); box-shadow: 0 1px 0 rgba(255,255,255,0.25) inset, 0 8px 22px -10px rgba(90, 200, 250, 0.5); }
.cw-feat:nth-child(3) .cw-ic-circ { background: linear-gradient(135deg, var(--cw-mint) 0%, var(--cw-green) 100%); box-shadow: 0 1px 0 rgba(255,255,255,0.25) inset, 0 8px 22px -10px rgba(48, 209, 88, 0.5); }
.cw-feat h4 { font-size: var(--cw-fs-h5); letter-spacing: var(--cw-tracking-tighter); margin: 0 0 8px; }
.cw-feat p { color: var(--cw-fg-muted); font-size: 14.5px; margin: 0; line-height: 1.55; }

/* ======================== COMPARE / SPLIT BANNER ======================== */

.cw-compare {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(20px, 2vw, 28px);
}
.cw-compare-card {
	padding: clamp(24px, 3vw, 36px);
	border-radius: var(--cw-radius-lg);
	background: var(--cw-card-bg);
	border: 1px solid var(--cw-border);
	-webkit-backdrop-filter: blur(20px);
	backdrop-filter: blur(20px);
}
.cw-compare-card h4 {
	margin: 0 0 18px;
	font-size: var(--cw-fs-h5);
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 8px 14px;
	border-radius: 999px;
	background: var(--cw-bg-soft);
	border: 1px solid var(--cw-border);
}
.cw-compare-card.cw-good h4 { color: #246B3A; background: rgba(48, 209, 88, 0.10); border-color: rgba(48, 209, 88, 0.25); }
:root[data-theme="dark"] .cw-compare-card.cw-good h4,
:root.cw-dark .cw-compare-card.cw-good h4 { color: #66E296; }
.cw-compare-card.cw-bad h4 { color: var(--cw-fg-muted); }
.cw-compare-card h4 .cw-ic { width: 16px; height: 16px; }
.cw-compare-card ul { list-style: none; padding: 0; margin: 0; }
.cw-compare-card li { padding: 10px 0; display: flex; gap: 10px; align-items: flex-start; color: var(--cw-fg-muted); border-bottom: 1px solid var(--cw-border); }
.cw-compare-card li:last-child { border-bottom: 0; }
.cw-compare-card li .cw-ic { margin-top: 3px; flex-shrink: 0; }
.cw-compare-card.cw-good li .cw-ic { color: var(--cw-green); }
.cw-compare-card.cw-bad li .cw-ic { color: var(--cw-fg-subtle); }
.cw-compare-card.cw-bad li { text-decoration: line-through; }
@media (max-width: 720px) { .cw-compare { grid-template-columns: 1fr; } }

/* ======================== INLINE LINK ======================== */

.cw-inline-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: var(--cw-blue-deep);
	font-weight: 500;
	border-bottom: 1px solid currentColor;
	padding-bottom: 1px;
	transition: opacity 0.2s var(--cw-ease);
}
.cw-inline-link:hover { opacity: 0.75; }
.cw-inline-link .cw-ic { transition: transform 0.3s var(--cw-spring); }
.cw-inline-link:hover .cw-ic { transform: translate(2px, -2px); }

/* ======================== HERO TYPE TWEAKS FOR DESKTOP ======================== */

@media (min-width: 1100px) {
	.cw-hero-inner h1 {
		max-width: 16ch;
	}
	.cw-hero-stats {
		gap: 16px;
	}
	.cw-stat {
		padding: 28px 28px;
	}
}

/* ======================== KEY ANIMATIONS ======================== */

@keyframes cw-float {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(-6px); }
}

/* ======================== SVG SUBTLE GRID OVERLAY ======================== */

.cw-grid-bg {
	position: absolute; inset: 0;
	pointer-events: none;
	background-image:
		linear-gradient(to right, rgba(0,0,0,0.04) 1px, transparent 1px),
		linear-gradient(to bottom, rgba(0,0,0,0.04) 1px, transparent 1px);
	background-size: 60px 60px;
	mask-image: radial-gradient(ellipse at center, black 30%, transparent 70%);
	-webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 70%);
}
:root[data-theme="dark"] .cw-grid-bg,
:root.cw-dark .cw-grid-bg {
	background-image:
		linear-gradient(to right, rgba(255,255,255,0.04) 1px, transparent 1px),
		linear-gradient(to bottom, rgba(255,255,255,0.04) 1px, transparent 1px);
}
@media (prefers-color-scheme: dark) {
	:root:not([data-theme="light"]) .cw-grid-bg {
		background-image:
			linear-gradient(to right, rgba(255,255,255,0.04) 1px, transparent 1px),
			linear-gradient(to bottom, rgba(255,255,255,0.04) 1px, transparent 1px);
	}
}

/*  ==========================================================================
    v7 — APPLE POLISH LAYER
    Surgical refinements on top of v6. Goals:
    • Editorial type rhythm with bigger, calmer display
    • A single elegant gradient sweep that doesn't feel candy
    • Real product UI feel inside the featured Stream Ingest Panel mock
    • Hairline stat strip (Apple.com style) instead of 4-up card grid
    • iOS-Settings-app tinted service icon containers
    • Section heads with a tiny accent rule + better hierarchy
    • Refined ribbon, refined CTAs, refined nav surface
    • Quieter dark CTA block with intent
    • Footer that feels like a sign-off, not a sitemap
    ========================================================================== */

:root {
	/* Refined gradient stops — pulled in from the cooler half of the spectrum.
	   The earlier mint→cyan→purple sweep read as candy. This version reads
	   as iCloud / Apple Intelligence — purple → indigo → cyan, no green spike. */
	--cw-grad-display: linear-gradient(115deg,
		#A78BFA 0%, #7C9BF7 28%, #5AC8FA 56%, #63E6E2 92%);
	--cw-grad-display-warm: linear-gradient(115deg,
		#FF6A8B 0%, #FF9F0A 50%, #FFD60A 100%);

	/* Stronger inner-glow tokens for the dark CTA block. */
	--cw-cta-bg-dark: radial-gradient(120% 80% at 20% 0%,
		#1A1430 0%,
		#0B0B17 45%,
		#040408 100%);
}

/* Refine the standard grad-text helper to use the new sweep
   everywhere it's already used (hero subline, footer tagline, stat numbers). */
.cw-grad-text {
	background: var(--cw-grad-display);
	background-size: 200% 100%;
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
}

/* ---------- Nav: tightened scrolled state, real iOS 26 capsule ---------- */

.cw-nav { padding-top: 16px; padding-bottom: 16px; }
.cw-nav[data-state="scrolled"] { padding-top: 10px; padding-bottom: 10px; }
.cw-nav-inner {
	padding: 10px 12px 10px 18px;
	box-shadow:
		0 1px 0 rgba(255,255,255,0.6) inset,
		0 0 0 1px rgba(0,0,0,0.04),
		0 10px 30px -16px rgba(0,0,0,0.18);
	-webkit-backdrop-filter: blur(28px) saturate(180%);
	backdrop-filter: blur(28px) saturate(180%);
}
:root[data-theme="dark"] .cw-nav-inner,
:root.cw-dark .cw-nav-inner {
	box-shadow:
		0 1px 0 rgba(255,255,255,0.06) inset,
		0 0 0 1px rgba(0,0,0,0.4),
		0 14px 40px -20px rgba(0,0,0,0.7);
}
@media (prefers-color-scheme: dark) {
	:root:not([data-theme="light"]) .cw-nav-inner {
		box-shadow:
			0 1px 0 rgba(255,255,255,0.06) inset,
			0 0 0 1px rgba(0,0,0,0.4),
			0 14px 40px -20px rgba(0,0,0,0.7);
	}
}
.cw-nav[data-state="scrolled"] .cw-nav-inner {
	background: var(--cw-glass-bg-strong);
}

.cw-brand { font-size: 16px; }
.cw-brand-mark { width: 30px; height: 30px; }
.cw-brand-mark svg { border-radius: 9px; }

/* ---------- Ribbon: more presence, gradient chip, subtle inner border ---------- */

.cw-ribbon {
	padding: 6px 16px 6px 6px;
	gap: 10px;
	font-size: 13.5px;
	font-weight: 500;
	letter-spacing: -0.005em;
	background: var(--cw-glass-bg-strong);
	border: 1px solid var(--cw-border);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.6) inset,
		0 8px 20px -10px rgba(0,0,0,0.15);
}
:root[data-theme="dark"] .cw-ribbon,
:root.cw-dark .cw-ribbon {
	box-shadow:
		0 1px 0 rgba(255,255,255,0.07) inset,
		0 8px 20px -10px rgba(0,0,0,0.5);
}
@media (prefers-color-scheme: dark) {
	:root:not([data-theme="light"]) .cw-ribbon {
		box-shadow:
			0 1px 0 rgba(255,255,255,0.07) inset,
			0 8px 20px -10px rgba(0,0,0,0.5);
	}
}
.cw-ribbon .tag {
	padding: 5px 11px;
	font-size: 10.5px;
	font-weight: 700;
	letter-spacing: 0.08em;
	background: linear-gradient(135deg, #7C3AED 0%, #5AC8FA 100%);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.35) inset,
		0 4px 14px -4px rgba(124, 58, 237, 0.5);
}
.cw-ribbon .ar {
	width: 18px; height: 18px;
	display: inline-flex; align-items: center; justify-content: center;
	border-radius: 999px;
	background: var(--cw-bg-soft);
	color: var(--cw-fg);
	font-size: 12px;
	transition: transform 0.3s var(--cw-spring), background 0.2s var(--cw-ease);
}
.cw-ribbon:hover .ar { background: var(--cw-fg); color: var(--cw-bg); transform: translateX(3px); }

/* ---------- Hero: bigger weight, refined sub, calmer CTA ---------- */

.cw-hero {
	padding-top: clamp(86px, 13vw, 176px);
	padding-bottom: clamp(56px, 8vw, 110px);
}
.cw-hero-orb { opacity: 0.42; filter: blur(110px); }
.cw-hero-orb--a { opacity: 0.50; }
.cw-hero-orb--c { opacity: 0.30; }

.cw-hero-inner h1 {
	max-width: 17ch;
	margin: 0 auto 26px;
	font-weight: 700;
	letter-spacing: -0.044em;
}
.cw-hero-inner h1 .cw-grad-text {
	background-size: 200% 100%;
	animation: cw-shimmer 14s ease-in-out infinite;
}
.cw-hero-inner .lead {
	max-width: 52ch;
	font-size: clamp(17px, 0.45vw + 15px, 21px);
	line-height: 1.55;
	color: var(--cw-fg-muted);
	margin-bottom: 40px;
}

.cw-hero-ctas { gap: 14px; }
.cw-hero-ctas .cw-btn { padding: 15px 26px; font-size: 15.5px; }
.cw-hero-ctas .cw-btn-primary {
	box-shadow:
		0 1px 0 rgba(255,255,255,0.22) inset,
		0 12px 30px -10px rgba(0,0,0,0.30);
}

/* ---------- Hero stats: hairline horizontal strip ---------- */

.cw-hero-stats {
	margin-top: clamp(60px, 8vw, 100px);
	max-width: 980px;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	background: var(--cw-card-bg);
	border: 1px solid var(--cw-border);
	border-radius: var(--cw-radius-xl);
	padding: 8px;
	-webkit-backdrop-filter: blur(28px) saturate(160%);
	backdrop-filter: blur(28px) saturate(160%);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.5) inset,
		0 18px 50px -24px rgba(0,0,0,0.15);
}
:root[data-theme="dark"] .cw-hero-stats,
:root.cw-dark .cw-hero-stats {
	box-shadow:
		0 1px 0 rgba(255,255,255,0.06) inset,
		0 20px 60px -28px rgba(0,0,0,0.7);
}
@media (prefers-color-scheme: dark) {
	:root:not([data-theme="light"]) .cw-hero-stats {
		box-shadow:
			0 1px 0 rgba(255,255,255,0.06) inset,
			0 20px 60px -28px rgba(0,0,0,0.7);
	}
}
.cw-hero-stats .cw-stat {
	background: transparent;
	border: 0;
	box-shadow: none;
	padding: 22px 24px;
	border-right: 1px solid var(--cw-border);
	border-radius: 0;
	-webkit-backdrop-filter: none;
	backdrop-filter: none;
}
.cw-hero-stats .cw-stat:last-child { border-right: 0; }
.cw-hero-stats .cw-stat:hover { transform: none; background: rgba(0,0,0,0.025); border-radius: calc(var(--cw-radius-xl) - 10px); }
:root[data-theme="dark"] .cw-hero-stats .cw-stat:hover,
:root.cw-dark .cw-hero-stats .cw-stat:hover { background: rgba(255,255,255,0.04); }
@media (prefers-color-scheme: dark) {
	:root:not([data-theme="light"]) .cw-hero-stats .cw-stat:hover {
		background: rgba(255,255,255,0.04);
	}
}
.cw-hero-stats .cw-stat .num {
	font-size: clamp(32px, 2.8vw, 44px);
	letter-spacing: -0.038em;
}
.cw-hero-stats .cw-stat .label {
	color: var(--cw-fg-subtle);
	font-size: 12.5px;
	font-weight: 500;
	letter-spacing: 0.005em;
}

@media (max-width: 720px) {
	.cw-hero-stats { grid-template-columns: repeat(2, 1fr); }
	.cw-hero-stats .cw-stat { border-right: 0; border-bottom: 1px solid var(--cw-border); }
	.cw-hero-stats .cw-stat:nth-child(2n) { border-right: 0; }
	.cw-hero-stats .cw-stat:nth-child(odd) { border-right: 1px solid var(--cw-border); }
	.cw-hero-stats .cw-stat:nth-last-child(-n+2) { border-bottom: 0; }
}

/* ---------- Section heads: accent rule + breathing room ---------- */

.cw-section-head .cw-eyebrow {
	margin-bottom: 22px;
	font-size: 12px;
	font-weight: 600;
}
.cw-section-head .cw-eyebrow::before {
	width: 7px; height: 7px;
	box-shadow: 0 0 14px rgba(122, 102, 250, 0.7);
}
.cw-section-head h2 {
	font-size: clamp(32px, 2.4vw + 18px, 60px);
	margin-bottom: 18px;
	letter-spacing: -0.040em;
	text-wrap: balance;
}
.cw-section-head p {
	font-size: clamp(17px, 0.4vw + 14px, 20px);
	color: var(--cw-fg-muted);
	line-height: 1.5;
}

/* ---------- Feature card: bigger frame, proper "real-product" panel mock ---------- */

.cw-feature-card {
	padding: clamp(32px, 4.5vw, 56px);
	grid-template-columns: 1fr 1.05fr;
	gap: clamp(36px, 5vw, 72px);
	border-radius: var(--cw-radius-2xl);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.5) inset,
		0 30px 80px -32px rgba(0,0,0,0.18);
}
:root[data-theme="dark"] .cw-feature-card,
:root.cw-dark .cw-feature-card {
	box-shadow:
		0 1px 0 rgba(255,255,255,0.06) inset,
		0 30px 80px -28px rgba(0,0,0,0.7);
}
@media (prefers-color-scheme: dark) {
	:root:not([data-theme="light"]) .cw-feature-card {
		box-shadow:
			0 1px 0 rgba(255,255,255,0.06) inset,
			0 30px 80px -28px rgba(0,0,0,0.7);
	}
}
.cw-feature-card .cw-tag {
	background: rgba(48, 209, 88, 0.10);
	border-color: rgba(48, 209, 88, 0.30);
	color: #246B3A;
}
:root[data-theme="dark"] .cw-feature-card .cw-tag,
:root.cw-dark .cw-feature-card .cw-tag { color: #66E296; }
@media (prefers-color-scheme: dark) {
	:root:not([data-theme="light"]) .cw-feature-card .cw-tag { color: #66E296; }
}

.cw-feature-card h3 {
	font-size: clamp(30px, 2.6vw + 14px, 52px);
	margin: 14px 0 18px;
	letter-spacing: -0.038em;
	line-height: 1.05;
}

/* The panel mock now renders like an actual app surface. */
.cw-feature-art--panel {
	padding: 0;
	background: linear-gradient(160deg,
		#1B1430 0%,
		#0E1228 45%,
		#0A1226 100%);
	border-radius: var(--cw-radius-xl);
}
.cw-feature-art--panel::before {
	content: '';
	position: absolute; inset: 0;
	background:
		radial-gradient(60% 40% at 20% 10%, rgba(167, 139, 250, 0.35), transparent 60%),
		radial-gradient(50% 40% at 80% 90%, rgba(90, 200, 250, 0.30), transparent 60%);
	pointer-events: none;
}
.cw-feature-art--panel::after {
	content: '';
	position: absolute; inset: 0;
	background-image: linear-gradient(to right, rgba(255,255,255,0.025) 1px, transparent 1px),
		linear-gradient(to bottom, rgba(255,255,255,0.025) 1px, transparent 1px);
	background-size: 28px 28px;
	mask-image: radial-gradient(ellipse at center, black 40%, transparent 80%);
	-webkit-mask-image: radial-gradient(ellipse at center, black 40%, transparent 80%);
	pointer-events: none;
}
.cw-panel-mock {
	width: 88%;
	max-width: 440px;
	border-radius: 18px;
	background: rgba(10, 10, 16, 0.78);
	border: 1px solid rgba(255,255,255,0.10);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.10) inset,
		0 30px 70px -20px rgba(0,0,0,0.7);
	-webkit-backdrop-filter: blur(24px) saturate(160%);
	backdrop-filter: blur(24px) saturate(160%);
}
.cw-panel-bar {
	padding: 12px 14px;
	background: rgba(255,255,255,0.04);
	border-bottom: 1px solid rgba(255,255,255,0.08);
	display: flex;
	align-items: center;
	gap: 8px;
}
.cw-panel-bar::after {
	content: 'Stream Ingest Panel';
	margin-left: auto;
	font-size: 11px;
	font-weight: 600;
	color: rgba(255,255,255,0.50);
	letter-spacing: 0.02em;
}
.cw-panel-bar span { width: 11px; height: 11px; }
.cw-panel-body { padding: 16px 14px 18px; gap: 8px; }
.cw-panel-row {
	padding: 11px 13px;
	background: rgba(255,255,255,0.035);
	border: 1px solid rgba(255,255,255,0.06);
	border-radius: 10px;
}
.cw-panel-row .line { height: 9px; }
.cw-panel-row .badge { padding: 4px 9px; font-size: 9.5px; }

/* ---------- Service cards: tinted icon containers (iOS Settings vibe) ---------- */

.cw-card { padding: 34px 32px 30px; border-radius: var(--cw-radius-xl); }
.cw-card-icon {
	width: 52px; height: 52px;
	border-radius: 14px;
	background: linear-gradient(135deg, #A78BFA 0%, #7C3AED 100%);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.25) inset,
		0 10px 26px -10px rgba(122, 102, 250, 0.45);
	position: relative;
}
.cw-card-icon::before {
	content: '';
	position: absolute; inset: -1px;
	border-radius: inherit;
	background: linear-gradient(180deg, rgba(255,255,255,0.18), rgba(255,255,255,0));
	pointer-events: none;
	z-index: 1;
}
.cw-card-icon svg { width: 26px; height: 26px; stroke-width: 1.75; position: relative; z-index: 2; }
.cw-card[data-tone="b"] .cw-card-icon { background: linear-gradient(135deg, #5AC8FA 0%, #0A84FF 100%); box-shadow: 0 1px 0 rgba(255,255,255,0.25) inset, 0 10px 26px -10px rgba(10, 132, 255, 0.45); }
.cw-card[data-tone="c"] .cw-card-icon { background: linear-gradient(135deg, #FF6A8B 0%, #FF9F0A 100%); box-shadow: 0 1px 0 rgba(255,255,255,0.25) inset, 0 10px 26px -10px rgba(255, 100, 130, 0.45); }
.cw-card[data-tone="d"] .cw-card-icon { background: linear-gradient(135deg, #63E6E2 0%, #30D158 100%); box-shadow: 0 1px 0 rgba(255,255,255,0.25) inset, 0 10px 26px -10px rgba(48, 209, 88, 0.45); }

.cw-card-title { font-size: clamp(20px, 0.9vw + 16px, 26px); margin-bottom: 10px; letter-spacing: -0.025em; }
.cw-card-desc { color: var(--cw-fg-muted); margin-bottom: 22px; font-size: 15px; line-height: 1.6; }

.cw-card-points li {
	font-size: 14px;
	padding: 8px 0;
	border-top: 1px solid var(--cw-border);
}
.cw-card-points li:first-child { border-top: 0; padding-top: 6px; }
.cw-card-points li .cw-ic { width: 15px; height: 15px; flex: 0 0 15px; margin-top: 3px; color: var(--cw-green); }

/* ---------- Project cards: refined art block ---------- */

.cw-project-card .cw-project-art {
	height: 156px;
	margin: 0 -32px 24px;
}
.cw-project-card .cw-project-art::before { opacity: 0.95; }
.cw-project-card[data-tone="a"] .cw-project-art::before { background: linear-gradient(135deg, #7C3AED 0%, #5AC8FA 100%); }
.cw-project-card[data-tone="b"] .cw-project-art::before { background: linear-gradient(135deg, #0A84FF 0%, #63E6E2 100%); }
.cw-project-card[data-tone="c"] .cw-project-art::before { background: linear-gradient(135deg, #FF375F 0%, #FF9F0A 100%); }
.cw-project-card[data-tone="d"] .cw-project-art::before { background: linear-gradient(135deg, #30D158 0%, #63E6E2 100%); }
.cw-project-card .cw-project-art-icon {
	width: 52px; height: 52px;
	padding: 13px;
	border-radius: 14px;
	background: rgba(255,255,255,0.16);
	-webkit-backdrop-filter: blur(10px);
	backdrop-filter: blur(10px);
	border: 1px solid rgba(255,255,255,0.28);
	box-shadow: 0 1px 0 rgba(255,255,255,0.4) inset, 0 8px 20px -8px rgba(0,0,0,0.4);
}
.cw-project-card .cw-project-art-icon svg { width: 100%; height: 100%; stroke-width: 1.6; }

/* Project art status badge — small live indicator in corner */
.cw-project-card .cw-project-art::after {
	background:
		radial-gradient(circle at 85% 15%, rgba(255,255,255,0.50), transparent 45%),
		radial-gradient(circle at 15% 90%, rgba(0,0,0,0.45), transparent 60%);
}

/* ---------- Why-CarterWare feature row: cleaner cards ---------- */

.cw-feat {
	padding: clamp(28px, 3.2vw, 36px);
	border-radius: var(--cw-radius-xl);
}
.cw-feat .cw-ic-circ {
	width: 50px; height: 50px;
	border-radius: 15px;
}
.cw-feat .cw-ic-circ svg { width: 24px; height: 24px; stroke-width: 1.75; }
.cw-feat h4 { font-size: 19px; letter-spacing: -0.022em; margin-bottom: 10px; }
.cw-feat p { font-size: 15px; line-height: 1.55; }

/* ---------- Trust strip: bigger, calmer ---------- */

.cw-trust {
	padding: clamp(48px, 6vw, 84px) clamp(36px, 5vw, 72px);
	border-radius: var(--cw-radius-2xl);
}
.cw-trust .num {
	font-size: clamp(64px, 6.5vw, 104px);
	letter-spacing: -0.055em;
	font-weight: 700;
	background: var(--cw-grad-display);
	background-size: 240% 100%;
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	animation: cw-shimmer 12s ease-in-out infinite;
}
.cw-trust .label {
	font-size: 15px;
	max-width: 26ch;
	color: var(--cw-fg-muted);
	line-height: 1.5;
}
.cw-trust .item + .item::before {
	top: 18%;
	bottom: 18%;
	background: linear-gradient(to bottom,
		transparent,
		var(--cw-border-strong) 35%,
		var(--cw-border-strong) 65%,
		transparent);
}

/* ---------- Dark CTA: cleaner gradient, refined buttons ---------- */

.cw-cta {
	background: var(--cw-cta-bg-dark);
	padding: clamp(64px, 8vw, 112px) clamp(40px, 6vw, 96px);
	border-radius: var(--cw-radius-2xl);
	border: 1px solid rgba(255,255,255,0.06);
}
.cw-cta::before {
	background:
		radial-gradient(80% 60% at 15% 15%, rgba(167, 139, 250, 0.42) 0%, transparent 55%),
		radial-gradient(70% 55% at 85% 85%, rgba(90, 200, 250, 0.28) 0%, transparent 55%);
	filter: blur(50px);
	opacity: 0.95;
}
.cw-cta h2 {
	font-size: clamp(36px, 3.2vw + 16px, 72px);
	letter-spacing: -0.045em;
	max-width: 20ch;
	margin-bottom: 22px;
	line-height: 1.05;
}
.cw-cta p {
	font-size: clamp(17px, 0.4vw + 14px, 21px);
	max-width: 56ch;
	color: rgba(255,255,255,0.74);
	margin-bottom: 38px;
}
.cw-cta .cw-btn { padding: 16px 28px; font-size: 16px; }
.cw-cta .cw-btn-primary {
	background: #fff; color: #000;
	box-shadow:
		0 1px 0 rgba(255,255,255,0.5) inset,
		0 14px 36px -10px rgba(255,255,255,0.35);
}
.cw-cta .cw-btn-primary:hover {
	background: linear-gradient(120deg, #A78BFA, #5AC8FA);
	color: #fff;
}
.cw-cta .cw-eyebrow { color: rgba(255,255,255,0.6); }
.cw-cta .cw-eyebrow::before {
	background: linear-gradient(135deg, #A78BFA, #5AC8FA);
	box-shadow: 0 0 16px rgba(167, 139, 250, 0.7);
}

/* ---------- Footer: editorial sign-off ---------- */

.cw-footer {
	padding-top: clamp(64px, 8vw, 112px);
	padding-bottom: 40px;
}
.cw-footer-top { gap: clamp(40px, 6vw, 96px); }
.cw-footer-brand .cw-brand { font-size: 18px; }
.cw-footer-brand .cw-brand-mark { width: 36px; height: 36px; }
.cw-footer-brand p { font-size: 14.5px; margin-top: 18px; line-height: 1.6; }
.cw-footer-nav h4 {
	font-size: 11px;
	letter-spacing: 0.08em;
	margin-bottom: 20px;
	color: var(--cw-fg-subtle);
}
.cw-footer-nav li { margin-bottom: 11px; }
.cw-footer-nav a { font-size: 14px; color: var(--cw-fg-muted); }
.cw-footer-nav a:hover { color: var(--cw-fg); }
.cw-footer-bottom {
	font-size: 12.5px;
	color: var(--cw-fg-subtle);
	letter-spacing: -0.005em;
}
.cw-footer-tag { font-weight: 500; }
.cw-footer-tag .cw-grad-text {
	font-weight: 600;
	background: var(--cw-grad-display);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}

/* ---------- Service-card hover lifts a touch less, more refined ---------- */

.cw-card:hover {
	transform: translateY(-3px);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.4) inset,
		0 28px 60px -22px rgba(0,0,0,0.18);
}
:root[data-theme="dark"] .cw-card:hover,
:root.cw-dark .cw-card:hover {
	box-shadow:
		0 1px 0 rgba(255,255,255,0.06) inset,
		0 28px 60px -22px rgba(0,0,0,0.65),
		0 0 0 1px rgba(255,255,255,0.05);
}
@media (prefers-color-scheme: dark) {
	:root:not([data-theme="light"]) .cw-card:hover {
		box-shadow:
			0 1px 0 rgba(255,255,255,0.06) inset,
			0 28px 60px -22px rgba(0,0,0,0.65),
			0 0 0 1px rgba(255,255,255,0.05);
	}
}

/* ---------- Game cards: slightly more punch, refined tag ---------- */

.cw-game-card { min-height: 360px; border-radius: var(--cw-radius-2xl); }
.cw-game-card::before { opacity: 0.14; }
.cw-game-card h3 { font-size: clamp(30px, 2.5vw + 14px, 48px); letter-spacing: -0.038em; }
.cw-game-card p { font-size: 15.5px; line-height: 1.55; }

/* ---------- Body cleanup: subtle background depth in dark mode ---------- */

:root[data-theme="dark"] body,
:root.cw-dark body {
	background:
		radial-gradient(60% 40% at 50% 0%, rgba(122, 102, 250, 0.10), transparent 60%),
		var(--cw-bg);
}
@media (prefers-color-scheme: dark) {
	:root:not([data-theme="light"]) body {
		background:
			radial-gradient(60% 40% at 50% 0%, rgba(122, 102, 250, 0.10), transparent 60%),
			var(--cw-bg);
	}
}

/* ---------- "View Our Work" ghost CTA — slightly stronger border for legibility ---------- */

.cw-btn-ghost {
	border-width: 1.5px;
}

/* ---------- Inline link refinement ---------- */

.cw-inline-link {
	color: var(--cw-fg);
	border-bottom: 1px solid var(--cw-border-strong);
	font-size: 15px;
	font-weight: 500;
}
.cw-inline-link:hover { opacity: 1; color: var(--cw-violet); border-bottom-color: var(--cw-violet); }
:root[data-theme="dark"] .cw-inline-link:hover,
:root.cw-dark .cw-inline-link:hover { color: var(--cw-purple); border-bottom-color: var(--cw-purple); }

/* ---------- Mobile polish ---------- */

@media (max-width: 720px) {
	.cw-hero-inner h1 { font-size: clamp(40px, 11vw, 64px); letter-spacing: -0.04em; }
	.cw-hero-inner .lead { font-size: 16.5px; }
	.cw-feature-card { grid-template-columns: 1fr; padding: 28px; }
	.cw-feature-card h3 { font-size: clamp(26px, 7vw, 36px); }
	.cw-section-head h2 { font-size: clamp(30px, 8vw, 44px); }
	.cw-cta h2 { font-size: clamp(30px, 8vw, 44px); }
	.cw-trust .num { font-size: clamp(48px, 14vw, 80px); }
}
/* v7 polish layer end */

/* =====================================================================
   V8 POLISH LAYER — "Chief UI Designer" pass
   Goal: make every surface feel intentional, Apple-quality.
   Focus areas: hero rhythm, type weight, stat strip, why-cards,
   service cards, project art blocks, trust, dark CTA, footer.
   ===================================================================== */

/* ---------- Display gradient — softer, more editorial sweep ---------- */

:root {
	--cw-grad-display:
		linear-gradient(96deg,
			#8E7DFF 0%,
			#A78BFA 28%,
			#7CB8FF 62%,
			#67D4D9 100%);
}
:root[data-theme="dark"],
:root.cw-dark {
	--cw-grad-display:
		linear-gradient(96deg,
			#B8A6FF 0%,
			#C9B8FF 28%,
			#90D0FF 62%,
			#7FE8E8 100%);
}

/* ---------- Hero — tighter vertical rhythm, weightier ---------- */

.cw-hero {
	padding-top: clamp(56px, 9vh, 100px);
	padding-bottom: clamp(72px, 12vh, 132px);
}
.cw-hero-inner {
	max-width: 1080px;
}
.cw-hero-inner h1 {
	font-size: clamp(48px, 7.4vw, 104px);
	line-height: 0.96;
	letter-spacing: -0.045em;
	font-weight: 700;
	max-width: 16ch;
	margin-inline: auto;
}
.cw-hero-inner .lead {
	font-size: clamp(17px, 1.35vw, 21px);
	line-height: 1.55;
	color: var(--cw-fg-muted);
	max-width: 60ch;
	margin: 28px auto 36px;
	font-weight: 420;
}

/* CTAs — give them real weight */
.cw-hero-ctas, .cw-hero-cta { gap: 14px; margin-top: 8px; display: inline-flex; flex-wrap: wrap; justify-content: center; }
.cw-hero-ctas .cw-btn, .cw-hero-cta .cw-btn {
	padding: 16px 26px;
	font-size: 15.5px;
	font-weight: 600;
	letter-spacing: -0.005em;
	border-radius: 999px;
}
.cw-hero-ctas .cw-btn-primary, .cw-hero-cta .cw-btn-primary {
	background: linear-gradient(180deg, #1f1f23 0%, #0c0c0f 100%);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.08) inset,
		0 -1px 0 rgba(255,255,255,0.04) inset,
		0 14px 36px -14px rgba(0,0,0,0.55),
		0 2px 6px -2px rgba(0,0,0,0.25);
	color: #fff;
}
:root[data-theme="light"] .cw-hero-ctas .cw-btn-primary,
:root[data-theme="light"] .cw-hero-cta .cw-btn-primary,
:root:not(.cw-dark):not([data-theme="dark"]) .cw-hero-ctas .cw-btn-primary,
:root:not(.cw-dark):not([data-theme="dark"]) .cw-hero-cta .cw-btn-primary {
	background: linear-gradient(180deg, #1d1d1f 0%, #050505 100%);
	color: #fff;
}
.cw-hero-ctas .cw-btn-ghost, .cw-hero-cta .cw-btn-ghost {
	background: transparent;
	color: var(--cw-fg);
	border: 1.25px solid var(--cw-border-strong);
}
.cw-hero-ctas .cw-btn-ghost:hover, .cw-hero-cta .cw-btn-ghost:hover {
	background: rgba(0,0,0,0.04);
	border-color: rgba(0,0,0,0.22);
}
:root[data-theme="dark"] .cw-hero-ctas .cw-btn-ghost:hover,
:root[data-theme="dark"] .cw-hero-cta .cw-btn-ghost:hover,
:root.cw-dark .cw-hero-ctas .cw-btn-ghost:hover,
:root.cw-dark .cw-hero-cta .cw-btn-ghost:hover {
	background: rgba(255,255,255,0.06);
	border-color: rgba(255,255,255,0.30);
}

/* ---------- Ribbon — quieter, more polished ---------- */

.cw-ribbon {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 7px 14px 7px 7px;
	font-size: 13px;
	color: var(--cw-fg);
	background: var(--cw-bg-elevated);
	border: 1px solid var(--cw-border);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.5) inset,
		0 6px 16px -8px rgba(0,0,0,0.15);
}
:root[data-theme="dark"] .cw-ribbon,
:root.cw-dark .cw-ribbon {
	background: rgba(255,255,255,0.04);
	border-color: rgba(255,255,255,0.10);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.06) inset,
		0 6px 18px -8px rgba(0,0,0,0.6);
}
.cw-ribbon .cw-ribbon-tag,
.cw-ribbon .tag {
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: 4px 9px;
	border-radius: 999px;
	background: linear-gradient(135deg, var(--cw-purple), var(--cw-blue));
	color: #fff;
	box-shadow: 0 2px 8px -2px rgba(124,58,237,0.45);
}
.cw-ribbon .ar {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	border-radius: 999px;
	background: rgba(0,0,0,0.05);
	font-size: 12px;
	margin-left: 4px;
	transition: transform 0.3s cubic-bezier(0.2, 0.8, 0.2, 1), background 0.3s ease;
}
:root[data-theme="dark"] .cw-ribbon .ar,
:root.cw-dark .cw-ribbon .ar {
	background: rgba(255,255,255,0.08);
}
.cw-ribbon:hover .ar { transform: translateX(2px); background: rgba(124,58,237,0.18); color: var(--cw-violet); }

/* ---------- Hero stats — apple-style, weightier numerals ---------- */

.cw-hero-stats {
	margin-top: clamp(48px, 7vh, 84px);
	max-width: 980px;
	margin-inline: auto;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	padding: 22px 28px;
	border-radius: 22px;
	background: var(--cw-bg-elevated);
	border: 1px solid var(--cw-border);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.6) inset,
		0 24px 60px -32px rgba(0,0,0,0.18),
		0 6px 18px -10px rgba(0,0,0,0.10);
}
:root[data-theme="dark"] .cw-hero-stats,
:root.cw-dark .cw-hero-stats {
	background: rgba(255,255,255,0.025);
	border-color: rgba(255,255,255,0.08);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.05) inset,
		0 30px 70px -38px rgba(0,0,0,0.6),
		0 8px 24px -14px rgba(0,0,0,0.4);
	backdrop-filter: blur(20px) saturate(180%);
	-webkit-backdrop-filter: blur(20px) saturate(180%);
}
.cw-stat {
	padding: 8px 22px;
	border-right: 1px solid var(--cw-border);
	display: flex;
	flex-direction: column;
	gap: 6px;
	transition: transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.cw-stat:last-child { border-right: none; }
.cw-stat:hover { transform: translateY(-1px); }
.cw-stat .num {
	font-size: clamp(34px, 3.4vw, 48px);
	font-weight: 700;
	letter-spacing: -0.035em;
	line-height: 1;
	background: var(--cw-grad-display);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
}
.cw-stat .num sup {
	font-size: 0.5em;
	font-weight: 600;
	vertical-align: super;
	margin-left: 1px;
}
.cw-stat[data-tone="violet"] .num {
	background: linear-gradient(135deg, #B8A6FF 0%, #7C3AED 100%);
	-webkit-background-clip: text; background-clip: text;
	-webkit-text-fill-color: transparent; color: transparent;
}
.cw-stat[data-tone="blue"] .num {
	background: linear-gradient(135deg, #90D0FF 0%, #0071E3 100%);
	-webkit-background-clip: text; background-clip: text;
	-webkit-text-fill-color: transparent; color: transparent;
}
.cw-stat[data-tone="mint"] .num {
	background: linear-gradient(135deg, #7FE8C9 0%, #059669 100%);
	-webkit-background-clip: text; background-clip: text;
	-webkit-text-fill-color: transparent; color: transparent;
}
.cw-stat[data-tone="orange"] .num {
	background: linear-gradient(135deg, #FFB47A 0%, #EA580C 100%);
	-webkit-background-clip: text; background-clip: text;
	-webkit-text-fill-color: transparent; color: transparent;
}
.cw-stat .label {
	font-size: 12px;
	color: var(--cw-fg-muted);
	letter-spacing: -0.005em;
	line-height: 1.35;
	max-width: 22ch;
}

/* ---------- Section heads — quieter eyebrow, tighter type ---------- */

.cw-section-head { margin-bottom: clamp(40px, 5vw, 64px); }
.cw-section-head .eyebrow {
	display: inline-block;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--cw-fg-subtle);
	margin-bottom: 16px;
	padding: 6px 12px;
	border-radius: 999px;
	background: var(--cw-bg-soft);
	border: 1px solid var(--cw-border);
}
:root[data-theme="dark"] .cw-section-head .eyebrow,
:root.cw-dark .cw-section-head .eyebrow {
	background: rgba(255,255,255,0.03);
	color: var(--cw-fg-muted);
}
.cw-section-head h2 {
	font-size: clamp(36px, 4.4vw, 60px);
	letter-spacing: -0.035em;
	line-height: 1.04;
	font-weight: 700;
	max-width: 22ch;
	margin-inline: auto;
}
.cw-section-head p {
	font-size: clamp(16px, 1.2vw, 19px);
	line-height: 1.55;
	margin-top: 18px;
}

/* ---------- "Why CarterWare" — refined cards ---------- */

.cw-feat-row { gap: 18px; }
.cw-feat {
	padding: 32px 28px;
	border-radius: 22px;
	background: var(--cw-bg-elevated);
	border: 1px solid var(--cw-border);
	transition: transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 0.4s ease, border-color 0.3s ease;
	box-shadow:
		0 1px 0 rgba(255,255,255,0.5) inset,
		0 18px 40px -28px rgba(0,0,0,0.12);
}
:root[data-theme="dark"] .cw-feat,
:root.cw-dark .cw-feat {
	background: rgba(255,255,255,0.025);
	border-color: rgba(255,255,255,0.08);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.04) inset,
		0 20px 50px -28px rgba(0,0,0,0.5);
}
.cw-feat:hover {
	transform: translateY(-2px);
	border-color: var(--cw-border-strong);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.5) inset,
		0 28px 56px -28px rgba(0,0,0,0.16);
}
.cw-feat .cw-ic-circ {
	width: 44px;
	height: 44px;
	border-radius: 12px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 18px;
	background: linear-gradient(135deg, rgba(124,58,237,0.12), rgba(0,113,227,0.12));
	border: 1px solid rgba(124,58,237,0.18);
	color: var(--cw-violet);
	box-shadow: 0 6px 16px -8px rgba(124,58,237,0.25);
}
:root[data-theme="dark"] .cw-feat .cw-ic-circ,
:root.cw-dark .cw-feat .cw-ic-circ {
	background: linear-gradient(135deg, rgba(167,139,250,0.18), rgba(64,156,255,0.16));
	border-color: rgba(167,139,250,0.30);
	color: #C9B8FF;
}
.cw-feat .cw-ic-circ svg { width: 22px; height: 22px; }
.cw-feat h4 {
	font-size: 19px;
	font-weight: 600;
	letter-spacing: -0.012em;
	margin-bottom: 8px;
	color: var(--cw-fg);
}
.cw-feat p {
	font-size: 15px;
	line-height: 1.55;
	color: var(--cw-fg-muted);
	margin: 0;
}

/* ---------- About strip — refine 2-col ---------- */

.cw-about-strip {
	display: grid;
	grid-template-columns: minmax(0, 5fr) minmax(0, 6fr);
	gap: clamp(48px, 6vw, 96px);
	align-items: start;
}
.cw-about-strip .cw-eyebrow {
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--cw-fg-subtle);
	margin-bottom: 18px;
	display: block;
}
.cw-about-strip h2 {
	font-size: clamp(30px, 3.2vw, 44px);
	letter-spacing: -0.03em;
	line-height: 1.08;
	font-weight: 700;
	margin: 0;
	max-width: 16ch;
}
.cw-about-strip .cw-about-body p {
	font-size: clamp(16px, 1.18vw, 18px);
	line-height: 1.65;
	color: var(--cw-fg-muted);
	margin: 0 0 18px 0;
	max-width: 60ch;
}
.cw-about-strip .cw-about-body p:last-of-type { margin-bottom: 22px; }

/* ---------- Card-bg overlay (legacy) — neutralize so v8 surfaces show clean ---------- */

.cw-card .cw-card-bg { display: none; }
.cw-card { position: relative; }

/* ---------- Service cards — refined boxes, smaller icons, tighter list ---------- */

.cw-card {
	padding: 30px;
	border-radius: 22px;
	background: var(--cw-bg-elevated);
	border: 1px solid var(--cw-border);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.55) inset,
		0 18px 44px -30px rgba(0,0,0,0.14);
	transition: transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 0.4s ease, border-color 0.3s ease;
}
:root[data-theme="dark"] .cw-card,
:root.cw-dark .cw-card {
	background: rgba(255,255,255,0.025);
	border-color: rgba(255,255,255,0.08);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.04) inset,
		0 20px 56px -32px rgba(0,0,0,0.55);
}
.cw-card:hover {
	transform: translateY(-3px);
	border-color: var(--cw-border-strong);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.55) inset,
		0 32px 64px -28px rgba(0,0,0,0.18);
}
.cw-card-icon {
	width: 48px;
	height: 48px;
	border-radius: 14px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 20px;
	color: #fff;
	box-shadow:
		0 1px 0 rgba(255,255,255,0.18) inset,
		0 6px 16px -6px rgba(0,0,0,0.25);
}
.cw-card-icon svg { width: 22px; height: 22px; }
/* per-tone gradients on icon */
.cw-card[data-tone="violet"] .cw-card-icon { background: linear-gradient(135deg, #8B5CF6, #6D28D9); }
.cw-card[data-tone="blue"]   .cw-card-icon { background: linear-gradient(135deg, #60A5FA, #2563EB); }
.cw-card[data-tone="orange"] .cw-card-icon { background: linear-gradient(135deg, #FB923C, #EA580C); }
.cw-card[data-tone="mint"]   .cw-card-icon { background: linear-gradient(135deg, #34D399, #059669); }
.cw-card[data-tone="pink"]   .cw-card-icon { background: linear-gradient(135deg, #F472B6, #DB2777); }

.cw-card .cw-card-title,
.cw-card h3 {
	font-size: 21px;
	font-weight: 600;
	letter-spacing: -0.018em;
	margin: 0 0 8px 0;
	color: var(--cw-fg);
}
.cw-card .cw-card-desc {
	font-size: 14.5px;
	line-height: 1.6;
	color: var(--cw-fg-muted);
	margin: 0 0 18px 0;
}
.cw-card-points {
	list-style: none;
	margin: 0;
	padding: 0;
	border-top: 1px solid var(--cw-border);
}
.cw-card-points li {
	font-size: 14px;
	color: var(--cw-fg);
	padding: 12px 0;
	border-bottom: 1px solid var(--cw-border);
	display: flex;
	align-items: center;
	gap: 10px;
}
.cw-card-points li:last-child { border-bottom: none; }
.cw-card-points li > svg { display: none; }
.cw-card-points li::before {
	content: "";
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: currentColor;
	opacity: 0.4;
	flex: 0 0 4px;
}
.cw-card-points .cw-pt-label { color: var(--cw-fg); }

/* ---------- Project cards — refined art block ---------- */

.cw-project-card {
	padding: 24px;
	border-radius: 22px;
	background: var(--cw-bg-elevated);
	border: 1px solid var(--cw-border);
	transition: transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 0.4s ease, border-color 0.3s ease;
	box-shadow:
		0 1px 0 rgba(255,255,255,0.5) inset,
		0 16px 38px -28px rgba(0,0,0,0.13);
	position: relative;
	overflow: hidden;
}
:root[data-theme="dark"] .cw-project-card,
:root.cw-dark .cw-project-card {
	background: rgba(255,255,255,0.025);
	border-color: rgba(255,255,255,0.08);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.04) inset,
		0 20px 50px -32px rgba(0,0,0,0.5);
}
.cw-project-card:hover {
	transform: translateY(-3px);
	border-color: var(--cw-border-strong);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.5) inset,
		0 28px 56px -28px rgba(0,0,0,0.18);
}
.cw-project-card .cw-project-art {
	position: relative;
	height: 200px;
	border-radius: 16px;
	margin-bottom: 20px;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	background:
		radial-gradient(ellipse 80% 60% at 50% 110%, rgba(124,58,237,0.35), transparent 70%),
		linear-gradient(135deg, #1a1a25 0%, #0f0f17 100%);
	border: 1px solid rgba(255,255,255,0.06);
}
.cw-project-card[data-tone="violet"] .cw-project-art {
	background:
		radial-gradient(ellipse 80% 60% at 30% 100%, rgba(139,92,246,0.45), transparent 70%),
		radial-gradient(ellipse 60% 40% at 80% 0%, rgba(96,165,250,0.20), transparent 70%),
		linear-gradient(135deg, #1d1830 0%, #100a1d 100%);
}
.cw-project-card[data-tone="blue"] .cw-project-art {
	background:
		radial-gradient(ellipse 80% 60% at 30% 100%, rgba(96,165,250,0.45), transparent 70%),
		radial-gradient(ellipse 60% 40% at 80% 0%, rgba(52,211,153,0.16), transparent 70%),
		linear-gradient(135deg, #102137 0%, #060f1f 100%);
}
.cw-project-card[data-tone="orange"] .cw-project-art {
	background:
		radial-gradient(ellipse 80% 60% at 30% 100%, rgba(251,146,60,0.40), transparent 70%),
		radial-gradient(ellipse 60% 40% at 80% 0%, rgba(244,114,182,0.20), transparent 70%),
		linear-gradient(135deg, #2b1a0f 0%, #1a0d06 100%);
}
.cw-project-card[data-tone="mint"] .cw-project-art {
	background:
		radial-gradient(ellipse 80% 60% at 30% 100%, rgba(52,211,153,0.40), transparent 70%),
		radial-gradient(ellipse 60% 40% at 80% 0%, rgba(96,165,250,0.18), transparent 70%),
		linear-gradient(135deg, #0e251c 0%, #061410 100%);
}
.cw-project-card[data-tone="pink"] .cw-project-art {
	background:
		radial-gradient(ellipse 80% 60% at 30% 100%, rgba(244,114,182,0.42), transparent 70%),
		radial-gradient(ellipse 60% 40% at 80% 0%, rgba(167,139,250,0.20), transparent 70%),
		linear-gradient(135deg, #2a1224 0%, #170811 100%);
}
.cw-project-card .cw-project-art .cw-pa-icon {
	width: 56px;
	height: 56px;
	border-radius: 16px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: rgba(255,255,255,0.10);
	backdrop-filter: blur(14px) saturate(180%);
	-webkit-backdrop-filter: blur(14px) saturate(180%);
	border: 1px solid rgba(255,255,255,0.20);
	color: #fff;
	box-shadow:
		0 1px 0 rgba(255,255,255,0.25) inset,
		0 12px 28px -10px rgba(0,0,0,0.4);
}
.cw-project-card .cw-project-art .cw-pa-icon svg { width: 26px; height: 26px; }
.cw-project-card .cw-project-art .cw-pa-status {
	position: absolute;
	top: 14px;
	right: 14px;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.10em;
	text-transform: uppercase;
	padding: 5px 10px;
	border-radius: 999px;
	background: rgba(255,255,255,0.10);
	backdrop-filter: blur(10px) saturate(180%);
	-webkit-backdrop-filter: blur(10px) saturate(180%);
	border: 1px solid rgba(255,255,255,0.22);
	color: #fff;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.cw-project-card .cw-project-art .cw-pa-status::before {
	content: "";
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: #34D399;
	box-shadow: 0 0 0 2px rgba(52,211,153,0.25);
}
.cw-project-card .cw-project-art .cw-pa-status[data-state="dev"]::before { background: #FBBF24; box-shadow: 0 0 0 2px rgba(251,191,36,0.25); }
.cw-project-card .cw-project-art .cw-pa-status[data-state="concept"]::before { background: #A78BFA; box-shadow: 0 0 0 2px rgba(167,139,250,0.25); }

.cw-project-card .cw-project-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-bottom: 8px;
}
.cw-project-card .cw-project-head .cw-tag {
	margin: 0;
}
.cw-project-card .cw-card-title,
.cw-project-card h3 {
	font-size: 19px;
	font-weight: 600;
	letter-spacing: -0.012em;
	margin: 0 0 6px 0;
}
.cw-project-card .cw-card-desc,
.cw-project-card .cw-project-desc {
	font-size: 14px;
	line-height: 1.55;
	color: var(--cw-fg-muted);
	margin: 0 0 14px 0;
}
.cw-project-card .cw-tag {
	font-size: 11px;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	font-weight: 600;
	color: var(--cw-fg-muted);
}

/* ---------- Trust strip — refined ---------- */

.cw-trust {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 0;
	padding: clamp(40px, 5vw, 64px) clamp(28px, 4vw, 56px);
	border-radius: 28px;
	background: var(--cw-bg-elevated);
	border: 1px solid var(--cw-border);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.55) inset,
		0 24px 60px -32px rgba(0,0,0,0.16);
}
:root[data-theme="dark"] .cw-trust,
:root.cw-dark .cw-trust {
	background:
		radial-gradient(ellipse 60% 80% at 50% 0%, rgba(124,58,237,0.06), transparent 70%),
		rgba(255,255,255,0.02);
	border-color: rgba(255,255,255,0.08);
}
.cw-trust .cw-trust-item,
.cw-trust .item {
	padding: 0 clamp(16px, 2vw, 32px);
	border-right: 1px solid var(--cw-border);
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.cw-trust .cw-trust-item:last-child,
.cw-trust .item:last-child { border-right: none; }
.cw-trust .num {
	font-size: clamp(48px, 5.5vw, 80px);
	font-weight: 700;
	letter-spacing: -0.045em;
	line-height: 0.95;
	background: var(--cw-grad-display);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
}
.cw-trust .label {
	font-size: 13px;
	color: var(--cw-fg-muted);
	line-height: 1.45;
	max-width: 24ch;
}

/* ---------- Dark CTA — cleaner surface ---------- */

.cw-cta {
	position: relative;
	padding: clamp(56px, 8vw, 96px) clamp(32px, 5vw, 80px);
	border-radius: 32px;
	overflow: hidden;
	text-align: center;
	background:
		radial-gradient(ellipse 60% 80% at 50% 0%, rgba(124,58,237,0.30), transparent 70%),
		radial-gradient(ellipse 60% 80% at 50% 110%, rgba(0,113,227,0.20), transparent 70%),
		linear-gradient(180deg, #0a0a10 0%, #050508 100%);
	border: 1px solid rgba(255,255,255,0.08);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.06) inset,
		0 40px 90px -40px rgba(0,0,0,0.5);
	color: #fff;
}
.cw-cta::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
	background-size: 32px 32px;
	mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, #000 30%, transparent 70%);
	-webkit-mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, #000 30%, transparent 70%);
	pointer-events: none;
}
.cw-cta > * { position: relative; z-index: 1; }
.cw-cta h2 {
	font-size: clamp(36px, 4.8vw, 64px);
	letter-spacing: -0.035em;
	line-height: 1.05;
	font-weight: 700;
	margin: 0 auto 18px;
	max-width: 22ch;
}
.cw-cta p {
	font-size: clamp(15.5px, 1.2vw, 19px);
	line-height: 1.55;
	color: rgba(255,255,255,0.65);
	margin: 0 auto 32px;
	max-width: 56ch;
}
.cw-cta .cw-hero-ctas .cw-btn-primary,
.cw-cta .cw-hero-cta .cw-btn-primary,
.cw-cta .cw-btn-primary {
	background: #fff !important;
	color: #0a0a10 !important;
	padding: 16px 28px;
	font-size: 15.5px;
	font-weight: 600;
	border-radius: 999px;
	box-shadow:
		0 1px 0 rgba(255,255,255,0.5) inset,
		0 18px 40px -16px rgba(0,0,0,0.5);
}
.cw-cta .cw-hero-ctas .cw-btn-primary:hover,
.cw-cta .cw-hero-cta .cw-btn-primary:hover,
.cw-cta .cw-btn-primary:hover {
	background: #f5f5f7 !important;
	transform: translateY(-1px);
}
.cw-cta .cw-hero-ctas .cw-btn-ghost,
.cw-cta .cw-hero-cta .cw-btn-ghost {
	color: rgba(255,255,255,0.92);
	border-color: rgba(255,255,255,0.20);
}
.cw-cta .cw-hero-ctas .cw-btn-ghost:hover,
.cw-cta .cw-hero-cta .cw-btn-ghost:hover {
	background: rgba(255,255,255,0.08);
	border-color: rgba(255,255,255,0.35);
}

/* ---------- Featured card — refine panel mock ---------- */

.cw-feature-card {
	padding: clamp(32px, 4vw, 56px);
	border-radius: 32px;
	background: var(--cw-bg-elevated);
	border: 1px solid var(--cw-border);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.55) inset,
		0 28px 70px -36px rgba(0,0,0,0.16);
	display: grid;
	grid-template-columns: minmax(0, 5fr) minmax(0, 6fr);
	gap: clamp(32px, 4vw, 56px);
	align-items: center;
}
:root[data-theme="dark"] .cw-feature-card,
:root.cw-dark .cw-feature-card {
	background:
		radial-gradient(ellipse 60% 80% at 0% 100%, rgba(124,58,237,0.06), transparent 60%),
		rgba(255,255,255,0.025);
	border-color: rgba(255,255,255,0.08);
}
.cw-feature-card .cw-tag {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.10em;
	text-transform: uppercase;
	padding: 6px 12px;
	border-radius: 999px;
	background: rgba(52,211,153,0.10);
	border: 1px solid rgba(52,211,153,0.25);
	color: #10B981;
	margin-bottom: 18px;
}
.cw-feature-card .cw-tag::before {
	content: "";
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: #10B981;
	box-shadow: 0 0 0 3px rgba(16,185,129,0.18);
}
.cw-feature-card h3 {
	font-size: clamp(32px, 4vw, 52px);
	letter-spacing: -0.035em;
	line-height: 1.04;
	font-weight: 700;
	margin: 0 0 16px 0;
}
.cw-feature-card .cw-feature-desc {
	font-size: clamp(15.5px, 1.18vw, 18px);
	line-height: 1.55;
	color: var(--cw-fg-muted);
	margin: 0 0 24px 0;
	max-width: 50ch;
}
.cw-feature-meta {
	list-style: none;
	display: grid;
	grid-template-columns: repeat(3, auto);
	gap: 22px;
	margin: 0 0 24px 0;
	padding: 18px 0;
	border-top: 1px solid var(--cw-border);
	border-bottom: 1px solid var(--cw-border);
}
.cw-feature-meta li {
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 0;
}
.cw-feature-meta .k {
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.10em;
	text-transform: uppercase;
	color: var(--cw-fg-subtle);
}
.cw-feature-meta .v {
	font-size: 14px;
	font-weight: 500;
	color: var(--cw-fg);
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.cw-feature-meta .v .cw-status-dot {
	display: inline-block;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: #10B981;
	box-shadow: 0 0 0 3px rgba(16,185,129,0.18);
}

/* ---------- Footer — refined alignment & spacing ---------- */

.cw-footer {
	padding: clamp(64px, 7vw, 96px) 0 clamp(28px, 3vw, 40px);
	border-top: 1px solid var(--cw-border);
	background: var(--cw-bg-soft);
}
.cw-footer-grid,
.cw-footer-top {
	display: grid;
	grid-template-columns: minmax(0, 1.4fr) minmax(0, 2fr);
	gap: clamp(32px, 4vw, 80px);
	margin-bottom: clamp(40px, 5vw, 56px);
	align-items: start;
}
.cw-footer-nav {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: clamp(24px, 3vw, 48px);
}
.cw-footer .cw-brand--lg { font-size: 22px; letter-spacing: -0.012em; }
.cw-footer .cw-brand--lg .cw-brand-mark svg { width: 28px; height: 28px; }
.cw-footer-brand .cw-brand-mark { font-size: 22px; }
.cw-footer-brand p {
	font-size: 14px;
	line-height: 1.55;
	color: var(--cw-fg-muted);
	margin-top: 14px;
	max-width: 32ch;
}
.cw-footer h4 {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--cw-fg-subtle);
	margin: 0 0 16px 0;
}
.cw-footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.cw-footer ul a {
	font-size: 14px;
	color: var(--cw-fg-muted);
	text-decoration: none;
	transition: color 0.2s ease;
}
.cw-footer ul a:hover { color: var(--cw-fg); }
.cw-footer-bottom {
	padding-top: 24px;
	border-top: 1px solid var(--cw-border);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
	flex-wrap: wrap;
}
.cw-footer-bottom .cw-footer-copy {
	font-size: 12.5px;
	color: var(--cw-fg-subtle);
}
.cw-footer-bottom .cw-footer-tag {
	font-size: 12.5px;
	color: var(--cw-fg-muted);
}
.cw-footer-bottom .cw-footer-tag .cw-grad-text {
	font-weight: 600;
}

/* ---------- Nav — quieter scrolled state ---------- */

.cw-nav {
	transition: padding 0.3s cubic-bezier(0.2, 0.8, 0.2, 1), background 0.3s ease;
}
.cw-nav.cw-nav-scrolled .cw-nav-inner {
	background: rgba(251,251,253,0.78);
	border-color: rgba(0,0,0,0.07);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.6) inset,
		0 14px 36px -14px rgba(0,0,0,0.10);
	backdrop-filter: blur(28px) saturate(200%);
	-webkit-backdrop-filter: blur(28px) saturate(200%);
}
:root[data-theme="dark"] .cw-nav.cw-nav-scrolled .cw-nav-inner,
:root.cw-dark .cw-nav.cw-nav-scrolled .cw-nav-inner {
	background: rgba(10,10,15,0.72);
	border-color: rgba(255,255,255,0.07);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.04) inset,
		0 18px 40px -16px rgba(0,0,0,0.55);
}

/* ---------- Mobile fine-tuning for v8 ---------- */

@media (max-width: 980px) {
	.cw-hero-stats { grid-template-columns: repeat(2, 1fr); padding: 18px 18px; gap: 0; }
	.cw-hero-stats .cw-stat:nth-child(2) { border-right: none; }
	.cw-hero-stats .cw-stat { padding: 14px 18px; border-bottom: 1px solid var(--cw-border); }
	.cw-hero-stats .cw-stat:nth-last-child(-n+2) { border-bottom: none; }
	.cw-trust { grid-template-columns: repeat(2, 1fr); }
	.cw-trust .cw-trust-item { padding: 18px 16px; border-right: 1px solid var(--cw-border); border-bottom: 1px solid var(--cw-border); }
	.cw-trust .cw-trust-item:nth-child(2) { border-right: none; }
	.cw-trust .cw-trust-item:nth-last-child(-n+2) { border-bottom: none; }
	.cw-feature-card { grid-template-columns: 1fr; }
	.cw-about-strip { grid-template-columns: 1fr; gap: 24px; }
	.cw-footer-grid, .cw-footer-top { grid-template-columns: 1fr; }
	.cw-footer-nav { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 640px) {
	.cw-hero { padding-top: clamp(40px, 7vh, 64px); padding-bottom: clamp(48px, 9vh, 84px); }
	.cw-hero-inner h1 { font-size: clamp(44px, 11vw, 72px); }
	.cw-hero-inner .lead { font-size: 16px; }
	.cw-hero-cta { flex-direction: column; align-items: stretch; }
	.cw-hero-cta .cw-btn { width: 100%; justify-content: center; }
	.cw-footer-grid, .cw-footer-top { grid-template-columns: 1fr; }
	.cw-footer-nav { grid-template-columns: 1fr; gap: 24px; }
	.cw-trust { grid-template-columns: 1fr; }
	.cw-trust .cw-trust-item { padding: 20px 0; border-right: none; }
	.cw-trust .cw-trust-item:last-child { border-bottom: none; }
}

/* ---------- Reduced motion — respect user preference ---------- */

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
	.cw-hero-orb { animation: none !important; opacity: 0.3 !important; }
}

/* ---------- Contact form refinement ---------- */

.cw-contact-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
	gap: clamp(28px, 3vw, 44px);
	align-items: start;
}
@media (max-width: 980px) {
	.cw-contact-grid { grid-template-columns: 1fr; }
}

.cw-form {
	display: flex;
	flex-direction: column;
	gap: 18px;
	padding: clamp(28px, 3.2vw, 44px);
	border-radius: 26px;
	background: var(--cw-bg-elevated);
	border: 1px solid var(--cw-border);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.5) inset,
		0 22px 56px -32px rgba(0,0,0,0.14);
}
:root[data-theme="dark"] .cw-form,
:root.cw-dark .cw-form {
	background: rgba(255,255,255,0.025);
	border-color: rgba(255,255,255,0.08);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.04) inset,
		0 30px 70px -38px rgba(0,0,0,0.55);
}
.cw-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}
@media (max-width: 640px) {
	.cw-form-row { grid-template-columns: 1fr; }
}
.cw-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.cw-field label {
	font-size: 12.5px;
	font-weight: 500;
	letter-spacing: -0.005em;
	color: var(--cw-fg-muted);
	display: inline-flex;
	gap: 4px;
	align-items: center;
}
.cw-field label .req { color: var(--cw-violet); }
:root[data-theme="dark"] .cw-field label .req,
:root.cw-dark .cw-field label .req { color: var(--cw-purple); }
.cw-field input,
.cw-field textarea,
.cw-field select {
	font: inherit;
	font-size: 15px;
	color: var(--cw-fg);
	background: var(--cw-bg);
	border: 1px solid var(--cw-border);
	border-radius: 12px;
	padding: 12px 14px;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
	width: 100%;
}
.cw-field textarea {
	min-height: 130px;
	resize: vertical;
	line-height: 1.5;
}
.cw-field input:hover,
.cw-field textarea:hover,
.cw-field select:hover {
	border-color: var(--cw-border-strong);
}
.cw-field input:focus,
.cw-field textarea:focus,
.cw-field select:focus {
	outline: none;
	border-color: var(--cw-violet);
	box-shadow: 0 0 0 4px rgba(124,58,237,0.14);
	background: var(--cw-bg-elevated);
}
:root[data-theme="dark"] .cw-field input,
:root[data-theme="dark"] .cw-field textarea,
:root[data-theme="dark"] .cw-field select,
:root.cw-dark .cw-field input,
:root.cw-dark .cw-field textarea,
:root.cw-dark .cw-field select {
	background: rgba(0,0,0,0.35);
	border-color: rgba(255,255,255,0.10);
}
:root[data-theme="dark"] .cw-field input:focus,
:root[data-theme="dark"] .cw-field textarea:focus,
:root[data-theme="dark"] .cw-field select:focus,
:root.cw-dark .cw-field input:focus,
:root.cw-dark .cw-field textarea:focus,
:root.cw-dark .cw-field select:focus {
	border-color: var(--cw-purple);
	box-shadow: 0 0 0 4px rgba(167,139,250,0.18);
	background: rgba(255,255,255,0.04);
}
.cw-field select {
	appearance: none;
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	padding-right: 38px;
}

.cw-form .cw-form-status {
	font-size: 13.5px;
	color: var(--cw-fg-muted);
	min-height: 1.2em;
}
.cw-form .cw-form-status[data-state="success"] { color: #10B981; }
.cw-form .cw-form-status[data-state="error"]   { color: #F87171; }

.cw-form .cw-btn-primary {
	padding: 13px 22px;
	font-size: 14.5px;
	font-weight: 600;
	border-radius: 999px;
	background: linear-gradient(180deg, #1d1d1f 0%, #050505 100%);
	color: #fff;
	box-shadow:
		0 1px 0 rgba(255,255,255,0.08) inset,
		0 12px 30px -12px rgba(0,0,0,0.45);
}

/* ---------- Contact info cards ---------- */

.cw-contact-info {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.cw-contact-info a {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 16px 18px;
	border-radius: 16px;
	background: var(--cw-bg-elevated);
	border: 1px solid var(--cw-border);
	color: var(--cw-fg);
	text-decoration: none;
	transition: transform 0.3s cubic-bezier(0.2, 0.8, 0.2, 1), border-color 0.2s ease, box-shadow 0.3s ease;
	box-shadow:
		0 1px 0 rgba(255,255,255,0.5) inset,
		0 10px 26px -20px rgba(0,0,0,0.13);
}
:root[data-theme="dark"] .cw-contact-info a,
:root.cw-dark .cw-contact-info a {
	background: rgba(255,255,255,0.025);
	border-color: rgba(255,255,255,0.08);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.04) inset,
		0 14px 32px -24px rgba(0,0,0,0.5);
}
.cw-contact-info a:hover {
	transform: translateY(-1px);
	border-color: var(--cw-border-strong);
}
.cw-contact-info a .ic {
	width: 38px;
	height: 38px;
	border-radius: 11px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 38px;
	color: #fff;
	background: linear-gradient(135deg, #8B5CF6, #6D28D9);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.18) inset,
		0 4px 14px -4px rgba(124,58,237,0.35);
}
.cw-contact-info a:nth-child(2) .ic { background: linear-gradient(135deg, #60A5FA, #2563EB); box-shadow: 0 1px 0 rgba(255,255,255,0.18) inset, 0 4px 14px -4px rgba(37,99,235,0.35); }
.cw-contact-info a:nth-child(3) .ic { background: linear-gradient(135deg, #1f1f23, #0c0c0f); }
.cw-contact-info a:nth-child(4) .ic { background: linear-gradient(135deg, #F472B6, #DB2777); box-shadow: 0 1px 0 rgba(255,255,255,0.18) inset, 0 4px 14px -4px rgba(219,39,119,0.35); }
.cw-contact-info a .ic svg { width: 18px; height: 18px; }
.cw-contact-info a .label {
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.10em;
	text-transform: uppercase;
	color: var(--cw-fg-subtle);
	margin-bottom: 2px;
}
.cw-contact-info a .value {
	font-size: 14.5px;
	font-weight: 500;
	color: var(--cw-fg);
	letter-spacing: -0.005em;
}

/* ---------- About page founder block polish ---------- */

.cw-founder-mark {
	width: 100%;
	aspect-ratio: 1 / 1;
	border-radius: 28px;
	display: flex;
	align-items: center;
	justify-content: center;
	background:
		radial-gradient(circle at 30% 30%, rgba(255,255,255,0.4), transparent 50%),
		linear-gradient(135deg, #A78BFA 0%, #5AC8FA 60%, #30D158 100%);
	color: #fff;
	font-size: clamp(64px, 9vw, 128px);
	font-weight: 700;
	letter-spacing: -0.05em;
	font-family: var(--cw-font-sans);
	text-shadow: 0 4px 24px rgba(0,0,0,0.18);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.25) inset,
		0 30px 70px -28px rgba(124,58,237,0.40);
}

/* ---------- Process timeline polish (services page) ---------- */

.cw-process {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 18px;
	margin-top: 36px;
}
.cw-process .cw-step {
	padding: 28px;
	border-radius: 20px;
	background: var(--cw-bg-elevated);
	border: 1px solid var(--cw-border);
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 18px;
	grid-template-columns: none;
	box-shadow:
		0 1px 0 rgba(255,255,255,0.5) inset,
		0 16px 40px -28px rgba(0,0,0,0.13);
}
:root[data-theme="dark"] .cw-process .cw-step,
:root.cw-dark .cw-process .cw-step {
	background: rgba(255,255,255,0.025);
	border-color: rgba(255,255,255,0.08);
	box-shadow:
		0 1px 0 rgba(255,255,255,0.04) inset,
		0 20px 50px -32px rgba(0,0,0,0.5);
}
.cw-process .cw-step-num {
	font-size: 52px;
	font-weight: 700;
	letter-spacing: -0.045em;
	line-height: 1;
	background: linear-gradient(120deg, var(--cw-purple), var(--cw-blue));
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: transparent;
}
.cw-process .cw-step h4 {
	font-size: 17px;
	font-weight: 600;
	letter-spacing: -0.012em;
	margin: 0 0 6px 0;
	color: var(--cw-fg);
}
.cw-process .cw-step p {
	font-size: 14px;
	line-height: 1.55;
	color: var(--cw-fg-muted);
	margin: 0;
}

/* ---------- Compare panel (Best fits / Worst fits) ---------- */

.cw-compare {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px;
	margin-top: 28px;
}
@media (max-width: 720px) {
	.cw-compare { grid-template-columns: 1fr; }
}
.cw-compare-card {
	padding: 28px;
	border-radius: 22px;
	background: var(--cw-bg-elevated);
	border: 1px solid var(--cw-border);
}
:root[data-theme="dark"] .cw-compare-card,
:root.cw-dark .cw-compare-card {
	background: rgba(255,255,255,0.025);
	border-color: rgba(255,255,255,0.08);
}
.cw-compare-card.is-good,
.cw-compare-card.cw-good { border-color: rgba(16,185,129,0.30); }
.cw-compare-card.is-bad,
.cw-compare-card.cw-bad  { border-color: rgba(248,113,113,0.30); }
.cw-compare-card h4 {
	font-size: 17px;
	font-weight: 600;
	letter-spacing: -0.012em;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin: 0 0 16px 0;
	color: var(--cw-fg);
}
.cw-compare-card h4::before {
	content: "";
	width: 22px;
	height: 22px;
	border-radius: 50%;
	display: inline-block;
	background: linear-gradient(135deg, #34D399, #059669);
	box-shadow: 0 4px 12px -4px rgba(16,185,129,0.45);
}
.cw-compare-card.is-bad h4::before,
.cw-compare-card.cw-bad h4::before {
	background: linear-gradient(135deg, #FCA5A5, #DC2626);
	box-shadow: 0 4px 12px -4px rgba(220,38,38,0.45);
}
/* Hide the inline icon SVGs in the compare card heads (we use the dot prefix). */
.cw-compare-card h4 > svg { display: none; }
/* Tint the chip background in the head to subtly hint the category. */
.cw-compare-card.cw-good h4 { color: #047857; }
.cw-compare-card.cw-bad h4  { color: #B91C1C; }
:root[data-theme="dark"] .cw-compare-card.cw-good h4,
:root.cw-dark .cw-compare-card.cw-good h4 { color: #34D399; }
:root[data-theme="dark"] .cw-compare-card.cw-bad h4,
:root.cw-dark .cw-compare-card.cw-bad h4 { color: #FCA5A5; }
.cw-compare-card.cw-bad li {
	color: var(--cw-fg-muted);
	text-decoration: none;
}
.cw-compare-card ul {
	list-style: none;
	margin: 0;
	padding: 0;
	border-top: 1px solid var(--cw-border);
}
.cw-compare-card li {
	font-size: 14px;
	color: var(--cw-fg);
	padding: 12px 0;
	border-bottom: 1px solid var(--cw-border);
}
.cw-compare-card li:last-child { border-bottom: none; }

/* ---------- List row (for "Operating principles" on About) ---------- */

.cw-list-row {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 16px;
	margin-top: 28px;
}
.cw-list-row .cw-li-item {
	padding: 24px 22px;
	border-radius: 18px;
	background: var(--cw-bg-elevated);
	border: 1px solid var(--cw-border);
}
:root[data-theme="dark"] .cw-list-row .cw-li-item,
:root.cw-dark .cw-list-row .cw-li-item {
	background: rgba(255,255,255,0.025);
	border-color: rgba(255,255,255,0.08);
}
.cw-list-row .cw-li-item h4 {
	font-size: 16px;
	font-weight: 600;
	letter-spacing: -0.012em;
	margin: 0 0 6px 0;
	color: var(--cw-fg);
}
.cw-list-row .cw-li-item p {
	font-size: 14px;
	line-height: 1.55;
	color: var(--cw-fg-muted);
	margin: 0;
}

/* ---------- Founder tag chips ---------- */

.cw-founder-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 18px;
}
.cw-founder-tags .cw-chip {
	display: inline-flex;
	align-items: center;
	padding: 6px 12px;
	font-size: 12.5px;
	font-weight: 500;
	color: var(--cw-fg-muted);
	background: var(--cw-bg-soft);
	border: 1px solid var(--cw-border);
	border-radius: 999px;
}
:root[data-theme="dark"] .cw-founder-tags .cw-chip,
:root.cw-dark .cw-founder-tags .cw-chip {
	background: rgba(255,255,255,0.04);
	border-color: rgba(255,255,255,0.10);
}

/* ---------- Page-head polish (all non-home pages) ---------- */

.cw-eyebrow {
	display: inline-block;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--cw-fg-subtle);
	margin-bottom: 18px;
}
.cw-eyebrow::before {
	content: "";
	display: inline-block;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--cw-violet);
	margin-right: 8px;
	vertical-align: middle;
	box-shadow: 0 0 0 3px rgba(124,58,237,0.18);
}
:root[data-theme="dark"] .cw-eyebrow::before,
:root.cw-dark .cw-eyebrow::before {
	background: var(--cw-purple);
	box-shadow: 0 0 0 3px rgba(167,139,250,0.18);
}

/* v8 polish layer end */
