/* Group Starlight Web & Software Development page. All rules are module-scoped. */
html:has(body.starlight-service-page-active) {
	overflow-x: clip;
}

body.starlight-service-page-active {
	overflow-x: clip;
}

body.starlight-service-page-active .cs-site-content {
	padding-top: 0 !important;
	padding-bottom: 0 !important;
}

body.starlight-service-page-active .cs-read-next {
	padding-top: 0 !important;
}

.starlight-webdev-page {
	--swd-page: #f7f6fb;
	--swd-surface: #ffffff;
	--swd-surface-soft: #f0edf8;
	--swd-surface-accent: #eee9fb;
	--swd-text: #17131f;
	--swd-muted: #655f70;
	--swd-line: rgba(36, 24, 56, .12);
	--swd-accent: #7c3aed;
	--swd-accent-strong: #a855f7;
	--swd-accent-soft: #ede9fe;
	--swd-on-accent: #ffffff;
	--swd-hero:
		radial-gradient(circle at 76% 12%, rgba(139, 92, 246, .24), transparent 32%),
		radial-gradient(circle at 12% 85%, rgba(168, 85, 247, .11), transparent 30%),
		linear-gradient(145deg, #faf9ff 0%, #f2edff 55%, #ece6fb 100%);
	--swd-console: rgba(255, 255, 255, .78);
	--swd-console-inner: rgba(247, 244, 253, .92);
	--swd-shadow: 0 24px 70px rgba(50, 32, 82, .1);
	--swd-shadow-strong: 0 40px 110px rgba(53, 28, 98, .2);
	--swd-radius: 24px;
	position: relative;
	display: block;
	width: 100vw;
	max-width: 100vw;
	margin-right: calc(50% - 50vw);
	margin-left: calc(50% - 50vw);
	overflow: clip;
	font-family: Inter, Montserrat, Arial, sans-serif;
	font-size: 16px;
	line-height: 1.65;
	color: var(--swd-text);
	background: var(--swd-page);
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	isolation: isolate;
}

body[data-scheme="dark"] .starlight-webdev-page {
	--swd-page: #09060f;
	--swd-surface: #120d1c;
	--swd-surface-soft: #171020;
	--swd-surface-accent: #1b1129;
	--swd-text: #f6f2fb;
	--swd-muted: #aaa3b7;
	--swd-line: rgba(232, 222, 248, .13);
	--swd-accent: #9b6cff;
	--swd-accent-strong: #c067ff;
	--swd-accent-soft: rgba(155, 108, 255, .16);
	--swd-hero:
		radial-gradient(circle at 76% 12%, rgba(139, 92, 246, .26), transparent 34%),
		radial-gradient(circle at 12% 85%, rgba(168, 85, 247, .12), transparent 32%),
		linear-gradient(145deg, #080411 0%, #120721 55%, #1b0a33 100%);
	--swd-console: rgba(19, 12, 31, .86);
	--swd-console-inner: rgba(11, 7, 18, .74);
	--swd-shadow: 0 24px 70px rgba(0, 0, 0, .26);
	--swd-shadow-strong: 0 40px 110px rgba(0, 0, 0, .46);
}

@media (prefers-color-scheme: dark) {
	body[data-scheme="auto"] .starlight-webdev-page {
		--swd-page: #09060f;
		--swd-surface: #120d1c;
		--swd-surface-soft: #171020;
		--swd-surface-accent: #1b1129;
		--swd-text: #f6f2fb;
		--swd-muted: #aaa3b7;
		--swd-line: rgba(232, 222, 248, .13);
		--swd-accent: #9b6cff;
		--swd-accent-strong: #c067ff;
		--swd-accent-soft: rgba(155, 108, 255, .16);
		--swd-hero:
			radial-gradient(circle at 76% 12%, rgba(139, 92, 246, .26), transparent 34%),
			radial-gradient(circle at 12% 85%, rgba(168, 85, 247, .12), transparent 32%),
			linear-gradient(145deg, #080411 0%, #120721 55%, #1b0a33 100%);
		--swd-console: rgba(19, 12, 31, .86);
		--swd-console-inner: rgba(11, 7, 18, .74);
		--swd-shadow: 0 24px 70px rgba(0, 0, 0, .26);
		--swd-shadow-strong: 0 40px 110px rgba(0, 0, 0, .46);
	}
}

.starlight-webdev-page *,
.starlight-webdev-page *::before,
.starlight-webdev-page *::after {
	box-sizing: border-box;
}

.starlight-webdev-page h1,
.starlight-webdev-page h2,
.starlight-webdev-page h3,
.starlight-webdev-page p,
.starlight-webdev-page ul {
	padding: 0;
	margin: 0;
}

.starlight-webdev-page h1,
.starlight-webdev-page h2,
.starlight-webdev-page h3 {
	font-family: inherit;
	font-weight: 750;
	line-height: 1.06;
	color: var(--swd-text);
	text-transform: none;
	letter-spacing: -.045em;
}

.starlight-webdev-page h1 {
	max-width: 760px;
	font-size: clamp(52px, 5.2vw, 76px);
	text-wrap: balance;
}

.starlight-webdev-page h1 span {
	color: transparent;
	background: linear-gradient(135deg, #6d28d9 5%, #8b5cf6 48%, #d946ef 100%);
	-webkit-background-clip: text;
	background-clip: text;
}

body[data-scheme="dark"] .starlight-webdev-page h1 span {
	background-image: linear-gradient(135deg, #c4b5fd 0%, #a855f7 52%, #f0abfc 100%);
}

@media (prefers-color-scheme: dark) {
	body[data-scheme="auto"] .starlight-webdev-page h1 span {
		background-image: linear-gradient(135deg, #c4b5fd 0%, #a855f7 52%, #f0abfc 100%);
	}
}

.starlight-webdev-page h2 {
	max-width: 830px;
	font-size: clamp(38px, 4.25vw, 60px);
	text-wrap: balance;
}

.starlight-webdev-page h3 {
	font-size: 23px;
	letter-spacing: -.03em;
}

.starlight-webdev-page a {
	color: inherit;
	text-decoration: none;
}

.starlight-webdev-page ul {
	list-style: none;
}

.starlight-webdev-page button,
.starlight-webdev-page a {
	-webkit-tap-highlight-color: transparent;
}

.starlight-webdev-page__container {
	position: relative;
	z-index: 2;
	width: min(calc(100% - 48px), 1320px);
	margin-inline: auto;
}

.starlight-webdev-page__section {
	position: relative;
	padding: clamp(82px, 8vw, 120px) 0;
	background: var(--swd-page);
}

.starlight-webdev-page__section--accent {
	background:
		radial-gradient(circle at 88% 4%, rgba(139, 92, 246, .13), transparent 30%),
		var(--swd-surface-accent);
}

.starlight-webdev-page__section--soft {
	background: var(--swd-surface-soft);
}

.starlight-webdev-page__eyebrow {
	display: inline-flex;
	gap: 11px;
	align-items: center;
	margin-bottom: 20px;
	font-size: 12px;
	font-weight: 800;
	line-height: 1.2;
	color: var(--swd-accent);
	text-transform: uppercase;
	letter-spacing: .16em;
}

.starlight-webdev-page__eyebrow::before {
	width: 30px;
	height: 1px;
	content: "";
	background: currentColor;
}

.starlight-webdev-page__section-heading {
	max-width: 850px;
	margin-bottom: clamp(42px, 5vw, 64px);
}

.starlight-webdev-page__section-heading > p:last-child,
.starlight-webdev-page__final-grid > div > p {
	max-width: 720px;
	margin-top: 22px;
	font-size: clamp(17px, 1.45vw, 20px);
	line-height: 1.7;
	color: var(--swd-muted);
}

.starlight-webdev-page__section-heading--center {
	margin-right: auto;
	margin-left: auto;
	text-align: center;
}

.starlight-webdev-page__section-heading--center h2,
.starlight-webdev-page__section-heading--center > p:last-child {
	margin-right: auto;
	margin-left: auto;
}

.starlight-webdev-page__hero {
	position: relative;
	min-height: 760px;
	padding: clamp(86px, 8vw, 120px) 0 clamp(78px, 7vw, 104px);
	overflow: hidden;
	background: var(--swd-hero);
}

.starlight-webdev-page__ambient {
	position: absolute;
	inset: 0;
	opacity: .48;
	pointer-events: none;
	background:
		linear-gradient(var(--swd-line) 1px, transparent 1px),
		linear-gradient(90deg, var(--swd-line) 1px, transparent 1px),
		radial-gradient(circle, rgba(139, 92, 246, .38) 0 1px, transparent 1.5px);
	background-size: 80px 80px, 80px 80px, 40px 40px;
	mask-image: radial-gradient(circle at 60% 43%, #000 0%, transparent 76%);
}

.starlight-webdev-page__hero-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.04fr) minmax(430px, .96fr);
	gap: clamp(48px, 6vw, 86px);
	align-items: center;
}

.starlight-webdev-page__lead {
	max-width: 680px;
	margin-top: 26px;
	font-size: clamp(18px, 1.55vw, 21px);
	line-height: 1.68;
	color: var(--swd-muted);
}

.starlight-webdev-page__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 13px;
	align-items: center;
	margin-top: 34px;
}

.starlight-webdev-page .starlight-hero-growth__button {
	display: inline-flex;
	gap: 12px;
	align-items: center;
	justify-content: center;
	min-height: 54px;
	padding: 16px 24px;
	font-size: 15px;
	font-weight: 800;
	line-height: 1.15;
	white-space: nowrap;
	border: 1px solid transparent;
	border-radius: 999px;
	transition: transform .2s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease;
}

.starlight-webdev-page .starlight-hero-growth__button:hover {
	text-decoration: none;
	transform: translateY(-2px);
}

.starlight-webdev-page .starlight-hero-growth__button:focus-visible {
	outline: 3px solid rgba(139, 92, 246, .42);
	outline-offset: 4px;
}

.starlight-webdev-page .starlight-hero-growth__button--primary {
	color: #fff;
	background: linear-gradient(135deg, var(--swd-accent), var(--swd-accent-strong));
	border-color: rgba(255, 255, 255, .22);
	box-shadow: 0 18px 42px rgba(124, 58, 237, .25), inset 0 1px rgba(255, 255, 255, .28);
}

.starlight-webdev-page .starlight-hero-growth__button--primary:hover {
	color: #fff;
	box-shadow: 0 24px 54px rgba(124, 58, 237, .35), inset 0 1px rgba(255, 255, 255, .32);
}

.starlight-webdev-page .starlight-hero-growth__button--secondary {
	color: var(--swd-text);
	background: color-mix(in srgb, var(--swd-surface) 78%, transparent);
	border-color: var(--swd-line);
	box-shadow: 0 14px 34px rgba(24, 12, 42, .08);
	backdrop-filter: blur(14px);
}

.starlight-webdev-page .starlight-hero-growth__button--secondary:hover {
	color: var(--swd-text);
	background: var(--swd-surface);
	border-color: rgba(139, 92, 246, .35);
}

.starlight-webdev-page .starlight-webdev-page__trust {
	display: flex;
	flex-wrap: wrap;
	gap: 14px 22px;
	margin-top: 42px;
	font-size: 15px;
	font-weight: 700;
	line-height: 1.4;
	color: var(--swd-muted);
}

.starlight-webdev-page__trust li {
	display: flex;
	gap: 8px;
	align-items: center;
}

.starlight-webdev-page__trust li::before {
	width: 8px;
	height: 8px;
	content: "";
	background: var(--swd-accent);
	border-radius: 50%;
	box-shadow: 0 0 14px rgba(139, 92, 246, .62);
}

.starlight-webdev-page__delivery-console {
	position: relative;
	overflow: hidden;
	background: var(--swd-console);
	border: 1px solid var(--swd-line);
	border-radius: 28px;
	box-shadow: var(--swd-shadow-strong);
	backdrop-filter: blur(22px);
	transform: perspective(1200px) rotateY(-3deg) rotateX(1deg);
}

.starlight-webdev-page__delivery-console::before {
	position: absolute;
	inset: -30% -15% auto auto;
	width: 260px;
	height: 260px;
	content: "";
	pointer-events: none;
	background: rgba(139, 92, 246, .22);
	border-radius: 50%;
	filter: blur(60px);
}

.starlight-webdev-page__console-bar {
	display: flex;
	gap: 7px;
	align-items: center;
	height: 50px;
	padding: 0 18px;
	border-bottom: 1px solid var(--swd-line);
}

.starlight-webdev-page__console-bar > span {
	width: 8px;
	height: 8px;
	background: color-mix(in srgb, var(--swd-muted) 46%, transparent);
	border-radius: 50%;
}

.starlight-webdev-page__console-bar strong {
	margin-left: 9px;
	overflow: hidden;
	font-size: 12px;
	font-weight: 700;
	color: var(--swd-muted);
	text-overflow: ellipsis;
	letter-spacing: .07em;
	white-space: nowrap;
}

.starlight-webdev-page__console-bar small {
	padding: 5px 8px;
	margin-left: auto;
	font-size: 11px;
	font-weight: 800;
	color: #047857;
	text-transform: uppercase;
	letter-spacing: .08em;
	background: rgba(16, 185, 129, .13);
	border-radius: 999px;
}

body[data-scheme="dark"] .starlight-webdev-page__console-bar small {
	color: #6ee7b7;
}

.starlight-webdev-page__console-body {
	position: relative;
	display: grid;
	gap: 22px;
	padding: clamp(24px, 3vw, 36px);
}

.starlight-webdev-page__console-heading > div {
	display: flex;
	gap: 8px;
	align-items: center;
	font-size: 12px;
	font-weight: 800;
	color: var(--swd-accent);
	text-transform: uppercase;
	letter-spacing: .13em;
}

.starlight-webdev-page__console-heading > strong {
	display: block;
	max-width: 390px;
	margin-top: 11px;
	font-size: clamp(24px, 2.3vw, 34px);
	line-height: 1.13;
	letter-spacing: -.04em;
}

.starlight-webdev-page__pulse {
	width: 8px;
	height: 8px;
	background: #10b981;
	border-radius: 50%;
	box-shadow: 0 0 0 5px rgba(16, 185, 129, .12);
}

.starlight-webdev-page__console-flow {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
}

.starlight-webdev-page__console-flow article {
	position: relative;
	min-height: 106px;
	padding: 17px;
	background: var(--swd-console-inner);
	border: 1px solid var(--swd-line);
	border-radius: 16px;
}

.starlight-webdev-page__console-flow article::after {
	position: absolute;
	right: 15px;
	bottom: 15px;
	width: 28px;
	height: 4px;
	content: "";
	background: var(--swd-accent-soft);
	border-radius: 999px;
	box-shadow: -9px 0 0 var(--swd-accent-soft), -18px 0 0 var(--swd-accent-soft);
}

.starlight-webdev-page__console-flow span,
.starlight-webdev-page__card-number {
	display: block;
	font-size: 11px;
	font-weight: 850;
	color: var(--swd-accent);
	letter-spacing: .08em;
}

.starlight-webdev-page__console-flow strong {
	display: block;
	margin-top: 10px;
	font-size: 15px;
}

.starlight-webdev-page__console-flow small {
	display: block;
	margin-top: 3px;
	font-size: 13px;
	color: var(--swd-muted);
}

.starlight-webdev-page__console-result {
	padding: 18px;
	background: linear-gradient(135deg, color-mix(in srgb, var(--swd-accent) 14%, var(--swd-surface)), var(--swd-console-inner));
	border: 1px solid color-mix(in srgb, var(--swd-accent) 28%, var(--swd-line));
	border-radius: 17px;
}

.starlight-webdev-page__console-result > div:first-child {
	display: flex;
	gap: 14px;
	align-items: center;
	justify-content: space-between;
}

.starlight-webdev-page__console-result span,
.starlight-webdev-page__console-result small {
	font-size: 13px;
	font-weight: 650;
	color: color-mix(in srgb, var(--swd-text) 72%, transparent);
}

.starlight-webdev-page__console-result strong {
	font-size: 14px;
}

.starlight-webdev-page__progress {
	height: 7px;
	margin: 14px 0 9px;
	overflow: hidden;
	background: var(--swd-line);
	border-radius: 999px;
}

.starlight-webdev-page__progress span {
	display: block;
	width: 88%;
	height: 100%;
	background: linear-gradient(90deg, var(--swd-accent), var(--swd-accent-strong));
	border-radius: inherit;
}

.starlight-webdev-page__service-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 18px;
}

.starlight-webdev-page__service-card {
	position: relative;
	min-height: 360px;
	padding: 30px 27px;
	overflow: hidden;
	background: var(--swd-surface);
	border: 1px solid var(--swd-line);
	border-radius: var(--swd-radius);
	box-shadow: var(--swd-shadow);
}

.starlight-webdev-page__service-card::before {
	position: absolute;
	top: -70px;
	right: -70px;
	width: 150px;
	height: 150px;
	content: "";
	background: var(--swd-accent-soft);
	border-radius: 50%;
	transition: transform .3s ease;
}

.starlight-webdev-page__service-card:hover::before {
	transform: scale(1.18);
}

.starlight-webdev-page__service-card h3 {
	margin-top: 52px;
}

.starlight-webdev-page__service-card > p {
	margin-top: 14px;
	font-size: 15px;
	line-height: 1.68;
	color: var(--swd-muted);
}

.starlight-webdev-page__service-card ul {
	display: grid;
	gap: 9px;
	margin-top: 24px;
}

.starlight-webdev-page__service-card li,
.starlight-webdev-page__delivery-card li {
	display: flex;
	gap: 9px;
	align-items: flex-start;
	font-size: 13px;
	font-weight: 700;
	color: var(--swd-text);
}

.starlight-webdev-page__service-card li::before,
.starlight-webdev-page__delivery-card li::before {
	display: grid;
	width: 18px;
	height: 18px;
	font-size: 10px;
	color: var(--swd-accent);
	content: "\2713";
	background: var(--swd-accent-soft);
	border-radius: 50%;
	place-items: center;
	flex: 0 0 auto;
}

.starlight-webdev-page__fit-strip {
	display: flex;
	gap: 24px;
	align-items: center;
	padding: 22px 24px;
	margin-top: 20px;
	background: var(--swd-surface-soft);
	border: 1px solid var(--swd-line);
	border-radius: 18px;
}

.starlight-webdev-page__fit-strip > strong {
	font-size: 12px;
	color: var(--swd-accent);
	text-transform: uppercase;
	letter-spacing: .12em;
	white-space: nowrap;
}

.starlight-webdev-page__fit-strip > div {
	display: flex;
	flex-wrap: wrap;
	gap: 9px;
}

.starlight-webdev-page__fit-strip span,
.starlight-webdev-page__pills span {
	padding: 8px 11px;
	font-size: 12px;
	font-weight: 700;
	color: var(--swd-muted);
	background: var(--swd-surface);
	border: 1px solid var(--swd-line);
	border-radius: 999px;
}

.starlight-webdev-page__outcomes-layout {
	display: grid;
	grid-template-columns: minmax(0, .88fr) minmax(440px, 1.12fr);
	gap: clamp(55px, 8vw, 110px);
	align-items: start;
}

.starlight-webdev-page__outcomes-layout .starlight-webdev-page__section-heading {
	position: sticky;
	top: 120px;
	margin-bottom: 0;
}

.starlight-webdev-page__outcome-grid {
	display: grid;
	gap: 12px;
}

.starlight-webdev-page__outcome-grid article {
	display: grid;
	grid-template-columns: 48px minmax(0, 1fr);
	gap: 20px;
	padding: 27px;
	background: color-mix(in srgb, var(--swd-surface) 84%, transparent);
	border: 1px solid var(--swd-line);
	border-radius: 20px;
	box-shadow: 0 16px 42px rgba(39, 21, 70, .06);
	backdrop-filter: blur(12px);
}

.starlight-webdev-page__outcome-grid article > span,
.starlight-webdev-page__steps article > span,
.starlight-webdev-page__foundation-grid article > span {
	display: grid;
	width: 44px;
	height: 44px;
	font-size: 11px;
	font-weight: 850;
	color: var(--swd-accent);
	background: var(--swd-accent-soft);
	border-radius: 13px;
	place-items: center;
}

.starlight-webdev-page__outcome-grid h3 {
	font-size: 21px;
}

.starlight-webdev-page__outcome-grid p {
	margin-top: 8px;
	font-size: 14px;
	line-height: 1.7;
	color: var(--swd-muted);
}

.starlight-webdev-page__process-layout {
	display: grid;
	grid-template-columns: minmax(0, 1.18fr) minmax(360px, .72fr);
	gap: clamp(58px, 8vw, 110px);
	align-items: start;
}

.starlight-webdev-page__steps {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	border-top: 1px solid var(--swd-line);
	border-left: 1px solid var(--swd-line);
}

.starlight-webdev-page__steps article {
	display: grid;
	grid-template-columns: 44px minmax(0, 1fr);
	gap: 17px;
	min-height: 220px;
	padding: 28px 26px;
	border-right: 1px solid var(--swd-line);
	border-bottom: 1px solid var(--swd-line);
}

.starlight-webdev-page__steps h3 {
	font-size: 20px;
}

.starlight-webdev-page__steps p {
	margin-top: 8px;
	font-size: 14px;
	line-height: 1.68;
	color: var(--swd-muted);
}

.starlight-webdev-page__delivery-card {
	position: sticky;
	top: 110px;
	padding: 34px;
	background:
		radial-gradient(circle at 95% 0%, rgba(168, 85, 247, .18), transparent 34%),
		var(--swd-surface);
	border: 1px solid var(--swd-line);
	border-radius: 26px;
	box-shadow: var(--swd-shadow);
}

.starlight-webdev-page__delivery-card .starlight-webdev-page__eyebrow {
	margin-bottom: 16px;
}

.starlight-webdev-page__delivery-card h3 {
	font-size: 28px;
}

.starlight-webdev-page__delivery-card ul {
	display: grid;
	gap: 13px;
	margin-top: 27px;
}

.starlight-webdev-page__delivery-card > a {
	display: flex;
	gap: 12px;
	align-items: center;
	justify-content: space-between;
	padding: 17px 19px;
	margin-top: 30px;
	font-size: 13px;
	font-weight: 800;
	color: #fff;
	background: linear-gradient(135deg, var(--swd-accent), var(--swd-accent-strong));
	border-radius: 14px;
}

.starlight-webdev-page__foundation-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.starlight-webdev-page__foundation-grid article {
	min-height: 270px;
	padding: 30px;
	background: var(--swd-surface);
	border: 1px solid var(--swd-line);
	border-radius: var(--swd-radius);
	box-shadow: var(--swd-shadow);
}

.starlight-webdev-page__foundation-grid h3 {
	margin-top: 42px;
	font-size: 27px;
}

.starlight-webdev-page__foundation-grid p {
	margin-top: 13px;
	font-size: 15px;
	line-height: 1.7;
	color: var(--swd-muted);
}

.starlight-webdev-page__pills {
	display: flex;
	flex-wrap: wrap;
	gap: 9px;
	justify-content: center;
	max-width: 980px;
	margin: 34px auto 0;
}

.starlight-webdev-page__faq-section {
	padding-bottom: 0;
}

.starlight-webdev-page__faq-grid {
	display: grid;
	grid-template-columns: minmax(300px, .72fr) minmax(0, 1.28fr);
	gap: clamp(55px, 8vw, 110px);
	align-items: start;
}

.starlight-webdev-page__faq-grid .starlight-webdev-page__section-heading {
	position: sticky;
	top: 110px;
	margin-bottom: 0;
}

.starlight-webdev-page__accordion {
	display: grid;
	gap: 14px;
}

.starlight-webdev-page__faq-item {
	padding-bottom: 14px;
	border-bottom: 1px solid var(--swd-line);
}

.starlight-webdev-page__faq-item h3 {
	font-size: inherit;
	letter-spacing: 0;
}

.starlight-webdev-page__faq-item button {
	display: flex;
	gap: 20px;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	padding: 22px 24px;
	font: inherit;
	font-size: 19px;
	font-weight: 800;
	line-height: 1.4;
	color: var(--swd-text);
	text-align: left;
	cursor: pointer;
	background:
		linear-gradient(145deg, color-mix(in srgb, var(--swd-surface) 92%, #ffffff 8%), var(--swd-surface));
	border: 1px solid var(--swd-line);
	border-radius: 18px;
	box-shadow: 0 14px 36px rgba(20, 10, 38, .08);
	transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.starlight-webdev-page__faq-item.is-open button {
	border-color: color-mix(in srgb, var(--swd-accent) 48%, var(--swd-line));
	box-shadow: 0 18px 46px rgba(91, 47, 150, .13);
}

.starlight-webdev-page__faq-item button:focus-visible {
	outline: 3px solid rgba(139, 92, 246, .34);
	outline-offset: 5px;
}

.starlight-webdev-page__faq-icon {
	position: relative;
	width: 34px;
	height: 34px;
	background: var(--swd-accent-soft);
	border-radius: 50%;
	flex: 0 0 auto;
}

.starlight-webdev-page__faq-icon::before,
.starlight-webdev-page__faq-icon::after {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 13px;
	height: 2px;
	content: "";
	background: var(--swd-accent);
	transform: translate(-50%, -50%);
	transition: transform .2s ease;
}

.starlight-webdev-page__faq-icon::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.starlight-webdev-page__faq-item.is-open .starlight-webdev-page__faq-icon::after {
	transform: translate(-50%, -50%) rotate(0deg);
}

.starlight-webdev-page__faq-panel {
	padding: 18px 24px 10px;
}

.starlight-webdev-page__faq-panel p {
	font-size: 16px;
	line-height: 1.72;
	color: var(--swd-muted);
}

.starlight-webdev-page__faq-panel[hidden] {
	display: none;
}

.starlight-webdev-page__final-cta {
	position: relative;
	padding: clamp(84px, 9vw, 128px) 0;
	margin-top: clamp(82px, 8vw, 118px);
	overflow: hidden;
	color: #fff;
	background:
		radial-gradient(circle at 82% 20%, rgba(168, 85, 247, .3), transparent 32%),
		radial-gradient(circle at 5% 90%, rgba(124, 58, 237, .2), transparent 30%),
		linear-gradient(145deg, #080311 0%, #140627 54%, #220c3f 100%);
}

.starlight-webdev-page__final-cta::before {
	position: absolute;
	inset: 0;
	content: "";
	pointer-events: none;
	background:
		linear-gradient(rgba(255, 255, 255, .05) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, .05) 1px, transparent 1px);
	background-size: 72px 72px;
	mask-image: radial-gradient(circle at 50% 50%, #000, transparent 78%);
}

.starlight-webdev-page__final-grid {
	max-width: 920px;
	text-align: center;
}

.starlight-webdev-page__final-grid h2 {
	margin-inline: auto;
	color: #fff !important;
}

.starlight-webdev-page__final-grid > div > p {
	margin-right: auto;
	margin-left: auto;
	color: rgba(255, 255, 255, .7) !important;
}

.starlight-webdev-page__final-grid .starlight-webdev-page__eyebrow {
	color: #c4b5fd !important;
}

.starlight-webdev-page__final-grid .starlight-webdev-page__actions {
	justify-content: center;
}

.starlight-webdev-page__final-grid .starlight-hero-growth__button--secondary {
	color: #fff;
	background: rgba(255, 255, 255, .08);
	border-color: rgba(255, 255, 255, .17);
}

.starlight-webdev-page__final-grid--form {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(370px, .76fr);
	gap: clamp(42px, 7vw, 82px);
	align-items: center;
	max-width: 1200px;
	text-align: left;
}

.starlight-webdev-page__final-grid--form h2,
.starlight-webdev-page__final-grid--form > div > p {
	margin-left: 0;
}

.starlight-webdev-page__final-grid--form .starlight-webdev-page__actions {
	justify-content: flex-start;
}

.starlight-webdev-page__form-card {
	padding: clamp(27px, 4vw, 40px);
	color: #17131f;
	text-align: left;
	background: #fff;
	border: 1px solid rgba(255, 255, 255, .35);
	border-radius: 26px;
	box-shadow: 0 30px 80px rgba(0, 0, 0, .32);
}

.starlight-webdev-page__form-card > p {
	margin-top: 12px;
	font-size: 14px;
	color: #655f70;
}

.starlight-webdev-page .starlight-webdev-page__form-card h3 {
	color: #17131f;
}

.starlight-webdev-page__form-card .wpforms-container {
	margin: 24px 0 0;
}

.starlight-webdev-page__form-card input[type="text"],
.starlight-webdev-page__form-card input[type="email"],
.starlight-webdev-page__form-card input[type="tel"],
.starlight-webdev-page__form-card textarea,
.starlight-webdev-page__form-card select {
	width: 100%;
	color: #17131f;
	background: #f8f7fc;
	border: 1px solid #dcd7e7;
	border-radius: 10px;
}

.starlight-webdev-page__form-card button[type="submit"] {
	min-height: 50px;
	padding: 14px 22px;
	font-weight: 800;
	color: #fff;
	background: linear-gradient(135deg, #7c3aed, #a855f7);
	border: 0;
	border-radius: 999px;
}

body.starlight-service-page-active #pum-1278.pum-overlay {
	background: rgba(6, 0, 24, .72) !important;
	backdrop-filter: blur(12px);
}

body.starlight-service-page-active #popmake-1278.pum-container {
	box-sizing: border-box;
	width: min(calc(100vw - 32px), 640px) !important;
	max-width: calc(100vw - 32px) !important;
	height: auto !important;
	min-height: 0 !important;
	max-height: calc(100vh - 48px) !important;
	padding: clamp(24px, 4vw, 36px) !important;
	overflow-y: auto !important;
	color: #ffffff;
	background:
		radial-gradient(circle at 78% 12%, rgba(139, 92, 246, .30), transparent 34%),
		radial-gradient(circle at 10% 86%, rgba(168, 85, 247, .18), transparent 38%),
		linear-gradient(145deg, rgba(255, 255, 255, .12), rgba(255, 255, 255, .06)) !important;
	border: 1px solid rgba(255, 255, 255, .16) !important;
	border-radius: 28px !important;
	box-shadow: 0 34px 100px rgba(0, 0, 0, .48), 0 0 80px rgba(139, 92, 246, .24) !important;
	backdrop-filter: blur(22px);
}

body.starlight-service-page-active #popmake-1278 .pum-content,
body.starlight-service-page-active #popmake-1278 .wpforms-container,
body.starlight-service-page-active #popmake-1278 .wpforms-form {
	margin: 0 !important;
	color: #ffffff;
}

body.starlight-service-page-active #popmake-1278 .wpforms-field {
	padding: 0 0 17px !important;
}

body.starlight-service-page-active #popmake-1278 .wpforms-field-label {
	margin: 0 0 8px !important;
	font-size: 15px !important;
	font-weight: 750 !important;
	line-height: 1.35 !important;
	color: #ffffff !important;
}

body.starlight-service-page-active #popmake-1278 .wpforms-required-label {
	color: #c084fc !important;
}

body.starlight-service-page-active #popmake-1278 input[type="text"],
body.starlight-service-page-active #popmake-1278 input[type="email"],
body.starlight-service-page-active #popmake-1278 input[type="tel"],
body.starlight-service-page-active #popmake-1278 textarea {
	width: 100% !important;
	max-width: 100% !important;
	font-size: 16px !important;
	color: #ffffff !important;
	background: rgba(255, 255, 255, .08) !important;
	border: 1px solid rgba(255, 255, 255, .16) !important;
	border-radius: 16px !important;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, .08) !important;
	transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

body.starlight-service-page-active #popmake-1278 input[type="text"],
body.starlight-service-page-active #popmake-1278 input[type="email"],
body.starlight-service-page-active #popmake-1278 input[type="tel"] {
	min-height: 50px !important;
	padding: 12px 14px !important;
}

body.starlight-service-page-active #popmake-1278 textarea {
	min-height: 132px !important;
	padding: 14px !important;
	resize: vertical;
}

body.starlight-service-page-active #popmake-1278 input[type="text"]:focus,
body.starlight-service-page-active #popmake-1278 input[type="email"]:focus,
body.starlight-service-page-active #popmake-1278 input[type="tel"]:focus,
body.starlight-service-page-active #popmake-1278 textarea:focus {
	background: rgba(255, 255, 255, .11) !important;
	border-color: rgba(168, 85, 247, .72) !important;
	box-shadow: 0 0 0 3px rgba(139, 92, 246, .22) !important;
	outline: none !important;
}

body.starlight-service-page-active #popmake-1278 .wpforms-submit-container {
	padding: 4px 0 0 !important;
}

body.starlight-service-page-active #popmake-1278 button.wpforms-submit {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	min-height: 50px !important;
	padding: 13px 26px !important;
	font-size: 15px !important;
	font-weight: 800 !important;
	line-height: 1.2 !important;
	color: #ffffff !important;
	background: linear-gradient(135deg, #8b5cf6, #a855f7) !important;
	border: 0 !important;
	border-radius: 999px !important;
	box-shadow: 0 18px 42px rgba(124, 58, 237, .34) !important;
	transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
}

body.starlight-service-page-active #popmake-1278 button.wpforms-submit:hover,
body.starlight-service-page-active #popmake-1278 button.wpforms-submit:focus,
body.starlight-service-page-active #popmake-1278 button.wpforms-submit:focus-visible {
	color: #ffffff !important;
	box-shadow: 0 22px 52px rgba(124, 58, 237, .42) !important;
	filter: brightness(1.05);
	transform: translateY(-1px);
	outline: none !important;
}

body.starlight-service-page-active #popmake-1278 .wpforms-error,
body.starlight-service-page-active #popmake-1278 em.wpforms-error {
	color: #fca5a5 !important;
}

body.starlight-service-page-active #popmake-1278 .pum-close {
	top: 12px !important;
	right: 12px !important;
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	width: 38px !important;
	height: 38px !important;
	padding: 0 !important;
	font-size: 24px !important;
	line-height: 1 !important;
	color: #ffffff !important;
	background: rgba(255, 255, 255, .10) !important;
	border: 1px solid rgba(255, 255, 255, .16) !important;
	border-radius: 999px !important;
	box-shadow: none !important;
}

body.starlight-service-page-active #popmake-1278 .pum-close:hover,
body.starlight-service-page-active #popmake-1278 .pum-close:focus-visible {
	color: #ffffff !important;
	background: rgba(168, 85, 247, .24) !important;
	outline: 2px solid rgba(168, 85, 247, .58);
	outline-offset: 2px;
}

@media (max-width: 1100px) {
	.starlight-webdev-page__hero-grid {
		grid-template-columns: minmax(0, 1fr) minmax(380px, .86fr);
		gap: 42px;
	}

	.starlight-webdev-page__service-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.starlight-webdev-page__service-card {
		min-height: 320px;
	}
}

@media (max-width: 960px) {
	.starlight-webdev-page__hero {
		min-height: 0;
	}

	.starlight-webdev-page__hero-grid,
	.starlight-webdev-page__outcomes-layout,
	.starlight-webdev-page__process-layout,
	.starlight-webdev-page__faq-grid,
	.starlight-webdev-page__final-grid--form {
		grid-template-columns: 1fr;
	}

	.starlight-webdev-page__hero-copy {
		max-width: 760px;
	}

	.starlight-webdev-page__delivery-console {
		width: min(100%, 680px);
		margin-inline: auto;
		transform: none;
	}

	.starlight-webdev-page__outcomes-layout .starlight-webdev-page__section-heading,
	.starlight-webdev-page__delivery-card,
	.starlight-webdev-page__faq-grid .starlight-webdev-page__section-heading {
		position: relative;
		top: auto;
	}

	.starlight-webdev-page__outcomes-layout .starlight-webdev-page__section-heading,
	.starlight-webdev-page__faq-grid .starlight-webdev-page__section-heading {
		margin-bottom: 0;
	}

	.starlight-webdev-page__delivery-card {
		max-width: 680px;
	}

	.starlight-webdev-page__final-grid--form {
		max-width: 720px;
	}
}

@media (max-width: 680px) {
	.starlight-webdev-page__container {
		width: min(calc(100% - 32px), 1320px);
	}

	.starlight-webdev-page__section {
		padding: 74px 0;
	}

	.starlight-webdev-page__hero {
		padding: 70px 0 76px;
	}

	.starlight-webdev-page h1 {
		font-size: clamp(42px, 12vw, 54px);
		line-height: 1.02;
	}

	.starlight-webdev-page h2 {
		font-size: clamp(34px, 10vw, 44px);
	}

	.starlight-webdev-page__lead {
		font-size: 17px;
	}

	.starlight-webdev-page__actions {
		align-items: stretch;
	}

	.starlight-webdev-page .starlight-hero-growth__button {
		width: 100%;
		white-space: normal;
	}

	.starlight-webdev-page .starlight-webdev-page__trust {
		display: grid;
		grid-template-columns: 1fr;
		gap: 13px;
		margin-top: 36px;
	}

	.starlight-webdev-page__console-body {
		padding: 20px;
	}

	.starlight-webdev-page__console-heading > strong {
		font-size: 25px;
	}

	.starlight-webdev-page__console-flow {
		grid-template-columns: 1fr;
	}

	.starlight-webdev-page__console-flow article {
		min-height: 92px;
	}

	.starlight-webdev-page__service-grid,
	.starlight-webdev-page__steps,
	.starlight-webdev-page__foundation-grid {
		grid-template-columns: 1fr;
	}

	.starlight-webdev-page__service-card {
		min-height: 0;
	}

	.starlight-webdev-page__fit-strip {
		align-items: flex-start;
		flex-direction: column;
	}

	.starlight-webdev-page__outcome-grid article {
		grid-template-columns: 42px minmax(0, 1fr);
		gap: 15px;
		padding: 22px 18px;
	}

	.starlight-webdev-page__steps {
		border-left: 0;
	}

	.starlight-webdev-page__steps article {
		min-height: 0;
		padding: 25px 0;
		border-right: 0;
	}

	.starlight-webdev-page__delivery-card,
	.starlight-webdev-page__foundation-grid article {
		padding: 26px 23px;
	}

	.starlight-webdev-page__faq-item button {
		padding: 19px 18px;
		font-size: 17px;
	}

	.starlight-webdev-page__faq-panel {
		padding: 16px 18px 8px;
	}

	.starlight-webdev-page__final-cta {
		margin-top: 74px;
	}

	body.starlight-service-page-active #popmake-1278 .pum-close {
		top: 10px !important;
		right: 10px !important;
		width: 30px !important;
		height: 30px !important;
		font-size: 20px !important;
	}
}

@media (max-width: 480px) {
	body.starlight-service-page-active #ckyPreferenceCenter {
		width: calc(100vw - 24px) !important;
		max-width: calc(100vw - 24px) !important;
	}

	body.starlight-service-page-active #ckyPreferenceCenter .cky-preference-header,
	body.starlight-service-page-active #ckyPreferenceCenter .cky-preference-body-wrapper,
	body.starlight-service-page-active #ckyPreferenceCenter .cky-preference-content-wrapper,
	body.starlight-service-page-active #ckyPreferenceCenter .cky-accordion-wrapper,
	body.starlight-service-page-active #ckyPreferenceCenter .cky-accordion {
		width: 100% !important;
		max-width: 100% !important;
		box-sizing: border-box;
	}

	body.starlight-service-page-active #popmake-1278.pum-container {
		width: calc(100vw - 24px) !important;
		max-width: calc(100vw - 24px) !important;
		max-height: calc(100vh - 24px) !important;
		padding: 24px 16px !important;
		border-radius: 22px !important;
	}

	body.starlight-service-page-active #popmake-1278 button.wpforms-submit {
		width: 100% !important;
	}
}

@media (max-width: 360px) {
	body.starlight-service-page-active .cs-header__inner-mobile .cs-header__logo,
	body.starlight-service-page-active .cs-header__inner-mobile .cs-header__logo a {
		max-width: 158px !important;
		font-size: 19px !important;
		white-space: nowrap;
	}
}

@media (prefers-reduced-motion: reduce) {
	.starlight-webdev-page .starlight-hero-growth__button,
	.starlight-webdev-page__service-card::before,
	.starlight-webdev-page__faq-icon::after {
		transition: none;
	}
}
